diff options
author | vnugent <public@vaughnnugent.com> | 2023-04-13 11:36:37 -0400 |
---|---|---|
committer | vnugent <public@vaughnnugent.com> | 2023-04-13 11:36:37 -0400 |
commit | 8c5e9dae712227bef7cede73fac16bf3e48b19c6 (patch) | |
tree | 388ae13e89c9ab256e2aa65c29a664b14b54fcc6 /lib/VNLib.Plugins.Extensions.Loading.Sql/src/IDbTableDefinition.cs | |
parent | e77477b81e5623502b19db0fb29d4ea88c26b934 (diff) |
Database creation helpers w/ fluent api
Diffstat (limited to 'lib/VNLib.Plugins.Extensions.Loading.Sql/src/IDbTableDefinition.cs')
-rw-r--r-- | lib/VNLib.Plugins.Extensions.Loading.Sql/src/IDbTableDefinition.cs | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/lib/VNLib.Plugins.Extensions.Loading.Sql/src/IDbTableDefinition.cs b/lib/VNLib.Plugins.Extensions.Loading.Sql/src/IDbTableDefinition.cs new file mode 100644 index 0000000..7730afe --- /dev/null +++ b/lib/VNLib.Plugins.Extensions.Loading.Sql/src/IDbTableDefinition.cs @@ -0,0 +1,41 @@ +/* +* Copyright (c) 2023 Vaughn Nugent +* +* Library: VNLib +* Package: VNLib.Plugins.Extensions.Loading.Sql +* File: IDbTableDefinition.cs +* +* IDbTableDefinition.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/. +*/ + +namespace VNLib.Plugins.Extensions.Loading.Sql +{ + /// <summary> + /// When implemented by a <see cref="Microsoft.EntityFrameworkCore.DbContext"/> allows + /// for the custom creation of database tables for any given entity + /// </summary> + public interface IDbTableDefinition + { + /// <summary> + /// Invoked when the model is being evaluated and the database tables are being created. You will define + /// your database tables on your entities. + /// </summary> + /// <param name="builder">The <see cref="IDbTableDefinition"/> used to define the tables and columns in your database</param> + /// <param name="userState">An optional user-supplied state instace passed from the creation method</param> + void OnDatabaseCreating(IDbContextBuilder builder, object? userState); + } +} |