//
using System;
using Marco.Pms.DataAccess.Data;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Infrastructure;
using Microsoft.EntityFrameworkCore.Metadata;
using Microsoft.EntityFrameworkCore.Migrations;
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
#nullable disable
namespace Marco.Pms.DataAccess.Migrations
{
[DbContext(typeof(ApplicationDbContext))]
[Migration("20250514103249_Added_Directory_Related_Tables")]
partial class Added_Directory_Related_Tables
{
///
protected override void BuildTargetModel(ModelBuilder modelBuilder)
{
#pragma warning disable 612, 618
modelBuilder
.HasAnnotation("ProductVersion", "8.0.12")
.HasAnnotation("Relational:MaxIdentifierLength", 64);
//MySqlModelBuilderExtensions.AutoIncrementColumns(modelBuilder);
modelBuilder.Entity("Marco.Pms.Model.Activities.TaskAllocation", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("AssignedBy")
.HasColumnType("char(36)");
b.Property("AssignmentDate")
.HasColumnType("datetime(6)");
b.Property("CompletedTask")
.HasColumnType("double");
b.Property("Description")
.HasColumnType("longtext");
b.Property("PlannedTask")
.HasColumnType("double");
b.Property("ReportedDate")
.HasColumnType("datetime(6)");
b.Property("TenantId")
.HasColumnType("char(36)");
b.Property("WorkItemId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("AssignedBy");
b.HasIndex("TenantId");
b.HasIndex("WorkItemId");
b.ToTable("TaskAllocations");
});
modelBuilder.Entity("Marco.Pms.Model.Activities.TaskComment", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Comment")
.IsRequired()
.HasColumnType("longtext");
b.Property("CommentDate")
.HasColumnType("datetime(6)");
b.Property("CommentedBy")
.HasColumnType("char(36)");
b.Property("TaskAllocationId")
.HasColumnType("char(36)");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("CommentedBy");
b.HasIndex("TaskAllocationId");
b.HasIndex("TenantId");
b.ToTable("TaskComments");
});
modelBuilder.Entity("Marco.Pms.Model.Activities.TaskMembers", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("EmployeeId")
.HasColumnType("char(36)");
b.Property("TaskAllocationId")
.HasColumnType("char(36)");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("EmployeeId");
b.HasIndex("TaskAllocationId");
b.HasIndex("TenantId");
b.ToTable("TaskMembers");
});
modelBuilder.Entity("Marco.Pms.Model.AttendanceModule.Attendance", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Activity")
.HasColumnType("int");
b.Property("ApprovedBy")
.HasColumnType("char(36)");
b.Property("AttendanceDate")
.HasColumnType("datetime(6)");
b.Property("Comment")
.IsRequired()
.HasColumnType("longtext");
b.Property("Date")
.HasColumnType("datetime(6)");
b.Property("EmployeeID")
.HasColumnType("char(36)");
b.Property("InTime")
.HasColumnType("datetime(6)");
b.Property("IsApproved")
.HasColumnType("tinyint(1)");
b.Property("OutTime")
.HasColumnType("datetime(6)");
b.Property("ProjectID")
.HasColumnType("char(36)");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("EmployeeID");
b.HasIndex("TenantId");
b.ToTable("Attendes");
});
modelBuilder.Entity("Marco.Pms.Model.AttendanceModule.AttendanceLog", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Activity")
.HasColumnType("int");
b.Property("ActivityTime")
.HasColumnType("datetime(6)");
b.Property("AttendanceId")
.HasColumnType("char(36)");
b.Property("Comment")
.IsRequired()
.HasColumnType("longtext");
b.Property("DocumentId")
.HasColumnType("char(36)");
b.Property("EmployeeID")
.HasColumnType("char(36)");
b.Property("Latitude")
.HasColumnType("longtext");
b.Property("Longitude")
.HasColumnType("longtext");
b.Property("Photo")
.HasColumnType("longblob");
b.Property("TenantId")
.HasColumnType("char(36)");
b.Property("UpdatedBy")
.HasColumnType("char(36)");
b.Property("UpdatedOn")
.HasColumnType("datetime(6)");
b.HasKey("Id");
b.HasIndex("AttendanceId");
b.HasIndex("DocumentId");
b.HasIndex("EmployeeID");
b.HasIndex("TenantId");
b.HasIndex("UpdatedBy");
b.ToTable("AttendanceLogs");
});
modelBuilder.Entity("Marco.Pms.Model.Authentication.RefreshToken", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("CreatedAt")
.HasColumnType("datetime(6)");
b.Property("ExpiryDate")
.HasColumnType("datetime(6)");
b.Property("IsRevoked")
.HasColumnType("tinyint(1)");
b.Property("IsUsed")
.HasColumnType("tinyint(1)");
b.Property("RevokedAt")
.HasColumnType("datetime(6)");
b.Property("Token")
.HasColumnType("longtext");
b.Property("UserId")
.HasColumnType("varchar(255)");
b.HasKey("Id");
b.HasIndex("UserId");
b.ToTable("RefreshTokens");
});
modelBuilder.Entity("Marco.Pms.Model.Directory.Bucket", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Description")
.IsRequired()
.HasColumnType("longtext");
b.Property("Name")
.IsRequired()
.HasColumnType("longtext");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("TenantId");
b.ToTable("Buckets");
});
modelBuilder.Entity("Marco.Pms.Model.Directory.Contact", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Address")
.HasColumnType("longtext");
b.Property("ContactCategoryId")
.HasColumnType("char(36)");
b.Property("CreatedAt")
.HasColumnType("datetime(6)");
b.Property("CreatedById")
.HasColumnType("char(36)");
b.Property("Description")
.IsRequired()
.HasColumnType("longtext");
b.Property("IsActive")
.HasColumnType("tinyint(1)");
b.Property("Name")
.IsRequired()
.HasColumnType("longtext");
b.Property("Organization")
.IsRequired()
.HasColumnType("longtext");
b.Property("ProjectId")
.HasColumnType("char(36)");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("ContactCategoryId");
b.HasIndex("CreatedById");
b.HasIndex("TenantId");
b.ToTable("Contacts");
});
modelBuilder.Entity("Marco.Pms.Model.Directory.ContactBucketMapping", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("BucketId")
.HasColumnType("char(36)");
b.Property("ContactId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("BucketId");
b.HasIndex("ContactId");
b.ToTable("ContactBucketMappings");
});
modelBuilder.Entity("Marco.Pms.Model.Directory.ContactCategoryMaster", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Description")
.IsRequired()
.HasColumnType("longtext");
b.Property("Name")
.IsRequired()
.HasColumnType("longtext");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("TenantId");
b.ToTable("ContactCategoryMasters");
});
modelBuilder.Entity("Marco.Pms.Model.Directory.ContactEmail", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("ContactId")
.HasColumnType("char(36)");
b.Property("EmailAddress")
.IsRequired()
.HasColumnType("longtext");
b.Property("IsPrimary")
.HasColumnType("tinyint(1)");
b.Property("Label")
.IsRequired()
.HasColumnType("longtext");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("ContactId");
b.ToTable("ContactsEmails");
});
modelBuilder.Entity("Marco.Pms.Model.Directory.ContactNote", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("ContactId")
.HasColumnType("char(36)");
b.Property("CreatedAt")
.HasColumnType("datetime(6)");
b.Property("CreatedById")
.HasColumnType("char(36)");
b.Property("IsActive")
.HasColumnType("tinyint(1)");
b.Property("Note")
.IsRequired()
.HasColumnType("longtext");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("ContactId");
b.HasIndex("CreatedById");
b.HasIndex("TenantId");
b.ToTable("ContactNotes");
});
modelBuilder.Entity("Marco.Pms.Model.Directory.ContactPhone", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("ContactId")
.HasColumnType("char(36)");
b.Property("IsPrimary")
.HasColumnType("tinyint(1)");
b.Property("Label")
.IsRequired()
.HasColumnType("longtext");
b.Property("PhoneNumber")
.IsRequired()
.HasColumnType("longtext");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("ContactId");
b.ToTable("ContactsPhones");
});
modelBuilder.Entity("Marco.Pms.Model.Directory.ContactTagMapping", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("ContactId")
.HasColumnType("char(36)");
b.Property("ContactTagId")
.HasColumnType("char(36)");
b.Property("ContactTagtId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("ContactId");
b.HasIndex("ContactTagId");
b.ToTable("ContactTagMappings");
});
modelBuilder.Entity("Marco.Pms.Model.Directory.ContactTagMaster", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Description")
.IsRequired()
.HasColumnType("longtext");
b.Property("Name")
.IsRequired()
.HasColumnType("longtext");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("TenantId");
b.ToTable("ContactTagMasters");
});
modelBuilder.Entity("Marco.Pms.Model.Directory.DirectoryUpdateLog", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("RefereanceId")
.HasColumnType("char(36)");
b.Property("UpdateAt")
.HasColumnType("datetime(6)");
b.Property("UpdatedById")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("UpdatedById");
b.ToTable("DirectoryUpdateLogs");
});
modelBuilder.Entity("Marco.Pms.Model.Directory.EmployeeBucketMapping", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("BucketId")
.HasColumnType("char(36)");
b.Property("EmployeeId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("BucketId");
b.HasIndex("EmployeeId");
b.ToTable("EmployeeBucketMappings");
});
modelBuilder.Entity("Marco.Pms.Model.DocumentManager.Document", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Base64Data")
.HasColumnType("longtext");
b.Property("BatchId")
.HasColumnType("char(36)");
b.Property("ContentType")
.IsRequired()
.HasColumnType("longtext");
b.Property("FileName")
.IsRequired()
.HasColumnType("longtext");
b.Property("FileSize")
.HasColumnType("bigint");
b.Property("S3Key")
.IsRequired()
.HasColumnType("longtext");
b.Property("TenantId")
.HasColumnType("char(36)");
b.Property("ThumbS3Key")
.HasColumnType("longtext");
b.Property("UploadedAt")
.HasColumnType("datetime(6)");
b.HasKey("Id");
b.HasIndex("TenantId");
b.ToTable("Documents");
});
modelBuilder.Entity("Marco.Pms.Model.Employees.Employee", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("AadharNumber")
.HasColumnType("longtext");
b.Property("ApplicationUserId")
.HasColumnType("varchar(255)");
b.Property("BirthDate")
.HasColumnType("datetime(6)");
b.Property("CurrentAddress")
.HasColumnType("longtext");
b.Property("Email")
.HasColumnType("longtext");
b.Property("EmergencyContactPerson")
.HasColumnType("longtext");
b.Property("EmergencyPhoneNumber")
.HasColumnType("longtext");
b.Property("FirstName")
.HasColumnType("longtext");
b.Property("Gender")
.HasColumnType("longtext");
b.Property("IsActive")
.HasColumnType("tinyint(1)");
b.Property("IsSystem")
.HasColumnType("tinyint(1)");
b.Property("JobRoleId")
.HasColumnType("char(36)");
b.Property("JoiningDate")
.HasColumnType("datetime(6)");
b.Property("LastName")
.HasColumnType("longtext");
b.Property("MiddleName")
.HasColumnType("longtext");
b.Property("PanNumber")
.HasColumnType("longtext");
b.Property("PermanentAddress")
.HasColumnType("longtext");
b.Property("PhoneNumber")
.HasColumnType("longtext");
b.Property("Photo")
.HasColumnType("longblob");
b.Property("RoleId")
.HasColumnType("char(36)");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("ApplicationUserId");
b.HasIndex("JobRoleId");
b.HasIndex("TenantId");
b.ToTable("Employees");
});
modelBuilder.Entity("Marco.Pms.Model.Employees.EmployeeRoleMapping", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("EmployeeId")
.HasColumnType("char(36)");
b.Property("IsEnabled")
.HasColumnType("tinyint(1)");
b.Property("RoleId")
.HasColumnType("char(36)");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("EmployeeId");
b.HasIndex("RoleId");
b.HasIndex("TenantId");
b.ToTable("EmployeeRoleMappings");
});
modelBuilder.Entity("Marco.Pms.Model.Employees.WorkShift", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("EndTime")
.HasColumnType("time(6)");
b.Property("Name")
.HasColumnType("longtext");
b.Property("StartTime")
.HasColumnType("time(6)");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("TenantId");
b.ToTable("WorkShifts");
});
modelBuilder.Entity("Marco.Pms.Model.Entitlements.ActivityCheckList", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("ActivityId")
.HasColumnType("char(36)");
b.Property("Description")
.HasColumnType("longtext");
b.Property("IsChecked")
.HasColumnType("tinyint(1)");
b.Property("IsMandatory")
.HasColumnType("tinyint(1)");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.ToTable("ActivityCheckLists");
});
modelBuilder.Entity("Marco.Pms.Model.Entitlements.CheckListMappings", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("CheckListId")
.HasColumnType("char(36)");
b.Property("TaskAllocationId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.ToTable("CheckListMappings");
});
modelBuilder.Entity("Marco.Pms.Model.Entitlements.FeaturePermission", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Description")
.HasColumnType("longtext");
b.Property("FeatureId")
.HasColumnType("char(36)");
b.Property("IsEnabled")
.HasColumnType("tinyint(1)");
b.Property("Name")
.HasColumnType("longtext");
b.HasKey("Id");
b.HasIndex("FeatureId");
b.ToTable("FeaturePermissions");
b.HasData(
new
{
Id = new Guid("6ea44136-987e-44ba-9e5d-1cf8f5837ebc"),
Description = "",
FeatureId = new Guid("53176ebf-c75d-42e5-839f-4508ffac3def"),
IsEnabled = true,
Name = "View Project"
},
new
{
Id = new Guid("172fc9b6-755b-4f62-ab26-55c34a330614"),
Description = "",
FeatureId = new Guid("53176ebf-c75d-42e5-839f-4508ffac3def"),
IsEnabled = true,
Name = "Manage Project"
},
new
{
Id = new Guid("b94802ce-0689-4643-9e1d-11c86950c35b"),
Description = "",
FeatureId = new Guid("53176ebf-c75d-42e5-839f-4508ffac3def"),
IsEnabled = true,
Name = "Manage Team"
},
new
{
Id = new Guid("c7b68e33-72f0-474f-bd96-77636427ecc8"),
Description = "",
FeatureId = new Guid("9666de86-d7c7-4d3d-acaa-fcd6d6b81f3c"),
IsEnabled = true,
Name = "View Project Infra"
},
new
{
Id = new Guid("f2aee20a-b754-4537-8166-f9507b44585b"),
Description = "",
FeatureId = new Guid("9666de86-d7c7-4d3d-acaa-fcd6d6b81f3c"),
IsEnabled = true,
Name = "Manage Project Infra"
},
new
{
Id = new Guid("9fcc5f87-25e3-4846-90ac-67a71ab92e3c"),
Description = "",
FeatureId = new Guid("9d4b5489-2079-40b9-bd77-6e1bf90bc19f"),
IsEnabled = true,
Name = "View Task"
},
new
{
Id = new Guid("08752f33-3b29-4816-b76b-ea8a968ed3c5"),
Description = "",
FeatureId = new Guid("9d4b5489-2079-40b9-bd77-6e1bf90bc19f"),
IsEnabled = true,
Name = "Manage Task"
},
new
{
Id = new Guid("d135a4b0-4f9a-4903-ab9c-4843839ebdee"),
Description = "",
FeatureId = new Guid("39e66f81-efc6-446c-95bd-46bff6cfb606"),
IsEnabled = true,
Name = "Assign Task and Report Progress"
},
new
{
Id = new Guid("ed99ecd4-1bed-42e1-b7b3-d64c04493823"),
Description = "",
FeatureId = new Guid("39e66f81-efc6-446c-95bd-46bff6cfb606"),
IsEnabled = true,
Name = "Approve Task"
},
new
{
Id = new Guid("b82d2b7e-0d52-45f3-997b-c008ea460e7f"),
Description = "",
FeatureId = new Guid("81ab8a87-8ccd-4015-a917-0627cee6a100"),
IsEnabled = true,
Name = "View Employee"
},
new
{
Id = new Guid("a97d366a-c2bb-448d-be93-402bd2324566"),
Description = "",
FeatureId = new Guid("81ab8a87-8ccd-4015-a917-0627cee6a100"),
IsEnabled = true,
Name = "Manage Employee"
},
new
{
Id = new Guid("fbd213e0-0250-46f1-9f5f-4b2a1e6e76a3"),
Description = "",
FeatureId = new Guid("81ab8a87-8ccd-4015-a917-0627cee6a100"),
IsEnabled = true,
Name = "Assign To Project"
},
new
{
Id = new Guid("915e6bff-65f6-4e3f-aea8-3fd217d3ea9e"),
Description = "",
FeatureId = new Guid("52c9cf54-1eb2-44d2-81bb-524cf29c0a94"),
IsEnabled = true,
Name = "Perform Attendance "
},
new
{
Id = new Guid("57802c4a-00aa-4a1f-a048-fd2f70dd44b6"),
Description = "",
FeatureId = new Guid("52c9cf54-1eb2-44d2-81bb-524cf29c0a94"),
IsEnabled = true,
Name = "Regularize Attendance"
},
new
{
Id = new Guid("5ffbafe0-7ab0-48b1-bb50-c1bf76b65f9d"),
Description = "",
FeatureId = new Guid("be3b3afc-6ccf-4566-b9b6-aafcb65546be"),
IsEnabled = true,
Name = "View Masters"
},
new
{
Id = new Guid("588a8824-f924-4955-82d8-fc51956cf323"),
Description = "",
FeatureId = new Guid("be3b3afc-6ccf-4566-b9b6-aafcb65546be"),
IsEnabled = true,
Name = "Manage Masters"
},
new
{
Id = new Guid("cb8ec407-46d4-4467-930c-69127cda6dec"),
Description = "",
FeatureId = new Guid("660131a4-788c-4739-a082-cbbf7879cbf2"),
IsEnabled = true,
Name = "View Masters"
},
new
{
Id = new Guid("6b1a6d97-a951-4de5-9b19-709bac7c4f18"),
Description = "",
FeatureId = new Guid("660131a4-788c-4739-a082-cbbf7879cbf2"),
IsEnabled = true,
Name = "Manage Masters"
});
});
modelBuilder.Entity("Marco.Pms.Model.Entitlements.RolePermissionMappings", b =>
{
b.Property("ApplicationRoleId")
.HasColumnType("char(36)");
b.Property("FeaturePermissionId")
.HasColumnType("char(36)");
b.HasKey("ApplicationRoleId", "FeaturePermissionId");
b.HasIndex("FeaturePermissionId");
b.ToTable("RolePermissionMappings");
});
modelBuilder.Entity("Marco.Pms.Model.Entitlements.Tenant", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("ContactName")
.HasColumnType("longtext");
b.Property("ContactNumber")
.HasColumnType("longtext");
b.Property("Description")
.HasColumnType("longtext");
b.Property("DomainName")
.HasColumnType("longtext");
b.Property("IndustryId")
.HasColumnType("char(36)");
b.Property("IsActive")
.HasColumnType("tinyint(1)");
b.Property("Name")
.HasColumnType("longtext");
b.Property("OnBoardingDate")
.HasColumnType("datetime(6)");
b.Property("OragnizationSize")
.HasColumnType("longtext");
b.HasKey("Id");
b.HasIndex("IndustryId");
b.ToTable("Tenants");
b.HasData(
new
{
Id = new Guid("b3466e83-7e11-464c-b93a-daf047838b26"),
ContactName = "Admin",
ContactNumber = "123456789",
Description = "",
DomainName = "www.marcobms.org",
IndustryId = new Guid("15436ee3-a650-469e-bfc2-59993f7514bb"),
IsActive = true,
Name = "MarcoBMS",
OnBoardingDate = new DateTime(1, 1, 1, 0, 0, 0, 0, DateTimeKind.Unspecified),
OragnizationSize = "100-200"
});
});
modelBuilder.Entity("Marco.Pms.Model.Forum.TicketAttachment", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("CommentId")
.HasColumnType("char(36)");
b.Property("FileId")
.HasColumnType("char(36)");
b.Property("FileName")
.IsRequired()
.HasColumnType("longtext");
b.Property("TicketId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("CommentId");
b.HasIndex("TicketId");
b.ToTable("TicketAttachments");
});
modelBuilder.Entity("Marco.Pms.Model.Forum.TicketComment", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("AuthorId")
.HasColumnType("char(36)");
b.Property("MessageText")
.IsRequired()
.HasColumnType("longtext");
b.Property("ParentMessageId")
.HasColumnType("char(36)");
b.Property("SentAt")
.HasColumnType("datetime(6)");
b.Property("TenantId")
.HasColumnType("char(36)");
b.Property("TicketId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("TenantId");
b.ToTable("TicketComments");
});
modelBuilder.Entity("Marco.Pms.Model.Forum.TicketForum", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("CreatedAt")
.HasColumnType("datetime(6)");
b.Property("CreatedById")
.HasColumnType("char(36)");
b.Property("Description")
.IsRequired()
.HasColumnType("longtext");
b.Property("LinkedActivityId")
.HasColumnType("char(36)");
b.Property("LinkedProjectId")
.HasColumnType("char(36)");
b.Property("PriorityId")
.HasColumnType("char(36)");
b.Property("StatusId")
.HasColumnType("char(36)");
b.Property("Subject")
.IsRequired()
.HasColumnType("longtext");
b.Property("TenantId")
.HasColumnType("char(36)");
b.Property("TypeId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("PriorityId");
b.HasIndex("StatusId");
b.HasIndex("TenantId");
b.HasIndex("TypeId");
b.ToTable("Tickets");
});
modelBuilder.Entity("Marco.Pms.Model.Forum.TicketTag", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("TagId")
.HasColumnType("char(36)");
b.Property("TicketId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("TagId");
b.HasIndex("TicketId");
b.ToTable("TicketTags");
});
modelBuilder.Entity("Marco.Pms.Model.Forum.TicketTypeMaster", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Description")
.HasColumnType("longtext");
b.Property("IsDefault")
.HasColumnType("tinyint(1)");
b.Property("Name")
.IsRequired()
.HasColumnType("longtext");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.ToTable("TicketTypeMasters");
b.HasData(
new
{
Id = new Guid("c74e5480-2b71-483c-8f4a-1a9c69c32603"),
Description = "An identified problem that affects the performance, reliability, or standards of a product or service",
IsDefault = true,
Name = "Quality Issue",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("d1f55eab-9898-4e46-9f03-b263e33e5d38"),
Description = "A support service that assists users with technical issues, requests, or inquiries.",
IsDefault = true,
Name = "Help Desk",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
});
});
modelBuilder.Entity("Marco.Pms.Model.Master.ActivityMaster", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("ActivityName")
.HasColumnType("longtext");
b.Property("IsActive")
.HasColumnType("tinyint(1)");
b.Property("TenantId")
.HasColumnType("char(36)");
b.Property("UnitOfMeasurement")
.HasColumnType("longtext");
b.HasKey("Id");
b.HasIndex("TenantId");
b.ToTable("ActivityMasters");
});
modelBuilder.Entity("Marco.Pms.Model.Master.Feature", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Description")
.HasColumnType("longtext");
b.Property("IsActive")
.HasColumnType("tinyint(1)");
b.Property("ModuleId")
.HasColumnType("char(36)");
b.Property("Name")
.HasColumnType("longtext");
b.HasKey("Id");
b.HasIndex("ModuleId");
b.ToTable("Features");
b.HasData(
new
{
Id = new Guid("53176ebf-c75d-42e5-839f-4508ffac3def"),
Description = "Manage Project",
IsActive = true,
ModuleId = new Guid("bf59fd88-b57a-4d67-bf01-3780f385896b"),
Name = "Manage Project"
},
new
{
Id = new Guid("9666de86-d7c7-4d3d-acaa-fcd6d6b81f3c"),
Description = "Manage Infra",
IsActive = true,
ModuleId = new Guid("bf59fd88-b57a-4d67-bf01-3780f385896b"),
Name = "Manage Infra"
},
new
{
Id = new Guid("9d4b5489-2079-40b9-bd77-6e1bf90bc19f"),
Description = "Manage Tasks",
IsActive = true,
ModuleId = new Guid("bf59fd88-b57a-4d67-bf01-3780f385896b"),
Name = "Manage Tasks"
},
new
{
Id = new Guid("39e66f81-efc6-446c-95bd-46bff6cfb606"),
Description = "Assign and Update Tasks Progress",
IsActive = true,
ModuleId = new Guid("bf59fd88-b57a-4d67-bf01-3780f385896b"),
Name = "Assign and Update Tasks Progress"
},
new
{
Id = new Guid("81ab8a87-8ccd-4015-a917-0627cee6a100"),
Description = "Manage Employee",
IsActive = true,
ModuleId = new Guid("2a231490-bcb1-4bdd-91f1-f25fb7f25b23"),
Name = "Manage Employee"
},
new
{
Id = new Guid("52c9cf54-1eb2-44d2-81bb-524cf29c0a94"),
Description = "Attendance",
IsActive = true,
ModuleId = new Guid("2a231490-bcb1-4bdd-91f1-f25fb7f25b23"),
Name = "Attendance"
},
new
{
Id = new Guid("be3b3afc-6ccf-4566-b9b6-aafcb65546be"),
Description = "Global Masters",
IsActive = true,
ModuleId = new Guid("c43db8c7-ab73-47f4-9d3b-f83e81357924"),
Name = "Global Masters"
},
new
{
Id = new Guid("660131a4-788c-4739-a082-cbbf7879cbf2"),
Description = "Tenant Masters",
IsActive = true,
ModuleId = new Guid("c43db8c7-ab73-47f4-9d3b-f83e81357924"),
Name = "Tenant Masters"
});
});
modelBuilder.Entity("Marco.Pms.Model.Master.Industry", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Name")
.HasColumnType("longtext");
b.HasKey("Id");
b.ToTable("Industries");
b.HasData(
new
{
Id = new Guid("15436ee3-a650-469e-bfc2-59993f7514bb"),
Name = "Information Technology (IT) Services"
},
new
{
Id = new Guid("0a63e657-2c5f-49b5-854b-42c978293154"),
Name = "Manufacturing & Production"
},
new
{
Id = new Guid("bdc61e3b-69ea-4394-bab6-079ec135b5bd"),
Name = "Energy & Resources"
},
new
{
Id = new Guid("5ca200ac-00d7-415e-a410-b948e27ac9d2"),
Name = "Finance & Professional Services"
},
new
{
Id = new Guid("d5621700-cd87-441f-8cdb-6051ddfc83b4"),
Name = "Hospitals and Healthcare Services"
},
new
{
Id = new Guid("23608891-657e-40f0-bbd4-2b0a2ec1a76f"),
Name = "Social Services"
},
new
{
Id = new Guid("a493f4e3-16b1-4411-be3c-6bf2987a3168"),
Name = "Retail & Consumer Services"
},
new
{
Id = new Guid("e9d8ce92-9371-4ed9-9831-83c07f78edec"),
Name = "Transportation & Logistics"
},
new
{
Id = new Guid("8a0d6134-2dbe-4e0a-b250-ff34cb7b9df0"),
Name = "Education & Training"
});
});
modelBuilder.Entity("Marco.Pms.Model.Master.Module", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Description")
.HasColumnType("longtext");
b.Property("Key")
.IsRequired()
.HasColumnType("longtext");
b.Property("Name")
.IsRequired()
.HasColumnType("longtext");
b.HasKey("Id");
b.ToTable("Modules");
b.HasData(
new
{
Id = new Guid("bf59fd88-b57a-4d67-bf01-3780f385896b"),
Description = "Project Module",
Key = "b04da7e9-0406-409c-ac7f-b97256e6ea02",
Name = "Project"
},
new
{
Id = new Guid("2a231490-bcb1-4bdd-91f1-f25fb7f25b23"),
Description = "Employee Module",
Key = "0971c7fb-6ce1-458a-ae3f-8d3205893637",
Name = "Employee"
},
new
{
Id = new Guid("c43db8c7-ab73-47f4-9d3b-f83e81357924"),
Description = "Masters Module",
Key = "504ec132-e6a9-422f-8f85-050602cfce05",
Name = "Masters"
});
});
modelBuilder.Entity("Marco.Pms.Model.Master.StatusMaster", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Status")
.HasColumnType("longtext");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("TenantId");
b.ToTable("StatusMasters");
b.HasData(
new
{
Id = new Guid("b74da4c2-d07e-46f2-9919-e75e49b12731"),
Status = "Active",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("603e994b-a27f-4e5d-a251-f3d69b0498ba"),
Status = "In Progress",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("ef1c356e-0fe0-42df-a5d3-8daee355492d"),
Status = "On Hold",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("33deaef9-9af1-4f2a-b443-681ea0d04f81"),
Status = "Completed",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
});
});
modelBuilder.Entity("Marco.Pms.Model.Master.TicketPriorityMaster", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("ColorCode")
.HasColumnType("longtext");
b.Property("IsDefault")
.HasColumnType("tinyint(1)");
b.Property("Level")
.HasColumnType("int");
b.Property("Name")
.IsRequired()
.HasColumnType("longtext");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.ToTable("TicketPriorityMasters");
b.HasData(
new
{
Id = new Guid("188d29b3-10f3-42d0-9587-1a46ae7a0320"),
ColorCode = "008000",
IsDefault = true,
Level = 1,
Name = "Low",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("0919bc84-9f82-4ecf-98c7-962755dd9a97"),
ColorCode = "FFFF00",
IsDefault = true,
Level = 2,
Name = "Medium",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("a13b7e59-16fd-4665-b5cf-a97399e8445a"),
ColorCode = "#FFA500",
IsDefault = true,
Level = 3,
Name = "High",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("f340fbc3-c9fd-46aa-b063-0093418830e4"),
ColorCode = "#FFA500",
IsDefault = true,
Level = 4,
Name = "Critical",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("44a7b91d-a0dd-45d1-8616-4d2f71e16401"),
ColorCode = "#FF0000",
IsDefault = true,
Level = 5,
Name = "Urgent",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
});
});
modelBuilder.Entity("Marco.Pms.Model.Master.TicketStatusMaster", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("ColorCode")
.HasColumnType("longtext");
b.Property("Description")
.HasColumnType("longtext");
b.Property("IsDefault")
.HasColumnType("tinyint(1)");
b.Property("Name")
.IsRequired()
.HasColumnType("longtext");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.ToTable("TicketStatusMasters");
b.HasData(
new
{
Id = new Guid("6b0c409b-3e80-4165-8b39-f3fcacb4c797"),
ColorCode = "#FFCC99",
Description = "This is a newly created issue.",
IsDefault = true,
Name = "New",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("6c5ac37d-5b7d-40f3-adec-2dabaa5cca86"),
ColorCode = "#E6FF99",
Description = "Assigned to employee or team of employees",
IsDefault = true,
Name = "Assigned",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("7f96bcd5-0c66-411b-8a1d-9d1a4785194e"),
ColorCode = "#99E6FF",
Description = "These issues are currently in progress",
IsDefault = true,
Name = "In Progress",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("5c72b630-6923-4215-bf2c-b1622afd76e7"),
ColorCode = "#6c757d",
Description = "These issues are currently under review",
IsDefault = true,
Name = "In Review",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("8ff85685-a875-4f21-aa95-d99551315fcc"),
ColorCode = "#B399FF",
Description = "The following issues are resolved and closed",
IsDefault = true,
Name = "Done",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
});
});
modelBuilder.Entity("Marco.Pms.Model.Master.TicketTagMaster", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("ColorCode")
.HasColumnType("longtext");
b.Property("IsDefault")
.HasColumnType("tinyint(1)");
b.Property("Name")
.IsRequired()
.HasColumnType("longtext");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.ToTable("TicketTagMasters");
b.HasData(
new
{
Id = new Guid("ef6c2a65-f61d-4537-9650-a7ab7f8d98db"),
ColorCode = "#e59866",
IsDefault = true,
Name = "Quality Issue",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("5a168569-8ad7-4422-8db6-51ef25caddeb"),
ColorCode = "#85c1e9",
IsDefault = true,
Name = "Help Desk",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
});
});
modelBuilder.Entity("Marco.Pms.Model.Master.WorkCategoryMaster", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Description")
.IsRequired()
.HasColumnType("longtext");
b.Property("IsSystem")
.HasColumnType("tinyint(1)");
b.Property("Name")
.IsRequired()
.HasColumnType("longtext");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("TenantId");
b.ToTable("WorkCategoryMasters");
b.HasData(
new
{
Id = new Guid("86bb2cc8-f6b5-4fdd-bbee-c389c713a44b"),
Description = "Created new task in a professional or creative context",
IsSystem = true,
Name = "Fresh Work",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("9ebfa19c-53b9-481b-b863-c25d2f843201"),
Description = "Revising, modifying, or correcting a task to improve its quality or fix issues",
IsSystem = true,
Name = "Rework",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
},
new
{
Id = new Guid("11a79929-1d07-42dc-9e98-82d0d2f4a240"),
Description = "Any defect, deviation, or non-conformance in a task that fails to meet established standards or customer expectations.",
IsSystem = true,
Name = "Quality Issue",
TenantId = new Guid("b3466e83-7e11-464c-b93a-daf047838b26")
});
});
modelBuilder.Entity("Marco.Pms.Model.Projects.Building", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("Description")
.HasColumnType("longtext");
b.Property("Name")
.IsRequired()
.HasColumnType("longtext");
b.Property("ProjectId")
.HasColumnType("char(36)");
b.Property("TenantId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("TenantId");
b.ToTable("Buildings");
});
modelBuilder.Entity("Marco.Pms.Model.Projects.Floor", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property