Skip to main content
Version: 7.3

Configuration Details

The Ed-Fi ODS / API is configurable in a number of ways. Since the source code is available to licensees, one could argue that everything is configurable. But, what we’re discussing in this section are things like settings and options that do not require a change to the compiled code.

Key configuration points include: OAuth endpoints, Admin and Security datastore connections, Token timeouts, Enabling / disabling features. See the following sections for more details on important configuration options

Required Configuration Settings

Some configuration must be done for every Ed-Fi ODS / API platform instance. In Ed-Fi ODS / API, the appsettings.json file provides the primary configuration for the ASP.NET Core applications. Examples of required configurations include database connection strings, SMTP server locations, and similar.

To make it easier for developers to install and run the Ed-Fi ODS / API, the default download from source control is pre-configured with values appropriate for a developer or single-server test instance of the system.

The appsettings.json files provide the primary configurations for the ASP.NET applications described below, though the .NET architecture provides support for additional configuration sources such as environment variables, command-line arguments, and other sources (such as services from cloud providers). See the Configuration in ASP.NET Core documentation for more information.

EdFi.Ods.SwaggerUI

  • WebApiVersionUrl
    Example Valuehttp://site-address:port/
    DescriptionPoints to the version endpoint in the Ed-Fi ODS / API.

EdFi.Ods.SandboxAdmin

  • OAuthUrl
    Example Valuehttp://site-address:port/oauth
    DescriptionPoints to the root of the authorization API in the Ed-Fi ODS / API.

EdFi.Ods.WebApi

  • ConnectionStrings:EdFi_Admin
    Example ValueServer=(local); Database=EdFi_Admin; Trusted_Connection=True; Application Name=EdFi.Ods.WebApi;
    DescriptionConnection string for the Admin database.
  • ConnectionStrings:EdFi_Security
    Example ValueServer=(local); Database=EdFi_Security; Trusted_Connection=True; Persist Security Info=True; Application Name=EdFi.Ods.WebApi;
    DescriptionConnection string for the Security metadata database.
  • ApiSettings:OdsConnectionStringEncryptionKey
    Example ValueJivjQAm53kz9IaBLUJIk+Rd+1YaKNZ88PkxjiSsQNRQ=
    DescriptionAES Encryption key used to encrypt ODS connection strings configured in the Admin database. (Required everywhere other than development environment).

A deployment to a staging or production instance is usually more involved, and requires additional configuration. Required configurations for a production instance can be found in the Deployment section of this documentation.

Optional Configuration Settings

Although this list of settings is not exhaustive, other important and useful optional configuration values include:

EdFi.Ods.SwaggerUI

Setting NameExample ValueDescription
SwaggerUIOptions:OAuthConfigObject:ClientIdrcKsguTICAaBm9PxyUW4iOptionally provides the value to prefill in the "key" field of auth.
SwaggerUIOptions:OAuthConfigObject:ClientSecrett0CklTOfMBGZNPgVQDLHhOptionally provides the value to prefill in the "secret" field of auth.
Tenants
"Tenants": [
{
"Tenant": "Tenant1"
}
],

Optionally provides the name of a tenant. This setting is required if using Multi Tenant Configuration. A valid tenant name is required for SwaggerUI to retrieve the API metadata.

EdFi.Ods.SandboxAdmin

Setting NameExample ValueDescription
User
"User": {
"Test Admin": {
"Email": "<test@ed-fi.org>",
"Admin": "true",
"NamespacePrefixes": [
"uri://ed-fi.org",
"uri://gbisd.org"
],
"Password": "zSKj8DdR4mQlPp3X2i1ra",
"Sandboxes": {
"Minimal Demonstration Sandbox": {
"Key": "FLqUvMPSoG4ryp7HiRBmX",
"Type": "Minimal",
"Secret": "bhJfA6qt7iNP3Xd5as9O0",
"Refresh": "false"
},
"Populated Demonstration Sandbox": {
"Key": "rcKsguTICAaBm9PxyUW4i",
"Type": "Sample",
"Secret": "t0CklTOfMBGZNPgVQDLHh",
"Refresh": "false"
}
}
}
}

Defines automatically created user accounts and sandboxes. Also configures automatic refreshes of sandboxes to a clean state. Each user entry will be created with the given email/password, and the sandboxes defined underneath it will also be created for the type and key/secret values.

New: Must include the NamespacePrefixes elements, to deploy what namespaces for the associated vendor. This collection is required, and at least one namespace prefix is required.

MaximumSandboxesPerUser5The maximum number of sandboxes a sandbox admin user can create.
DefaultClaimSetNameSIS VendorThe claim set name for the default application for sandbox application clients.
MailSettings:Smtp:UserNameUser.NameThe username of the credentials that are used to create an SMTP client for sending email messages from the Sandbox Admin application for new user creation and password resets
MailSettings:Smtp:Passwordabcd1234The password of the credentials that are used to create an SMTP client for sending email messages from the Sandbox Admin application for new user creation and password resets
MailSettings:Smtp:Fromno-reply@example.comThe email address that will show up in the FROM field of any email messages sent from the Sandbox Admin application
MailSettings:Smtp:Hostsmtp.example.comThe SMTP server that is used for sending email messages from the Sandbox Admin application. This value is necessary when the DeliveryMethod of Network is specified
MailSettings:Smtp:Port25The port number used by the SMTP server for email messages. If no value is specified, then the default of 25 is used.

MailSettings:Smtp
:DeliveryMethod

Network

Specifies how email messages are delivered. The valid choices for this are:

  • Network - Email is sent through the network to an existing SMTP server
  • PickupDirectoryFromIis - Email is copied to the pickup directory used by IIS for delivery via its SMTP service
  • SpecifiedPickupDirectory - Email is copied to the specified directory for processing by an external mail application

MailSettings:Smtp
:SpecifiedPickupDirectory
:PickupDirectoryLocation

C:\temp\location\emailsWhen a Delivery Method of SpecifiedPickupDirectory is used, this is the folder where email messages will be saved to, to be picked up by an external mail application for processing and sending
MailSettings:Smtp:EnableSsltrueIndicates whether SSL encryption is used when establishing a connection with the SMTP server. This value is only applicable when the DeliveryMethod of Network is specified

EdFi.Ods.WebApi

Setting NameExample ValueDescription
QueueAutoCreate1Whether or not a message queue should be created if it is not found. For Azure or Active Directory queues, this should be 0.
CommitUploadCommandMessageEndPointlocalhostThe server hosting the message queues.
ApiSettings:BearerTokenTimeoutMinutes30The amount of time that an OAuth token remains valid.
🆕 ApiSettings:BearerTokenPerClientLimit15The maximum number of active (non-expired) OAuth tokens allowed for a client. Setting this value to -1 disables the limit.

ApiSettings:Caching
:Security:AbsoluteExpirationMinutes

10The amount of time the security metadata from EdFi_Security database is cached. E.g., if it is set to 10 mins, the claim set changes will reflect in the API at least after 10 mins without needing to recycle API process.

ApiSettings:Caching
:Descriptors:AbsoluteExpirationSeconds

1800Number of seconds after which the descriptor cache is refreshed.

ApiSettings:Caching
:Descriptors:UseExternalCache

trueWhen true, the Descriptor cache will use the configured external cache provider.

ApiSettings:Caching
:PersonUniqueIdToUsi:AbsoluteExpirationSeconds

14400Number of seconds after which the PersonUniqueIdToUsi mapping is refreshed. This settings is applied only when SlidingExpirationSeconds is not provided or set to 0.

ApiSettings:Caching
:PersonUniqueIdToUsi:SlidingExpirationSeconds

14400Number of seconds after which a PersonUniqueIdToUsi mapping is refreshed if not accessed.

ApiSettings:Caching
:PersonUniqueIdToUsi:UseProgressiveLoading

falseWhen set to true, PersonUniqueIdToUsi mapping is loaded progressively as needed to fulfill the API requests (rather than being fully initialized in the background upon first request).

ApiSettings:Caching
:PersonUniqueIdToUsi:CacheSuppression:Student

falseIndicates whether student UniqueId/USI mappings should be cached, or retrieved on demand with each request. When set to true,  caching is suppressed.

ApiSettings:Caching
:PersonUniqueIdToUsi:CacheSuppression:Staff

falseIndicates whether staff UniqueId/USI mappings should be cached, or retrieved on demand with each request. When set to true,  caching is suppressed.

ApiSettings:Caching
:PersonUniqueIdToUsi:CacheSuppression:Parent

falseIndicates whether parent UniqueId/USI mappings should be cached, or retrieved on demand with each request. When set to true, caching is suppressed. For use with data standard 4.0 and below. This setting has no affect after data standard 4.0.

ApiSettings:Caching
:PersonUniqueIdToUsi:CacheSuppression:Contact

trueIndicates whether contact UniqueId/USI mappings should be cached, or retrieved on demand with each request. When set to true, caching is suppressed. For use with data standard 5.0 and above. This setting has no affect before data standard 5.0.

ApiSettings:Caching
:PersonUniqueIdToUsi:UseExternalCache

trueWhen true, the Person cache will use the configured external cache provider.

ApiSettings:Caching
:ApiClientDetails:UseExternalCache

trueWhen true, the API Client cache will use the configured external cache provider.

ApiSettings:Caching
:ApiClientDetails:AbsoluteExpirationSeconds

14400Number of seconds after which API Client information is refreshed if not accessed.

ApiSettings:Caching
:ExternalCacheProvider

RedisCurrently the only available option is "Redis". When left blank (default), the application will use in-memory caching rather than an external provider, if any of the "UseExternalCache" options is set to true.

ApiSettings:Services
:Redis:Configuration

Example: see this documentWhen ExternalCacheProvider=="Redis" , provide the connection string information here. Default: an empty string

ApiSettings:Caching
:Security:AbsoluteExpirationMinutes

10The amount of time the security metadata from EdFi_Security database is cached. E.g., if it is set to 10 mins, the claim set changes will reflect in the API at least after 10 mins without needing to recycle API process.

ApiSettings:Caching
:Profiles:AbsoluteExpirationSeconds

1800Number of seconds after which API client profile information is refreshed if not accessed.

ApiSettings:Caching
:OdsInstances:AbsoluteExpirationSeconds

300Number of seconds after which ODS Instance mapping information is refreshed if not accessed.

ApiSettings:Caching
:Tenants:AbsoluteExpirationSeconds

600Number of seconds after which Tenant information is refreshed if not accessed.
🆕 ApiSettings:Features:SerializedDatatrueActivates optimized behavior in the API to serialize the resource data into a binary representation that is stored on the "root" record of the resource's underlying table in the ODS. This serialized representation is then used as the primary source for servicing future API requests. While the data in the ODS tables is still maintained, it is only used as the canonical source when the serialized data is invalidated by modification of the ODS data by other processes (detected by a change to LastModifiedDate).
🆕 ApiSettings:Features:ResourceLinkstrueControls the inclusion of link objects in references in responses from the Data Management resource endpoints. Disabling this feature is a server-side optimization reducing database load, but comes with the risk of breaking API client integrations that utilize them.
ApiSettings:Features:ExtensionstrueEnables the API endpoints created for all Extensions. An installation that is not customized at all and still has the GrandBend and Sample extensions can disable this feature in production.
ApiSettings:Features:UniqueIdValidationfalseEnables Unique ID System Integration. Must implement IUniqueIdToIdValueMapper and register within the implementation within the WebApi.
ApiSettings:Features:TokenInfotrueEnables the token_info introspective endpoint.
Plugin:Folder../../PluginConfigures the plugin folder that API looks to deploy extensions dynamically.
Plugin:Scripts["tpdm"]Configures the script (located in plugin folder by default) responsible for downloading the extension plugins and placing them in the plugin folder.

Environment Configuration

While appsettings.json provides the primary configuration for the ASP.NET Core applications in the ODS / API solution, appsettings.Environment.json can be used to override the settings in appsettings.json in deployment environments. In development environment, initdev creates appsettings.Development.json to override settings for development environment. Note that the settings in appsettings.Development.json are overwritten every time initdev is executed. See Configuration in ASP.NET Core for more details.

Secret Manager

In development environments ASP.NET Core applications in the ODS / API solution uses secret manager tool to provide a way for setting overrides away from the projects so that they aren't accidentally checked into source control. To set overrides, you can either use the .NET CLI Tool

PS D:\Ed-Fi-ODS-Implementation\Application\EdFi.Ods.WebApi> dotnet user-secrets set "ApiSettings:PopulatedTemplateScript" "Glendale"
Successfully saved ApiSettings:PopulatedTemplateScript = Glendale to the secret store.

or Manage User Secrets in Visual Studio.

Manage User Secrets

Both of the above methods will create a secret.json file in the local machine's user profile folder and will override settings in appsettings.Development.json.

Websitesecrets.json location in Windows
Ed-Fi ODS / API%APPDATA%\Microsoft\UserSecrets\f1506d66-289c-44cb-a2e2-80411cc690ec
Sandbox Administration%APPDATA%\Microsoft\UserSecrets\f1506d66-289c-44cb-a2e2-80411cc690ea
Ed-Fi ODS / API Documentation%APPDATA%\Microsoft\UserSecrets\f1506d66-289c-44cb-a2e2-80411cc690eb

e.g., Following secret.json overrides the default 'GrandBend' dataset and deploys with 'Glendale' sample dataset.

{
"ApiSettings": {
"PopulatedTemplateScript": "Glendale",
}
}

See Safe storage of app secrets in development in ASP.NET Core for more details.