public IccService(IccBackendContentDbContext dbContext, IConfiguration configuration, IUtcDateTimeProvider dateTimeProvider, IRandomNumberGenerator randomGenerator) { _DbContext = dbContext; _Configuration = configuration; _DateTimeProvider = dateTimeProvider; _RandomGenerator = randomGenerator; }
public static void ConfigureServices(IServiceCollection services) { services.AddSeriLog(Configuration); services.AddSingleton(Configuration); services.AddTransient <App>(); services.AddScoped(x => { var config = new StandardEfDbConfig(Configuration, "Content"); var builder = new SqlServerDbContextOptionsBuilder(config); var result = new ExposureContentDbContext(builder.Build()); return(result); }); services.AddScoped(x => { var config = new StandardEfDbConfig(Configuration, "Workflow"); var builder = new SqlServerDbContextOptionsBuilder(config); var result = new WorkflowDbContext(builder.Build()); return(result); }); services.AddScoped(x => { var config = new StandardEfDbConfig(Configuration, "Icc"); var builder = new SqlServerDbContextOptionsBuilder(config); var result = new IccBackendContentDbContext(builder.Build()); return(result); }); }
public CreateIccDatabase(IConfiguration configuration) { var config = new StandardEfDbConfig(configuration, "Icc"); var builder = new SqlServerDbContextOptionsBuilder(config); _Provider = new IccBackendContentDbContext(builder.Build()); }
public RedeemIccController(IIccService iccService, ILogger <RedeemIccController> logger, AppBackendService appBackendService, IccBackendContentDbContext dbContext) { _IccService = iccService; _AppBackendService = appBackendService; _Logger = logger; _DbContext = dbContext; }
public GenerateIccController(ILogger <GenerateIccController> logger, IConfiguration configuration, IIccService iccService, IccBackendContentDbContext dbContext) { _Logger = logger; _Configuration = configuration; _IccService = iccService; _DbContext = dbContext; }
// This method gets called by the runtime. Use this method to add services to the container. public void ConfigureServices(IServiceCollection services) { services.AddControllers(options => { options.RespectBrowserAcceptHeader = true; }); services.AddControllers(); // Database Scoping services.AddScoped(x => { var config = new StandardEfDbConfig(Configuration, "Icc"); var builder = new SqlServerDbContextOptionsBuilder(config); var result = new IccBackendContentDbContext(builder.Build()); result.BeginTransaction(); return(result); }); services.AddScoped <IEfDbConfig>(x => new StandardEfDbConfig(Configuration, "Icc")); services.AddScoped <ProvisionDatabasesCommandIcc, ProvisionDatabasesCommandIcc>(); services.AddScoped <IUtcDateTimeProvider, StandardUtcDateTimeProvider>(); services.AddScoped <IRandomNumberGenerator, RandomNumberGenerator>(); services.AddScoped <IBasicAuthenticationConfig, BasicAuthenticationConfig>(); services.AddScoped <IIccService, IccService>(); services.AddScoped <AppBackendService, AppBackendService>(); services.AddAuthentication("IccAuthentication") .AddScheme <AuthenticationSchemeOptions, IccAuthenticationHandler>("IccAuthentication", null); services.AddCors(); services.AddSwaggerGen(o => { o.SwaggerDoc("v1", new OpenApiInfo { Title = "Dutch Exposure Notification ICC API (inc. dev support)", Version = "v1", Description = "This specification describes the interface between the Dutch exposure notification app backend, ICC Webportal and the ICC backend service.", Contact = new OpenApiContact { Name = "Ministerie van Volksgezondheid Welzijn en Sport backend repository", //TODO looks wrong? Url = new Uri("https://github.com/minvws/nl-covid19-notification-app-backend"), }, License = new OpenApiLicense { Name = "European Union Public License v. 1.2", //TODO this should be https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12 Url = new Uri("https://github.com/minvws/nl-covid19-notification-app-backend/blob/master/LICENSE.txt") }, }); o.IncludeXmlComments(Path.Combine(AppContext.BaseDirectory, "NL.Rijksoverheid.ExposureNotification.BackEnd.Components.xml")); o.AddSecurityDefinition("Icc", new OpenApiSecurityScheme { Description = "Icc Code Authentication", Name = "Authorization", In = ParameterLocation.Header, Type = SecuritySchemeType.ApiKey, Scheme = "IccAuthentication" }); o.OperationFilter <SecurityRequirementsOperationFilter>(); }); }
public App(ILogger <App> logger, WorkflowDbContext workflowDbContext, ExposureContentDbContext exposureContentDbContext, IccBackendContentDbContext iccBackedBackendContentDb) { _Logger = logger; _WorkflowDbContext = workflowDbContext; _ExposureContentDbContext = exposureContentDbContext; _IccBackendContentDbContext = iccBackedBackendContentDb; }
public App(ILogger <App> logger, WorkflowDbContext workflowDbContext, ExposureContentDbContext exposureContentDbContext, IccBackendContentDbContext iccBackedBackendContentDb, IConfigurationRoot configuration) { _Logger = logger; _WorkflowDbContext = workflowDbContext; _ExposureContentDbContext = exposureContentDbContext; _IccBackendContentDbContext = iccBackedBackendContentDb; _Configuration = configuration; }
public IccDatabaseCreateCommand(IConfiguration configuration) { if (configuration == null) { throw new ArgumentNullException(nameof(configuration)); } var config = new StandardEfDbConfig(configuration, "Icc"); var builder = new SqlServerDbContextOptionsBuilder(config); _Provider = new IccBackendContentDbContext(builder.Build()); }
public IccAuthenticationHandler( IOptionsMonitor <AuthenticationSchemeOptions> options, ILoggerFactory logger, UrlEncoder encoder, IIccService iccService, IccBackendContentDbContext dbContext, ISystemClock clock) : base(options, logger, encoder, clock) { _DbContext = dbContext; _IccService = iccService; _Logger = logger.CreateLogger <IccAuthenticationHandler>(); }
// This method gets called by the runtime. Use this method to add services to the container. public void ConfigureServices(IServiceCollection services) { services .AddControllers(options => { options.RespectBrowserAcceptHeader = true; }) //Arming these options only makes them less tolerant of casing on Deserialization and DOES NOT for serialisation to camelCase. //.AddNewtonsoftJson(options => //{ // options.UseCamelCasing(false); //NB this IS setting camel case - just not for dictionary element names //}) ; //Same with this one. //services.AddMvc() // .AddJsonOptions(options => options.JsonSerializerOptions.PropertyNamingPolicy = JsonNamingPolicy.CamelCase); services.AddControllers(); services.AddSingleton <IUtcDateTimeProvider, StandardUtcDateTimeProvider>(); services.AddSingleton <IGaenContentConfig, GaenContentConfig>(); services.AddSingleton <IExposureKeySetBatchJobConfig, ExposureKeySetBatchJobConfig>(); services.AddScoped <IPublishingId, StandardPublishingIdFormatter>(); services.AddScoped(x => { var config = new StandardEfDbConfig(Configuration, "Content"); var builder = new SqlServerDbContextOptionsBuilder(config); var result = new ExposureContentDbContext(builder.Build()); result.BeginTransaction(); return(result); }); services.AddScoped(x => { var config = new StandardEfDbConfig(Configuration, "WorkFlow"); var builder = new SqlServerDbContextOptionsBuilder(config); var result = new WorkflowDbContext(builder.Build()); result.BeginTransaction(); return(result); }); services.AddScoped(x => { var config = new StandardEfDbConfig(Configuration, "Icc"); var builder = new SqlServerDbContextOptionsBuilder(config); var result = new IccBackendContentDbContext(builder.Build()); result.BeginTransaction(); return(result); }); //Just for the Batch Job //services.AddScoped<IEfDbConfig>(x => new StandardEfDbConfig(Configuration, "Job")); //services.AddScoped<IExposureKeySetHeaderInfoConfig, ExposureKeySetHeaderInfoConfig>(); services.AddScoped <IContentSigner, FakeContentSigner>(); services.AddSingleton <IGeanTekListValidationConfig, StandardGeanCommonWorkflowConfig>(); services.AddSingleton <ITemporaryExposureKeyValidator, TemporaryExposureKeyValidator>(); services.AddSingleton <ITemporaryExposureKeyValidatorConfig, TemporaryExposureKeyValidatorConfig>(); services.AddScoped <IPublishingId, StandardPublishingIdFormatter>(); services.AddScoped(x => new ExposureKeySetBatchJobMk2( x.GetService <IGaenContentConfig>(), x.GetService <IExposureKeySetBuilder>(), x.GetService <WorkflowDbContext>(), x.GetService <ExposureContentDbContext>(), x.GetService <IUtcDateTimeProvider>(), x.GetService <IPublishingId>() )); services.AddSingleton <IGaenContentConfig, GaenContentConfig>(); services.AddScoped <IExposureKeySetBuilder>(x => new ExposureKeySetBuilderV1( x.GetService <IExposureKeySetHeaderInfoConfig>(), new EcdSaSigner(new ResourceCertificateProvider("FakeECDSA.p12")), new CmsSigner(new ResourceCertificateProvider("FakeRSA.p12")), x.GetService <IUtcDateTimeProvider>(), //TODO pass in time thru execute new GeneratedProtobufContentFormatter() )); services.AddScoped <IExposureKeySetHeaderInfoConfig, ExposureKeySetHeaderInfoConfig>(); services.AddSingleton <ISignatureValidator>(new FakeSignatureValidator()); services.AddScoped(x => new ExposureKeySetBuilderV1( x.GetService <ExposureKeySetHeaderInfoConfig>(), new FakeContentSigner(), new FakeContentSigner(), x.GetService <IUtcDateTimeProvider>(), new GeneratedProtobufContentFormatter() )); services.AddScoped <ManifestBuilder, ManifestBuilder>(); services.AddScoped <GetActiveExposureKeySetsListCommand, GetActiveExposureKeySetsListCommand>(); services.AddScoped <ExposureKeySetSafeReadCommand, ExposureKeySetSafeReadCommand>(); services.AddScoped <SafeGetRiskCalculationConfigDbCommand, SafeGetRiskCalculationConfigDbCommand>(); services.AddScoped <HttpPostRiskCalculationConfigCommand, HttpPostRiskCalculationConfigCommand>(); services.AddScoped <RiskCalculationConfigValidator, RiskCalculationConfigValidator>(); services.AddScoped <RiskCalculationConfigInsertDbCommand, RiskCalculationConfigInsertDbCommand>(); services.AddScoped <HttpPostResourceBundleCommand, HttpPostResourceBundleCommand>(); services.AddScoped <ResourceBundleInsertDbCommand, ResourceBundleInsertDbCommand>(); services.AddScoped <ResourceBundleValidator, ResourceBundleValidator>(); services.AddScoped <ProvisionDatabasesCommand, ProvisionDatabasesCommand>(); services.AddScoped <ProvisionDatabasesCommandIcc, ProvisionDatabasesCommandIcc>(); services.AddScoped <HttpPostGenerateExposureKeySetsCommand, HttpPostGenerateExposureKeySetsCommand>(); //services.AddScoped<HttpGetCdnContentCommand<ManifestEntity>, HttpGetCdnContentCommand<ManifestEntity>>(); services.AddScoped <HttpGetSignedCdnContentOnlyCommand <ExposureKeySetContentEntity>, HttpGetSignedCdnContentOnlyCommand <ExposureKeySetContentEntity> >(); services.AddScoped <HttpGetCdnContentCommand <RiskCalculationContentEntity>, HttpGetCdnContentCommand <RiskCalculationContentEntity> >(); services.AddScoped <HttpGetCdnContentCommand <ResourceBundleContentEntity>, HttpGetCdnContentCommand <ResourceBundleContentEntity> >(); services.AddScoped <HttpGetCdnContentCommand <AppConfigContentEntity>, HttpGetCdnContentCommand <AppConfigContentEntity> >(); services.AddScoped <DynamicManifestReader, DynamicManifestReader>(); services.AddScoped <IReader <ExposureKeySetContentEntity>, SafeBinaryContentDbReader <ExposureKeySetContentEntity> >(); services.AddScoped <IReader <ResourceBundleContentEntity>, SafeBinaryContentDbReader <ResourceBundleContentEntity> >(); services.AddScoped <IReader <RiskCalculationContentEntity>, SafeBinaryContentDbReader <RiskCalculationContentEntity> >(); services.AddScoped <IReader <AppConfigContentEntity>, SafeBinaryContentDbReader <AppConfigContentEntity> >(); services.AddScoped <PurgeExpiredSecretsDbCommand, PurgeExpiredSecretsDbCommand>(); services.AddScoped <HttpPostRegisterSecret, HttpPostRegisterSecret>(); services.AddScoped <RandomNumberGenerator, RandomNumberGenerator>(); services.AddScoped <ISecretConfig, StandardSecretConfig>(); services.AddScoped <ISecretWriter, SecretWriter>(); services.AddScoped <AuthorisationWriter, AuthorisationWriter>(); services.AddScoped <HttpPostReleaseTeksCommand, HttpPostReleaseTeksCommand>(); services.AddScoped <IReleaseTeksValidator, ReleaseTeksValidator>(); services.AddScoped <ITekWriter, TekWriter>(); services.AddScoped <HttpPostAppConfigCommand, HttpPostAppConfigCommand>(); services.AddScoped <AppConfigInsertDbCommand, AppConfigInsertDbCommand>(); services.AddScoped <AppConfigValidator, AppConfigValidator>(); services.AddScoped <HttpPostAuthorise, HttpPostAuthorise>(); services.AddScoped <IAuthorisationWriter, AuthorisationWriter>(); services.AddScoped <IBasicAuthenticationConfig, BasicAuthenticationConfig>(); services.AddBasicAuthentication(); services.AddScoped <GetLatestContentCommand <ResourceBundleContentEntity>, GetLatestContentCommand <ResourceBundleContentEntity> >(); services.AddScoped <GetLatestContentCommand <RiskCalculationContentEntity>, GetLatestContentCommand <RiskCalculationContentEntity> >(); services.AddScoped <GetLatestContentCommand <AppConfigContentEntity>, GetLatestContentCommand <AppConfigContentEntity> >(); services.AddScoped <IContentEntityFormatter, StandardContentEntityFormatter>(); services.AddScoped <ZippedSignedContentFormatter, ZippedSignedContentFormatter>(); services.AddScoped <HttpGetManifestBinaryContentCommand, HttpGetManifestBinaryContentCommand>(); services.AddScoped <DynamicManifestReader, DynamicManifestReader>(); services.AddScoped <HttpGetManifestSasCommand, HttpGetManifestSasCommand>(); services.AddSwaggerGen(o => { o.SwaggerDoc("v1", new OpenApiInfo { Title = "Dutch Exposure Notification API (inc. dev support)", Version = "v1", Description = "This specification describes the interface between the Dutch exposure notification app and the backend service.\nTODO: Add signatures to manifest, riskcalculationparameters and appconfig", Contact = new OpenApiContact { Name = "Ministerie van Volksgezondheid Welzijn en Sport backend repository", //TODO looks wrong? Url = new Uri("https://github.com/minvws/nl-covid19-notification-app-backend"), }, License = new OpenApiLicense { Name = "European Union Public License v. 1.2", //TODO this should be https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12 Url = new Uri("https://github.com/minvws/nl-covid19-notification-app-backend/blob/master/LICENSE.txt") }, }); o.IncludeXmlComments(Path.Combine(AppContext.BaseDirectory, "NL.Rijksoverheid.ExposureNotification.BackEnd.ServerStandAlone.xml")); o.IncludeXmlComments(Path.Combine(AppContext.BaseDirectory, "NL.Rijksoverheid.ExposureNotification.BackEnd.Components.xml")); o.AddSecurityDefinition("basic", new OpenApiSecurityScheme { Name = "Authorization", Type = SecuritySchemeType.Http, Scheme = "basic", In = ParameterLocation.Header, Description = "Basic Authorization header." }); o.AddSecurityRequirement(new OpenApiSecurityRequirement { { new OpenApiSecurityScheme { Reference = new OpenApiReference { Type = ReferenceType.SecurityScheme, Id = "basic" } }, new string[] {} } }); }); }
private static void Configure(IServiceCollection services, IConfigurationRoot configuration) { services.AddScoped(x => { var config = new StandardEfDbConfig(configuration, "Content"); var builder = new SqlServerDbContextOptionsBuilder(config); var result = new ContentDbContext(builder.Build()); return(result); }); services.AddScoped(x => { var config = new StandardEfDbConfig(configuration, "Workflow"); var builder = new SqlServerDbContextOptionsBuilder(config); var result = new WorkflowDbContext(builder.Build()); return(result); }); services.AddScoped(x => { var config = new StandardEfDbConfig(configuration, "Icc"); var builder = new SqlServerDbContextOptionsBuilder(config); var result = new IccBackendContentDbContext(builder.Build()); return(result); }); services.AddScoped(x => { var config = new StandardEfDbConfig(configuration, "PublishingJob"); var builder = new SqlServerDbContextOptionsBuilder(config); var result = new PublishingJobDbContext(builder.Build()); return(result); }); services.AddTransient <WorkflowDatabaseCreateCommand>(); services.AddTransient <PublishingJobDatabaseCreateCommand>(); services.AddTransient <IccDatabaseCreateCommand>(); services.AddTransient <ContentDatabaseCreateCommand>(); services.AddLogging(); services.AddSingleton <IConfiguration>(configuration); services.AddTransient <IJsonSerializer, StandardJsonSerializer>(); services.AddTransient <ProvisionDatabasesCommand>(); services.AddSingleton <IUtcDateTimeProvider, StandardUtcDateTimeProvider>(); services.AddSingleton <IGaenContentConfig, StandardGaenContentConfig>(); services.AddTransient <IPublishingId, StandardPublishingIdFormatter>(); services.AddTransient <ContentValidator>(); services.AddTransient <ContentInsertDbCommand>(); services.AddTransient <ZippedSignedContentFormatter>(); if (configuration.GetValue("DevelopmentFlags:UseCertificatesFromResources", false)) { if (configuration.GetValue("DevelopmentFlags:Azure", false)) { //AZURE services.AddScoped <IContentSigner>(x => new CmsSigner(new AzureResourceCertificateProvider(new StandardCertificateLocationConfig(configuration, "Certificates:NL")))); } else { //UNIT TESTS, LOCAL DEBUG services.AddScoped <IContentSigner>(x => new CmsSigner(new LocalResourceCertificateProvider(new StandardCertificateLocationConfig(configuration, "Certificates:NL")))); } } else { services.AddScoped <IContentSigner>(x => new CmsSigner(new X509CertificateProvider(new CertificateProviderConfig(x.GetRequiredService <IConfiguration>(), "Certificates:NL"), x.GetRequiredService <ILogger <X509CertificateProvider> >()))); } }