130 lines
3.8 KiB
Makefile
130 lines
3.8 KiB
Makefile
SHELL := /bin/bash
|
|
|
|
NS ?= abhinavsingh
|
|
IMAGE_NAME ?= proxy.py
|
|
VERSION ?= v$(shell python -m proxy --version)
|
|
LATEST_TAG := $(NS)/$(IMAGE_NAME):latest
|
|
IMAGE_TAG := $(NS)/$(IMAGE_NAME):$(VERSION)
|
|
|
|
HTTPS_KEY_FILE_PATH := https-key.pem
|
|
HTTPS_CERT_FILE_PATH := https-cert.pem
|
|
HTTPS_CSR_FILE_PATH := https-csr.pem
|
|
HTTPS_SIGNED_CERT_FILE_PATH := https-signed-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 https-certificates ca-certificates autopep8 devtools
|
|
.PHONY: lib-version lib-clean lib-test lib-package lib-coverage lib-lint
|
|
.PHONY: lib-release-test lib-release lib-profile
|
|
.PHONY: container container-run container-release
|
|
.PHONY: dashboard dashboard-clean
|
|
|
|
all: lib-test
|
|
|
|
devtools:
|
|
pushd dashboard && npm run devtools && popd
|
|
|
|
autopep8:
|
|
autopep8 --recursive --in-place --aggressive examples
|
|
autopep8 --recursive --in-place --aggressive proxy
|
|
autopep8 --recursive --in-place --aggressive tests
|
|
autopep8 --recursive --in-place --aggressive setup.py
|
|
|
|
https-certificates:
|
|
# Generate server key
|
|
python -m proxy.common.pki gen_private_key \
|
|
--private-key-path $(HTTPS_KEY_FILE_PATH)
|
|
python -m proxy.common.pki remove_passphrase \
|
|
--private-key-path $(HTTPS_KEY_FILE_PATH)
|
|
# Generate server certificate
|
|
python -m proxy.common.pki gen_public_key \
|
|
--private-key-path $(HTTPS_KEY_FILE_PATH) \
|
|
--public-key-path $(HTTPS_CERT_FILE_PATH)
|
|
|
|
sign-https-certificates:
|
|
# Generate CSR request
|
|
python -m proxy.common.pki gen_csr \
|
|
--csr-path $(HTTPS_CSR_FILE_PATH) \
|
|
--private-key-path $(HTTPS_KEY_FILE_PATH) \
|
|
--public-key-path $(HTTPS_CERT_FILE_PATH)
|
|
# Sign CSR with CA
|
|
python -m proxy.common.pki sign_csr \
|
|
--csr-path $(HTTPS_CSR_FILE_PATH) \
|
|
--crt-path $(HTTPS_SIGNED_CERT_FILE_PATH) \
|
|
--hostname example.com \
|
|
--private-key-path $(CA_KEY_FILE_PATH) \
|
|
--public-key-path $(CA_CERT_FILE_PATH)
|
|
|
|
ca-certificates:
|
|
# Generate CA key
|
|
python -m proxy.common.pki gen_private_key \
|
|
--private-key-path $(CA_KEY_FILE_PATH)
|
|
python -m proxy.common.pki remove_passphrase \
|
|
--private-key-path $(CA_KEY_FILE_PATH)
|
|
# Generate CA certificate
|
|
python -m proxy.common.pki gen_public_key \
|
|
--private-key-path $(CA_KEY_FILE_PATH) \
|
|
--public-key-path $(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
|
|
python -m proxy.common.pki gen_private_key \
|
|
--private-key-path $(CA_SIGNING_KEY_FILE_PATH)
|
|
python -m proxy.common.pki remove_passphrase \
|
|
--private-key-path $(CA_SIGNING_KEY_FILE_PATH)
|
|
|
|
lib-version:
|
|
python version-check.py
|
|
|
|
lib-clean:
|
|
find . -name '*.pyc' -exec rm -f {} +
|
|
find . -name '*.pyo' -exec rm -f {} +
|
|
find . -name '*~' -exec rm -f {} +
|
|
rm -f .coverage
|
|
rm -rf htmlcov
|
|
rm -rf dist
|
|
rm -rf build
|
|
rm -rf proxy.py.egg-info
|
|
rm -rf .pytest_cache
|
|
rm -rf .hypothesis
|
|
|
|
lib-lint:
|
|
flake8 --ignore=W504 --max-line-length=127 --max-complexity=19 examples/ proxy/ tests/ setup.py
|
|
mypy --strict --ignore-missing-imports examples/ proxy/ tests/ setup.py
|
|
|
|
lib-test: lib-clean lib-version lib-lint
|
|
pytest -v tests/
|
|
|
|
lib-package: lib-clean lib-version
|
|
python setup.py sdist
|
|
|
|
lib-release-test: lib-package
|
|
twine upload --verbose --repository-url https://test.pypi.org/legacy/ dist/*
|
|
|
|
lib-release: lib-package
|
|
twine upload dist/*
|
|
|
|
lib-coverage:
|
|
pytest --cov=proxy --cov-report=html tests/
|
|
open htmlcov/index.html
|
|
|
|
lib-profile:
|
|
sudo py-spy record -o profile.svg -t -F -s -- python -m proxy
|
|
|
|
dashboard:
|
|
pushd dashboard && npm run build && popd
|
|
|
|
dashboard-clean:
|
|
if [[ -d dashboard/public ]]; then rm -rf dashboard/public; fi
|
|
|
|
container:
|
|
docker build -t $(LATEST_TAG) -t $(IMAGE_TAG) .
|
|
|
|
container-release:
|
|
docker push $(IMAGE_TAG)
|
|
docker push $(LATEST_TAG)
|
|
|
|
container-run:
|
|
docker run -it -p 8899:8899 --rm $(LATEST_TAG)
|