-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathquickstart.sh
executable file
·117 lines (94 loc) · 3.74 KB
/
quickstart.sh
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
#!/usr/bin/env bash
set -euo pipefail
cd "$(dirname "$0")"
source scripts/utils.sh
# Assert we're running on a recent bash
if [[ "$BASH_VERSINFO" -lt 4 ]]; then
color_print $red "This script requires GNU bash version 4 or later.
Please upgrade your system utilities and try again."
exit 1
fi
assert_outside_container
# Assert not root
if (( EUID == 0 )); then
color_print $red "Please run this script without sudo."
# Because sudo is used internally when required.
# Otherwise regular files would be created with owner as root
# and would require sudo later at various points.
# Also HOST_UID/GID would be set to 0 (although this could be handled with SUDO_UID/GID).
exit 1
fi
# Check if the host OS does support file execute permissions. If this is not
# the case, abort this script.
assert_fs_supports_exec_permission
# This solution is linux-based. macOS users are free to use and play with it but warn them
# to avoid unnecessary support requests.
if [[ "$OSTYPE" == darwin* ]]; then
message="WARNING: Django Project Template has not been thoroughly tested on
macOS systems. Expect things to break while running on this configuration.
There is NO official support for this platform."
color_print "$yellow" "$message"
fi
# Check this project has been properly set up.
if ! scripts/check-project-name.sh; then
exit 1
fi
# Stop this project's postgres so port is free:
has_compose_plugin && [ -f .env ] && \
echo "docker compose stop postgres || true" | newgrp docker
scripts/assert-15432-free.sh
# Create a local .env file if it does not exist
scripts/env-init-dev.sh
# Install docker and compose plugin
scripts/docker-install.sh
# Build and start the containers
title_print 'Building containers...'
if [[ ! -e docker-compose.override.yml ]]; then
color_print "$cyan" "Linking compose override to dev version..."
ln -s docker/docker-compose.dev.yml docker-compose.override.yml
fi
scripts/add-aliases.sh
echo "docker compose build" | newgrp docker
scripts/set-vscode-settings.sh
# Finally create and start the containers:
echo "docker compose up --detach" | newgrp docker
prompt "\n\nWould you like to run migrations? [Y/n]" "Y"
input_lower=${input,,}
if [[ $input_lower == y ]]; then
echo "docker compose exec -T django dj migrate" | newgrp docker
echo "docker compose exec -T django dj migrate --database logs" | newgrp docker
superuserexists_ret=0
echo "docker compose exec -T django dj superuserexists" | newgrp docker \
|| superuserexists_ret=$?
if (( superuserexists_ret == 1 )); then
prompt "\n\nWould you like to create a superuser? [Y/n]" "Y"
input_lower=${input,,}
if [[ $input_lower == y ]]; then
# Black magic: normally newgrp reads commands from pipe,
# so can't get keyboard answers to createsuperuser. https://www.scosales.com/ta/kb/104260.html
# (Less convoluted alternative: just run with sudo haha)
exec 3<&0
echo "exec \
docker compose exec django dj createsuperuser \
0<&3 3<&-" | newgrp docker
echo -e "\n"
fi
fi
prompt "\n\nWould you like to run updategroups? [Y/n]" "Y"
input_lower=${input,,}
if [[ $input_lower == y ]]; then
echo "docker compose exec django dj updategroups" | newgrp docker
fi
fi
# Done
color_print $green 'Completed!'
if [ -f quickstart-messages.log ]; then
color_print $yellow "$(cat quickstart-messages.log)"
rm quickstart-messages.log
fi
color_print $green 'After rebooting if required,
- Open this folder in VSCode
- Click "Install" when prompted to install the recommended extensions for this repository
- Then click "Reopen in Container" when prompted (or press F1 and choose "Reopen in Container")
Then in a VSCode terminal run "npm start",
and in another terminal, run "djs" and access the site at http://localhost:8000'