mirror of
https://github.com/spacebarchat/server.git
synced 2026-03-30 22:35:40 +00:00
37 lines
1.3 KiB
Plaintext
Executable File
37 lines
1.3 KiB
Plaintext
Executable File
#! /usr/bin/env nix-shell
|
|
#! nix-shell -i nix -p nix
|
|
#! nix shell nixpkgs#bash nixpkgs#dotnet-ef nixpkgs#postgresql --command bash
|
|
|
|
set -ex
|
|
rm -rfv Spacebar.Db
|
|
|
|
# prep temporary db
|
|
# - Update collation version for template1 just incase!
|
|
psql -U postgres -c 'ALTER DATABASE template1 REFRESH COLLATION VERSION;'
|
|
dropdb -U postgres sb-server-scaffold --if-exists --force || true
|
|
createdb -U postgres sb-server-scaffold
|
|
DATABASE=postgres://postgres@127.0.0.1/sb-server-scaffold nix shell nixpkgs#nodejs ../.. --command npm run sync:db
|
|
|
|
# Create new project
|
|
dotnet new classlib --no-restore -o Spacebar.Db
|
|
cd Spacebar.Db
|
|
rm Class1.cs
|
|
dotnet add package Npgsql.EntityFrameworkCore.PostgreSQL -n -f net9.0
|
|
dotnet add package Microsoft.EntityFrameworkCore.Design -n -f net9.0
|
|
|
|
dotnet restore
|
|
|
|
dotnet-ef dbcontext scaffold "Host=127.0.0.1; Username=postgres; Database=sb-server-scaffold" \
|
|
Npgsql.EntityFrameworkCore.PostgreSQL \
|
|
-o Models \
|
|
-c SpacebarDbContext \
|
|
--context-dir Contexts \
|
|
--force \
|
|
--no-onconfiguring \
|
|
--data-annotations
|
|
|
|
for patch in ../db-patches/*.patch; do
|
|
patch -p1 < $patch
|
|
done
|
|
|
|
echo 'Scaffolded database and applied patches. Dont forget to generate new patches with `git diff --relative Spacebar.Db/path/xyz > db-patches/001-your-patch-name.patch!`' |