From 8c5e9dae712227bef7cede73fac16bf3e48b19c6 Mon Sep 17 00:00:00 2001 From: vnugent Date: Thu, 13 Apr 2023 11:36:37 -0400 Subject: Database creation helpers w/ fluent api --- .../src/IDbContextBuilder.cs | 51 ++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 lib/VNLib.Plugins.Extensions.Loading.Sql/src/IDbContextBuilder.cs (limited to 'lib/VNLib.Plugins.Extensions.Loading.Sql/src/IDbContextBuilder.cs') diff --git a/lib/VNLib.Plugins.Extensions.Loading.Sql/src/IDbContextBuilder.cs b/lib/VNLib.Plugins.Extensions.Loading.Sql/src/IDbContextBuilder.cs new file mode 100644 index 0000000..01e9b2f --- /dev/null +++ b/lib/VNLib.Plugins.Extensions.Loading.Sql/src/IDbContextBuilder.cs @@ -0,0 +1,51 @@ +/* +* Copyright (c) 2023 Vaughn Nugent +* +* Library: VNLib +* Package: VNLib.Plugins.Extensions.Loading.Sql +* File: IDbContextBuilder.cs +* +* IDbContextBuilder.cs is part of VNLib.Plugins.Extensions.Loading.Sql which is part of the larger +* VNLib collection of libraries and utilities. +* +* VNLib.Plugins.Extensions.Loading.Sql is free software: you can redistribute it and/or modify +* it under the terms of the GNU Affero General Public License as +* published by the Free Software Foundation, either version 3 of the +* License, or (at your option) any later version. +* +* VNLib.Plugins.Extensions.Loading.Sql is distributed in the hope that it will be useful, +* but WITHOUT ANY WARRANTY; without even the implied warranty of +* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +* GNU Affero General Public License for more details. +* +* You should have received a copy of the GNU Affero General Public License +* along with this program. If not, see https://www.gnu.org/licenses/. +*/ + +using System.ComponentModel.DataAnnotations.Schema; + +namespace VNLib.Plugins.Extensions.Loading.Sql +{ + /// + /// Passed to a during a database creation event. + /// + public interface IDbContextBuilder + { + /// + /// Defines the existance of a table within the database by its type name + /// + /// If your entity defines a , this name value is used + /// + /// + /// The entity type to build + /// A new used to build the table for this entity + IDbTableBuilder DefineTable(); + + /// + /// Defines the existance of a table within the database by the supplied table name + /// + /// The entity type to build + /// A new used to build the table for this entity + IDbTableBuilder DefineTable(string tableName); + } +} -- cgit