-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathMakefile
77 lines (58 loc) · 2.64 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
PY?=python3
PELICAN?=pelican
PELICANOPTS=
BASEDIR=$(CURDIR)
INPUTDIR=$(BASEDIR)/content
OUTPUTDIR=$(BASEDIR)/output
CONFFILE=$(BASEDIR)/pelicanconf.py
PUBLISHCONF=$(BASEDIR)/publishconf.py
SITE_NAME=codependentcodr
USER_NAME=pzelnip
REPO_NAME=$(USER_NAME)/www.codependentcodr.com
SHA := $(shell git rev-parse --short HEAD)
DEPLOY_TIME := $(shell date -u +"%Y-%m-%dT%H-%M-%SZ_%s")
HOST := $(shell hostname)
RELATIVE ?= 0
ifeq ($(RELATIVE), 1)
PELICANOPTS += --relative-urls
endif
html:
$(PELICAN) $(INPUTDIR) -o $(OUTPUTDIR) -s $(CONFFILE) $(PELICANOPTS)
if test -d $(BASEDIR)/extra; then cp $(BASEDIR)/extra/* $(OUTPUTDIR)/; fi
clean:
[ ! -d $(OUTPUTDIR) ] || rm -rf $(OUTPUTDIR)
docker images | grep $(SITE_NAME) | awk {'print $3'} | xargs docker rmi
regenerate:
$(PELICAN) $(INPUTDIR) -o $(OUTPUTDIR) -s $(CONFFILE) $(PELICANOPTS)
if test -d $(BASEDIR)/extra; then cp $(BASEDIR)/extra/* $(OUTPUTDIR)/; fi
publish:
$(PELICAN) $(INPUTDIR) -o $(OUTPUTDIR) -s $(PUBLISHCONF) $(PELICANOPTS)
if test -d $(BASEDIR)/extra; then cp $(BASEDIR)/extra/* $(OUTPUTDIR)/; fi
devserver: regenerate
$(PELICAN) --listen
cleanbranches:
git remote | xargs -n 1 git fetch -v --prune $1
git branch --merged | egrep -v "(^\*|mainline|dev)" | xargs git branch -d
tag:
echo "tagging: $(DEPLOY_TIME)_$(SHA)"
git tag "$(DEPLOY_TIME)_$(SHA)"
git push https://${GH_TOKEN}@github.com/$(REPO_NAME) $(DEPLOY_TIME)_$(SHA)
dockerbuild:
echo "$$DOCKER_PASSWORD" | docker login -u "$$DOCKER_USERNAME" --password-stdin
docker build -t $(SITE_NAME):latest .
dockerrun: dockerbuild
docker run -it --rm $(SITE_NAME):latest /bin/sh
dockerpush:
echo "$(DOCKER_PASSWORD)" | docker login -u "$(DOCKER_USERNAME)" --password-stdin
docker tag $(SITE_NAME) $(USER_NAME)/$(SITE_NAME):latest
docker tag $(SITE_NAME) $(USER_NAME)/$(SITE_NAME):$(SHA)
docker push $(USER_NAME)/$(SITE_NAME):latest
docker push $(USER_NAME)/$(SITE_NAME):$(SHA)
slackpost:
curl -X POST --data-urlencode "payload={\"channel\": \"#$(SITE_NAME)\", \"username\": \"$(USER)@$(HOST)\", \"text\": \"Deployed $(SITE_NAME), $(SHA). https://www.$(SITE_NAME).com\", \"icon_emoji\": \":rocket:\"}" https://hooks.slack.com/services/$(SLACK_TOKEN)
cfinvalidate:
aws cloudfront create-invalidation --distribution-id ER3YIY14W87BX --paths '/*.html' '/' '/feeds/all.atom.xml'
s3_upload:
docker run -e AWS_ACCESS_KEY_ID=$(AWS_ACCESS_KEY_ID) -e AWS_SECRET_ACCESS_KEY=$(AWS_SECRET_ACCESS_KEY) --rm -it -w /build $(SITE_NAME):latest ./s3_push.sh
deploy: dockerbuild s3_upload tag dockerpush slackpost
.PHONY: html clean regenerate devserver stopserver publish s3_upload cleanbranches tag dockerbuild dockerrun dockerpush slackpost cfinvalidate deploy