-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjustfile
executable file
·147 lines (121 loc) · 7.26 KB
/
justfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
# Good info on syntax: https://cheatography.com/linux-china/cheat-sheets/justfile/
# Easiest way to install on Ubuntu:
# $ snap install --edge --classic just
# Default shell and settings used in the recipes
set shell := ["bash", "-uc"]
# Set user ID and group ID dynamically, which are in turn used in compose.yaml,
# so the admin-site-container runs as your own user instead of the BPC user
# This should get us closer to being able to remove "privileged", and make permissions errors (and "just fix-permissions") less relevant
# NOTE: If you get a permissions error running the server, you can try commenting these out. Doing so might cause some other issues, though,
# such as /media and /log being owned by the bpc user (set by Dockerfile) and thus script uploads fail.
# We've also seen an occasional permissions error related to .po files
# export DEV_UID := `id -u`
# export DEV_GID := `id -g`
# Aliases
alias r := run
alias rd := run-debug
alias fp := fix-permissions
alias tmm := translations-make-messages
alias tcm := translations-compile-messages
# Variables
compose_django_service := "os2borgerpc-admin"
# container_name isn't currently set in compose.yaml, so the container name is determined in part by the dir the compose file is in. Determine that dynamically.
django_container := `basename $PWD` + "-os2borgerpc-admin-1"
db_container := `basename $PWD` + "-db-1"
compose_db_service := "db"
db_data_file := "db-data.json"
db_structure_file := "db-structure.psql"
models_output_file_name := "models_graphed.png"
# The default recipe, if none is specified
@default:
@just --list
# Help command, which lists available recipes
help:
@just --list
# A helper recipe that ensures that a given docker container is running
_verify-container-running container:
#!/usr/bin/env sh
# this shebang is to prevent just complaining about whitespace
# https://github.com/casey/just#indentation
if ! docker ps | grep "{{container}}"; then
printf "%s\n" "Container not running. Exiting."
exit 1
fi
bash-django: (_verify-container-running django_container)
docker exec -i --tty {{django_container}} /bin/bash
# Run bash in a django container without first running migrations - convenient for e.g. makemigrations
bash-django-skip-entrypoint:
docker compose run --rm --entrypoint bash {{compose_django_service}}
# Runs black on the python codebase
black:
black admin_site
# Dump the database to a file named {{db_data_file}}
dump-db-data: (_verify-container-running django_container)
docker exec {{django_container}} django-admin dumpdata > {{db_data_file}}
# Dump the database structure to a file named db-structure.psql
dump-db-structure: (_verify-container-running django_container)
docker exec -i --tty {{db_container}} pg_dump -U postgres --schema-only bpc > {{db_structure_file}}
# View the db file contents from a dumped db
# it can also be viewed with fx.: jq . < out.json | view
view-dumped-db-data:
if ! which nvim > /dev/null; then jq . {{db_data_file}} | less; else nvim -c ":%! jq ." {{db_data_file}}; fi
# Fix adminsite permissions in case you get "Permission Denied" errors
fix-permissions:
#!/usr/bin/env sh
# Setting all directories to 777, all files to 666 and finally set the executable bit for the few files needing that
if ! which fd > /dev/null; then
printf '%s\n' "fd not installed. If on Ubuntu: Install the fd-find package, and create a symlink like this:" \
"sudo ln -s /usr/bin/fdfind /usr/local/bin/fd"
exit 1
fi
sudo fd --hidden --type directory -x chmod 777
sudo fd --hidden --type file -x chmod 666
sudo chmod 755 justfile docker/docker-entrypoint.sh scripts/cleanup_old_media_files/cleanup_old_media_files.py admin_site/manage.py
# Run arbitrary manage.py commands. Examples: makemigrations/migrate/showmigrations/shell_plus
managepy +COMMAND: (_verify-container-running django_container)
docker exec -i --tty {{django_container}} ./manage.py {{COMMAND}}
# Related to: https://docs.djangoproject.com/en/4.2/howto/upgrade-version/
# Checks for any deprecation warnings in your project
check-deprecation-warnings: (_verify-container-running django_container)
docker exec -i --tty {{django_container}} python -Wa manage.py test
# Useful if changing requirements.txt and ...?
recreate-django:
docker compose up --build
# Recreate the django database, replacing what you have with what's in the fixtures
recreate-db:
docker compose down --volumes
# Start the admin-site stack
run:
docker compose up
printf '%s' "If permissions fail, verify umask and/or manually check if the permissions differ on the file mentioned, e.g. initialize.py"
# Start the admin-site stack in the background and attach specifically to the django container - so python breakpoints work
run-debug:
docker compose up -d
docker attach {{django_container}}
# --no-obsolete removes unused translations, --add-location file is there to make diffs clearer by skipping line
# numbers, so a change early in views.py doesn't make makemessages update hundreds of line references
# TODO: makemessages sometimes suddenly makes changes to where it line wraps, making diffs hard to read. Seemingly there's
# no hard line wrap set, and the only option is to disable line wrap completely which doesn't seem ideal. Hopefully a
# future Django version provides a solution.
[doc("Run django's make-messages for translations, including translations for javascript files (djangojs)")]
translations-make-messages: (_verify-container-running django_container) fix-permissions
@just managepy makemessages --all --ignore venv --add-location file --no-obsolete
@just managepy makemessages --all --ignore venv --add-location file --no-obsolete -d djangojs
# Run django's compile-messages (usually after make-messages) for translations
translations-compile-messages: (_verify-container-running django_container)
@just managepy compilemessages --locale da --locale sv
# Replace all the fixtures (test data) with what you currently have in your local adminsite db
update-test-data: (_verify-container-running django_container)
docker compose exec -u 0 -T {{compose_django_service}} python manage.py dumpdata --indent 4 auth > dev-environment/system_fixtures/050_auth.json
docker compose exec -u 0 -T {{compose_django_service}} python manage.py dumpdata --indent 4 system > dev-environment/system_fixtures/100_system.json
docker compose exec -u 0 -T {{compose_django_service}} python manage.py dumpdata --indent 4 account > dev-environment/system_fixtures/150_account.json
docker compose exec -u 0 -T {{compose_django_service}} python manage.py dumpdata --indent 4 changelog > dev-environment/changelog_fixtures/100_changelog.json
# Create a graph of the django models to a file named models_graphed.png
graph-models: (_verify-container-running django_container)
# Tried using pip install instead but it kept complaining about missing graphviz binaries
docker exec -it -u 0 {{django_container}} apt-get update
docker exec -it -u 0 {{django_container}} apt-get install --assume-yes python3-pydotplus # alternately pytnho3-pygraphviz
docker exec -it -u 0 {{django_container}} pip install pydotplus
@just managepy graph_models -a -g -o /tmp/{{models_output_file_name}}
# docker cp is not part of docker compose, so can't docker compose exec that
docker cp {{django_container}}:/tmp/{{models_output_file_name}} {{models_output_file_name}}