public static DataContractClassDefinition GetDataContractClassDefinition(this EntityFrameworkCoreProject project, ITable table, bool isDomainDrivenDesign) { var definition = new DataContractClassDefinition { Namespaces = { "System" }, Namespace = isDomainDrivenDesign ? project.GetDomainQueryModelsNamespace() : project.GetDataLayerDataContractsNamespace(), AccessModifier = AccessModifier.Public, Name = project.GetDataContractName(table), DbObject = table }; foreach (var column in table.Columns) { definition.Properties.Add(new PropertyDefinition(AccessModifier.Public, project.Database.ResolveDatabaseType(column), project.GetPropertyName(table, column)) { IsAutomatic = true }); } foreach (var foreignKey in table.ForeignKeys) { var foreignTable = project.Database.FindTable(foreignKey.References); if (foreignTable == null) { continue; } var foreignKeyAlias = NamingConvention.GetCamelCase(project.GetEntityName(foreignTable)); foreach (var column in foreignTable?.GetColumnsWithNoPrimaryKey()) { var col = (Column)column; var propertyName = project.GetPropertyName(foreignTable, col); var target = string.Format("{0}{1}", project.GetEntityName(foreignTable), propertyName); if (definition.Properties.Count(item => item.Name == propertyName) == 0) { definition.Properties.Add(new PropertyDefinition(AccessModifier.Public, project.Database.ResolveDatabaseType(col), target) { IsAutomatic = true }); } } } definition.SimplifyDataTypes(); return(definition); }
public static DataContractClassDefinition GetDataContractClassDefinition(this EntityFrameworkCoreProject project, ITable table) { var definition = new DataContractClassDefinition { Namespaces = { "System" }, Namespace = project.GetDataLayerDataContractsNamespace(), Name = project.GetDataContractName(table) }; foreach (var column in table.Columns) { definition.Properties.Add(new PropertyDefinition(project.Database.ResolveDatabaseType(column), column.GetPropertyName())); } foreach (var foreignKey in table.ForeignKeys) { var foreignTable = project.Database.FindTable(foreignKey.References); if (foreignTable == null) { continue; } var foreignKeyAlias = NamingConvention.GetCamelCase(project.GetEntityName(foreignTable)); foreach (var column in foreignTable?.GetColumnsWithNoPrimaryKey()) { var target = string.Format("{0}{1}", project.GetEntityName(foreignTable), column.GetPropertyName()); if (definition.Properties.Count(item => item.Name == column.GetPropertyName()) == 0) { definition.Properties.Add(new PropertyDefinition(project.Database.ResolveDatabaseType(column), target)); } } } return(definition); }
public static DataContractClassDefinition GetDataContractClassDefinition(this EntityFrameworkCoreProject project, IView view) { var definition = new DataContractClassDefinition { Namespaces = { "System" }, Namespace = project.GetDataLayerDataContractsNamespace(), AccessModifier = AccessModifier.Public, Name = project.GetDataContractName(view), DbObject = view }; foreach (var column in view.Columns) { definition.Properties.Add(new PropertyDefinition(AccessModifier.Public, project.Database.ResolveDatabaseType(column), project.GetPropertyName(view, column)) { IsAutomatic = true }); } return(definition); }