- Created by lee.morrow , last modified by Chris Moffatt (Deactivated) on Mar 09, 2021
You are viewing an old version of this page. View the current version.
Compare with Current View Page History
« Previous Version 16 Next »
Use this Setup Guide to install and configure your Family Engagement solution using test data. At the end of this Setup Guide you'll have a test environment which closely mimics a production environment. This test environment allows administrators and stakeholders to test configuration changes being considered for the production environment without an impact on end-users. This test environment is separate and distinct from the sample environment created during the Quick Start.
Summary
More information
This Setup Guide builds on core skills and concepts in the Family Engagement Quick Start. We recommend running that Quick Start before moving on to this more detailed Setup Guide.
Solution Overview
In this section you'll get a general understanding of the components of your Family Engagement solution to provide context for completing the remainder of the Setup Guide.
The below diagram depicts the general architecture of your Family Engagement solution.
Once you complete this Setup Guide:
- Data from your Student Information System will flow into your Operational Data Store (ODS) via the ODS / API.
- Connections between your SIS and the ODS / API will be managed using the ODS / API Admin App.
- The Family Portal web application will connect directly to the database to retrieve your data and use it to generate your Family Engagement detailed views.
The core components, including web apps, are described in the /wiki/spaces/SK/pages/22018859 section and can be set up using the /wiki/spaces/SK/pages/21992748.
The rest of this guide will instruct you on installing these components, connecting your SIS to the ODS via the ODS API, connecting the portal application to your ODS, conforming your SIS data to the Ed-Fi Data Standard, and using the Family Portal to engage and support your family members, students, and staff with your data.
Step 1. Install
In this step you will install components of the Ed-Fi solution required for this starter kit. The installation requires Windows Server 2016-2019. If you would like additional information on what's required to install your solution please see general system and starter kit specific requirements.
Install Microsoft SQL Server
- Starting with a base Windows Server 2019 image install Microsoft SQL Server Standard (or higher).
- Setup your organization's authentication with the database
Install the Ed-Fi Solution
Install the Ed-Fi Solution using the /wiki/spaces/TSINSTALL/overview.
- Review the Tech Suite Installer /wiki/spaces/TSINSTALL/pages/20055180 and /wiki/spaces/TSINSTALL/pages/20055184 details to determine if you want to use the EXE installer or Powershell scripts.
- Install the Ed-Fi components using the /wiki/spaces/TSINSTALL/pages/20055784of the installer.
Once completed you will have the following Ed-Fi components installed:
- ODS / API for Suite 3 v5.1
- Admin App v2.1
Install Microsoft Visual Studio
The Family Engagement solution requires the Microsoft Visual Studio tool to build and deploy the portal web application. The Family Portal web application maintains a live connection to the ODS/API, but can be deployed to a separate Windows IIS-based web application server from the database server, You will be able to adjust those connection settings as needed during the deployment of the portal application.
You may prefer to use a more advanced edition of Visual Studio, however this guide does not address the installation and administration of the Visual Studio product itself.
After completing these installation steps, you will have a working Ed-Fi ODS/API which we can now use in the next section to load test data before we launch and share our portal application.
Reminder
If you do not have a Visual Studio license, you will automatically obtain a trial license for all of the features needed with the Community Edition. This trial license is valid for 30 days after you first launch and build the portal application.
You will only need a licensed copy of Visual Studio when you are building and deploying the Family Portal web application and will not need to keep a license after the application is deployed in production, except of course if you must rebuild and re-deploy the application.
Step 2. Load Test Data
In this step you will load test data from your SIS to the ODS API so it can be available to the Family Portal web application.
Understand Dependencies When Loading Data
Before you can load your production or test data, your Ed-Fi ODS/API requires that each data item, whether submitted via API from your SIS or directly loaded in bulk to the ODS database, must be structurally consistent and syntactically valid according to the Ed-Fi Data Standard v3.1.
Put simply, some data items must be loaded correctly before others can be loaded - and - each data item must follow the rules of the standardized vocabulary to load correctly.
But don't panic! You won't have to load everything in your SIS to get started. Furthermore, acceptable defaults for some needed data are already loaded in your Ed-Fi ODS/API to ease your start. If your SIS is Ed-Fi-certified, it will already have tackled these load order dependencies and other requirements, and you won't have to worry about these details now. However, it is important to know the proper loading order for your data to minimize the frustration of tracking down potential errors during the loading process.
Below, is a dependency graph for loading data into the ODS/API highlighted with the specific data needs for Family Engagement. The vertical path represents dependencies that must be satisfied as you move downward, while items in the same horizontal position can be loaded independently or simultaneously. The purple labels to the side describe key Ed-Fi concepts that may be new to you. Again, don't worry, you will learn more about these concepts as you continue.
Note that to get to the "green light" of successfully loaded student performance data, you must load the set of needed "reference" data above it in this chart.
Next, we will configure your Ed-Fi ODS/API and SIS to communicate via the API.
Add your Student Information System in the Admin App
- Follow the Admin App - Getting Started instructions in the to complete its initial configuration steps.
- Follow the Admin App - Next Steps to configure your first Vendor and Application entry for your Student Information System.
- Once you create an Application in the Admin App, you will store and use the generated "Key" and "Secret" in the next section.
- Note: Treat the Key and Secret as secure information for your organization (because it will control student data exchange from your SIS).
- Store it according to your local IT Security policy. Often this will be in password keeper app, or on a secure file server, or similar method (check with your IT department).
- Note that other applications you may add over time, for example Assessment applications used in other starter kits, will each have their own "key" and "secret".
Deep dive
For additional information on the Ed-Fi Data standard and vendors who support it see the pages below.
Links:
More Information
If your SIS vendor is not Ed-Fi certified use the Vendor Request Form and we can help you make the ask of your vendor to support data interoperability and certify their product.
Configure your Student Information System
Each SIS provider has its own vendor-specific configuration tool and steps to connect to the Ed-Fi API, perform basic data mapping, provide descriptors, and to enable you to begin loading data into your ODS API. You will connect your SIS to your ODS API using the key and secret you generated in the Admin App.
- Verify that your SIS supports Ed-Fi data interoperability, and is certified to use the ODS API to allow you to use this Family Engagement starter kit: Registry of Ed-Fi Certified Products - Student Information Systems API v3 Certification
- Verify that your district is using the version of your SIS that the vendor certified.
- If you are not running the current certified version of your SIS (or newer), plan your update/upgrade to the certified version of your SIS.
- If your SIS is not listed as an Ed-Fi certified SIS, use the vendor request form to the right side of this page to get our help in making your ask and conveying your requirements of your vendor.
- Request Ed-Fi enablement and configuration from your SIS vendor's product support team.
- Log into your SIS vendor's customer support portal or knowledge base to find the most current help documentation to guide you in the SIS configuration steps.
- Follow your SIS vendor's configuration guide to configure the product to connect to your ODS API and prepare for loading your data.
See General Reference page for a list of publicly known vendor configuration guides.
Map SIS Codes to the ODS API
- Once your SIS is configured to connect with the Ed-Fi API, the next step to getting your data to the ODS API is to map "code sets", or Descriptors, as they are known in the Ed-Fi data standard, from the data elements and codes used in your SIS to those you will use in the Ed-Fi ODS API. To do this:
- Refer to your SIS vendor configuration guide you used above to locate and use the data mapping tools in your SIS application.
- Proceed with your SIS vendor's data mapping instructions, referring to their configuration guide and the dependency chart provided above to work through the data mapping and loading in the right sequence.
- In the next step (3) of this setup guide, you will use these descriptors to understand how your data is displayed in the Family Engagement portal application.
- Review the Best Practices for Descriptors presentation if you would like more background explanation of descriptors and why they're relevant to your needs.
Need help?
Having difficulty configuring your SIS or mapping SIS codes? Reach out to an Ed-Fi Alliance representative for assistance.
- Ed-Fi Slack channel #starter-kits
- Open a ticket in Ed-Fi Tracker
Step 3. Configure
In this step you will configure and use the data visualizations and reports included in this Family Engagement starter kit.
Build and Deploy the Family Portal web application from Visual Studio
Once you have installed Visual Studio, from the Windows Desktop of your installation environment:
- Open the Ed-Fi Solutions Folder, then locate and open the FamilyPortal folder
- Select and open this file in Visual Studio: Open ParentPortal Project in Visual Studio Community
If this is your first time launching Visual Studio, you will have some initial setup tasks outlined below
- Select OK
- It is not necessary to login to the Visual Studio developer services to continue.
- Choose the option of downloading the appropriate Microsoft .NET Targeting pack.
- Accept the defaults to install all of the needed Visual Studio build dependencies.
- Click Install
- The Visual Studio installer will now download and apply those updates.
There is no need to watch the installer after you have clicked Install. However, this download and install process may take as much as an hour to complete depending on your internet bandwidth.
Please allow it to complete. - Visual Studio will finish launching once it has completed.
- Once the ParentPortal project is opened in Visual Studio, expand the Student1.ParentPortal.Web in the Solution Explorer on the left side.
- Open the Web.config file to modify the following settings:
- If you are using a remote database server, modify the connectionStrings section as appropriate.
- In the AppSettings section, adjust the follow key values to fit your installation:
- authentication.azure.tenant value = "[Enter your tenant name here e.g. contoso.onmicrosoft.com]"
- authentication.azure.audience value = "[Enter your clientId here e.g. e9a5a8b6-8af7-4719-9821-0deef255f68e]"
- feedback.emails value ="[e.g. dontreply@student1.org]"
- messaging.email.defaultFromEmail value="[e.g. dontreply@student1.org]"
- messaging.email.server value="[e.g. smtp.sendgrid.net]"
- messaging.email.port value="587"
- Expand the clientapp folder under the Student1.Portal.Web project, and open app.config.js to modify the following Azure Active Directory settings:
- instance: "[e.g. https://login.microsoftonline.com/ or appropriate Active Directory source]"
- tenant: "[enter your tenant e.g. toolwise.onmicrosoft.com]"
- clientId: "[enter your clientid e.g. c34f1634-092c-476e-baa9-29e429717879]"
- Save and close all files, then test the Web Application by by pressing the F5 key, or by clicking on the Run icon:
- The Family Portal should then launch and open your web browser to the Portal Login page
- When configured correctly, you will be able to login successfully if you have an appropriate staff or parent test login with an email address that matches the test data in your Ed-Fi ODS/API.
- Use SQL Server Management Studio or your preferred database tool to check what email addresses are present in your data by querying either the StaffElectronicMail table or ParentElectronicMail table in your EdFi_Ods_Test_v320 database.
- Close the web browser to return to the project in Visual Studio and stop the test.
- We will explore more of the configuration details in the steps below.
- Once you've completed testing and reconfiguring for your needs, you will deploy the application to your test environments web servers.
- If you are familiar with .NET web apps, refer to the Microsoft guide to publish web apps from Visual Studio to your IIS web server environment.
- Alternatively, the portal app includes a deployment script to simplify that process, look in the C:\Ed-Fi\FamilyPortal directory for the deploy.cmd file.
- Note that you can also find these project files and additional help documentation in the Family Engagement repository on GitHub.
Note that this guide will not cover the detailed deployment of .NET web applications. Refer to the support documentation from Microsoft for that detail.
As you dig into the details and configure this starter kit for your organization's specific needs, you'll build your understanding of these key skills:
- Working with Descriptors
- Connecting data in the ODS/API with portal users
Let's check your understanding of those two topics now, skip to the next section if you are already comfortable with them.
Working with Descriptors
As you worked through the "Codes" to Descriptors mapping in the previous step, you learned the scope of descriptors and their importance to your data. Descriptors help standardize the vocabulary of education data across your organization and across all education-connected organizations, from students to staff to agencies to vendors. You can think of descriptors as "options" for particular types of data, similar to how "codes" work in many education tools, but focused on complete understanding of the data rather than simplified codes. Typical examples of descriptors are: KG for kindergarten, 01 for 1st Grade, and the sets of absence codes used in marking attendance each day/period for students.
To maintain our data standard, it is important to keep the set of descriptors as consistent as possible across all implementations. However, you will find that different agencies and organizations have chosen different "code sets", often for legal or historical reasons. Because of this differentiation, it may be necessary for you to look closely at the SQL queries in this starter kit and adjust them to match your organization's specific needs (these queries were built and used in other LEAs' projects and shared for your use and adaptation).
Below, you'll look at where and how those descriptors are used in the calculations and visualizations of the Family Engagement starter kit and apply that knowledge to make this starter kit work for your organization and prepare you for the next data challenge.
Linking Student, Parent/Guardian, and Staff Data to the Family Portal
You are beginning to understand the size, shape, and characteristics of your data as it is standardized and loaded into your Ed-Fi environment. The next step is to learn how that data is assembled, consumed, aggregated, or generalized in the Family Engagement application, and therefore, how you can apply your organization's needs to this solution.
To help you understand where and how your core data fits to the data standard, and thus how it is landing in the Ed-Fi ODS/API, take a look at the Overview Diagrams from the Ed-Fi Unifying Data Model, the detailed documentation and model of the Ed-Fi Data Standard, below:
The ODS/API is the physical instantiation of the UDM's logical model. You don't need to learn all of the details of the standard yet, but referring to the UDM's logical model may help you "see the big picture" which in turn can help you learn how to find data items and understand the structure of your standardized data .
As mentioned above, the portal application reads and gathers data from the ODS (or your read-only copy of the ODS) in real-time for display or delivery to users of the portal. We will look at configuration files which tune the database queries and use that tuning to understand more about where your data lands in the Ed-Fi ODS and how we can use it.
You can also use the SQL Server Management Studio, the SQL command line, or your preferred data tool for taking a closer look at the data used.
Configuring key metrics in the Family Portal
In Visual Studio, open the Student1.ParentPortal.Web project and locate the customizableParameters31.json file. The following sections detail how you will use the configuration items in this file to make this Family Engagement solution yours.
Attendance Metrics
Purpose: In addition to providing a quick reference for a student's current attendance, the portal app provides a set of configurable rules to track and notify family members or staff of a student's attendance changes.
Configure: The rules for attendance tracking are the section labeled attendance in the configuration file.
1. ADA (Average Daily Attendance of student for the school)
Purpose: The ADA subsection provides thresholds and user-friendly mappings of calculated attendance metrics which display in the portal. These metrics include: tardy, excused absence, and unexcused absence.
Details: Each metric has four thresholdRules to map total occurrences of each to a particular interpretation bucket: Great, Good, Warning, and Bad. The rules can be tuned for each by adjusting the value and operator accordingly.
"unexcused": { "maxAbsencesCountThreshold": 10, "thresholdRules": [ { "interpretation": "great", "operator": "==", "value": 0 }, ...
2. PeriodLevelAttendance (PLA or class section attendance)
Purpose: The PLA subsection, similar to the ADA, provides thresholds and user-friendly mappings of section attendance metrics which display in the portal for each of the students' classes. These metrics include: tardy, excused absence, and unexcused absence
Details: Each metric has 4 thresholdRules to map total occurrences of each to a particular interpretation bucket: Great, Good, Warning, and Bad. The rules can be tuned for each by adjusting the value and operator accordingly.
"tardy": { "maxAbsencesCountThreshold": 10, "thresholdRules": [ { "interpretation": "great", "operator": "==", "value": 0 }, ...
Behavior Metrics
Purpose: The behavior section provides rules and mappings for student behavioral incidents, and linkage to external behavior tracking tools.
Configure: In the behavior section of the configuration file, the ThresholdRules subsection, similar to the attendance examples, can be configured by adjusting the value and operator items as needed. You can configure the link to an external behavior system in the linkToSystemWithDetails subsection.
"behavior": { "maxDisciplineIncidentsCountThreshold": 3, "linkToSystemWithDetails": { "title": "Hero K12", "linkText": "Hero", "url": "https://access.heropowered-stg.com/sso/parent/login" }, "thresholdRules": [ { "interpretation": "great", "operator": "<=", "value": 0 }, ...
Student Grades and Averages Data
Purpose: The Grades section brings data from students' gradebook results to the portal, including GPA, course averages, assignments, and linkage to other systems with greater detail such as a SIS family portal.
Configure: Configure these rules for student grades and linkages to external systems in the "Grades" section of the configuration file.
1. GPA (overall grade point average)
Purpose: Similar to the attendance examples above, this subsection provides thresholds and user-friendly mappings of grade point average for display in the portal for each of the students' classes, including a comparison to the national average.
Details: You can configure the ranges for comparative analysis and classification of a student's GPA using the value and operator settings for each of three classification buckets: Good, Warning, and Bad
"courseGrades": { "linkToSystemWithDetails": { "title": "HAC - Detail", "linkText": "Skyward Family Access", "url": "https://skyward.iscorp.com/YESPrepTXStuSTS/Session/Signin" }, "gpa": { "nationalAverage": 3.38, "thresholdRules": [ { "interpretation": "good", "operator": ">=", "value": 3.0 }, ...
2. courseAverage (gradebook)
Purpose: This subsection provides thresholds and user-friendly mappings of students' performance in each of their Sections (classes).
Details: Configure the ranges for classification of a student's performance using the value and operator settings for each of four classification buckets: Great, Good, Warning, and Bad
"courseAverage": { "thresholdRules": [ { "interpretation": "great", "operator": ">=", "value": 90 }, ...
Student Assignments (coursework)
Purpose: The assignments section provides rules and mappings for student performance with assignments in each of their sections (classes). You can also configure linkage to external tracking tools.
Configure: In the configuration file, the ThresholdRules subsection, similar to the attendance examples, can be configured by adjusting the value and operator items as needed. You can configure the link to an external behavior system in the linkToSystemWithDetails subsection.
"assignments": { "maxAssigmentsCountThreshold": 3, "linkToSystemWithDetails": { "title": "HAC - Detail", "linkText": "Skyward Family Access", "url": "https://skyward.iscorp.com/YESPrepTXStuSTS/Session/Signin" }, "thresholdRules": [ { "interpretation": "great", "operator": "==", "value": 0 }, ...
Student Graduation Readiness
Purpose: The graduationReadiness section indicates a positive or negative interpretation of a student as on track to graduate.
Configure: In the configuration file, the ThresholdRules subsection, similar to above examples, can be configured by adjusting the value and operator items as needed.
"graduationReadiness": { "thresholdRules": [ { "interpretation": "good", "operator": "==", "value": true }, { "interpretation": "bad", "operator": "==", "value": false } ] }, ...
Student Assessments
Purpose: The assessments section allows you to configure identifiers, friendly name mappings, scoring types, and external links for each of the key assessment types displayed in the portal app.
Configure: In the assessment section of the configuration file, you will see a list of the named assessment types along with relevant info and configuration details. You can add or modify these examples to match the assessment instruments your organization uses.
Details: Each assessment has a a title, description, identifiers from the ODS/API, reporting/scoring type values e.g. scale score or raw score, and links to the specific reporting tool for that assessment provider.
"assessments": [ { "title": "STAAR", // EoC -- STAAR Algebra II, STAAR English III "assessmentIdentifiers": [ "STAAR English I", "STAAR Algebra I", "STAAR English II", "STAAR Biology", "STAAR U.S. History" ], "assessmentReportingMethodTypeDescriptor": "Scale score", "shortDescription": "State of Texas Assessments of Academic Readiness", "externalLink": "https://txparentportal.emetric.net/login" }, ...
Descriptors Configuration
Purpose: The descriptors section allows for fine tuning of mappings and displayed values for Descriptors. This allows you to match values from your data, if they differ from defaults, to what is displayed on the portal.
Configure: The descriptors configuration enables you to manage the mappings and included data points of each of the student metrics used in the portal. For example, you can include or remove gradebook types from the assignments category, or change the valid types for the "parent" role used by the portal, or modify the grading period types as appropriate for your school.
Review the example here for more detail.
"descriptors": { "excusedAbsenceDescriptorCodeValue": "Excused Absence", // "AE", "unexcusedAbsenceDescriptorCodeValue": "Unexcused Absence", // "AU", "tardyDescriptorCodeValue": "Tardy", // "T", "absentDescriptorCodeValue": "Absent", // "A", "gradeBookMissingAssignmentTypeDescriptors": [ "HMWK" ], //["Assignment","Homework"], [895,897] "gradeTypeGradingPeriodDescriptor": "Grading Period", // 928 "gradeTypeSemesterDescriptor": "Semester", // 926 "gradeTypeExamDescriptor": "Exam", "gradeTypeFinalDescriptor": "Final", // 925 "validParentDescriptors": [ "Father", "Mother", "Step", "Guardian", "Foster", "GrandParent" ], //[ "F", "FP", "G", "M", "SP", "GP" ] "validCampusLeaderDescriptors": [ "Assistant Principal", "Counselor", "Principal", "School Administrator", "School Leader" ], "schoolGradingPeriodDescriptors": [ "First Six Weeks", "Second Six Weeks", "Third Six Weeks", "Fourth Six Weeks", "Fifth Six Weeks", "Sixth Six Weeks" ], // They have to be in order [ "A1", "A2", "A3", "A4", "A5", "A6" ] "examGradingPeriods": [ "A3", "A6" ], "disciplineIncidentDescriptor": "Perpetrator", "missingAssignmentLetterGrade": "M", "validEmailTypeDescriptors": [ "Home/Personal" ] },
Update and Publish Portal Application
As noted previously, if you don't already have a .NET web app deployment process, you can use the deploy.cmd file in the C:\Ed-Fi\FamilyPortal directory to automate the process of deploying the app to your web server.
- deploy.cmd is a command script file that uses Visual Studio and the Node.JS version of KuduSync to build, deploy, and perform initial tests on the portal app.
- Open and edit the deploy.cmd file to fit your deployment needs.
- Use
SET DEPLOYMENT_TARGET="your deployment path"
prior to running the command to set the deploy path. - Make sure you have correct file permission settings for your deployment location.
- Use
You may also refer to the Microsoft guide to publish web apps from Visual Studio to your IIS web server environment.
Step 4. Rollout
By completing the Quick Start you created a sample environment to familiarize yourself with the solution and demonstrate its value to key stakeholders. In this Setup Guide you created a testing environment which you can use to:
- Verify functionality and support from key systems
- Understand what resources and technical skills you need, and
- Test this solution with your key audience in a pilot
The next step is to conduct a production rollout of your solution.
Rollout Planning
It is recommended that your rollout planning follow the general steps outlined below. All of these steps are are covered in more detail in the Production Rollout Checklist
1. Plan | 2. Prepare | 3. Rollout | 4. Improve |
---|---|---|---|
|
|
|
|
|
|
|
|
|
|
|
|
Tips for a Successful Production Rollout
Engage your leadership and key stakeholders
- Clearly define the roles ands responsibilities of your team members as early in the process as possible so
Foster and support "Power Users"
- Your pilot audience should include "power users" from your organization who will be using your solution most heavily.
- Encourage power users to form mentoring relationships with each other and other uses and give them strong support.
Use the "Train the Trainer" model
- Leverage your power users to guide training sessions and develop supplemental content to assist others with using the solution.
- Keep training focused on specific use cases that deliver a clear value to users. Don't try to cover every topic.
Build data literacy and governance
- Do not treat data governance as a separate project or dependency to fulfill in advance.
- Effective data governance processes don't operate in a vacuum, they need real examples that people can buy into.
- Build your process by answering questions about data ownership and responsibility.
Promote your Minimum Viable Product (MVP) approach
- Don't get bogged down in perfection or questions of data ownership
- Show stakeholders that their contributions are needed
More Information
Once you have your own test data loaded, you no longer need a demonstration environment with sample data. You can deploy your new prototype against your existing Ed-Fi test environment.
Next Steps
Prepare for Production
- Take a deep dive on security with the Platform Dev. Guide - Security.
- Review the technology and skill requirements to choose your deployment team.
Take a Deeper Dive Into the Technology
- Instruction to schedule an LEA working session.
- Technical Documentation for the Ed-Fi ODS / API v3.2.
- Ed-Fi Data Standard v3.1.
- Source files for the Family Engagement solution.
More Information
By completing the Family Engagement starter kit you have already accomplished a large portion of the work required for other Ed-Fi solutions. To finish setting up those solutions see their Starter Kit on the Starter Kit Home Page.
Link: Starter Kits
- No labels