Esempio n. 1
0
        public override void ConfigureElsa(ElsaOptionsBuilder elsa, IConfiguration configuration)
        {
            var services             = elsa.Services;
            var section              = configuration.GetSection($"Elsa:Features:WorkflowSettings");
            var connectionStringName = section.GetValue <string>("ConnectionStringIdentifier");
            var connectionString     = section.GetValue <string>("ConnectionString");

            if (string.IsNullOrWhiteSpace(connectionString))
            {
                if (string.IsNullOrWhiteSpace(connectionStringName))
                {
                    connectionStringName = ProviderName;
                }

                connectionString = configuration.GetConnectionString(connectionStringName);
            }

            if (string.IsNullOrWhiteSpace(connectionString))
            {
                connectionString = GetDefaultConnectionString();
            }

            var workflowSettingsOptionsBuilder = new WorkflowSettingsOptionsBuilder(services);

            workflowSettingsOptionsBuilder.UseWorkflowSettingsYesSqlPersistence(options => Configure(options, connectionString));
            services.AddScoped(sp => workflowSettingsOptionsBuilder.WorkflowSettingsOptions.WorkflowSettingsStoreFactory(sp));

            elsa.AddWorkflowSettings();
        }
Esempio n. 2
0
        public override void ConfigureElsa(ElsaOptionsBuilder elsa, IConfiguration configuration)
        {
            var services             = elsa.Services;
            var section              = configuration.GetSection($"Elsa:Features:WorkflowSettings");
            var connectionStringName = section.GetValue <string>("ConnectionStringIdentifier");
            var connectionString     = section.GetValue <string>("ConnectionString");

            if (string.IsNullOrWhiteSpace(connectionString))
            {
                if (string.IsNullOrWhiteSpace(connectionStringName))
                {
                    connectionStringName = "MongoDb";
                }

                connectionString = configuration.GetConnectionString(connectionStringName);
            }

            if (string.IsNullOrWhiteSpace(connectionString))
            {
                connectionString = "mongodb://localhost:27017/Elsa";
            }

            var workflowSettingsOptionsBuilder = new WorkflowSettingsOptionsBuilder(services);

            workflowSettingsOptionsBuilder.UseWorkflowSettingsMongoDbPersistence(options => options.ConnectionString = connectionString);
            services.AddScoped(sp => workflowSettingsOptionsBuilder.WorkflowSettingsOptions.WorkflowSettingsStoreFactory(sp));

            elsa.AddWorkflowSettings();
        }
Esempio n. 3
0
        private static void AddCore <TDbContext>(WorkflowSettingsOptionsBuilder workflowSettingsOptions) where TDbContext : ElsaMongoDbContext
        {
            workflowSettingsOptions.Services
            .AddSingleton <MongoDbWorkflowSettingsStore>()
            .AddSingleton <TDbContext>()
            .AddSingleton <ElsaMongoDbContext, TDbContext>()
            .AddSingleton(sp => sp.GetRequiredService <TDbContext>().WorkflowSettings)
            .AddStartupTask <DatabaseInitializer>();

            workflowSettingsOptions.UseWorkflowSettingsStore(sp => sp.GetRequiredService <MongoDbWorkflowSettingsStore>());

            DatabaseRegister.RegisterMapsAndSerializers();
        }
Esempio n. 4
0
 public static WorkflowSettingsOptionsBuilder UseWorkflowSettingsMongoDbPersistence <TDbContext>(this WorkflowSettingsOptionsBuilder workflowSettingsOptions, IConfiguration configuration) where TDbContext : ElsaMongoDbContext
 {
     AddCore <TDbContext>(workflowSettingsOptions);
     workflowSettingsOptions.Services.Configure <ElsaMongoDbOptions>(configuration);
     return(workflowSettingsOptions);
 }
Esempio n. 5
0
 public static WorkflowSettingsOptionsBuilder UseWorkflowSettingsMongoDbPersistence(this WorkflowSettingsOptionsBuilder workflowSettingsOptions, IConfiguration configuration) => UseWorkflowSettingsMongoDbPersistence <ElsaMongoDbContext>(workflowSettingsOptions, configuration);
Esempio n. 6
0
 public static WorkflowSettingsOptionsBuilder UseWorkflowSettingsMongoDbPersistence(this WorkflowSettingsOptionsBuilder workflowSettingsOptions, Action <ElsaMongoDbOptions> configureOptions) => UseWorkflowSettingsMongoDbPersistence <ElsaMongoDbContext>(workflowSettingsOptions, configureOptions);
 public static WorkflowSettingsOptionsBuilder UseWorkflowSettingsYesSqlPersistence(this WorkflowSettingsOptionsBuilder workflowSettingsOptions, Action <IConfiguration> configure) => workflowSettingsOptions.UseWorkflowSettingsYesSqlPersistence((_, config) => configure(config));
        public static WorkflowSettingsOptionsBuilder UseWorkflowSettingsYesSqlPersistence(this WorkflowSettingsOptionsBuilder workflowSettingsOptions, Action <IServiceProvider, IConfiguration> configure)
        {
            workflowSettingsOptions.Services
            .AddScoped <YesSqlWorkflowSettingsStore>()
            .AddSingleton(sp => CreateStore(sp, configure))
            .AddStartupTask <DatabaseInitializer>()
            .AddDataMigration <Migrations>()
            .AddAutoMapperProfile <AutoMapperProfile>()
            .AddIndexProvider <WorkflowSettingsIndexProvider>();

            workflowSettingsOptions.UseWorkflowSettingsStore(sp => sp.GetRequiredService <YesSqlWorkflowSettingsStore>());

            return(workflowSettingsOptions);
        }
Esempio n. 9
0
 /// <summary>
 /// Configures Elsa to use Entity Framework Core for persistence, using pooled DB Context instances.
 /// </summary>
 /// <remarks>
 /// <para>
 /// Pooled DB Context instances is a performance optimisation which is documented in more detail at
 /// https://docs.microsoft.com/en-us/ef/core/performance/advanced-performance-topics?tabs=with-constant#dbcontext-pooling.
 /// </para>
 /// </remarks>
 /// <param name="workflowSettingsOptions">An Elsa options builder</param>
 /// <param name="configure">A configuration builder callback, which also provides access to a service provider</param>
 /// <param name="autoRunMigrations">If <c>true</c> then database migrations will be auto-executed on startup</param>
 /// <typeparam name="TWorkflowSettingsContext">The concrete type of <see cref="WorkflowSettingsContext"/> to use.</typeparam>
 /// <returns>The Elsa options builder, so calls may be chained</returns>
 public static WorkflowSettingsOptionsBuilder UseEntityFrameworkPersistence <TWorkflowSettingsContext>(this WorkflowSettingsOptionsBuilder workflowSettingsOptions,
                                                                                                       Action <IServiceProvider, DbContextOptionsBuilder> configure,
                                                                                                       bool autoRunMigrations = true) where TWorkflowSettingsContext : WorkflowSettingsContext =>
 UseEntityFrameworkPersistence <TWorkflowSettingsContext>(workflowSettingsOptions, configure, autoRunMigrations, true, ServiceLifetime.Singleton);
 public static WorkflowSettingsOptionsBuilder UseWorkflowSettingsYesSqlPersistence(this WorkflowSettingsOptionsBuilder workflowSettingsOptions) => workflowSettingsOptions.UseWorkflowSettingsYesSqlPersistence(config => config.UseSqLite("Data Source=elsa.yessql.db;Cache=Shared", IsolationLevel.ReadUncommitted));
Esempio n. 11
0
 /// <summary>
 /// Configures Elsa to use Entity Framework Core for persistence, using pooled DB Context instances.
 /// </summary>
 /// <remarks>
 /// <para>
 /// Pooled DB Context instances is a performance optimisation which is documented in more detail at
 /// https://docs.microsoft.com/en-us/ef/core/performance/advanced-performance-topics?tabs=with-constant#dbcontext-pooling.
 /// </para>
 /// </remarks>
 /// <param name="workflowSettingsOptions">An Elsa options builder</param>
 /// <param name="configure">A configuration builder callback, which also provides access to a service provider</param>
 /// <param name="autoRunMigrations">If <c>true</c> then database migrations will be auto-executed on startup</param>
 /// <returns>The Elsa options builder, so calls may be chained</returns>
 public static WorkflowSettingsOptionsBuilder UseEntityFrameworkPersistence(this WorkflowSettingsOptionsBuilder workflowSettingsOptions,
                                                                            Action <IServiceProvider, DbContextOptionsBuilder> configure,
                                                                            bool autoRunMigrations = true) =>
 workflowSettingsOptions.UseEntityFrameworkPersistence <WorkflowSettingsContext>(configure, autoRunMigrations);
Esempio n. 12
0
 /// <summary>
 /// Configures Elsa to use Entity Framework Core for persistence, using pooled DB Context instances.
 /// </summary>
 /// <remarks>
 /// <para>
 /// Pooled DB Context instances is a performance optimisation which is documented in more detail at
 /// https://docs.microsoft.com/en-us/ef/core/performance/advanced-performance-topics?tabs=with-constant#dbcontext-pooling.
 /// </para>
 /// </remarks>
 /// <param name="workflowSettingsOptions">An Elsa options builder</param>
 /// <param name="configure">A configuration builder callback</param>
 /// <param name="autoRunMigrations">If <c>true</c> then database migrations will be auto-executed on startup</param>
 /// <typeparam name="TWorkflowSettingsContext">The concrete type of <see cref="WorkflowSettingsContext"/> to use.</typeparam>
 /// <returns>The Elsa options builder, so calls may be chained</returns>
 public static WorkflowSettingsOptionsBuilder UseEntityFrameworkPersistence <TWorkflowSettingsContext>(this WorkflowSettingsOptionsBuilder workflowSettingsOptions,
                                                                                                       Action <DbContextOptionsBuilder> configure,
                                                                                                       bool autoRunMigrations = true) where TWorkflowSettingsContext : WorkflowSettingsContext =>
 workflowSettingsOptions.UseEntityFrameworkPersistence <TWorkflowSettingsContext>((_, builder) => configure(builder), autoRunMigrations);
Esempio n. 13
0
        static WorkflowSettingsOptionsBuilder UseEntityFrameworkPersistence <TWorkflowSettingsContext>(WorkflowSettingsOptionsBuilder workflowSettingsOptions,
                                                                                                       Action <IServiceProvider, DbContextOptionsBuilder> configure,
                                                                                                       bool autoRunMigrations,
                                                                                                       bool useContextPooling,
                                                                                                       ServiceLifetime serviceLifetime) where TWorkflowSettingsContext : WorkflowSettingsContext
        {
            /* Auto-running migrations is intentionally unavailable when not using context pooling.
             * When we aren't using pooling then it probably means that each DB Context is different
             * in some manner.  That could easily mean the connection strings (IE: Contexts might not
             * all connect to the same DB).  In that case, without further logic (which can't be
             * pre-empted by Elsa), we can't be sure we're connecting to the right DBs when running
             * migrations.
             *
             * It's much more sane just to explicitly not-support it and leave it to the app developer.
             * They can run their own migrations in line with their own logic.
             */

            if (useContextPooling)
            {
                workflowSettingsOptions.Services.AddPooledDbContextFactory <TWorkflowSettingsContext>(configure);
            }
            else
            {
                workflowSettingsOptions.Services.AddDbContextFactory <TWorkflowSettingsContext>(configure, serviceLifetime);
            }

            workflowSettingsOptions.Services
            .AddSingleton <IWorkflowSettingsContextFactory, WorkflowSettingsContextFactory <TWorkflowSettingsContext> >()
            .AddScoped <EntityFrameworkWorkflowSettingsStore>();

            if (autoRunMigrations)
            {
                workflowSettingsOptions.Services.AddStartupTask <RunMigrations>();
            }

            workflowSettingsOptions.UseWorkflowSettingsStore(sp => sp.GetRequiredService <EntityFrameworkWorkflowSettingsStore>());

            return(workflowSettingsOptions);
        }
Esempio n. 14
0
 /// <summary>
 /// Configures Elsa to use Entity Framework Core for persistence, without using pooled DB Context instances.
 /// </summary>
 /// <remarks>
 /// <para>
 /// Use this method when you do not wish to use DB connection pooling, such as when integrating with a multi-tenant
 /// application, where re-use of DB Context objects is impractical.
 /// </para>
 /// <para>
 /// Although auto-running of migrations is supported in this scenario, use this with caution. When pooling is not in use and each instance of
 /// the DB Context may differ, it is not feasible to try to automatically migrate them.
 /// Your application is ultimately responsible for executing the contents of the <see cref="RunMigrations"/> class in a manner
 /// which is suitable for your use-case.
 /// </para>
 /// </remarks>
 /// <param name="workflowSettingsOptions">An Elsa options builder</param>
 /// <param name="configure">A configuration builder callback, which also provides access to a service provider</param>
 /// <param name="serviceLifetime">The service lifetime which will be used for each DB Context instance</param>
 /// <param name="autoRunMigrations">If <c>true</c> then database migrations will be auto-executed on startup</param>
 /// <returns>The Elsa options builder, so calls may be chained</returns>
 public static WorkflowSettingsOptionsBuilder UseNonPooledEntityFrameworkPersistence(this WorkflowSettingsOptionsBuilder workflowSettingsOptions,
                                                                                     Action <IServiceProvider, DbContextOptionsBuilder> configure,
                                                                                     ServiceLifetime serviceLifetime = ServiceLifetime.Singleton,
                                                                                     bool autoRunMigrations          = false) =>
 workflowSettingsOptions.UseNonPooledEntityFrameworkPersistence <WorkflowSettingsContext>(configure, serviceLifetime, autoRunMigrations);
Esempio n. 15
0
 /// <summary>
 /// Configures Elsa to use Entity Framework Core for persistence, without using pooled DB Context instances.
 /// </summary>
 /// <remarks>
 /// <para>
 /// Use this method when you do not wish to use DB connection pooling, such as when integrating with a multi-tenant
 /// application, where re-use of DB Context objects is impractical.
 /// </para>
 /// <para>
 /// Although auto-running of migrations is supported in this scenario, use this with caution. When pooling is not in use and each instance of
 /// the DB Context may differ, it is not feasible to try to automatically migrate them.
 /// Your application is ultimately responsible for executing the contents of the <see cref="RunMigrations"/> class in a manner
 /// which is suitable for your use-case.
 /// </para>
 /// </remarks>
 /// <param name="workflowSettingsOptions">An Elsa options builder</param>
 /// <param name="configure">A configuration builder callback</param>
 /// <param name="serviceLifetime">The service lifetime which will be used for each DB Context instance</param>
 /// <param name="autoRunMigrations">If <c>true</c> then database migrations will be auto-executed on startup</param>
 /// <typeparam name="TWorkflowSettingsContext">The concrete type of <see cref="WorkflowSettingsContext"/> to use.</typeparam>
 /// <returns>The Elsa options builder, so calls may be chained</returns>
 public static WorkflowSettingsOptionsBuilder UseNonPooledEntityFrameworkPersistence <TWorkflowSettingsContext>(this WorkflowSettingsOptionsBuilder workflowSettingsOptions,
                                                                                                                Action <DbContextOptionsBuilder> configure,
                                                                                                                ServiceLifetime serviceLifetime = ServiceLifetime.Singleton,
                                                                                                                bool autoRunMigrations          = false) where TWorkflowSettingsContext : WorkflowSettingsContext =>
 workflowSettingsOptions.UseNonPooledEntityFrameworkPersistence <TWorkflowSettingsContext>((_, builder) => configure(builder), serviceLifetime, autoRunMigrations);