116 lines
3.9 KiB
Makefile
116 lines
3.9 KiB
Makefile
pg_pass := "password"
|
|
pg_user := "postgres"
|
|
pg_container := "postgres-frostbyte" # This is the name of the postgres container
|
|
pg_port := "5432"
|
|
network := "fb_network"
|
|
db_name := "frostbyte" # This is the name of the database
|
|
|
|
conn_string := "postgres://" + pg_user + ":" + pg_pass + "@" + pg_container + ":" + pg_port / db_name
|
|
conn_local := "postgres://" + pg_user + ":" + pg_pass + "@" + "localhost" + ":" + pg_port / db_name
|
|
env_string := "DATABASE_URL=" + conn_string
|
|
env_local := "DATABASE_URL=" + conn_local
|
|
|
|
# Builds a debug container and runs it
|
|
dev: start-debug
|
|
@echo "Cd into client and run 'npm run dev' to start the client in dev mode."
|
|
|
|
# Builds a debug container
|
|
[private]
|
|
build-container-server-debug:
|
|
podman build -t fb-server-debug -f container/ContainerfileDebug .
|
|
|
|
# Builds a debug container and runs it
|
|
[private]
|
|
start-debug: start-postgres-dev clean-podman init-sqlx build-container-server-debug
|
|
podman network create {{network}} --ignore
|
|
podman run -d --network {{network}} -e {{env_string}} -p 8080:8080 --name frostbyte-debug fb-server-debug
|
|
podman ps | grep frostbyte-debug
|
|
@echo "Debug server started."
|
|
|
|
# Builds a release container
|
|
[private]
|
|
build-container-release:
|
|
podman build -t fb-server -f container/Containerfile .
|
|
|
|
# Builds a release container and runs it
|
|
start-release: start-postgres-dev clean-podman init-sqlx build-container-release create-network
|
|
podman run -d --network {{network}} -e {{env_string}} -p 8080:8080 --name frostbyte fb-server
|
|
|
|
# Initializes the database, runs migrations and then prepares sqlx
|
|
[private]
|
|
init-sqlx: install-sqlx
|
|
echo {{env_local}} > server/.env
|
|
cd server && sqlx database create --connect-timeout 40 # Postgres takes a while to start up
|
|
cd server && sqlx migrate run
|
|
cd server && cargo sqlx prepare # If this fails, try running just clean
|
|
|
|
# Shorthand for installing sqlx
|
|
[private]
|
|
install-sqlx:
|
|
cargo install sqlx-cli
|
|
|
|
# Starts a postgres container for development
|
|
[private]
|
|
start-postgres-dev: create-network
|
|
podman rm -f {{pg_container}}
|
|
podman run --network {{network}} --name {{pg_container}} -e POSTGRES_PASSWORD={{pg_pass}} -d -p {{pg_port}}:5432 docker.io/postgres:16.1-alpine
|
|
|
|
pgshell:
|
|
podman exec -it {{pg_container}} psql -U {{pg_user}} -d {{db_name}}
|
|
|
|
re-migrate:
|
|
echo {{env_local}} > server/.env
|
|
cd server && cargo sqlx database drop -y
|
|
cd server && cargo sqlx database create
|
|
cd server && cargo sqlx migrate run
|
|
@echo "Database re-initialized and migrations re-run."
|
|
|
|
db-backup:
|
|
podman exec -t {{pg_container}} pg_dump -U {{pg_user}} -d {{db_name}} | gzip > frostbyte_backup$(date +'%Y-%m-%d_%H:%M:%S').sql.gz
|
|
|
|
# Drops the database and restores it from a backup file
|
|
db-restore backupfile: db-backup
|
|
podman exec -i {{pg_container}} psql -U {{pg_user}} -d {{db_name}} -c "DROP SCHEMA public CASCADE; CREATE SCHEMA public;"
|
|
gunzip -c {{backupfile}} | podman exec -i {{pg_container}} psql -U {{pg_user}} -d {{db_name}}
|
|
|
|
[private]
|
|
create-network:
|
|
podman network create {{network}} --ignore
|
|
|
|
# Forcefully stops and removes the frostbyte container
|
|
[private]
|
|
clean-podman:
|
|
podman container rm -f frostbyte
|
|
podman container rm -f frostbyte-debug
|
|
|
|
# Removes the database container
|
|
[private]
|
|
clean-db:
|
|
podman container rm -f {{pg_container}}
|
|
|
|
# Removes the network
|
|
[private]
|
|
clean-network:
|
|
podman network rm -f {{network}}
|
|
|
|
# Forcefully removes the frostbyte images
|
|
[private]
|
|
clean-images:
|
|
podman image rm -f fb-server
|
|
podman image rm -f fb-server-debug
|
|
podman image rm -f postgres
|
|
podman image prune -af
|
|
|
|
# Cleans up everything related to the project
|
|
clean: clean-podman clean-db clean-images clean-network && state
|
|
rm -rf client-solid/dist
|
|
rm -rf client-solid/node_modules
|
|
rm -rf server/public
|
|
rm -rf server/target
|
|
@echo "Cleaned up! Make sure to clean up podman volumes and networks."
|
|
|
|
state:
|
|
podman ps -a
|
|
podman images ls -a
|
|
podman network ls
|
|
du -sch client* server
|