Merge branch 'main' into snyk-fix-4bb5414255ab6a79b6697d6e1969ccff
This commit is contained in:
commit
5eecd59645
@ -5,4 +5,4 @@ ADMIN_EMAIL=""
|
|||||||
ADMIN_FIRST_NAME=""
|
ADMIN_FIRST_NAME=""
|
||||||
BOT_NAME=""
|
BOT_NAME=""
|
||||||
N8N_WEBHOOK_URL=""
|
N8N_WEBHOOK_URL=""
|
||||||
WEBEX_API_KEY=""
|
WEBEX_API_KEY=""
|
||||||
|
2
.github/CODEOWNERS
vendored
2
.github/CODEOWNERS
vendored
@ -1 +1 @@
|
|||||||
* @luketainton
|
* @luketainton
|
||||||
|
34
.github/renovate.json
vendored
34
.github/renovate.json
vendored
@ -1,47 +1,47 @@
|
|||||||
{
|
{
|
||||||
|
"assignAutomerge": true,
|
||||||
|
"assigneesFromCodeOwners": true,
|
||||||
|
"baseBranches": [
|
||||||
|
"main"
|
||||||
|
],
|
||||||
|
"dependencyDashboardAutoclose": true,
|
||||||
"extends": [
|
"extends": [
|
||||||
"config:base",
|
"config:base",
|
||||||
":semanticCommits",
|
":semanticCommits",
|
||||||
":semanticCommitTypeAll(fix)"
|
":semanticCommitTypeAll(fix)"
|
||||||
],
|
],
|
||||||
"baseBranches": [
|
|
||||||
"next"
|
|
||||||
],
|
|
||||||
"platformCommit": true,
|
|
||||||
"dependencyDashboardAutoclose": true,
|
|
||||||
"assignAutomerge": true,
|
|
||||||
"assigneesFromCodeOwners": true,
|
|
||||||
"rebaseWhen": "behind-base-branch",
|
|
||||||
"rollbackPrs": true,
|
|
||||||
"labels": [
|
"labels": [
|
||||||
"dependencies"
|
"dependencies"
|
||||||
],
|
],
|
||||||
"packageRules": [
|
"packageRules": [
|
||||||
{
|
{
|
||||||
|
"labels": [
|
||||||
|
"linting"
|
||||||
|
],
|
||||||
"matchPackagePatterns": [
|
"matchPackagePatterns": [
|
||||||
"black",
|
"black",
|
||||||
"pylint"
|
"pylint"
|
||||||
],
|
|
||||||
"labels": [
|
|
||||||
"linting"
|
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
"labels": [
|
||||||
|
"unit-tests"
|
||||||
|
],
|
||||||
"matchPackagePatterns": [
|
"matchPackagePatterns": [
|
||||||
"coverage",
|
"coverage",
|
||||||
"pytest"
|
"pytest"
|
||||||
],
|
|
||||||
"labels": [
|
|
||||||
"unit-tests"
|
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"platformCommit": true,
|
||||||
|
"rebaseWhen": "behind-base-branch",
|
||||||
|
"rollbackPrs": true,
|
||||||
"vulnerabilityAlerts": {
|
"vulnerabilityAlerts": {
|
||||||
|
"commitMessagePrefix": "[SECURITY] ",
|
||||||
"enabled": true,
|
"enabled": true,
|
||||||
"labels": [
|
"labels": [
|
||||||
"security"
|
"security"
|
||||||
],
|
],
|
||||||
"commitMessagePrefix": "[SECURITY] ",
|
|
||||||
"prCreation": "immediate"
|
"prCreation": "immediate"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
64
.github/workflows-old/release.yml
vendored
Normal file
64
.github/workflows-old/release.yml
vendored
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
name: Build
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [main]
|
||||||
|
|
||||||
|
env:
|
||||||
|
REGISTRY: ghcr.io
|
||||||
|
IMAGE_NAME: ${{ github.repository }}
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
release:
|
||||||
|
name: Release
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
outputs:
|
||||||
|
new_tag: ${{ steps.tag_version.outputs.new_tag }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
- name: Bump version and push tag
|
||||||
|
id: tag_version
|
||||||
|
uses: mathieudutour/github-tag-action@v6.2
|
||||||
|
with:
|
||||||
|
github_token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
default_bump: minor
|
||||||
|
- name: Create a GitHub release
|
||||||
|
uses: ncipollo/release-action@v1
|
||||||
|
with:
|
||||||
|
tag: ${{ steps.tag_version.outputs.new_tag }}
|
||||||
|
name: ${{ steps.tag_version.outputs.new_tag }}
|
||||||
|
body: ${{ steps.tag_version.outputs.changelog }}
|
||||||
|
generateReleaseNotes: true
|
||||||
|
|
||||||
|
publish:
|
||||||
|
name: GitHub Container Registry
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
needs: release
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
packages: write
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
- name: Login to GitHub Container Registry
|
||||||
|
run: echo ${{ secrets.GITHUB_TOKEN }} | docker login ${{ env.REGISTRY }} -u ${{ github.actor }} --password-stdin
|
||||||
|
- name: Build image for GitHub Package Registry
|
||||||
|
run: |
|
||||||
|
docker build . --file Dockerfile \
|
||||||
|
--build-arg "version=${{ needs.release.outputs.new_tag }}" \
|
||||||
|
--tag ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ needs.release.outputs.new_tag }} \
|
||||||
|
--tag ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:latest
|
||||||
|
- name: Push image to GitHub Package Registry
|
||||||
|
run: |
|
||||||
|
docker push ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:latest
|
||||||
|
docker push ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ needs.release.outputs.new_tag }}
|
||||||
|
|
||||||
|
# deploy:
|
||||||
|
# name: Update Portainer Deployment
|
||||||
|
# runs-on: ubuntu-latest
|
||||||
|
# needs: publish
|
||||||
|
# steps:
|
||||||
|
# - uses: fjogeleit/http-request-action@v1
|
||||||
|
# with:
|
||||||
|
# url: ${{ secrets.PORTAINER_WEBHOOK_URL }}
|
||||||
|
# method: POST
|
||||||
|
# timeout: 60000
|
||||||
|
# preventFailureOnNoResponse: "true"
|
67
.github/workflows/release.yml
vendored
67
.github/workflows/release.yml
vendored
@ -1,57 +1,18 @@
|
|||||||
name: Build
|
name: Release
|
||||||
on:
|
on:
|
||||||
push:
|
workflow_dispatch:
|
||||||
branches: [main]
|
schedule:
|
||||||
|
- cron: "0 9 * * 0"
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
release:
|
create_release:
|
||||||
name: Release
|
name: Create Release
|
||||||
runs-on: ubuntu-latest
|
uses: luketainton/gha-workflows/.github/workflows/create-release.yml@main
|
||||||
outputs:
|
|
||||||
new_tag: ${{ steps.tag_version.outputs.new_tag }}
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
- name: Bump version and push tag
|
|
||||||
id: tag_version
|
|
||||||
uses: mathieudutour/github-tag-action@v6.2
|
|
||||||
with:
|
|
||||||
github_token: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
default_bump: minor
|
|
||||||
- name: Create a GitHub release
|
|
||||||
uses: ncipollo/release-action@v1
|
|
||||||
with:
|
|
||||||
tag: ${{ steps.tag_version.outputs.new_tag }}
|
|
||||||
name: ${{ steps.tag_version.outputs.new_tag }}
|
|
||||||
body: ${{ steps.tag_version.outputs.changelog }}
|
|
||||||
generateReleaseNotes: true
|
|
||||||
|
|
||||||
publish:
|
create_docker:
|
||||||
name: GitHub Container Registry
|
name: Create Docker Image
|
||||||
runs-on: ubuntu-latest
|
needs: create_release
|
||||||
needs: release
|
if: ${{ needs.create_release.outputs.success == 'true' }}
|
||||||
steps:
|
uses: luketainton/gha-workflows/.github/workflows/build-push-attest-docker.yml@main
|
||||||
- uses: actions/checkout@v4
|
with:
|
||||||
- name: Login to GitHub Container Registry
|
release: ${{ needs.create_release.outputs.release_name }}
|
||||||
run: echo ${{ secrets.GHCR_ACCESS_TOKEN }} | docker login ghcr.io -u luketainton --password-stdin
|
|
||||||
- name: Build image for GitHub Package Registry
|
|
||||||
run: |
|
|
||||||
docker build . --file Dockerfile \
|
|
||||||
--build-arg "version=${{ needs.release.outputs.new_tag }}" \
|
|
||||||
--tag ghcr.io/luketainton/roboluke-tasks:${{ needs.release.outputs.new_tag }} \
|
|
||||||
--tag ghcr.io/luketainton/roboluke-tasks:latest
|
|
||||||
- name: Push image to GitHub Package Registry
|
|
||||||
run: |
|
|
||||||
docker push ghcr.io/luketainton/roboluke-tasks:latest
|
|
||||||
docker push ghcr.io/luketainton/roboluke-tasks:${{ needs.release.outputs.new_tag }}
|
|
||||||
|
|
||||||
deploy:
|
|
||||||
name: Update Portainer Deployment
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
needs: publish
|
|
||||||
steps:
|
|
||||||
- uses: fjogeleit/http-request-action@v1
|
|
||||||
with:
|
|
||||||
url: ${{ secrets.PORTAINER_WEBHOOK_URL }}
|
|
||||||
method: POST
|
|
||||||
timeout: 60000
|
|
||||||
preventFailureOnNoResponse: "true"
|
|
||||||
|
60
.pre-commit-config.yaml
Normal file
60
.pre-commit-config.yaml
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
fail_fast: false
|
||||||
|
|
||||||
|
minimum_pre_commit_version: 3.8.0
|
||||||
|
|
||||||
|
default_install_hook_types: [pre-commit, commit-msg]
|
||||||
|
|
||||||
|
default_language_version:
|
||||||
|
python: python3.11
|
||||||
|
|
||||||
|
repos:
|
||||||
|
- repo: https://github.com/pre-commit/pre-commit-hooks
|
||||||
|
rev: v4.6.0
|
||||||
|
hooks:
|
||||||
|
- id: trailing-whitespace
|
||||||
|
- id: mixed-line-ending
|
||||||
|
- id: end-of-file-fixer
|
||||||
|
- id: requirements-txt-fixer
|
||||||
|
- id: check-yaml
|
||||||
|
- id: check-added-large-files
|
||||||
|
- id: check-ast
|
||||||
|
- id: check-docstring-first
|
||||||
|
- id: check-json
|
||||||
|
- id: check-merge-conflict
|
||||||
|
- id: check-toml
|
||||||
|
- id: check-xml
|
||||||
|
- id: detect-private-key
|
||||||
|
- id: no-commit-to-branch
|
||||||
|
- id: requirements-txt-fixer
|
||||||
|
- id: name-tests-test
|
||||||
|
args: [--pytest-test-first]
|
||||||
|
- id: pretty-format-json
|
||||||
|
args: [--autofix]
|
||||||
|
|
||||||
|
- repo: https://github.com/astral-sh/ruff-pre-commit
|
||||||
|
rev: v0.5.6
|
||||||
|
hooks:
|
||||||
|
- id: ruff-format # Run the formatter.
|
||||||
|
- id: ruff # Run the linter.
|
||||||
|
args: [--fix]
|
||||||
|
|
||||||
|
- repo: https://github.com/pycqa/isort
|
||||||
|
rev: 5.13.2
|
||||||
|
hooks:
|
||||||
|
- id: isort
|
||||||
|
|
||||||
|
- repo: https://github.com/pre-commit/pygrep-hooks
|
||||||
|
rev: v1.10.0
|
||||||
|
hooks:
|
||||||
|
- id: python-use-type-annotations
|
||||||
|
|
||||||
|
- repo: https://github.com/asottile/pyupgrade
|
||||||
|
rev: v3.17.0
|
||||||
|
hooks:
|
||||||
|
- id: pyupgrade
|
||||||
|
|
||||||
|
- repo: https://github.com/compilerla/conventional-pre-commit
|
||||||
|
rev: v3.4.0
|
||||||
|
hooks:
|
||||||
|
- id: conventional-pre-commit
|
||||||
|
stages: [commit-msg]
|
@ -1,18 +1,18 @@
|
|||||||
#!/usr/bin/env python3
|
#!/usr/bin/env python3
|
||||||
|
|
||||||
from zoneinfo import ZoneInfo
|
|
||||||
|
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
|
from zoneinfo import ZoneInfo
|
||||||
|
|
||||||
|
|
||||||
def timestamp_to_date(timestamp: int) -> str:
|
def timestamp_to_date(timestamp: int) -> str:
|
||||||
"""Convert timestamp to date.
|
"""Convert timestamp to date.
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
timestamp (int): Timestamp to convert.
|
timestamp (int): Timestamp to convert.
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
str: Date in the format YYYY-MM-DD.
|
str: Date in the format YYYY-MM-DD.
|
||||||
"""
|
"""
|
||||||
return datetime.fromtimestamp(timestamp=timestamp, tz=ZoneInfo("UTC")).strftime("%Y-%m-%d")
|
return datetime.fromtimestamp(timestamp=timestamp, tz=ZoneInfo("UTC")).strftime(
|
||||||
|
"%Y-%m-%d"
|
||||||
|
)
|
||||||
|
@ -6,10 +6,10 @@ from app.utils.config import config
|
|||||||
|
|
||||||
def __n8n_post(data: dict) -> bool:
|
def __n8n_post(data: dict) -> bool:
|
||||||
"""Post data to N8N webhook URL.
|
"""Post data to N8N webhook URL.
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
data (dict): Data to post to webhook URL.
|
data (dict): Data to post to webhook URL.
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
bool: True if successful, else False.
|
bool: True if successful, else False.
|
||||||
"""
|
"""
|
||||||
@ -26,13 +26,13 @@ def __n8n_post(data: dict) -> bool:
|
|||||||
|
|
||||||
def submit_task(summary, description, completion_date, requestor) -> bool:
|
def submit_task(summary, description, completion_date, requestor) -> bool:
|
||||||
"""Submit task to N8N webhook URL.
|
"""Submit task to N8N webhook URL.
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
summary (str): Summary of task.
|
summary (str): Summary of task.
|
||||||
description (str): Description of task.
|
description (str): Description of task.
|
||||||
completion_date (str): Completion date of task.
|
completion_date (str): Completion date of task.
|
||||||
requestor (str): Requestor of task.
|
requestor (str): Requestor of task.
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
bool: True if successful, else False.
|
bool: True if successful, else False.
|
||||||
"""
|
"""
|
||||||
@ -49,10 +49,10 @@ def submit_task(summary, description, completion_date, requestor) -> bool:
|
|||||||
|
|
||||||
def get_tasks(requestor) -> bool:
|
def get_tasks(requestor) -> bool:
|
||||||
"""Get tasks from N8N webhook URL.
|
"""Get tasks from N8N webhook URL.
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
requestor (str): Requestor of tasks.
|
requestor (str): Requestor of tasks.
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
bool: True if successful, else False.
|
bool: True if successful, else False.
|
||||||
"""
|
"""
|
||||||
|
@ -7,4 +7,4 @@ services:
|
|||||||
dockerfile: Dockerfile
|
dockerfile: Dockerfile
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
env_file: .env
|
env_file: .env
|
||||||
...
|
...
|
||||||
|
@ -4,3 +4,4 @@ isort
|
|||||||
pylint
|
pylint
|
||||||
pylint-exit
|
pylint-exit
|
||||||
pytest
|
pytest
|
||||||
|
zipp>=3.19.1 # not directly required, pinned by Snyk to avoid a vulnerability
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
appdirs==1.4.4
|
appdirs==1.4.4
|
||||||
astroid==3.2.2
|
astroid==3.3.2
|
||||||
attrs==23.2.0
|
attrs==24.2.0
|
||||||
autopep8==2.3.1
|
autopep8==2.3.1
|
||||||
backoff==2.2.1
|
backoff==2.2.1
|
||||||
certifi==2024.6.2
|
certifi==2024.7.4
|
||||||
cfgv==3.4.0
|
cfgv==3.4.0
|
||||||
charset-normalizer==3.3.2
|
charset-normalizer==3.3.2
|
||||||
click==8.1.7
|
click==8.1.7
|
||||||
@ -13,8 +13,8 @@ distlib==0.3.8
|
|||||||
filelock==3.15.4
|
filelock==3.15.4
|
||||||
future==1.0.0
|
future==1.0.0
|
||||||
humanfriendly==10.0
|
humanfriendly==10.0
|
||||||
identify==2.5.36
|
identify==2.6.0
|
||||||
idna==3.7
|
idna==3.8
|
||||||
iniconfig==2.0.0
|
iniconfig==2.0.0
|
||||||
lazy-object-proxy==1.10.0
|
lazy-object-proxy==1.10.0
|
||||||
mccabe==0.7.0
|
mccabe==0.7.0
|
||||||
@ -25,23 +25,24 @@ pathspec==0.12.1
|
|||||||
platformdirs==4.2.2
|
platformdirs==4.2.2
|
||||||
pluggy==1.5.0
|
pluggy==1.5.0
|
||||||
py==1.11.0
|
py==1.11.0
|
||||||
pycodestyle==2.12.0
|
pycodestyle==2.12.1
|
||||||
PyJWT==2.8.0
|
PyJWT==2.9.0
|
||||||
pyparsing==3.1.2
|
pyparsing==3.1.4
|
||||||
python-dateutil==2.9.0.post0
|
python-dateutil==2.9.0.post0
|
||||||
python-dotenv==1.0.1
|
python-dotenv==1.0.1
|
||||||
PyYAML==6.0.1
|
PyYAML==6.0.2
|
||||||
requests==2.32.3
|
requests==2.32.3
|
||||||
requests-toolbelt==1.0.0
|
requests-toolbelt==1.0.0
|
||||||
sentry-sdk==2.7.1
|
sentry-sdk==2.13.0
|
||||||
six==1.16.0
|
six==1.16.0
|
||||||
toml==0.10.2
|
toml==0.10.2
|
||||||
tomli==2.0.1
|
tomli==2.0.1
|
||||||
tomlkit==0.12.5
|
tomlkit==0.13.2
|
||||||
urllib3==2.2.2
|
urllib3==2.2.2
|
||||||
virtualenv==20.26.3
|
virtualenv==20.26.3
|
||||||
webex-bot==0.5.1
|
webex-bot==0.5.2
|
||||||
webexteamssdk==1.6.1
|
webexteamssdk==1.6.1
|
||||||
websockets==11.0.3
|
websockets==11.0.3
|
||||||
wrapt==1.16.0
|
wrapt==1.16.0
|
||||||
xmltodict==0.13.0
|
xmltodict==0.13.0
|
||||||
|
zipp>=3.19.1 # not directly required, pinned by Snyk to avoid a vulnerability
|
||||||
|
Loading…
Reference in New Issue
Block a user