proxy.py/Makefile

78 lines
2.1 KiB
Makefile
Raw Normal View History

2018-12-22 15:08:04 +00:00
SHELL := /bin/bash
NS ?= abhinavsingh
IMAGE_NAME ?= proxy.py
VERSION ?= v$(shell python proxy.py --version)
LATEST_TAG := $(NS)/$(IMAGE_NAME):latest
2018-12-22 15:08:04 +00:00
IMAGE_TAG := $(NS)/$(IMAGE_NAME):$(VERSION)
HTTPS_KEY_FILE_PATH := https-key.pem
HTTPS_CERT_FILE_PATH := https-cert.pem
CA_KEY_FILE_PATH := ca-key.pem
CA_CERT_FILE_PATH := ca-cert.pem
CA_SIGNING_KEY_FILE_PATH := ca-signing-key.pem
.PHONY: all clean test package test-release release coverage lint autopep8
.PHONY: container run-container release-container https-certificates ca-certificates
2013-12-23 21:51:45 +00:00
all: clean test
clean:
find . -name '*.pyc' -exec rm -f {} +
find . -name '*.pyo' -exec rm -f {} +
find . -name '*~' -exec rm -f {} +
rm -f .coverage
2019-09-27 20:42:53 +00:00
rm -rf htmlcov dist build
2013-12-23 21:51:45 +00:00
test:
python -m unittest tests
2013-12-23 21:51:45 +00:00
2019-02-09 02:57:44 +00:00
package: clean
python setup.py sdist bdist_wheel
2013-12-23 21:51:45 +00:00
2019-02-09 02:57:44 +00:00
test-release: package
2019-09-27 20:42:53 +00:00
twine upload --verbose --repository-url https://test.pypi.org/legacy/ dist/*
2018-12-22 15:08:04 +00:00
2019-02-09 02:57:44 +00:00
release: package
twine upload dist/*
coverage:
coverage3 run tests.py
coverage3 html
open htmlcov/index.html
lint:
mypy --strict --ignore-missing-imports proxy.py plugin_examples.py tests.py
flake8 --ignore=E501,W504 proxy.py
flake8 --ignore=E501,W504 tests.py
autopep8:
autopep8 --recursive --in-place --aggressive proxy.py
autopep8 --recursive --in-place --aggressive tests.py
autopep8 --recursive --in-place --aggressive plugin_examples.py
2019-02-09 02:57:44 +00:00
container:
docker build -t $(LATEST_TAG) -t $(IMAGE_TAG) .
run-container:
docker run -it -p 8899:8899 --rm $(LATEST_TAG)
release-container:
docker push $(IMAGE_TAG)
https-certificates:
# Generate server key
openssl genrsa -out $(HTTPS_KEY_FILE_PATH) 2048
# Generate server certificate
openssl req -new -x509 -days 3650 -key $(HTTPS_KEY_FILE_PATH) -out $(HTTPS_CERT_FILE_PATH)
ca-certificates:
# Generate CA key
openssl genrsa -out $(CA_KEY_FILE_PATH) 2048
# Generate CA certificate
openssl req -new -x509 -days 3650 -key $(CA_KEY_FILE_PATH) -out $(CA_CERT_FILE_PATH)
# Generate key that will be used to generate domain certificates on the fly
# Generated certificates are then signed with CA certificate / key generated above
openssl genrsa -out $(CA_SIGNING_KEY_FILE_PATH) 2048