EntityFrameworkCore.Scaffolding.Handlebars 1.1.1

There is a newer version of this package available.
See the version list below for details.
dotnet add package EntityFrameworkCore.Scaffolding.Handlebars --version 1.1.1
                    
NuGet\Install-Package EntityFrameworkCore.Scaffolding.Handlebars -Version 1.1.1
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="EntityFrameworkCore.Scaffolding.Handlebars" Version="1.1.1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="EntityFrameworkCore.Scaffolding.Handlebars" Version="1.1.1" />
                    
Directory.Packages.props
<PackageReference Include="EntityFrameworkCore.Scaffolding.Handlebars" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add EntityFrameworkCore.Scaffolding.Handlebars --version 1.1.1
                    
#r "nuget: EntityFrameworkCore.Scaffolding.Handlebars, 1.1.1"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package EntityFrameworkCore.Scaffolding.Handlebars@1.1.1
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=EntityFrameworkCore.Scaffolding.Handlebars&version=1.1.1
                    
Install as a Cake Addin
#tool nuget:?package=EntityFrameworkCore.Scaffolding.Handlebars&version=1.1.1
                    
Install as a Cake Tool

Entity Framework Core Scaffolding with Handlebars

Scaffold EF Core models using Handlebars templates.

Prerequisites

Database Setup

  1. Use SQL Server Management Studio to connect to SQL Server
    • The easiest is to use LocalDb, which is installed with Visual Studio.
      Connect to: (localdb)\MsSqlLocalDb.
    • Create a new database named NorthwindSlim.
    • Download the data file from http://bit.ly/northwindslim.
    • Unzip NorthwindSlim.sql and run the script to create tables and populate them with data.

Usage

  1. Create a new .NET Core class library.

    • If necessary, edit the csproj file to update the TargetFramework to 2.1.

    Note: Using the EF Core toolchain with a .NET Standard class library is currently not supported. Instead, you can add a .NET Standard class library to the same solution as the .NET Core library, then add existing items and select Add As Link to include entity classes.

  2. Add EF Core SQL Server and Tools NuGet packages.

    • Open the Package Manager Console, select the default project and enter:
      • Install-Package Microsoft.EntityFrameworkCore.SqlServer
    • If needed update EF Core to version 2.1.
  3. Add the EntityFrameworkCore.Scaffolding.Handlebars NuGet package:

    • Install-Package EntityFrameworkCore.Scaffolding.Handlebars
  4. Remove Class1.cs and add a ScaffoldingDesignTimeServices class.

    • Implement IDesignTimeServices by adding a ConfigureDesignTimeServices method that calls services.AddHandlebarsScaffolding.
    • You can optionally pass a ReverseEngineerOptions enum to indicate if you wish to generate only entity types, only a DbContext class, or both (which is the default).
    public class ScaffoldingDesignTimeServices : IDesignTimeServices
    {
        public void ConfigureDesignTimeServices(IServiceCollection services)
        {
            var options = ReverseEngineerOptions.DbContextAndEntities;
            services.AddHandlebarsScaffolding(options);
        }
    }
    
  5. Open a command prompt at the project level and use the EF .NET Core CLI tools to reverse engineer a context and models from an existing database.

    • Get help on dotnet-ef-dbcontext-scaffold at the command line: dotnet ef dbcontext scaffold -h
    • Execute the following command to reverse engineer classes from the NorthwindSlim database:
    dotnet ef dbcontext scaffold "Data Source=(localdb)\MSSQLLocalDB; Initial Catalog=NorthwindSlim; Integrated Security=True" Microsoft.EntityFrameworkCore.SqlServer -o Models -c NorthwindSlimContext -f --context-dir Contexts
    
    • You should see context and/or entity classes appear in the Models folder of the project.
    • You will also see a CodeTemplates folder appear containing Handlebars templates for customizing generation of context and entity type classes.
    • Add -d to the command to use data annotations. You will need to add the System.ComponentModel.Annotations package to a .NET Standard library containing linked entity classes.
  6. You may edit any of the template files which appear under the CodeTemplates folder.

    • For now you can just add some comments, but you may wish to customize the templates in other ways, for example, by inheriting entities from a base class or implementing specific interfaces.
    • When you run the dotnet-ef-dbcontext-scaffold command again, you will see your updated reflected in the generated classes.

Handlebars Helpers

You can register Handlebars helpers in the ScaffoldingDesignTimeServices where setup takes place.

  • Create a named tuple as shown with myHelper below.
  • Pass the tuple to the AddHandlebarsScaffolding extension method.
  • You may register as many helpers as you wish.
public class ScaffoldingDesignTimeServices : IDesignTimeServices
{
    public void ConfigureDesignTimeServices(IServiceCollection services)
    {
        // Generate both context and entitites
        var options = ReverseEngineerOptions.DbContextAndEntities;

        // Register Handlebars helper
        var myHelper = (helperName: "my-helper", helperFunction: (Action<TextWriter, object, object[]>) MyHbsHelper);

        // Add Handlebars scaffolding templates
        services.AddHandlebarsScaffolding(options, myHelper);
    }

    // Sample Handlebars helper
    void MyHbsHelper(TextWriter writer, object context, object[] parameters)
    {
        writer.Write("// My Handlebars Helper");
    }
}
  • To use Handlebars helper defined above, add the following to any of the .hbs files within the CodeTemplates folder: {{my-helper}}
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (14)

Showing the top 5 NuGet packages that depend on EntityFrameworkCore.Scaffolding.Handlebars:

Package Downloads
TrueSight

Package Description

WmsUtility.Database.Inventory

Wms Utility

WmsUtility.Database.Master

Scaffold-DbContext

WmsUtility.Database.Stagging

Add Reference Project WmsUtility.Database.Utility

WmsUtility.Database.Outbound

Add Reference Project WmsUtility.Database.Utility

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on EntityFrameworkCore.Scaffolding.Handlebars:

Repository Stars
ErikEJ/EFCorePowerTools
Entity Framework Core Power Tools - reverse engineering, migrations and model visualization in Visual Studio & CLI
Version Downloads Last Updated
9.0.0 67,398 3/23/2025
9.0.0-beta1 21,804 11/26/2024
8.0.0 339,483 1/27/2024
8.0.0-beta2 995 12/30/2023
8.0.0-beta1 1,866 11/23/2023
7.0.0 115,826 6/12/2023
7.0.0-beta1 20,354 11/20/2022
6.0.3 432,335 1/22/2022
6.0.2 12,833 12/23/2021
6.0.1 1,578 12/21/2021
6.0.0 8,382 12/15/2021
6.0.0-preview5 340 12/15/2021
6.0.0-preview4 424 12/5/2021
6.0.0-preview3 5,730 11/30/2021
6.0.0-preview2 3,745 11/25/2021
6.0.0-preview1 3,504 11/25/2021
5.0.5-preview1 11,407 9/25/2021
5.0.4 83,366 9/23/2021
5.0.3 15,081 9/15/2021
5.0.2 94,646 2/19/2021
5.0.1 23,016 12/5/2020
5.0.0 2,489 11/15/2020
5.0.0-rc.2 836 10/18/2020
3.8.5 29,167 11/7/2020
3.8.4 15,270 9/28/2020
3.8.3 98,958 8/18/2020
3.8.2 3,711 7/21/2020
3.8.1 8,020 7/8/2020
3.7.0 46,022 5/1/2020
3.6.0 23,000 1/6/2020
3.5.1 2,445 12/15/2019
3.5.0 6,391 10/18/2019
3.0.0 1,400 10/14/2019
3.0.0-preview8 614 8/26/2019
2.1.1 37,336 8/5/2019
2.1.0 1,545 7/19/2019
2.0.0 6,489 6/25/2019
1.7.2 142,853 1/6/2019
1.7.1 1,261 1/5/2019
1.7.0 943 1/3/2019
1.6.0 1,558 12/17/2018
1.5.1 28,462 7/7/2018
1.5.0 1,685 6/22/2018
1.4.1 1,596 7/7/2018
1.4.0 1,468 6/23/2018
1.1.1 1,516 6/19/2018
1.1.0 1,595 6/3/2018
1.0.0 1,620 5/30/2018
1.0.0-rc3 1,491 5/26/2018
1.0.0-rc2 1,268 5/26/2018
1.0.0-rc 1,285 5/24/2018
1.0.0-beta 3,002 10/25/2017