-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathMakefile
171 lines (155 loc) · 4.79 KB
/
Makefile
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
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
## ----------------------------------------------------------------------
## The purpose of this Makefile is to simplify common development tasks.
## ----------------------------------------------------------------------
##
.PHONY:help
help: ## Show this help.
##
@sed -ne '/@sed/!s/##//p' $(MAKEFILE_LIST)
run: ## run the app in dev mode
##
## Usage:
## run the app
## Example:
## make run
go run ./cmd/main
build-ui: ## builds the ui
## allows for embedding the ui in the shippable binary
bash ./scripts/build_ui.sh
.PHONY:migration
migration: ## Create a new migration
## Create a new migration with name
## Usage:
## make migration name=<NAME>
## Arguments:
## <NAME> The name for the migration
## Example:
## make migration name=communication_log
##
ifdef name
migrate create -ext sql -dir dev/migrations -seq $(name)
else
@echo No name provided. Provide a name to make a migration
@echo Example:
@echo " make migration name=communication_log"
endif
.PHONY:migrate-up
migrate-up: ## Apply database migrations
## Apply all or N up migrations
## Usage:
## make migrate-up [n=<N>]
## Arguments:
## <N> The number of migrations to apply
## Example:
## make migrate-up
## or
## make migrate-up n=2
##
migrate -database ${DB_CONNECTION_STRING}?sslmode=disable -verbose -path dev/migrations up $(n)
.PHONY:migrate-down
migrate-down: ## Revert database migrations
## Apply all or N down migrations
## Usage:
## make migrate-down [n=<N>]
## Arguments:
## <N> The number of migrations to apply
## Example:
## make migrate-to version=2
## or
## make migrate-down n=2
##
migrate -database ${DB_CONNECTION_STRING}?sslmode=disable -verbose -path dev/migrations down $(n)
.PHONY:migrate-to
migrate-to: ## Migrate to the specified version
## Migrate to the specified database version
## Usage:
## make migrate-to version=<VERSION>
## Arguments:
## <VERSION> The version to migrate to
## Example:
## make migrate-to version=2
##
ifdef version
migrate -database ${DB_CONNECTION_STRING}?sslmode=disable -verbose -path dev/migrations goto $(version)
else
@echo No version provided. Provide a version to migrate to
@echo Example:
@echo " make migrate-to version=2"
endif
.PHONY:migrate-force
migrate-force: ## Force migrate to a database version
## Force migrate to the specified version to fix a dirty database version.
## Migrate to the specified database version
## Usage:
## make migrate-force version=<VERSION>
## Arguments:
## <VERSION> The version to migrate to
## Example:
## make migrate-force version=2
##
ifdef version
migrate -database ${DB_CONNECTION_STRING}?sslmode=disable -verbose -path dev/migrations force $(version)
else
@echo No version provided. Provide a version to force migrate
@echo Example:
@echo " make migrate-force version=2"
endif
.PHONY:seed
seed: ## Seed the db with member data and a test user
## Run a sql script file against postgres by specifying a script path
## Usage:
## make seed
## Example:
## make seed
##
go run ./test/generators/members.go 50
.PHONY:run-sql
run-sql: ## Run a sql script
## Run a sql script file against postgres by specifying a script path
## Usage:
## make run-sql script=<SCRIPT>
## Arguments:
## <SCRIPT> The path to the sql script to run
## Example:
## make run-sql script=test/postgres/myscript.sql
##
ifdef script
psql -Atx $(DB_CONNECTION_STRING) $(script)
else
@echo No script provided. Provide a script to run sql
@echo Example:
@echo " make run-sql script=test/postgres/myscript.sql"
endif
.PHONY:run-sql-command
run-sql-command: ## Run a sql command
## Run a sql command against postgres by specifying a command
## Usage:
## make run-sql-command command="<COMMAND>"
## Arguments:
## <COMMAND> The sql command to execute
## Example:
## make run-sql-command command="\copy membership.member_credit FROM 'test/postgres/seedData/member_credit.csv' DELIMITER ',' CSV HEADER;"
##
ifdef command
psql -Atx $(DB_CONNECTION_STRING) -c "$(command)"
else
@echo No command provided. Provide a command to run
@echo Example:
@echo " make run-sql-command command=\"\\\copy membership.member_credit FROM 'test/postgres/seedData/member_credit.csv' DELIMITER ',' CSV HEADER;\""
endif
.PHONY:swagger
swagger: ## Generate swagger doc
swagger generate spec -o ./api/openapi/swagger.json --scan-models
watch-ui: ## run ui in watch mode
## Usage: make watch-ui
npm --prefix=web start
serve-docs: ## serve-docs locally
## Usage: make serve-docs
bash ./scripts/serve-docs.sh
deploy-docs: ## deploy-docs to gh-pages
## Usage: make deploy-docs
bash ./scripts/deploy-docs.sh
clean:
rm -rf ./internal/ui/web/
mkdir ./internal/ui/web/
echo "this is a placeholder file/nthe ui should be copied to this dir" >> ./internal/ui/web/_blank_