From 2b92548349ecf15ddc82e3901c63ceb7e8d33380 Mon Sep 17 00:00:00 2001 From: Paul Spooren Date: Sun, 11 Apr 2021 22:44:26 -1000 Subject: [PATCH] version: bump to 0.5.0 * move asu/__init__.py to asu/asu.py * add CI to publish releases to PyPi. * apply black style Signed-off-by: Paul Spooren --- .github/workflows/publish.yml | 31 +++++++++++++ README.md | 10 ++--- asu/__init__.py | 85 +---------------------------------- asu/asu.py | 84 ++++++++++++++++++++++++++++++++++ asu/common.py | 2 +- requirements.txt | 32 +++++++------ setup.py | 4 +- tests/conftest.py | 4 +- 8 files changed, 146 insertions(+), 106 deletions(-) create mode 100644 .github/workflows/publish.yml create mode 100644 asu/asu.py diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml new file mode 100644 index 00000000..4e60f4ba --- /dev/null +++ b/.github/workflows/publish.yml @@ -0,0 +1,31 @@ +name: Upload Python Package + +on: + release: + types: [created] + +jobs: + deploy: + + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v2 + + - name: Set up Python + uses: actions/setup-python@v2 + with: + python-version: '3.x' + + - name: Install dependencies + run: | + python -m pip install --upgrade pip + pip install setuptools wheel twine + + - name: Build and publish + env: + TWINE_USERNAME: ${{ secrets.PYPI_USERNAME }} + TWINE_PASSWORD: ${{ secrets.PYPI_PASSWORD }} + run: | + python setup.py sdist bdist_wheel + twine upload dist/* diff --git a/README.md b/README.md index 25cbf881..ed09c94f 100644 --- a/README.md +++ b/README.md @@ -64,9 +64,9 @@ Install *asu*: Start the server via the following commands: - export FLASK_APP=asu # set Flask app to asu - flask janitor update # download upstream profiles/packages - flask run # run development server + export FLASK_APP=asu.asu # set Flask app to asu + flask janitor update # download upstream profiles/packages + flask run # run development server Start the worker via the following comand: @@ -94,8 +94,8 @@ the dependencies: python3 -m venv . source bin/activate pip install -r requirements.txt - export FLASK_APP=asu # set Flask app to asu - export FLASK_DEBUG=1 # run Flask in debug mode (autoreload) + export FLASK_APP=asu.asu # set Flask app to asu + export FLASK_DEBUG=1 # run Flask in debug mode (autoreload) flask run ## API diff --git a/asu/__init__.py b/asu/__init__.py index 59dc303b..3d187266 100644 --- a/asu/__init__.py +++ b/asu/__init__.py @@ -1,84 +1 @@ -from pathlib import Path -from redis import Redis - -from flask import Flask, redirect, send_from_directory -from flask_cors import CORS - -import json -from os import getenv - - -def create_app(test_config: dict = None) -> Flask: - """Create the main Flask application - - Args: - test_config (dict): A dictionry containing a configuration during tests - - Returns: - Flask: The application - """ - - redis_host = getenv("REDIS_HOST", "localhost") - redis_port = getenv("REDIS_PORT", 6379) - - app = Flask(__name__, instance_relative_config=True) - app.config.from_mapping( - CA_PUBKEY=None, - STORE_PATH=app.instance_path + "/public/store", - JSON_PATH=app.instance_path + "/public/json", - CACHE_PATH=app.instance_path + "/cache/", - REDIS_CONN=Redis(host=redis_host, port=redis_port), - TESTING=False, - DEBUG=False, - UPSTREAM_URL="https://downloads.cdn.openwrt.org", - BRANCHES={}, - ) - - if not test_config: - for config_file in [ - "./config.py", - app.instance_path + "/config.py", - "/etc/asu/config.py", - ]: - if Path(config_file).exists(): - app.config.from_pyfile(config_file, silent=True) - else: - app.config.from_mapping(test_config) - - for option, value in app.config.items(): - if option.endswith("_PATH") and isinstance(value, str): - app.config[option] = Path(value) - app.config[option].mkdir(parents=True, exist_ok=True) - - Path(app.instance_path).mkdir(exist_ok=True, parents=True) - - CORS(app, resources={r"/api/*": {"origins": "*"}}) - - # only serve files in DEBUG/TESTING mode - # production should use nginx for static files - if app.config["DEBUG"] or app.config["TESTING"]: - - @app.route("/") - @app.route("/") - def root(path="index.html"): - return send_from_directory(Path(app.instance_path) / "public", path) - - else: - - @app.route("/") - def root(path="index.html"): - return redirect("https://github.com/aparcar/asu/#api") - - from . import janitor - - app.register_blueprint(janitor.bp) - - from . import api - - app.register_blueprint(api.bp) - - (app.config["JSON_PATH"] / "branches.json").write_text( - json.dumps(app.config["BRANCHES"]) - ) - - return app +__version__ = "0.5.0" diff --git a/asu/asu.py b/asu/asu.py new file mode 100644 index 00000000..59dc303b --- /dev/null +++ b/asu/asu.py @@ -0,0 +1,84 @@ +from pathlib import Path +from redis import Redis + +from flask import Flask, redirect, send_from_directory +from flask_cors import CORS + +import json +from os import getenv + + +def create_app(test_config: dict = None) -> Flask: + """Create the main Flask application + + Args: + test_config (dict): A dictionry containing a configuration during tests + + Returns: + Flask: The application + """ + + redis_host = getenv("REDIS_HOST", "localhost") + redis_port = getenv("REDIS_PORT", 6379) + + app = Flask(__name__, instance_relative_config=True) + app.config.from_mapping( + CA_PUBKEY=None, + STORE_PATH=app.instance_path + "/public/store", + JSON_PATH=app.instance_path + "/public/json", + CACHE_PATH=app.instance_path + "/cache/", + REDIS_CONN=Redis(host=redis_host, port=redis_port), + TESTING=False, + DEBUG=False, + UPSTREAM_URL="https://downloads.cdn.openwrt.org", + BRANCHES={}, + ) + + if not test_config: + for config_file in [ + "./config.py", + app.instance_path + "/config.py", + "/etc/asu/config.py", + ]: + if Path(config_file).exists(): + app.config.from_pyfile(config_file, silent=True) + else: + app.config.from_mapping(test_config) + + for option, value in app.config.items(): + if option.endswith("_PATH") and isinstance(value, str): + app.config[option] = Path(value) + app.config[option].mkdir(parents=True, exist_ok=True) + + Path(app.instance_path).mkdir(exist_ok=True, parents=True) + + CORS(app, resources={r"/api/*": {"origins": "*"}}) + + # only serve files in DEBUG/TESTING mode + # production should use nginx for static files + if app.config["DEBUG"] or app.config["TESTING"]: + + @app.route("/") + @app.route("/") + def root(path="index.html"): + return send_from_directory(Path(app.instance_path) / "public", path) + + else: + + @app.route("/") + def root(path="index.html"): + return redirect("https://github.com/aparcar/asu/#api") + + from . import janitor + + app.register_blueprint(janitor.bp) + + from . import api + + app.register_blueprint(api.bp) + + (app.config["JSON_PATH"] / "branches.json").write_text( + json.dumps(app.config["BRANCHES"]) + ) + + return app diff --git a/asu/common.py b/asu/common.py index e8c68c9e..264f4a9d 100644 --- a/asu/common.py +++ b/asu/common.py @@ -75,7 +75,7 @@ def get_request_hash(req: dict) -> str: req.get("profile", "").replace(",", "_"), get_packages_hash(req.get("packages", "")), get_manifest_hash(req.get("packages_versions", {})), - str(req.get("diff_packages", False)) + str(req.get("diff_packages", False)), ] return get_str_hash(" ".join(request_array), 12) diff --git a/requirements.txt b/requirements.txt index 405e452d..834dc9fe 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,14 +1,18 @@ -Click -Flask-Cors -Flask -Jinja2 -MarkupSafe -PyNaCl -Werkzeug -cffi -itsdangerous -pycparser -redis -requests -rq -six +certifi==2020.12.5 +cffi==1.14.5 +chardet==4.0.0 +click==7.1.2 +Flask==1.1.2 +Flask-Cors==3.0.10 +idna==2.10 +itsdangerous==1.1.0 +Jinja2==2.11.3 +MarkupSafe==1.1.1 +pycparser==2.20 +PyNaCl==1.4.0 +redis==3.5.3 +requests==2.25.1 +rq==1.8.0 +six==1.15.0 +urllib3==1.26.4 +Werkzeug==1.0.1 diff --git a/setup.py b/setup.py index c3b97df8..bf581d1c 100644 --- a/setup.py +++ b/setup.py @@ -3,6 +3,8 @@ from setuptools import find_packages, setup from os.path import dirname, abspath, join +from asu import __version__ + with io.open("README.md", "rt", encoding="utf8") as f: readme = f.read() @@ -14,7 +16,7 @@ setup( name="asu", - version="0.4.1", + version=__version__, url="https://github.com/aparcar/asu", maintainer="Paul Spooren", maintainer_email="mail@aparcar.org", diff --git a/tests/conftest.py b/tests/conftest.py index 65c499de..97d5bebe 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -37,7 +37,9 @@ def redis(): "profiles-SNAPSHOT-SNAPSHOT", mapping={"testprofile": "testtarget/testsubtarget"}, ) - r.hset("mapping-SNAPSHOT-SNAPSHOT", mapping={"testvendor,testprofile": "testprofile"}) + r.hset( + "mapping-SNAPSHOT-SNAPSHOT", mapping={"testvendor,testprofile": "testprofile"} + ) r.sadd("targets-SNAPSHOT", "testtarget/testsubtarget") yield r