Some push services might require that the server identifies itself with a VAPID key pair. It is required by Apple. Keys can be generated here.
dotnet user-secrets set Push__PublicKey "..."
dotnet user-secrets set Push__PrivateKey "..."
dotnet user-secrets set Push__Subject "mailto:..."
After modifying the Db
, you have to create new migrations:
# Go to the server project directory (e.g. ~/src/StartSCH/StartSch)
cd StartSch
# Make sure you can run `dotnet ef`.
# One of these commands, ideally the first one, should install it.
dotnet tool restore
dotnet tool install dotnet-ef
dotnet tool install dotnet-ef --global
# Describe the migration
export MIGRATION_MESSAGE=AddSomethingToSomeOtherThing
# Add migration
dotnet ef migrations add --context SqliteDb $MIGRATION_MESSAGE
dotnet ef migrations add --context PostgresDb $MIGRATION_MESSAGE
# Remove latest migration
dotnet ef migrations remove --context SqliteDb
dotnet ef migrations remove --context PostgresDb
# Reset migrations
rm -r Data/Migrations
dotnet ef migrations add --context SqliteDb --output-dir Data/Migrations/Sqlite $MIGRATION_MESSAGE
dotnet ef migrations add --context PostgresDb --output-dir Data/Migrations/Postgres $MIGRATION_MESSAGE
Migrations are applied automatically on server startup.
- Docs: DbContext Lifetime, Configuration, and Initialization
- Docs: ASP.NET Core Blazor with Entity Framework Core
Depending on where you want to access the database, you have to decide between injecting Db
or IDbContextFactory<Db>
.
For example, static forms or API controllers that run in a scope should use Db
, while methods in an interactive Blazor component should request a new Db
instance every time they run.