-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #3 from merschformann/merschformann/fix-dependabot…
…-alert-change-project-setup Fix security issue in opencv dependency, rework project structure and workflows, fix overflow
- Loading branch information
Showing
9 changed files
with
232 additions
and
121 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,26 +1,128 @@ | ||
name: publish | ||
|
||
on: | ||
release: | ||
types: [created] | ||
workflow_dispatch: | ||
inputs: | ||
VERSION: | ||
description: "The version to release" | ||
required: true | ||
IS_PRE_RELEASE: | ||
description: "It IS a pre-release" | ||
required: true | ||
default: false | ||
type: boolean | ||
|
||
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/* | ||
bump: # This job is used to bump the version and create a release | ||
runs-on: ubuntu-latest | ||
env: | ||
VERSION: ${{ inputs.VERSION }} | ||
GH_TOKEN: ${{ github.token }} | ||
SSH_AUTH_SOCK: /tmp/ssh_agent.sock | ||
permissions: | ||
contents: write | ||
steps: | ||
- name: set up Python | ||
uses: actions/setup-python@v5 | ||
with: | ||
python-version: "3.12" | ||
|
||
- name: install dependencies | ||
run: | | ||
pip install --upgrade pip | ||
pip install build hatch | ||
- name: configure git with the bot credentials | ||
run: | | ||
mkdir -p ~/.ssh | ||
ssh-keyscan github.com >> ~/.ssh/known_hosts | ||
ssh-agent -a $SSH_AUTH_SOCK > /dev/null | ||
ssh-add - <<< "${{ secrets.BOT_SSH_KEY }}" | ||
echo "${{ secrets.BOT_SIGNING_KEY }}" > ~/.ssh/signing.key | ||
chmod 600 ~/.ssh/signing.key | ||
git config --global user.name "Merschbotmann" | ||
git config --global user.email "bot.merschformann@gmail.com" | ||
git config --global gpg.format ssh | ||
git config --global user.signingkey ~/.ssh/signing.key | ||
git clone git@github.com:merschformann/brickmos.git | ||
- name: upgrade version with hatch | ||
run: hatch version ${{ env.VERSION }} | ||
working-directory: ./brickmos | ||
|
||
- name: commit new version | ||
run: | | ||
git add brickmos/__about__.py | ||
git commit -S -m "Bump version to $VERSION" | ||
git push | ||
git tag $VERSION | ||
git push origin $VERSION | ||
working-directory: ./brickmos | ||
|
||
- name: create release | ||
run: | | ||
PRERELEASE_FLAG="" | ||
if [ ${{ inputs.IS_PRE_RELEASE }} = true ]; then | ||
PRERELEASE_FLAG="--prerelease" | ||
fi | ||
gh release create $VERSION \ | ||
--verify-tag \ | ||
--generate-notes \ | ||
--title $VERSION $PRERELEASE_FLAG | ||
working-directory: ./brickmos | ||
|
||
- name: ensure passing build | ||
run: python -m build | ||
working-directory: ./brickmos | ||
|
||
publish: # This job is used to publish the release to PyPI/TestPyPI | ||
runs-on: ubuntu-latest | ||
needs: bump | ||
strategy: | ||
matrix: | ||
include: | ||
- target-env: pypi | ||
target-url: https://pypi.org/p/brickmos | ||
- target-env: testpypi | ||
target-url: https://test.pypi.org/p/brickmos | ||
environment: | ||
name: ${{ matrix.target-env }} | ||
url: ${{ matrix.target-url }} | ||
permissions: | ||
contents: read | ||
id-token: write # This is required for trusted publishing to PyPI | ||
steps: | ||
- name: git clone main | ||
uses: actions/checkout@v4 | ||
with: | ||
ref: main | ||
|
||
- name: set up Python | ||
uses: actions/setup-python@v5 | ||
with: | ||
python-version: "3.12" | ||
|
||
- name: install dependencies | ||
run: | | ||
pip install --upgrade pip | ||
pip install build hatch | ||
- name: build binary wheel and source tarball | ||
run: python -m build | ||
|
||
- name: Publish package distributions to PyPI | ||
if: ${{ matrix.target-env == 'pypi' }} | ||
uses: pypa/gh-action-pypi-publish@release/v1 | ||
with: | ||
packages-dir: ./dist | ||
|
||
- name: Publish package distributions to TestPyPI | ||
if: ${{ matrix.target-env == 'testpypi' }} | ||
uses: pypa/gh-action-pypi-publish@release/v1 | ||
with: | ||
repository-url: https://test.pypi.org/legacy/ | ||
packages-dir: ./dist |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,6 +4,7 @@ | |
|
||
# Ignore general python stuff | ||
venv/ | ||
.venv/ | ||
__pycache__/ | ||
.pytest_cache/ | ||
*.egg-info/ | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
__version__ = "v0.0.4" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
[build-system] | ||
build-backend = "hatchling.build" | ||
requires = ["hatchling >= 1.13.0"] | ||
|
||
[project] | ||
authors = [ | ||
{ email = "marius.merschformann@gmail.com", name = "Marius Merschformann" } | ||
] | ||
maintainers = [ | ||
{ email = "marius.merschformann@gmail.com", name = "Marius Merschformann" } | ||
] | ||
classifiers = [ | ||
"License :: OSI Approved :: MIT License", | ||
"Operating System :: OS Independent", | ||
"Programming Language :: Python :: 3", | ||
] | ||
dependencies = [ | ||
"opencv-python>=4.8.1.78", | ||
] | ||
description = "brickmos is a humble Lego mosaic generator." | ||
dynamic = [ | ||
"version", | ||
] | ||
keywords = [ | ||
"lego", | ||
"mosaic", | ||
"bricklink", | ||
] | ||
license = { file = "LICENSE" } | ||
name = "brickmos" | ||
readme = "README.md" | ||
requires-python = ">=3.9" | ||
|
||
[project.urls] | ||
Homepage = "https://github.com/merschformann/brickmos" | ||
Repository = "https://github.com/merschformann/brickmos" | ||
|
||
[project.scripts] | ||
brickmos = "brickmos.brickify:main" | ||
|
||
[tool.ruff] | ||
target-version = "py312" | ||
select = [ | ||
"E", # pycodestyle errors | ||
"W", # pycodestyle warnings | ||
"F", # pyflakes | ||
"I", # isort | ||
"C", # flake8-comprehensions | ||
"B", # flake8-bugbear | ||
"UP", # pyupgrade | ||
] | ||
line-length = 120 | ||
[tool.ruff.lint.mccabe] | ||
max-complexity = 15 | ||
|
||
[tool.hatch.version] | ||
path = "brickmos/__about__.py" |
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.