# Incluir las variables de entorno mkfile_path := $(abspath $(lastword $(MAKEFILE_LIST))) root_dir := $(patsubst %/,%,$(dir $(mkfile_path))) include $(root_dir)/.env delegate := athshe assets := package.json yarn.lock $(shell find app/assets/ app/javascript/ -type f) alpine_version := 3.13 hain ?= ../haini.sh/haini.sh export public/packs/manifest.json.br: $(assets) $(hain) 'cd /Sutty/sutty; PANEL_URL=https://panel.sutty.nl RAILS_ENV=production NODE_ENV=production bundle exec rake assets:precompile assets:clean' assets: public/packs/manifest.json.br test/%_test.rb: always $(hain) 'cd /Sutty/sutty; bundle exec rake test TEST="$@" RAILS_ENV=test' test: always $(hain) 'cd /Sutty/sutty; bundle exec rake test' serve: /etc/hosts $(hain) 'cd /Sutty/sutty; bundle exec rails s -b "ssl://0.0.0.0:3000?key=../sutty.local/domain/$(SUTTY).key&cert=../sutty.local/domain/$(SUTTY).crt"' # make rails args="db:migrate" rails: $(hain) 'cd /Sutty/sutty; bundle exec rails $(args)' rake: $(hain) 'cd /Sutty/sutty; bundle exec rake $(args)' # Servir JS con el dev server. # Esto acelera la compilaciĆ³n del javascript, tiene que correrse por separado # de serve. serve-js: /etc/hosts $(hain) 'cd /Sutty/sutty; bundle exec ./bin/webpack-dev-server' # Limpiar los archivos de testeo clean: rm -rf _sites/test-* _deploy/test-* # Generar la imagen Docker build: assets time docker build --build-arg="RAILS_MASTER_KEY=`cat config/master.key`" -t sutty/sutty . docker tag sutty/sutty:latest sutty:keep save: time docker save sutty/sutty:latest | ssh root@$(delegate).sutty.nl docker load date +%F | xargs git tag -f @echo -e "\a" # Crear el directorio donde se almacenan las gemas binarias ../gems/: mkdir -p $@ gem_dir := $(shell readlink -f ../gems) gem_cache_dir := $(gem_dir)/cache gem_binary_dir := $(gem_dir)/$(alpine_version) ifeq ($(MAKECMDGOALS),build-gems) gems := $(shell bundle show --paths | xargs -I {} sh -c 'find {}/ext/ -name extconf.rb &>/dev/null && basename {}') gems := $(patsubst %-x86_64-linux,%,$(gems)) gems := $(patsubst %,$(gem_cache_dir)/%.gem,$(gems)) gems_musl := $(patsubst $(gem_cache_dir)/%.gem,$(gem_binary_dir)/%-x86_64-linux-musl.gem,$(gems)) endif $(gem_binary_dir)/%-x86_64-linux-musl.gem: @docker run \ -v $(gem_dir):/srv/gems \ -v `readlink -f ~/.ccache`:/home/builder/.ccache \ -e HTTP_BASIC_USER=$(HTTP_BASIC_USER) \ -e HTTP_BASIC_PASSWORD=$(HTTP_BASIC_PASSWORD) \ -e GEM=`echo $(notdir $*) | sed -re "s/-[^-]+$$//"` \ -e VERSION=`echo $(notdir $*) | sed -re "s/.*-([^-]+)$$/\1/"` \ -e JOBS=2 \ --rm -it \ sutty/gem-compiler:latest || echo "No se pudo compilar $*" # Compilar todas las gemas binarias y subirlas a gems.sutty.nl para que # al crear el contenedor no tengamos que compilarlas cada vez build-gems: $(gems_musl) cached_gems = $(wildcard $(gem_dir)/cache/*.gem) rebuild_gems = $(patsubst $(gem_dir)/cache/%.gem,$(gem_dir)/$(alpine_version)/%-x86_64-linux-musl.gem,$(cached_gems)) rebuild-gems: $(rebuild_gems) dirs := $(patsubst %,root/%,data sites deploy public) $(dirs): mkdir -p $@ app/assets/fonts/forkawesome-webfont.woff2: fa.txt which glyphhanger || npm i -g glyphhanger grep -v "^#" fa.txt | sed "s/^/U+/" | cut -d " " -f 1 | tr "\n" "," | xargs -rI {} glyphhanger --subset=node_modules/fork-awesome/fonts/forkawesome-webfont.ttf --formats=woff2 --whitelist="{}" mv node_modules/fork-awesome/fonts/forkawesome-webfont-subset.woff2 $@ fa: app/assets/fonts/forkawesome-webfont.woff2 ## Fork Awesome ota: assets sudo chgrp -R 82 public/ rsync -av --delete-after public/ athshe:/srv/sutty/srv/http/data/_public/ # Hotfixes ota-rb: umask 022; git format-patch $(commit) scp ./0*.patch root@athshe.sutty.nl:/tmp/ rm ./0*.patch /etc/hosts: always @echo "Chequeando si es necesario agregar el dominio local $(SUTTY)" @grep -q " $(SUTTY)$$" $@ || echo -e "127.0.0.1 $(SUTTY)\n::1 $(SUTTY)" | sudo tee -a $@ @grep -q " api.$(SUTTY)$$" $@ || echo -e "127.0.0.1 api.$(SUTTY)\n::1 api.$(SUTTY)" | sudo tee -a $@ @grep -q " panel.$(SUTTY)$$" $@ || echo -e "127.0.0.1 panel.$(SUTTY)\n::1 panel.$(SUTTY)" | sudo tee -a $@ .PHONY: always