Adding Custom ODS / API Features
The Ed-Fi ODS / API comes with a set of configurable features that can be enabled or disabled using configuration settings in deployed API. Additional custom features could be implemented by following the steps outlined here:
Step 1. Create a Service
namespace EdFi.Ods.Services
{
public class TestService : ITestService
{
public void DoSomething() { }
}
}
Step 2. Add a New Autofac Module Class
- Inherit from
ConditionalModule
inEdFi.Ods.Common
. - Override
IsSelected
method - Override
ApplyConfigurationSpecificRegistrations
method
using Autofac;
using EdFi.Common.Configuration;
using EdFi.Ods.Common.Configuration;
using EdFi.Ods.Common.Container;
using EdFi.Ods.TestService;
namespace EdFi.Ods.Features.Container.Modules
{
public class TestModule : ConditionalModule
{
public TestModule(ApiSettings apiSettings) : base(apiSettings, nameof(TestModule)) { }
public override bool IsSelected() => IsFeatureEnabled(ApiFeature.TestService);
public override void ApplyConfigurationSpecificRegistrations(ContainerBuilder builder)
{
// TODO add components to register.
}
}
}
Step 3. Add Configuration Setting in appsettings.json in EdFi.Ods.WebApi Project
{
...
"Features": [
{
"Name": "TestService",
"IsEnabled": true
}
...
]
...
}