Ejemplo n.º 1
0
        public static async Task SeedAsync(TenantDataContext dataContext, CreateTenant createTenant)
        {
            try
            {
                // Console.WriteLine("Creating database");
                // await dataContext.Database.EnsureCreatedAsync();

                Console.WriteLine("Migrating database");
                await dataContext.Database.MigrateAsync();


                if (!dataContext.Projects.Any())
                {
                    Console.WriteLine("Adding data");

                    if (createTenant == null)
                    {
                        createTenant = new CreateTenant()
                        {
                            UserId = Guid.Parse("08d84f75-8698-4cf5-82a3-094415fcd132"),
                            Tenant =
                            {
                                Name = "Hello"
                            }
                        };
                    }

                    await AddData(dataContext, createTenant);
                }
            }
            catch (Exception exception)
            {
                Console.WriteLine(exception);
            }
        }
        // specialita: primary key je GUID a to framework nevie
        public TenantView CreateTenant(CreateTenant request)
        {
            Tenant rec = request.ConvertToEntity();

            rec.D_Tenant_Id     = Guid.NewGuid();
            rec.DatumVytvorenia = DateTime.Now;
            rec.DatumZmeny      = DateTime.Now;
            rec.Vytvoril        = Session.UserIdGuid;
            Create(rec); //Specialny pripad s GUID ako ID

            var t = GetList <TenantView>(t => t.D_Tenant_Id == rec.D_Tenant_Id).FirstOrDefault();

            var p = new DynamicParameters();

            p.Add("@Tenant", rec.D_Tenant_Id, dbType: DbType.Guid);
            p.Add("@OrganizaciaTypDetail_Id", rec.C_OrganizaciaTypDetail_Id, dbType: DbType.Int16);
            p.Add("@sName", rec.Nazov, dbType: DbType.String);

            SqlProcedure("[reg].[TenantCreate]", p);

            var tenantUser = new UserTenant()
            {
                D_User_Id       = (System.Guid)Session.UserIdGuid,
                D_Tenant_Id     = rec.D_Tenant_Id,
                DatumVytvorenia = DateTime.Now,
                DatumZmeny      = DateTime.Now,
                Vytvoril        = Session.UserIdGuid
            };

            Create(tenantUser);

            //SetCislovanie();  --nefunguje, lebo potrebujem mať CONTEXT nastavený na novovytvoreného tenanta
            //SetPredkontacia(); --nefunguje, lebo potrebujem mať CONTEXT nastavený na novovytvoreného tenanta
            return(t);
        }
Ejemplo n.º 3
0
        public static async Task SeedAsync(TenantDataContext dataContext, CreateTenant createTenant)
        {
            try
            {
                if (!dataContext.Projects.Any())
                {
                    Console.WriteLine("Adding data");

                    if (createTenant == null)
                    {
                        createTenant = new CreateTenant()
                        {
                            UserId = Guid.Parse("08d8419b-2bcb-4390-8b99-50960f9a3c59"),
                            Tenant =
                            {
                                Name = "Hello"
                            }
                        };
                    }

                    await AddData(dataContext, createTenant);
                }
            }
            catch (Exception exception)
            {
                Console.WriteLine(exception);
            }
        }
Ejemplo n.º 4
0
        public CreateTenantResponse Post(CreateTenant request)
        {
            var id = Db.Insert(new TenantData {
                Name = request.Name
            }, selectIdentity: true);

            _bus.Publish <TenantCreatedEvent>(new TenantCreatedEvent {
                Id = id
            });

            var model = Db.SingleById <TenantData>(id).ConvertTo <TenantModel>();

            return(new CreateTenantResponse {
                Tenant = model
            });
        }
Ejemplo n.º 5
0
        public async Task <TenantConfig> CreateTenantAsync(CreateTenant createTenant)
        {
            var tenant = new TenantConfig()
            {
                Name        = createTenant.Tenant.Name,
                DbName      = $"warehousedb{createTenant.Tenant.Name}",
                DbServer    = "localhost",
                DbUser      = "******",
                DbPassword  = "******",
                Accent      = createTenant.Tenant.Accent,
                Avatar      = createTenant.Tenant.Avatar,
                Description = createTenant.Tenant.Description
            };

            if ((await _multiTenantContext.TenantConfigs.FirstOrDefaultAsync(x => x.Name == tenant.Name)) != null)
            {
                return(null);
            }

            await _multiTenantContext.TenantConfigs.AddAsync(tenant);

            var employment = new Employment()
            {
                TenantId = tenant.Id,
                UserId   = createTenant.UserId
            };
            await _multiTenantContext.Employments.AddAsync(employment);

            try
            {
                await _multiTenantContext.SaveChangesAsync();

                var optionsBuilder = new DbContextOptionsBuilder <TenantDataContext>();
                optionsBuilder.UseMySql(tenant.ConnectionString());

                var dbContext = new TenantDataContext(optionsBuilder.Options);
                await TenantDataContextSeed.SeedAsync(dbContext, createTenant);

                return(tenant);
            }
            catch
            {
                return(null);
            }
        }
Ejemplo n.º 6
0
        private static async Task AddData(TenantDataContext dataContext, CreateTenant createTenant)
        {
            var projectId = Guid.NewGuid();
            var list2Id   = Guid.NewGuid();
            var list3Id   = Guid.NewGuid();
            var listId    = Guid.NewGuid();
            var userId    = createTenant.UserId;
            var roomId    = Guid.NewGuid();
            var moduleId  = Guid.NewGuid();

            var jobIds         = new List <Guid>();
            var jobEmployments = new List <JobEmployment>();

            for (int i = 0; i < 100; i++)
            {
                var id = Guid.NewGuid();
                jobIds.Add(id);
                jobEmployments.Add(new JobEmployment()
                {
                    JobId  = id,
                    UserId = userId
                });
            }

            var user = new UserId()
            {
                Id              = userId,
                Role            = Role.Owner,
                JobEmployments  = jobEmployments,
                ListEmployments = new List <ListEmployment>()
                {
                    new ListEmployment()
                    {
                        ListId = listId,
                        UserId = userId
                    },
                    new ListEmployment()
                    {
                        ListId = list2Id,
                        UserId = userId
                    },
                    new ListEmployment()
                    {
                        ListId = list3Id,
                        UserId = userId
                    },
                },
                ProjectEmployments = new List <ProjectEmployment>()
                {
                    new ProjectEmployment()
                    {
                        ProjectId = projectId,
                        UserId    = userId
                    }
                },
                RoomMemberships = new List <RoomMembership>()
                {
                    new RoomMembership()
                    {
                        RoomId = roomId, UserId = userId
                    }
                }
            };

            var statuses = new List <JobStatus>()
            {
                new JobStatus()
                {
                    Id       = Guid.NewGuid(),
                    Colour   = "#fec128",
                    Name     = "Todo",
                    Finished = false,
                    Order    = 0
                },
                new JobStatus()
                {
                    Id       = Guid.NewGuid(),
                    Colour   = "#f77d16",
                    Name     = "In progress",
                    Finished = false,
                    Order    = 1
                },
                new JobStatus()
                {
                    Id       = Guid.NewGuid(),
                    Colour   = "#03bbd3",
                    Name     = "Verify",
                    Finished = false,
                    Order    = 2
                },
                new JobStatus()
                {
                    Id       = Guid.NewGuid(),
                    Colour   = "#68B642",
                    Name     = "Completed",
                    Finished = true,
                    Order    = 3
                },
            };

            var types = new List <JobType>
            {
                new JobType()
                {
                    Id     = Guid.NewGuid(),
                    Colour = "#009688",
                    Name   = "Bug",
                    Order  = 0
                },
                new JobType()
                {
                    Id     = Guid.NewGuid(),
                    Colour = "#9e9e9e",
                    Name   = "Feature",
                    Order  = 1
                }
            };

            var priorities = new List <JobPriority>()
            {
                new JobPriority()
                {
                    Id     = Guid.NewGuid(),
                    Colour = "#ff5722",
                    Name   = "DEFCON 1",
                    Order  = 0
                },
                new JobPriority()
                {
                    Id     = Guid.NewGuid(),
                    Colour = "#ff9800",
                    Name   = "DEFCON 2",
                    Order  = 1
                },
                new JobPriority()
                {
                    Id     = Guid.NewGuid(),
                    Colour = "#ffc107",
                    Name   = "DEFCON 3",
                    Order  = 2
                },
                new JobPriority()
                {
                    Id     = Guid.NewGuid(),
                    Colour = "#8bc34a",
                    Name   = "DEFCON 4",
                    Order  = 3
                },
                new JobPriority()
                {
                    Id     = Guid.NewGuid(),
                    Colour = "#4caf50",
                    Name   = "DEFCON 5",
                    Order  = 4
                }
            };

            var project = new Project()
            {
                Created     = DateTime.Now,
                Description = "Development project for development",
                Id          = projectId,
                Short       = "Dev",
                Name        = "Development",
                Repo        = "https://github.com/MrHarrisonBarker/Warehouse",
                Accent      = "#1ad960",
                Avatar      = ""
            };

            var lists = new List <List>()
            {
                new List()
                {
                    Created     = DateTime.Now,
                    Description = "Phase-1 list",
                    Id          = listId,
                    Name        = "Phase-1",
                    Project     = project
                },
                new List()
                {
                    Created     = DateTime.Now,
                    Description = "Phase-2 list",
                    Id          = list2Id,
                    Name        = "Phase-2",
                    Project     = project
                },
                new List()
                {
                    Created     = DateTime.Now,
                    Description = "Phase-3 list",
                    Id          = list3Id,
                    Name        = "Phase-3",
                    Project     = project
                }
            };


            var module = new Module()
            {
                Id      = moduleId,
                Name    = "Seeded",
                Project = project
            };

            var generator = new Generator();

            var jobs  = new List <Job>();
            var count = 0;

            foreach (var id in jobIds)
            {
                jobs.Add(new Job()
                {
                    Created     = DateTime.Now,
                    Description =
                        "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.",
                    Id            = id,
                    Title         = generator.Generate(),
                    Project       = project,
                    List          = lists[new Random().Next(0, lists.Count)],
                    Link          = $"{project.Name.Substring(0,3)}-{count}",
                    AssociatedUrl = "harrisonbarker.co.uk",
                    JobStatus     = statuses[new Random().Next(0, statuses.Count)],
                    JobPriority   = priorities[new Random().Next(0, priorities.Count)],
                    JobType       = types[new Random().Next(0, types.Count)],
                    Commit        = "d1b13d624f6d812ffa39d8460716ca8087737f1c",
                    Module        = module
                });
                count++;
            }

            var room = new Room()
            {
                Id      = roomId,
                Chats   = new List <Chat>(),
                Name    = "General",
                Project = project
            };

            var creationEvent = new Event()
            {
                Id          = Guid.NewGuid(),
                Description = "Created new project",
                Name        = "Creation",
                Project     = project,
                Time        = DateTime.Now
            };



            dataContext.Events.Add(creationEvent);
            dataContext.UserIds.Add(user);
            dataContext.Projects.Add(project);
            dataContext.Lists.AddRange(lists);
            dataContext.Jobs.AddRange(jobs);
            dataContext.Rooms.Add(room);
            dataContext.JobStatuses.AddRange(statuses);
            dataContext.JobTypes.AddRange(types);
            dataContext.JobPriorities.AddRange(priorities);
            dataContext.Modules.Add(module);

            await dataContext.SaveChangesAsync();
        }
Ejemplo n.º 7
0
        // ----------------------------------------------------------

        #region Tenant

        public TenantView Any(CreateTenant request)
        {
            return(Repository.CreateTenant(request)); // specialita:  GUID ako primary key
        }
Ejemplo n.º 8
0
 public async Task <ActionResult <TenantConfig> > Create([FromBody] CreateTenant createTenant)
 {
     return(await _tenantService.CreateTenantAsync(createTenant));
 }
Ejemplo n.º 9
0
        private static async Task AddData(TenantDataContext dataContext, CreateTenant createTenant)
        {
            var projectId = Guid.NewGuid();
            var listId    = Guid.NewGuid();
            var userId    = createTenant.UserId;
            var roomId    = Guid.NewGuid();

            var jobIds         = new List <Guid>();
            var jobEmployments = new List <JobEmployment>();

            for (int i = 0; i < 10; i++)
            {
                var id = Guid.NewGuid();
                jobIds.Add(id);
                jobEmployments.Add(new JobEmployment()
                {
                    JobId  = id,
                    UserId = userId
                });
            }

            jobIds[0] = new Guid("0C8EBA6A-9765-43FB-A80D-A8C06D46AA2F");

            var user = new UserId()
            {
                Id              = userId,
                JobEmployments  = jobEmployments,
                ListEmployments = new List <ListEmployment>()
                {
                    new ListEmployment()
                    {
                        ListId = listId,
                        UserId = userId
                    }
                },
                ProjectEmployments = new List <ProjectEmployment>()
                {
                    new ProjectEmployment()
                    {
                        ProjectId = projectId,
                        UserId    = userId
                    }
                },
                RoomMemberships = new List <RoomMembership>()
                {
                    new RoomMembership()
                    {
                        RoomId = roomId, UserId = userId
                    }
                }
            };

            var statuses = new List <JobStatus>()
            {
                new JobStatus()
                {
                    Id       = Guid.NewGuid(),
                    Colour   = "#fec128",
                    Name     = "Todo",
                    Finished = false
                },
                new JobStatus()
                {
                    Id       = Guid.NewGuid(),
                    Colour   = "#f77d16",
                    Name     = "In progress",
                    Finished = false
                },
                new JobStatus()
                {
                    Id       = Guid.NewGuid(),
                    Colour   = "#03bbd3",
                    Name     = "Verify",
                    Finished = false
                },
                new JobStatus()
                {
                    Id       = Guid.NewGuid(),
                    Colour   = "#68B642",
                    Name     = "Completed",
                    Finished = true
                },
            };

            var types = new List <JobType>
            {
                new JobType()
                {
                    Id     = Guid.NewGuid(),
                    Colour = "#009688",
                    Name   = "Bug"
                },
                new JobType()
                {
                    Id     = Guid.NewGuid(),
                    Colour = "#9e9e9e",
                    Name   = "Feature"
                }
            };

            var priorities = new List <JobPriority>()
            {
                new JobPriority()
                {
                    Id     = Guid.NewGuid(),
                    Colour = "#ff5722",
                    Name   = "DEFCON 1"
                },
                new JobPriority()
                {
                    Id     = Guid.NewGuid(),
                    Colour = "#ff9800",
                    Name   = "DEFCON 2"
                },
                new JobPriority()
                {
                    Id     = Guid.NewGuid(),
                    Colour = "#ffc107",
                    Name   = "DEFCON 3"
                },
                new JobPriority()
                {
                    Id     = Guid.NewGuid(),
                    Colour = "#8bc34a",
                    Name   = "DEFCON 4"
                },
                new JobPriority()
                {
                    Id     = Guid.NewGuid(),
                    Colour = "#4caf50",
                    Name   = "DEFCON 5"
                }
            };

            var project = new Project()
            {
                Created     = DateTime.Now,
                Description = "Development project for development",
                Id          = projectId,
                Name        = "Development",
                Repo        = "",
                Accent      = "#1ad960",
                Avatar      = "https://pbs.twimg.com/profile_images/1292028907101671425/pp02tz90_400x400.jpg"
            };

            var list = new List()
            {
                Created     = DateTime.Now,
                Description = "Phase-1 list",
                Id          = listId,
                Name        = "Phase-1",
                Project     = project
            };

            var jobs  = new List <Job>();
            var count = 0;

            foreach (var id in jobIds)
            {
                jobs.Add(new Job()
                {
                    Created     = DateTime.Now,
                    Description =
                        "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.",
                    Id            = id,
                    Title         = $"job #{count}",
                    Project       = project,
                    List          = list,
                    Link          = $"{createTenant.Tenant.Name}-{count}",
                    AssociatedUrl = "harrisonbarker.co.uk",
                    JobStatus     = statuses[new Random().Next(0, statuses.Count)],
                    JobPriority   = priorities[new Random().Next(0, priorities.Count)],
                    JobType       = types[new Random().Next(0, types.Count)]
                });
                count++;
            }

            var room = new Room()
            {
                Id      = roomId,
                Chats   = new List <Chat>(),
                Name    = "General",
                Project = project
            };

            var creationEvent = new Event()
            {
                Id          = Guid.NewGuid(),
                Description = "Created new project",
                Name        = "Creation",
                Project     = project,
                Time        = DateTime.Now
            };

            dataContext.Events.Add(creationEvent);
            dataContext.UserIds.Add(user);
            dataContext.Projects.Add(project);
            dataContext.Lists.Add(list);
            dataContext.Jobs.AddRange(jobs);
            dataContext.Rooms.Add(room);
            dataContext.JobStatuses.AddRange(statuses);
            dataContext.JobTypes.AddRange(types);
            dataContext.JobPriorities.AddRange(priorities);

            await dataContext.SaveChangesAsync();
        }