Coverage Report - org.kuali.student.enrollment.courseoffering.infc.CourseOffering
 
Classes in this File Line Coverage Branch Coverage Complexity
CourseOffering
N/A
N/A
1
 
 1  
 /*
 2  
  * Copyright 2010 The Kuali Foundation 
 3  
  *
 4  
  * Licensed under the Educational Community License, Version 2.0 (the
 5  
  * "License"); you may not use this file except in compliance with the
 6  
  * License. You may obtain a copy of the License at
 7  
  *
 8  
  * http://www.osedu.org/licenses/ECL-2.0
 9  
  *
 10  
  * Unless required by applicable law or agreed to in writing, software
 11  
  * distributed under the License is distributed on an "AS IS" BASIS,
 12  
  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
 13  
  * implied. See the License for the specific language governing
 14  
  * permissions and limitations under the License.
 15  
  */
 16  
 
 17  
 package org.kuali.student.enrollment.courseoffering.infc;
 18  
 
 19  
 import org.kuali.student.r2.common.infc.IdNamelessEntity;
 20  
 import org.kuali.student.r2.common.infc.RichText;
 21  
 
 22  
 import java.util.List;
 23  
 
 24  
 /**
 25  
  * @author Kamal
 26  
  */
 27  
 
 28  
 public interface CourseOffering extends IdNamelessEntity{
 29  
 
 30  
     /**
 31  
      * A unique identifier assigned to all approved courses that exist
 32  
      * in the catalog This is not updatable once initialized.
 33  
      * 
 34  
      * @name Course Id
 35  
      * @readOnly
 36  
      * @required
 37  
      * @impl this maps the the version dependent id as the offering
 38  
      *       must point to one and only one version of the
 39  
      *       course. Maps to cluId in Lui.
 40  
      */
 41  
     public String getCourseId();
 42  
 
 43  
     /**
 44  
      * Academic term of course offering
 45  
      * 
 46  
      * @name Term Id
 47  
      * @readOnly on updates
 48  
      * @required
 49  
      * @impl set during the #createCourseOffering and then maps to
 50  
      *       the aptKey on the Lui
 51  
      */
 52  
     public String getTermId();
 53  
 
 54  
     /**
 55  
      * Custom Description for the course Offering.
 56  
      *
 57  
      * @name Course Offering Description
 58  
      */
 59  
     public RichText getDescr();
 60  
 
 61  
     /**
 62  
      * Identifies the number of a course as reflected in the course catalog.
 63  
      * This typically must be unique across all courses offered during that
 64  
      * term. If the user wants to create two separate offerings for the same
 65  
      * course they must modify this code to make it unique. For example: An
 66  
      * on-line offering of the course might have an "O" appended to it to
 67  
      * distinguish it from the face to face offering, i.e. ENG101 and ENG101O
 68  
      * Initially copied from the course catalog but then, depending on the
 69  
      * configuration it may be updatable. Often this field is configured so that
 70  
      * it is not not directly updatable but rather is calculated from it's two
 71  
      * constituent parts, the subject area and the course number suffix. For
 72  
      * example: Subject Area = "ENG" and Suffix = "101" then code = "ENG101"
 73  
      * 
 74  
      * @name Course Offering Code
 75  
      * @impl initialially this is copied from the course catalog code but then
 76  
      *       is subsequently stored in the lui as lui.officialIdentifier.code
 77  
      */
 78  
     public String getCourseOfferingCode();
 79  
 
 80  
     /**
 81  
      * Identifies the department and/subject code of the course as reflected in
 82  
      * the course catalog. Initially copied from the course catalog but then,
 83  
      * depending on the configuration it may be updatable. In most
 84  
      * configurations this should not be updatable. Often used in the
 85  
      * calculation of the courseCode
 86  
      * 
 87  
      * @name Subject Area
 88  
      * @impl initially copied from the canonical course but then stored in the
 89  
      *       Lui as lui.officialIdentifier.division
 90  
      */
 91  
     public String getSubjectArea();
 92  
 
 93  
     /**
 94  
      * A suffix of the course number as reflected in the college catalog. This
 95  
      * is the "number" portion of the course code. Initially copied from the
 96  
      * course catalog but then, depending on the configuration it may be
 97  
      * updatable. This field is often configured to be updatable but the updates
 98  
      * typically simply append something like an "O" for on-line to it to
 99  
      * differentiate multiple course offerings for the same course. Often used
 100  
      * in the calculation of the courseCode.
 101  
      * 
 102  
      * @name Course Number Suffix
 103  
      * @impl initially copied from the canonical course but then stored in the
 104  
      *       Lui as lui.officialIdentifier.suffixCode
 105  
      */
 106  
     public String getCourseNumberSuffix();
 107  
 
 108  
     /**
 109  
      * Name of the course used in the college catalog. Initially copied from the
 110  
      * course catalog but then, depending on the configuration it may be
 111  
      * updatable. For regular courses this is not generally allowed to be
 112  
      * updated on the offering, but for special topics courses this is often
 113  
      * overridden to capture the particular topic being taught offered this
 114  
      * term. Note: the configuration of the validation for titles is typically
 115  
      * restricted to exclude line breaks. This may have to be loosened as some
 116  
      * schools may want the particular topic to appear on a 2nd line. For
 117  
      * example: SPECIAL TOPICS: AN EXPLORATION OF DEEP SPACE ARTIFACTS
 118  
      * l
 119  
      * @name Course Title
 120  
      * @impl initially copied from the canonical course but then stored in the
 121  
      *       Lui as lui.officialIdentifier.longName
 122  
      */
 123  
     public String getCourseOfferingTitle();
 124  
 
 125  
     /**
 126  
      * Indicates that the entire course offering is an Honors Course ??? Is this
 127  
      * an enrollment restriction rule or a flag or both?
 128  
      * 
 129  
      * @name Is Honors Offering
 130  
      * @impl store in a generic lui luCodes type of field?
 131  
      */
 132  
     public Boolean getIsHonorsOffering();
 133  
 
 134  
     /**
 135  
      * Total maximum number of "seats" or enrollment slots that can be filled
 136  
      * for the offering. Calculated based on sum of all the maximum seats of
 137  
      * primary activity type offerings.
 138  
      * 
 139  
      * @name Maximum Enrollment
 140  
      * @impl maps to Lui.maximumEnrollment
 141  
      */
 142  
     public Integer getMaximumEnrollment();
 143  
 
 144  
     /**
 145  
      * Total minimum number of seats that must be filled for the offering not to
 146  
      * be canceled. Calculated based on sum of all the minimum seats of primary
 147  
      * activity type offerings
 148  
      * 
 149  
      * @name Minimum Enrollment
 150  
      * @impl maps to Lui.minimumEnrollment
 151  
      */
 152  
     public Integer getMinimumEnrollment();
 153  
 
 154  
     /**
 155  
      * The unique identifier of the other course offerings with which this
 156  
      * offering is joint-listed
 157  
      * 
 158  
      * @name Joint Offering Ids
 159  
      * @readOnly I think?
 160  
      * @impl Canonical might suggest offerings that can be jointly offered. This
 161  
      *       is stored as a luiluirelation of joint type
 162  
      */
 163  
     public List<String> getJointOfferingIds();
 164  
 
 165  
     /******** Assessment Information ***************/
 166  
     /**
 167  
      * The options/scales that indicate the allowable grades that can be
 168  
      * awarded. Typically the values here are constrained by the values on the
 169  
      * canonical course. If the value is set here then the Clu must have a
 170  
      * grading option set on the canonical activity. For example: an id might
 171  
      * point to Pass/Fail or Letter Graded option.
 172  
      * 
 173  
      * @name: Grading Option Ids
 174  
      * @impl these are actually Ids to ResultValuesGroup. Lui.resultOptionIds
 175  
      *       returns a list of resultOptions. Filter options with grading type
 176  
      *       and those should give the resultValueGroupIds
 177  
      */
 178  
     public List<String> getGradingOptionIds();
 179  
 
 180  
     /**
 181  
      * Type of credit of course offering. This field is initially copied from
 182  
      * the canonical course but then, depending on configuration, it may be
 183  
      * updated. TODO: figure out which of the credit options will be copied down
 184  
      * because the canonical has more than one! Often it is just a fixed single
 185  
      * value but a ResultValuesGroup could contain a range (with increments) or
 186  
      * even a discrete list of possible credit values.
 187  
      * 
 188  
      * @name Credit Options
 189  
      * @impl Lui.resultOptionIds returns a list of resultOptions. Filter option
 190  
      *       with credit type and that should give the resultValueGroup
 191  
      */
 192  
     public List<String> getCreditOptionIds();
 193  
 
 194  
 
 195  
 
 196  
     /******** Personnel Information *****************/
 197  
 
 198  
     /**
 199  
      * Instructors for this course offering TODO: find out if the canonical
 200  
      * instructors should be copied down
 201  
      * 
 202  
      * @name Instructors
 203  
      * @impl These are derived from Lui Person relations with instructor type
 204  
      */
 205  
     public List<? extends OfferingInstructor> getInstructors();
 206  
 
 207  
     /********* Organization Information **************/
 208  
 
 209  
     /**
 210  
      * Organization(s) that is responsible for administering the course delivery
 211  
      * - and all associated logistics - of the course Initially copied from the
 212  
      * canonical course then, depending on the configuration, updated This is
 213  
      * typically an academic department but could be for example the extended
 214  
      * studies office that is responsible for delivering the course even though
 215  
      * it's content is managed by an academic department.
 216  
      * 
 217  
      * @name Units Deployment
 218  
      * @impl initalized from canonical course units deployment but then stored
 219  
      *       in lui.unitsDeployment
 220  
      */
 221  
     public List<String> getUnitsDeploymentOrgIds();
 222  
 
 223  
     /**
 224  
      * Organization(s) that is responsible for the academic content of the
 225  
      * course as approved in its canonical form. This is the organization that
 226  
      * has oversight of the curriculum. This is typically an academic
 227  
      * department.
 228  
      * 
 229  
      * @name Units Content Owner
 230  
      * @readOnly on updates
 231  
      * @impl this is never updatable so it should just be grabbed from the
 232  
      *       canonical course and then stored in lui.unitsContentOwner
 233  
      */
 234  
     public List<String> getUnitsContentOwnerOrgIds();
 235  
 
 236  
 
 237  
 
 238  
     /*********** Waitlist *****************************/
 239  
 
 240  
     /*
 241  
      * TODO: Skip this section for core slice development
 242  
      */
 243  
 
 244  
     /**
 245  
      * Indicates whether a RegistrationGroup has a waitlist TODO: figure out how
 246  
      * to store this TODO: make sure we are consistent on how we spell Waitlist,
 247  
      * should be spelled Waitlist, or Wait List or Wait-List (as the
 248  
      * merriam-webster has it)
 249  
      * 
 250  
      * @name Has Waitlist
 251  
      * @impl not sure how to store this, it depends on how we end up
 252  
      *       implementing waitlists.
 253  
      */
 254  
     public Boolean getHasWaitlist();
 255  
 
 256  
     /**
 257  
      * Indicates the type of waitlist as it relates to processing students on
 258  
      * and off The three types predefined in kuali are Automatic, Semi-Automatic
 259  
      * and Manual TODO: Right not Waitlist types are not tied to any Waitlist
 260  
      * object so we need to define an "other key" to get the list of valid
 261  
      * values from the type service. TODO: Decide if we need a separate
 262  
      * getHasWaitList, perhaps no value in this field means no waitlist. TODO:
 263  
      * Cross validate with hasWaitlist
 264  
      * 
 265  
      * @name Waitlist Type Key
 266  
      * @impl TODO: decide if this this should be stored on the Lui or on a
 267  
      *       waitlist object?
 268  
      */
 269  
     public String getWaitlistTypeKey();
 270  
 
 271  
     /**
 272  
      *  Indicates the waitlist level, i.e., CourseOffering or ActivityOffering
 273  
      *
 274  
      * @name Waitlist Level Type Key
 275  
     */
 276  
 
 277  
     public String  getWaitlistLevelTypeKey();
 278  
 
 279  
   /************* Finances ***************************/
 280  
 
 281  
     /**
 282  
      * The primary source of funding for the offering.
 283  
      * 
 284  
      * @name Funding Source
 285  
      * @impl fyi "funding source" is an enumeration values are state support,
 286  
      *       self-support, contract funding
 287  
      */
 288  
     public String getFundingSource();
 289  
 
 290  
     /**
 291  
      * Flag indicating whether a course is eligible for Financial Aid. Derived
 292  
      * from course catalog (canonical) TODO: find a place to store this on the
 293  
      * canonical course because it does not currently exist there TODO: Decide
 294  
      * if this is really a rule or a CluSet or what?
 295  
      * 
 296  
      * @name Is Financial Aid Eligible
 297  
      * @impl TODO: decide where to store
 298  
      */
 299  
     public Boolean getIsFinancialAidEligible();
 300  
 
 301  
     /**
 302  
      * Is this Course Offering Financial aid eligible.  (why is this
 303  
      * here?) use getIsFinancialAidEligible().
 304  
      *
 305  
      * @name Financial Aid Eligible Flag
 306  
      */
 307  
     @Deprecated
 308  
     public Boolean getFinancialAidEligible();
 309  
 
 310  
     /**
 311  
      * Places where this Course offering is offered.
 312  
      *
 313  
      * @name Campus Locations
 314  
      */
 315  
     public List<String> getCampusLocations();
 316  
 
 317  
     /**
 318  
      * Is this a Honors Course offering
 319  
      *
 320  
      * @name Honors Flag
 321  
      */
 322  
     public Boolean getHonorsOffering();
 323  
 
 324  
     /**
 325  
      * Indicates the type of final exam ('STANDARD', 'ALTERNATE', 'NONE') to be given  for this format Offering, if any
 326  
      *
 327  
      * @name Final Exam Type
 328  
      */
 329  
     public String getFinalExamType();
 330  
 
 331  
     /**
 332  
      * Indicates whether the fee is at activity offering level or
 333  
      * course offering level. If true its at Activity Offering level,
 334  
      * if false its at CourseOffering level.
 335  
      *
 336  
      * @name Is Fee at Activity Offering
 337  
      */
 338  
     public Boolean getIsFeeAtActivityOffering();
 339  
 
 340  
     /**
 341  
      * Indicates whether the course offering has an evaluation.
 342  
      *
 343  
      * @name Is Evaluated
 344  
      */
 345  
     public Boolean getIsEvaluated();
 346  
 
 347  
     /**
 348  
      * Gets the Course Offering URL.
 349  
      *
 350  
      * @name Course Offering URL
 351  
      */
 352  
     public String getCourseOfferingURL();
 353  
 }