- Created by Ian Christopher (Deactivated) , last modified on Dec 30, 2019
You are viewing an old version of this page. View the current version.
Compare with Current View Page History
« Previous Version 33 Next »
The Scholarship Program Information Data Exchange specification is operational in a few solutions, but the standard itself is in pre-release. This section outlines the changes in v1.0d, the latest draft of the specification.
The NSPA and Dell Foundation teams thank all the NSPA Members, implementers, technologists, and subject matter experts who provided input.
Overview
The information that follows describes changes in the latest version of Scholar Snapp.
The changes include:
Detail on each change follows.
Changes to the Data Model
This section describes changes to the data model, which defines the data payload representing a scholarship program.
Add a Program Category Indicator (SSDS-102) (New 12/2)
Programs often have characteristics that indicate high-level categorizations, such as “for first-generation students” or “for families of servicemembers.” These characteristics can typically be inferred from eligibility criteria or other properties of a program record — but there’s no convenient, universal method to indicate a broad category.
The value is useful as a high-level filter both to prospective applicants searching a list of programs and client systems receiving a set of program data records.
Change Detail
For Scholarship Exchange v1.0d, we’ve created a new Program Categories element. The value is optional, and may have up to four entries (i.e., the cardinality is 0..4).
Program Categories are implemented as a short string, with values defined by reference to an NSPA list. The list includes values such as:
Academic
Armed Service Family Member
Armed Servicemember
Contest
First-Generation Student
Professional Certification
Transfer Student
Other
…and more. The list will be finalized with the v1.0d release.
An example usage is shown in the JSON snippet below:
"ScholarshipApplicationInfo": [ { "ProgramOrganizationName": "Scholar Snapp", "ProgramReferenceId": "cfc0fac3-5d0d-4c0d-b1ec-b25c47e1ecc4", ... "ProgramCategories": [ {"ProgramCategory": "Armed Service Family Member"}, {"ProgramCategory": "First-Generation Student"} ], ... } ]
Usage Guidelines
The Program Category indicator is not intended to indicate everything about a program, just a few select, high-level categorizations. Generally speaking, data administrators will restrict indicators to the most significant one or two on any given program.
The Program Category indicator is often inferable from eligibility criteria or other properties of a given program. Note that this new element is not intended to replace those other properties, which are typically convey additional detail. Where common sense dictates, implementers may make inferences about categories not present. For example, a program with eligibility criteria indicating that an applicant must be a child of an active duty army servicemember can be safely assumed to be categorizable as a program for armed service family members even if the category “Armed Service Family Member” is not present.
Generally speaking, the “Other” element should be infrequently used. Exchange data administrators will consult program leads before adding an “Other” value.
The Program Category element is conceptually close to the “Is Merit Based” and “Is Need Based” elements on the program. These may be merged in a future release, but for now are separate — and should not be added as “Other” Program Category criteria.
Add a New Associated Organization and Organization Type List (SSDS-110, SSDS-94) (New 12/30)
The current Program Info standard allows for a single, primary organization to be associated with any given program. In practice, there are often several secondary, but important, organizations associated with a program, such as the organization funding the program, the community foundation that lists and administers the program, and so forth.
This change proposes the addition of an optional list of additional associated organizations, with indicators for the type of organization, the nature of the association (i.e., the role or roles an organization plays in relation to a program), and other elements.
Change Detail
RFC Note: We have two issues under consideration:
The current draft allows for both a primary Organization Type and an array of Organization Roles. We’re considering whether we can collapse the two into a single element. While the two values are semantically different, most use cases we’re considering use only one value.
The current draft does not refactor the existing, primary program organization into this new array. We debated whether to do so, but, for the moment, have decided against it. The Additional Associated Organizations” is optional and will (likely) be sparsely populated, so we wanted to keep the distinction between this optional information and the more critical organization information on the program itself.
For Scholarship Exchange v1.0d, we’ve added a new Additional Associated Organizations element.
The entity is optional, and can list up to 4 additional organizations. We chose a reasonable upper limit because (a) there are only a few logical types of organization, and (b) each organization entity may contain a logo file, which could introduce file bloating if left unbounded.
The entity allows for both a primary organization type (which is a singular value) and an organization role (which can be multiple).
As noted, the entity allows for each listed organization to contain an associated logo file. The primary use case is for those programs that require attendance at a single, specific institution or graduation from a single, specific school. In listing use cases where the end user is a student searching for scholarship options, it may be useful to display a school or institution logo — which would allow for instant recognition that the program may have some applicability to the user. The school or institution logo may be displayed instead of or in addition to the primary logo, depending on the listing system’s user interface design.
Properties include:
Organization Name.
Organization Reference ID. In the NSPA Exchange implementation, this will be an internal NSPA Member ID for the organization, if available.
Organization Type. The primary type of organization. Options currently include:
College or University
Community Foundation
High School
Hosting Service
Private Foundation
Trade or Technical School
Organization Role. The role the organization plays in relation to the program. Options currently include:
Application Hosting Service Provider
Eligibility - Alumnus Requirement
Eligibility - Enrollment Requirement
Listing Service
Program Administrator
Program Funder
Logo File. A Base 64-encoded image file.
Logo File Name. A file name for the image file.
The following XSD snippet shows the definition with annotations:
... <xs:complexType name="AssociatedOrganization"> <xs:annotation> <xs:documentation>Information about organizations affiliated with the program aside from the primary organization. Includes a type, a logo, and other details.</xs:documentation> </xs:annotation> <xs:sequence> <xs:element name="OrganizationName" type="spi:ShortString"> <xs:annotation> <xs:documentation>The associated organization name</xs:documentation> </xs:annotation> </xs:element> <xs:element name="OrganizationReferenceId" type="spi:ShortString" minOccurs="0"> <xs:annotation> <xs:documentation>The ID the organization supplying the program information uses to uniquely identify the program. If the reference ID matches one previously supplied by this organization, the existing data will be updated (replaced by) the new information. There are no restrictions on the format of this id; it can be a number, a GUID, etc. It is simply matched as-is.</xs:documentation> </xs:annotation> </xs:element> <xs:element name="OrganizationType" type="spi:OrganizationTypeList" minOccurs="0"> <xs:annotation> <xs:documentation>The type of associated organization (e.g., Community Foundation, Hosting Service)</xs:documentation> </xs:annotation> </xs:element> <xs:element name="OrganizationRole" type="spi:OrganizationRoleList" minOccurs="0" maxOccurs="unbounded"> <xs:annotation> <xs:documentation>The roles played by the organization in relation to the program (e.g., Program Funder, Application Hosting Service Provider)</xs:documentation> </xs:annotation> </xs:element> <xs:element name="LogoFile" type="xs:base64Binary" minOccurs="0"> <xs:annotation> <xs:documentation>An image of a logo file in MIME base64 encoding. By convention, constrained to PNG, JPG, GIF file types.</xs:documentation> </xs:annotation> </xs:element> <xs:element name="LogoFileName" type="spi:ShortString" minOccurs="0"> <xs:annotation> <xs:documentation>A file name for the logo. The name should include the file extension indicating type (e.g., .png, .jpg, .gif).</xs:documentation> </xs:annotation> </xs:element> </xs:sequence> </xs:complexType> ...
Usage Details
Certain organization roles (such as when a college is listed because applicants must attend the specific institution) obviously have a relationship to the Eligibility Criteria. However, we do not intend for implementers use these additional organizations as an additional eligibility criteria — rather, the data is provided for informational and display purposes (at least in the current version).
In the current generation of the NSPA Exchange, the element may be sparsely populated. The data maintenance team will likely focus on populating those records for which we have a specific display or functionality use case. The initial uses include:
Displaying a logo for a college, university, or school that applicants must attend to qualify for the award.
Displaying a logo for a high school or other institution from which applicants must be a graduate.
Relating Program Records to NSPA Member IDs to facilitate reporting and data lookup in the internal NSPA systems.
Create Flexible Code List Pattern & Replace Evolving Enumerations (SSDS-103)
The current Program Info standard represents code lists/fixed vocabularies as classic enumerations. This provides welcome certainty in how to represent a fixed value. In unstructured lists, one sees various forms of the same information, such as "NMSI" or "National Math and Science Initiative" or "National Math and Science Initiative (NMSI)" in the same listing, so the controlled vocabulary provides assurance that values with the same definition have a single representation.
Changes to enumerations are considered breaking changes for implementers. (Or, at least those who perform schema validation or rely on enumerations for fixed lists in their applications.) However, in practice, there are several lists that need to evolve more rapidly than our annual major update lifecycle will allow.
Lists such as the eligibility criteria coding for Activities, College Readiness Programs, Interests, Demographics, and Miscellaneous change rapidly for a variety of reasons. Sometimes there are real-world changes such as a new College Readiness Program starting up, a new sport (Spikeball!? Whaaat?), or attitudes toward demographic categorizations such as gender identity. Other vocabulary items require change because new scholarships are found or created that have a particular requirement.
This change proposes the development of a flexible code list/vocabulary: one that has a fixed structure and a clear list of "known" values, but that may change during the life of a single generation of the standard.
Change Detail
For Scholarship Exchange v1.0d, we’ve changed several lists from enumerations to strings. The following enumerations have been removed:
ActivityList
AffiliationEntityList
CollegeReadinessProgramList
ConditionList
DemographicEligibilityCriteriaList
InterestCriteriaList
MiscellaneousCriteriaList
ProfessionList
SituationList
Where possible, a list’s reference will be to an existing, external standard (similar to how the school IDs are aligned with the CEEB and NCES codes by reference, or how country lists refer to the ISO-3166 2-letter country code).
Where no appropriate existing code list/vocabulary is found, the Exchange will publish and maintain its own standard. These Exchange standards will allow additive changes and deprecations within a single year/major version release. The lists may deprecate but will not remove or change existing values during a single year/major version release. This will allow an unambiguous set of “known” standard values, while allowing for rapid change during a single generation of the standard. A draft example for the Activity Code List is here.
We’ve replaced referenced enumerations such as the Activity Eligibility Criteria with a string. An example XML data snippet is shown below. Note that since the base type of enumerations in the Scholarship Exchange standard is also a string, the data file will appear largely unchanged.
... <EligibilityCriteria> ... <Activity> <ActivityCriteria>Ultimate Frisbee</ActivityCriteria> </Activity> ... </EligibilityCriteria> ...
Add an Element for Allowable Uses of Scholarship Funding (SSDS-95) (New 12/14)
The vast majority of scholarships have some restrictions on the purposes to which the award can be used. Uses are often restricted to tuition and books. However, the allowed uses sometimes include interesting values such as travel, tutoring, and similar.
Change Detail
Added a new Allowed Funding Uses free text element.
We considered adding a structured entity with enumerated funding use types. However, we’re not confident that applicants would find a detailed coding more useful than plain text, and we’re not sure that a fine-grained coding would support meaningful analysis. So, we’re proposing an unstructured text field for this version which we can change to a more structured approach if we get feedback from users that it would be useful.
Usage Details
Similar to the current Eligibility Criteria Detail element, we expect to enter values as a list (using markdown).
Example contents are shown in the JSON snippet below (\n
indicates a line break):
... "AllowedFundingUses": "- Tuition\n- Books\n- Study abroad expenses, including travel" ...
Add Application Cycle Indicator (SSDS-92)
Many scholarship programs make awards every year. The program name, purpose, and core characteristics mostly remain the same year over year, but values do change. For example, long-running major programs typically raise their award amount over time, online application links change, and so forth. Although most scholarship listing services simply use the most current information, many organizations and analysts desire to see the change over time for scholarship programs.
This change will add a value indicating the scholarship application cycle to which a particular record applies, allowing systems to support historical and longitudinal analysis of programs over time.
Change Detail
For Scholarship Exchange v1.0d, we’ve added a new Application Cycle element to the following information to the model:
Format. The value should follow the school academic year format (e.g., 2019-2020).
Usage details. The following general rules apply to this element:
The element is optional. If a value is not present, the record is assumed to be the current record.
Typically, the scholarship application cycle will precede the academic year in which an award will be used (e.g., awards made in the 2019-2020 application cycle will be used by scholars in the 2020-2021 academic year).
Notionally, the application cycle starts August 1 and ends July 31 the following year — with the vast majority of programs both opening and closing between those dates. For example, in 2019, Dell Scholars Program opened October 1 and closed December 1, which puts it squarely in the 2019-2020 application cycle.
A program that’s always open will typically have multiple records. For example, a program that was open throughout calendar years 2018 and 2019 will have one record for 2018-2019 and another for 2019-2020.
The following XSD snippet shows the definition of the Application Cycle element:
... <xs:element name="ApplicationCycle" type="spi:ShortString" minOccurs="0"> <xs:annotation> <xs:documentation>The scholarship application cycle during which this program was accepting applications. Should be formatted as a school academic year (e.g., 2019-2020). Usually precedes the academic year in which the award will be used (e.g., awards in the 2019-2020 application cycle will be used in the 2020-2021 academic year).</xs:documentation> </xs:annotation> </xs:element> ...
The following XML snippet shows the new Application Cycle value:
<ScholarshipApplicationInfo> ... <ApplicationCycle>2019-2020</ApplicationCycle> ... </ScholarshipApplicationInfo>
Add Award Duration and Renewability Information (SSDS-96)
Many scholarship programs have important properties related to the award duration. For example, it’s useful to know whether a program’s award is for a single year, or can be used across multiple years. For those programs that only offer single-year awards, it’s useful to know whether an applicant may re-apply for a subsequent award.
Change Detail
For Scholarship Exchange v1.0d, we’ve added the following information to the model:
An award duration type. To indicate the time period over which the award may be used. Values include “One-Time” (indicating a single point in time), “Multiyear” (indicating that the award spans multiple years), and “Renewable” (meaning that the award is a one-time award, but applicants are explicitly allowed to re-apply for subsequent years).
An award duration. For multiyear programs, indicates the number of years across which the award may be used. For renewable programs, indicates the number of renewal opportunities.
The following JSON snippet shows an example for a 4-year scholarship.
"ScholarshipApplicationInfo": [ { ... "AwardDuration": { "AwardDurationType": "Multiyear", "DurationYears": 4 }, ... } ]
Add Scholarship Program Self-Description (SSDS-93)
The Scholarship Exchange specification has had a Blurb since the first release. The Blurb is typically edited by Exchange administrators for consistency in voice, style, terminology, length, third-person perspective, and so forth. However, it’s useful for administrators — and potentially others — to see exactly how a program describes itself. This allows administrators doing QA to ensure important nuance isn’t missing from the Blurb or the Eligibility Criteria Detail. In addition, some programs that provide data may actively desire to have their own description shown to users.
Change Detail
For Scholarship Exchange v1.0d, we’ve added a new Program Self-Description element to the model:
Format. The element is a long string (which currently holds up to 4000 characters).
Usage Details. The following general rules apply to this element:
By design, the Self-Description should reflect what the providing organization wants to say about itself. Accordingly, the Self-Description will only receive light copy editing. It will not be rewritten for style, perspective, and so forth.
Most current consumers will prefer the Blurb to the Program Self-Description. Any that do receive and publish the self-description to end-users must frame the description accordingly (e.g., “From the Dell Scholars Program” or similar), to make clear the source of information and “who” is talking (e.g., so it’s clear who “we” are, if the self-description uses the first person).
Sharing the Value. The NSPA Exchange will record and review the value in advance of providing it to third parties. This will allow a trial period to ensure the quality, consistency, and value of the information.
The following XML snippet shows an example Program Self-Description:
<ScholarshipApplicationInfo> ... <ProgramSelfDescription>We believe that every student deserves a chance to experience art school. If you have a penchant for painting, a desire to draw, or an imperative desire for interpretive dance, then apply today!</ProgramSelfDescription> ... </ScholarshipApplicationInfo>
Add Award Announcement Date (SSDS-88)
Applicants are, understandably, curious to know when they can expect to hear whether or not they’ve been awarded a scholarship. Also, the length of time between an application close an the announcement is an interesting comparison point between programs.
Change Detail
For Scholarship Exchange v1.0d, we’ve added an Announcement Date element.
Format. A date string (e.g., “2019-11-11”).
Usage Details.
Ideally, the date that individual applicants are notified. If that value is unknown, the date that awards are posted publicly (e.g., on the program website) or shared (e.g., via notice on bulletin board, telegram, whatever).
It’s okay to enter an approximation, if known within a few week span. Just use the latest date in the approximate range. We don’t want to freak out applicants or make work for program administrators.
Prefer leaving the value blank if it’s “sometime before summer.”
The Announcement Date value is grouped with other program date values as shown in the XML snippet below:
<ScholarshipApplicationInfo> ... <OpenDate>2019-09-15</OpenDate> <CloseDate>2019-12-31</CloseDate> <AnnouncementDate>2020-02-01</AnnouncementDate> ... </ScholarshipApplicationInfo>
Add Country to Location Eligibility Criteria (SSDS-87)
The Scholarship Exchange has a Location Eligibility Criteria to indicate geographic area eligibility requirements for a program. The current model has City, County, and State or Province elements. The next generation of the Exchange will support programs from other countries, so a Country indicator will be useful.
Change Detail
For Scholarship Exchange v1.0d, we’ve added a Country element to Eligibility Location:
Format. A short string containing the ISO-3166 2-letter country code (e.g., CA, US, MX).
Usage Details.
Country should be present when other Location Criteria are present.
Country is NOT required for every listing, even if when implicit from other eligibility criteria.
For example, a U.S.-based program requiring U.S. citizenship can be inferred to have a Location Criteria where the Country is “US”. Nevertheless, a Location Criteria should not be added unless other explicit location restrictions are present.
This may change over time – but other elements and conventions are currently used to make this kind of national-level contextual filter.
The following JSON snippet shows an example of the Country element in use in the Locations entity:
"EligibilityCriteria": { ... "Locations": [ { "City": "Santa Monica", "County": "Los Angeles", "State": "California", "Country": "US" }, { "City": "Austin", "County": "Travis", "State": "Texas", "Country": "US" } ] ... }
Change Marines to Marine Corps in Armed Services List (SSDS-111) (New 12/14)
The Scholarship Exchange standard incorrectly lists the Marine Corps as “Marines” in the list of armed services.
Change Detail
For Scholarship Exchange v1.0d, we changed “Marines” to “Marine Corps” in the Armed Service List enumeration.
The following XSD snippet shows the new value in context:
... <xs:simpleType name="ArmedServicesList"> <xs:annotation> <xs:documentation>The list of Armed Services</xs:documentation> </xs:annotation> <xs:restriction base="spi:ShortString"> <xs:enumeration value="Army"/> <xs:enumeration value="Navy"/> <xs:enumeration value="Air Force"/> <xs:enumeration value="Marine Corps"/> <!-- Changed from "Marines" --> <xs:enumeration value="Coast Guard"/> <xs:enumeration value="National Guard"/> </xs:restriction> </xs:simpleType> ...
Add GED Indicator to Graduation Status List (SSDS-109) (New 12/14)
The Scholarship Exchange standard does not currently have a specific eligibility criteria representing GED or other high school equivalency. While this can be inferred by “High School Graduate,” some programs are explicitly for those with a GED, so it’s useful to have a separate representation.
Change Detail
For Scholarship Exchange v1.0d, we added an enumeration item “GED or High School Equivalency” to the Graduation Status List enumeration.
The following JSON Schema snippet shows the new value in context:
... "GraduationStatusCriteriaList": { "description": "The list of graduation status eligibility and qualification criteria. Snapp defaults to Graduating High School Senior if no criteria present.", "type": "string", "minLength": 1, "maxLength": 100, "enum": [ "Graduating High School Senior", "GED or High School Equivalency", // New "High School Graduate", "High School Graduate, No Prior College", "High School Graduate, No Prior Degrees", "Community College Freshman", "Community College Sophomore", "College Freshman", "College Sophomore", "Associate's Degree", "Bachelor's Degree", "Graduate Degree" ] }, ...
Usage Details
For the majority of programs, the value “High School Graduate” implicitly includes students who have graduated based on a GED or high school equivalency exam. Accordingly, when coding criteria, we reserve use of the “GED or High School Equivalency” item for programs that are targeted toward that specific population — and we don’t add it to every program that also has “High School Graduate” coded. When searching, applicants who indicate they have a GED or high school equivalency will find programs coded with “GED or High School Equivalency” as well as programs coded with “High School Graduate”.
Add California AB 540 Status to Citizenship Eligibility Requirements (New 12/14)
Many programs in California allow or explicitly serve undocumented students who have no formal citizenship status in the U.S. A common requirement for those students is that they have AB 540 status.
Change Detail
For Scholarship Exchange v1.0d, we added an enumeration item “California AB 540” to the U.S. Citizenship Eligibility Criteria List enumeration.
The following XSD snippet shows the addition in context:
<xs:simpleType name="USCitizenshipStatusEligibilityCriteriaList"> <xs:annotation> <xs:documentation>The list of U.S. citizenship eligibility and qualification criteria, roughly aligned with the FAFSA categories plus populations served by known providers. By convention, 'other' values will be ignored unless agreed upon between sender and receiver.</xs:documentation> </xs:annotation> <xs:restriction base="spi:ShortString"> <xs:enumeration value="U.S. Citizen"/> <xs:enumeration value="Permanent Resident"/> <xs:enumeration value="Conditional Permanent Resident"/> <xs:enumeration value="Current DACA Status"/> <xs:enumeration value="Pending DACA Application"/> <xs:enumeration value="FAFSA-Eligible Non-Citizen"/> <xs:enumeration value="Not a U.S. Citizen"/> <xs:enumeration value="Asylum-Seeker or Asylee"/> <xs:enumeration value="Cuban or Haitian Entrant"/> <xs:enumeration value="Humanitarian Parolee"/> <xs:enumeration value="Refugee"/> <xs:enumeration value="California AB 540"/> <!-- New --> <xs:enumeration value="Other"/> </xs:restriction> </xs:simpleType>
- No labels