Compare commits

..

97 Commits

Author SHA1 Message Date
58a827b1aa Rebase to Python 3.9.6 - Alpine 3.14 2021-07-06 22:31:54 +00:00
semantic-release-bot
adb4cb6060 chore(release): 1.7.6 [skip ci]
## [1.7.6](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/compare/v1.7.5...v1.7.6) (2021-05-10)

### Build

* Change docker driver to overlay2 ([13cb517](13cb51706b))
2021-05-10 17:00:45 +00:00
13cb51706b Build: Change docker driver to overlay2 2021-05-10 16:58:56 +00:00
e83a7bbfae Don't semantic release on tags 2021-05-09 06:18:31 +00:00
semantic-release-bot
49a8693fc0 chore(release): 1.7.5 [skip ci]
## [1.7.5](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/compare/v1.7.4...v1.7.5) (2021-05-09)

### Build

* push all tags instead of just latest ([b143379](b143379f20))
2021-05-09 03:55:28 +00:00
b143379f20 Build: push all tags instead of just latest 2021-05-09 03:53:17 +00:00
semantic-release-bot
534a8b805e chore(release): 1.7.4 [skip ci]
## [1.7.4](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/compare/v1.7.3...v1.7.4) (2021-05-09)

### Build

* cleanup long install line ([de1d073](de1d073c6d))

### ci

* Add git to node image ([6eb2d01](6eb2d0145e))
* change semantic release image to alpine to save space, updated to node 16 ([b1ca049](b1ca0497b0))
* Update DinD base to 20.10.6 and semantic release to node:15.  Also pin sonar-scanner-cli to 4.6 ([589fb4f](589fb4fcf7))
2021-05-09 03:44:55 +00:00
de1d073c6d Build: cleanup long install line 2021-05-09 03:42:44 +00:00
d3e34871aa Update .releaserc.yml 2021-05-09 03:35:18 +00:00
3e8aead632 Update .releaserc.yml 2021-05-09 03:27:45 +00:00
9498554758 Merge branch 'update-semantic-release' into 'master'
Update semantic release

See merge request erichardson/py-eagle-mqtt!4
2021-05-09 03:24:02 +00:00
c2167d5d97 Update semantic release 2021-05-09 03:24:02 +00:00
6eb2d0145e ci: Add git to node image 2021-05-09 03:01:59 +00:00
b1ca0497b0 ci: change semantic release image to alpine to save space, updated to node 16 2021-05-09 02:48:42 +00:00
589fb4fcf7 ci: Update DinD base to 20.10.6 and semantic release to node:15. Also pin sonar-scanner-cli to 4.6 2021-05-09 02:41:44 +00:00
51213c51e0 Merge branch 'add-trivy-scanner' into 'master'
Add Trivy scanner stage

See merge request erichardson/py-eagle-mqtt!3
2021-05-09 02:37:51 +00:00
da20bbe045 Add Trivy scanner stage 2021-05-09 02:37:51 +00:00
bb17ad6135 Change Base directory to just the python stuff 2021-04-30 00:38:42 +00:00
40c7d020d2 Add sonarqube-check 2021-04-30 00:26:12 +00:00
9b5adba3ed Add sonar-project.properties 2021-04-30 00:19:32 +00:00
semantic-release-bot
73740ffa39 chore(release): 1.7.3 [skip ci]
## [1.7.3](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/compare/v1.7.2...v1.7.3) (2021-04-12)

### Bug Fixes

* Empty commit to get recent changes into build (last commit should've been labeled this) ([e513752](e513752c46))
2021-04-12 22:11:57 +00:00
Evan Richardson
e513752c46 fix: Empty commit to get recent changes into build (last commit should've been labeled this) 2021-04-12 14:53:10 -07:00
evanrich
cfb392dc6a refactor: Add new docker labels to better identify container properties 2021-04-09 17:14:51 -07:00
f3f78c4ad5 docs: Fix badges formatting, also add docker version and # of pulls 2021-04-08 23:58:44 +00:00
d1723db798 docs: Add build status 2021-04-08 23:49:27 +00:00
ba8486017a docs: add dependency badge 2021-04-08 22:50:03 +00:00
37d8b17076 docs: add semantic-release badge 2021-04-08 22:29:53 +00:00
semantic-release-bot
da83d88229 chore(release): 1.7.2 [skip ci]
## [1.7.2](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/compare/v1.7.1...v1.7.2) (2021-04-08)

### Bug Fixes

* Cleanup CHANGELOG.md since using new semantic-release format ([a72ac7a](a72ac7a1df))
* fix asset info for git commit ([00c95c4](00c95c42ea))
2021-04-08 22:17:41 +00:00
evanrich
00c95c42ea fix: fix asset info for git commit 2021-04-08 15:16:21 -07:00
evanrich
a72ac7a1df fix: Cleanup CHANGELOG.md since using new semantic-release format
fix: Remove package-lock.json file (only commit CHANGELOG.md)
2021-04-08 15:11:32 -07:00
semantic-release-bot
ffbde1eff5 chore(release): 1.7.1 [skip ci]
## [1.7.1](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/compare/v1.7.0...v1.7.1) (2021-04-08)

### Bug Fixes

* refactor Dockerfile to improve build ([40ac8c5](40ac8c5ada))
2021-04-08 22:06:11 +00:00
1e58da7572 Merge branch 'dev' into 'master'
fix: refactor Dockerfile to improve build

See merge request erichardson/py-eagle-mqtt!2
2021-04-08 22:04:41 +00:00
evanrich
40ac8c5ada fix: refactor Dockerfile to improve build 2021-04-08 14:59:58 -07:00
evanrich
2c49af0f32 Merge branch 'master' of https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt 2021-04-08 14:47:21 -07:00
evanrich
a4c715068d Fix: Commit 3.9.4-alpine3.13 base change 2021-04-08 14:44:39 -07:00
91b6464e8c build: add missing npm install for git plugin 2021-04-08 21:34:14 +00:00
b9ad4e8ec1 build: add git plugin to sematic-release config file 2021-04-08 21:31:46 +00:00
evanrich
ac8c039b33 feat: remove astral again to try and fix semver (again?) 2021-04-07 15:12:30 -07:00
Evan Richardson
46cc86ed0b revert: add astral back in due to mistake in release system 2021-04-07 15:08:19 -07:00
Evan Richardson
3db668ff98 feat: remove astral package, since it actually isn't being used 2021-04-07 15:00:27 -07:00
evanrich
99661058bd Add Semver release mechanism 2021-04-06 20:59:01 -07:00
evanrich
575e2fe6ce Fix tagging issue 2021-04-06 15:31:09 -07:00
evanrich
10c5443914 Fix dockerhub push issue 2021-04-06 15:30:14 -07:00
evanrich
058638eb83 Add README
update CHANGELOG
remove extra section of CI file
2021-04-06 15:21:31 -07:00
evanrich
8cb86673ed 1.6.8 release 2021-04-06 15:18:26 -07:00
evanrich
6b500de774 Added CHANGELOG
Refactored ci file
2021-04-06 15:17:26 -07:00
6b26f12b9a Pin base image version 2021-04-04 03:35:12 +00:00
08b304be38 Update README.md 2021-04-04 01:24:44 +00:00
Evan Richardson
e6f6342027 Add missing defusedxml package 2021-04-03 18:19:15 -07:00
Evan Richardson
197c762909 Add ignore rule for assert test 2021-04-02 15:00:44 -07:00
e4a88ea26b Fix SAST errors 2021-04-02 21:39:06 +00:00
cadbfac97e Replace xml.etree with defusedxml for SAST scans 2021-04-02 21:36:56 +00:00
0f2098d884 Merge branch 'set-sast-config-1' into 'master'
Set .gitlab-ci.yml to enable or configure SAST

See merge request erichardson/py-eagle-mqtt!1
2021-04-02 21:27:26 +00:00
8f25241cc8 refactor ci file 2021-04-02 21:25:57 +00:00
0390fd17e7 Update .gitlab-ci.yml 2021-04-02 21:20:22 +00:00
11e271a368 Set .gitlab-ci.yml to enable or configure SAST 2021-04-02 21:14:57 +00:00
30d300c7fd Update Dockerfile 2021-03-05 05:42:56 +00:00
1cf7d117c7 Update .gitlab-ci.yml file 2021-03-04 22:55:39 +00:00
7e2fd67729 Update .gitlab-ci.yml file 2021-03-04 22:52:26 +00:00
245ebc8c2d Update .gitlab-ci.yml file 2021-03-04 22:47:24 +00:00
119f854de5 Update .gitlab-ci.yml file 2021-03-04 22:40:46 +00:00
Evan Richardson
c2925e425d Merge branch 'master' of https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt 2021-03-04 14:36:29 -08:00
Evan Richardson
b394aa9ee8 Add stage to push to docker hub 2021-03-04 14:36:24 -08:00
e6231d837f Update .gitlab-ci.yml file 2021-03-04 22:18:21 +00:00
Evan Richardson
dfb700aae4 move base image and variables out 2021-03-04 14:17:46 -08:00
Evan Richardson
e9b52ec54f Forgot docker build directory 2021-03-04 14:14:02 -08:00
Evan Richardson
695c4b3655 Add push stage 2021-03-04 14:12:49 -08:00
Evan Richardson
7b80ce48e1 Add feature flag to override registry 2021-03-04 14:04:59 -08:00
Evan Richardson
ff72639dbb Fix variable name for MQTT_PASSWORD
update deployment api version
2021-03-04 14:02:30 -08:00
096225b537 Update dependencies to latest version 2021-03-04 21:51:04 +00:00
eb78e4bd7c Update .gitlab-ci.yml file 2021-03-03 02:09:17 +00:00
44ff9a7c9a Update .gitlab-ci.yml file 2021-03-03 02:08:10 +00:00
2ae6ccabb9 Update .gitlab-ci.yml file 2021-03-03 01:44:28 +00:00
df9bbd1d47 Update .gitlab-ci.yml file 2021-03-03 01:41:34 +00:00
41c82e52b6 Update .gitlab-ci.yml file 2021-03-03 01:41:19 +00:00
44fef1d926 Update .gitlab-ci.yml file 2021-03-03 01:40:03 +00:00
f0a1401018 Update .gitlab-ci.yml file 2021-03-03 01:37:09 +00:00
54a838c2da Update .gitlab-ci.yml file 2021-03-03 01:19:39 +00:00
550ba6df4a Update .gitlab-ci.yml file 2021-03-03 01:18:28 +00:00
620ca572ff Update .gitlab-ci.yml file 2021-03-03 01:13:41 +00:00
4674578d88 Update .gitlab-ci.yml file 2021-03-03 01:12:58 +00:00
9913d0bcb3 Update .gitlab-ci.yml file 2021-03-03 01:10:18 +00:00
b24144cb4b Update .gitlab-ci.yml file 2021-03-03 01:08:55 +00:00
f568d5ba5b Update .gitlab-ci.yml file 2021-03-03 01:08:52 +00:00
6e3673fced Update .gitlab-ci.yml file 2021-03-03 01:07:00 +00:00
f1a87650f0 Update .gitlab-ci.yml file 2021-03-03 01:04:41 +00:00
29a221f449 Update .gitlab-ci.yml file 2021-03-03 01:03:01 +00:00
2f556ceadc Update .gitlab-ci.yml file 2021-03-03 01:01:50 +00:00
5e7d61c499 Update .gitlab-ci.yml file 2021-03-03 01:00:37 +00:00
7f2a4e40d6 Update .gitlab-ci.yml file 2021-03-03 00:58:53 +00:00
2052bcb96c Update .gitlab-ci.yml file 2021-03-03 00:55:10 +00:00
9f4cfceee7 Update .gitlab-ci.yml file 2021-03-03 00:55:06 +00:00
88ac743dda Update .gitlab-ci.yml file 2021-03-03 00:55:03 +00:00
631ee88812 Update .gitlab-ci.yml 2021-03-03 00:53:57 +00:00
4565a6f7ba Update .gitlab-ci.yml 2019-12-21 03:18:46 +00:00
ede4bb616d Update .gitlab-ci.yml 2019-12-21 03:16:55 +00:00
f30ae06f45 Update .gitlab-ci.yml 2019-12-21 03:14:49 +00:00
12 changed files with 328 additions and 54 deletions

View File

@@ -1,36 +1,147 @@
# This file is a template, and might need editing before it works on your project. # You can override the included template(s) by including variable overrides
# Official docker image. # See https://docs.gitlab.com/ee/user/application_security/sast/#customizing-the-sast-settings
image: docker:latest # Note that environment variables can be set in several places
# See https://docs.gitlab.com/ee/ci/variables/#priority-of-environment-variables
services:
- docker:18.09-dind
stages: stages:
- build - test
- build
- push_local
- release
- push_dockerhub
variables: .docker_base:
DOCKER_HOST: tcp://localhost:2375 image: docker:20.10.6-dind
DOCKER_DRIVER: overlay2 services:
#IMAGE_TAG: erichardson/py-eagle-mqtt:$CI_COMMIT_TAG - name: docker:20.10.6-dind
IMAGE_TAG: $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG command: ["--tls=false"]
variables:
before_script: DOCKER_DRIVER: overlay2
- docker version DOCKER_HOST: tcp://127.0.0.1:2375/
- docker info DOCKER_TLS_CERTDIR: ""
- docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY IMAGE_TAG: "$CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG"
FF_GITLAB_REGISTRY_HELPER_IMAGE: 1
before_script:
- docker version
- docker info
- docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY
build: build:
only: extends:
- tags - .docker_base
stage: build stage: build
script: script:
- docker build -t $IMAGE_TAG -t $CI_COMMIT_TAG ./Docker/ - docker pull $CI_REGISTRY_IMAGE:latest || true
- docker push $IMAGE_TAG $CI_COMMIT_TAG - >
docker build
--pull
--cache-from $CI_REGISTRY_IMAGE:latest
--tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA
--build-arg BUILD_DATE=$(date -u +'%Y-%m-%dT%H:%M:%SZ')
--build-arg VCS_REF=$CI_COMMIT_SHORT_SHA
./Docker/
- docker push $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA
#build: push local:
# stage: build extends:
# script: - .docker_base
# - docker build --pull -t "$CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG" . stage: push_local
# - docker push "$CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG" variables:
# except: GIT_STRATEGY: none
# - master only:
- master
script:
- docker pull $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA
- docker tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA $CI_REGISTRY_IMAGE:latest
- docker push $CI_REGISTRY_IMAGE:latest
push dockerhub:
extends:
- .docker_base
stage: push_dockerhub
variables:
GIT_STRATEGY: none
CI_DOCKERHUB_IMAGE: index.docker.io/evanrich/py-eagle-mqtt
CI_DOCKERHUB_REGISTRY: docker.io
only:
- tags
script:
- docker pull $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA
- docker tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA $CI_DOCKERHUB_IMAGE:$CI_COMMIT_REF_NAME
- docker tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA $CI_DOCKERHUB_IMAGE:latest
- docker login -u "$CI_DOCKERHUB_USER" -p "$CI_DOCKERHUB_PASSWORD" $CI_DOCKERHUB_REGISTRY
- docker push $CI_DOCKERHUB_IMAGE --all-tags
release:
image: node:16-alpine3.13
stage: release
only:
refs:
- master
- alpha
# This matches maintenance branches
- /^(([0-9]+)\.)?([0-9]+)\.x/
# This matches pre-releases
- /^([0-9]+)\.([0-9]+)\.([0-9]+)(?:-([0-9A-Za-z-]+(?:\.[0-9A-Za-z-]+)*))?(?:\+[0-9A-Za-z-]+)?$/
except:
refs:
- tags
script:
- touch CHANGELOG.md
- apk add --no-cache git
- npm install @semantic-release/gitlab @semantic-release/changelog
@semantic-release/git conventional-changelog-eslint
- npx semantic-release
artifacts:
paths:
- CHANGELOG.md
sast:
stage: test
include:
- template: Security/SAST.gitlab-ci.yml
sonarqube-check:
stage: test
image:
name: sonarsource/sonar-scanner-cli:4.6
entrypoint: [""]
variables:
SONAR_USER_HOME: "${CI_PROJECT_DIR}/.sonar" # Defines the location of the analysis task cache
GIT_DEPTH: "0" # Tells git to fetch all the branches of the project, required by the analysis task
cache:
key: "${CI_JOB_NAME}"
paths:
- .sonar/cache
script:
- sonar-scanner
allow_failure: true
only:
- master # or the name of your main branch
- branches
trivy:
stage: test
extends:
- .docker_base
before_script:
- export TRIVY_VERSION=$(wget -qO - "https://api.github.com/repos/aquasecurity/trivy/releases/latest" | grep '"tag_name":' | sed -E 's/.*"v([^"]+)".*/\1/')
- echo $TRIVY_VERSION
- wget --no-verbose https://github.com/aquasecurity/trivy/releases/download/v${TRIVY_VERSION}/trivy_${TRIVY_VERSION}_Linux-64bit.tar.gz -O - | tar -zxvf -
allow_failure: true
script:
# Build image
- docker build -t $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA ./Docker/
# Build report
- ./trivy --exit-code 0 --cache-dir .trivycache/ --no-progress --format template --template "@contrib/gitlab.tpl" -o gl-container-scanning-report.json image $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA
# Print report
- ./trivy --exit-code 0 --cache-dir .trivycache/ --no-progress --severity HIGH image $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA
# Fail on severe vulnerabilities
- ./trivy --exit-code 1 --cache-dir .trivycache/ --severity CRITICAL --no-progress image $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA
cache:
paths:
- .trivycache/
# Enables https://docs.gitlab.com/ee/user/application_security/container_scanning/ (Container Scanning report is available on GitLab EE Ultimate or GitLab.com Gold)
artifacts:
reports:
container_scanning: gl-container-scanning-report.json

View File

@@ -0,0 +1,6 @@
[bandit]
[[bandit.ruleset]]
disable = true
[bandit.ruleset.identifier]
type = "bandit_test_id"
value = "B101"

45
.releaserc.yml Normal file
View File

@@ -0,0 +1,45 @@
plugins:
- - "@semantic-release/commit-analyzer"
- preset: eslint
releaseRules:
- tag: Breaking
release: major
- tag: Build
release: patch
- tag: Chore
release: minor
- tag: Fix
release: patch
- tag: New
release: minor
- tag: Update
release: minor
- tag: Upgrade
release: minor
- - "@semantic-release/release-notes-generator"
- preset: eslint
releaseRules:
- tag: Breaking
release: major
- tag: Build
release: patch
- tag: Chore
release: minor
- tag: Fix
release: patch
- tag: New
release: minor
- tag: Update
release: minor
- tag: Upgrade
release: minor
- - "@semantic-release/changelog"
- changelogFile: CHANGELOG.md
- "@semantic-release/gitlab"
- - "@semantic-release/git"
- assets: CHANGELOG.md
branches:
- "master"
- "+([0-9])?(.{+([0-9]),x}).x"
- name: "alpha"
prerelease: "alpha"

102
CHANGELOG.md Normal file
View File

@@ -0,0 +1,102 @@
## [1.7.6](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/compare/v1.7.5...v1.7.6) (2021-05-10)
### Build
* Change docker driver to overlay2 ([13cb517](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/commit/13cb51706b97f25486f62dd6985903e834d28ee2))
## [1.7.5](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/compare/v1.7.4...v1.7.5) (2021-05-09)
### Build
* push all tags instead of just latest ([b143379](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/commit/b143379f2018f410677a9646234e7b483d9277d3))
## [1.7.4](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/compare/v1.7.3...v1.7.4) (2021-05-09)
### Build
* cleanup long install line ([de1d073](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/commit/de1d073c6daf5d43fb7d9b7dafddd3b0cbcffc9b))
### ci
* Add git to node image ([6eb2d01](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/commit/6eb2d0145eff50c3243a364d821e769ae2ee06c9))
* change semantic release image to alpine to save space, updated to node 16 ([b1ca049](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/commit/b1ca0497b0b51e0c50ca1e5f99e5c8abd4224d53))
* Update DinD base to 20.10.6 and semantic release to node:15. Also pin sonar-scanner-cli to 4.6 ([589fb4f](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/commit/589fb4fcf7841d3c5f08327d7fb5d5c107562ed6))
## [1.7.3](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/compare/v1.7.2...v1.7.3) (2021-04-12)
### Bug Fixes
* Empty commit to get recent changes into build (last commit should've been labeled this) ([e513752](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/commit/e513752c46cc0b3beb93530f6549661d67196905))
## [1.7.2](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/compare/v1.7.1...v1.7.2) (2021-04-08)
### Bug Fixes
* Cleanup CHANGELOG.md since using new semantic-release format ([a72ac7a](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/commit/a72ac7a1df91cb2231e38e8bbceb5ccf9c93328a))
* fix asset info for git commit ([00c95c4](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/commit/00c95c42ea98921a1b2da9d2069d41e8e32f34f5))
## [1.7.1](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/compare/v1.7.0...v1.7.1) (2021-04-08)
### Bug Fixes
* refactor Dockerfile to improve build ([40ac8c5](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/commit/40ac8c5ada9b993f53b72dcc14b2d9b7cd183e2f))
## [1.6.10] - 2021-04-06
### Fixed
- Fix docker tagging issue
## [1.6.9] - 2021-04-06
### Fixed
- Remove release-cli section of CI file
- Add updated README.md
## [1.6.8] - 2021-04-06
### Changed
- Fixed slight issue with tagging
## [1.6.7] - 2021-04-06
### Changed
- Updated base image to Python 3.9.4-alpine3.13
- Moved changes to this file
### Removed
- Changelog from README.md
## [1.6.6] - 2021-04-03
### Added
- Added CI/CD pipeline to project
### Changed
- Moved project to my own personal Gitlab server for CI/CD pipelines as well as to run security scans on the container image and code
- Updated base image to Python 3.9.3-alpine3.12
## [Unversioned history]
- 2019-07-24: Rebase to python 3.7.4-alpine3.10, update bottle to 0.12.17
- 2019-04-12: Rebase to python 3.7.3-alpine3.9
- 2019-03-08: Rebase to python 3.7.2-alpine3.9, update bottle and astral versions to latest
- 2019-01-03: Rebase to python 3.7.2-alpine3.8, changed logging level to Info (should output to /var/log/tHome/eagle.log)
- 2018-09-10: Ported to Python3, Added pricing info. Merged into master branch

View File

@@ -1,17 +1,26 @@
FROM python:3.7.4-alpine3.10 FROM python:3.9.6-alpine3.14
LABEL maintainer="Evan Richardson (evanrich81[at]gmail.com)" LABEL maintainer="Evan Richardson (evanrich81[at]gmail.com)"
LABEL version="1.5.1"
ARG BUILD_DATE
ARG VCS_REF
LABEL org.label-schema.schema-version="1.0"
LABEL org.label-schema.build-date=$BUILD_DATE
LABEL org.label-schema.name="evanrich/py-eagle-mqtt"
LABEL org.label-schema.description="Python Rainforest Eagle to MQTT Application"
LABEL org.label-schema.vcs-url="https://github.com/evanrich/py-eagle-mqtt"
LABEL org.label-schema.vcs-ref=$VCS_REF
LABEL org.label-schema.vendor="Evan Richardson"
LABEL org.label-schema.docker.cmd="docker run --name=py-eagle-mqtt -e MQTT_BROKER_IP=<IP> -e MQTT_BROKER_PORT=1883 -p 22042:22042 -d evanrich/py-eagle-mqtt"
WORKDIR /app WORKDIR /app
COPY . /app COPY requirements.txt /app
COPY ./src/conf/logrotate/tHome /etc/logrotate.d/ COPY ./src/conf/logrotate/tHome /etc/logrotate.d/
ENV PYTHONPATH=/app/src/python ENV PYTHONPATH=/app/src/python
RUN apk --update add --no-cache logrotate \ RUN apk --update add --no-cache logrotate \
&& pip3 install --no-cache-dir --upgrade pip \ && pip3 install --no-cache-dir --upgrade pip \
&& pip3 install --no-cache-dir -r requirements.txt && pip3 install --no-cache-dir -r requirements.txt
#RUN rm -rf /var/cache/apk COPY . /app
CMD ["/app/src/bin/tHome-eagle.py", "-c", "/app/src/conf"] CMD ["/app/src/bin/tHome-eagle.py", "-c", "/app/src/conf"]
EXPOSE 22042 EXPOSE 22042

View File

@@ -1,4 +1,3 @@
astral==1.10.1 paho-mqtt==1.5.1
paho-mqtt==1.4.0 bottle==0.12.19
bottle==0.12.17 defusedxml==0.7.1

View File

@@ -18,7 +18,7 @@ keepAlive = os.getenv('KEEPALIVE', 60)
# #
#=========================================================================== #===========================================================================
user = os.getenv('MQTT_USER', None) user = os.getenv('MQTT_USER', None)
password = os.getenv('MQTT_PASS', None) password = os.getenv('MQTT_PASSWORD', None)
#=========================================================================== #===========================================================================
# #
@@ -31,5 +31,3 @@ ca_certs = [
certFile = None certFile = None
keyFile = None keyFile = None

View File

@@ -6,7 +6,7 @@ from . import messages as msg
#from .InstantDemand import InstantDemand #from .InstantDemand import InstantDemand
#from .Reading import Reading #from .Reading import Reading
#from .Total import Total #from .Total import Total
import xml.etree.ElementTree as ET import defusedxml.ElementTree as ET
import socket import socket
#========================================================================== #==========================================================================

View File

@@ -3,7 +3,7 @@
# Parse XML messages into an object. # Parse XML messages into an object.
# #
#=========================================================================== #===========================================================================
import xml.etree.ElementTree as ET import defusedxml.ElementTree as ET
from . import messages from . import messages
#========================================================================== #==========================================================================

View File

@@ -1,19 +1,20 @@
# py-eagle-mqtt # py-eagle-mqtt
Python3 based Docker for Eagle to MQTT reader Python3 based Docker for Eagle to MQTT reader
I have only ported this into a dockerfile, All Original code (with one minor modification for XML root tag) is credit to [Ted Drain - TD22057](https://github.com/TD22057/T-Home). I have only ported this into a dockerfile, as well as made some changes to code for security or other purposes. All Original code is credit to [Ted Drain - TD22057](https://github.com/TD22057/T-Home).
This project utilizes the following tools:
[![semantic-release](https://img.shields.io/badge/%20%20%F0%9F%93%A6%F0%9F%9A%80-semantic--release-e10079.svg)](https://github.com/semantic-release/semantic-release)
[![Libraries.io dependency status for GitHub repo](https://img.shields.io/librariesio/github/evanrich/py-eagle-mqtt)]()
[![Gitlab pipeline status (self-hosted)](https://img.shields.io/gitlab/pipeline/erichardson/py-eagle-mqtt/master?gitlab_url=https%3A%2F%2Fgitlab.evanrichardsonphotography.com)]()
[![Docker Pulls](https://img.shields.io/docker/pulls/evanrich/py-eagle-mqtt)]()
[![Docker Image Version (latest by date)](https://img.shields.io/docker/v/evanrich/py-eagle-mqtt)]()
## UPDATES: ## UPDATES:
2019-07-24: Rebase to python 3.7.4-alpine3.10, update bottle to 0.12.17
2019-04-12: Rebase to python 3.7.3-alpine3.9
2019-03-08: Rebase to python 3.7.2-alpine3.9, update bottle and astral versions to latest
2019-01-03: Rebase to python 3.7.2-alpine3.8, changed logging level to Info (should output to /var/log/tHome/eagle.log)
2018-09-10: Ported to Python3, Added pricing info. Merged into master branch
2020-04-06: Moved Updates to a CHANGELOG.md file to clean this up.
## Usage ## Usage

View File

@@ -1,4 +1,4 @@
apiVersion: extensions/v1beta1 apiVersion: apps/v1
kind: Deployment kind: Deployment
metadata: metadata:
name: py-eagle-mqtt name: py-eagle-mqtt

3
sonar-project.properties Normal file
View File

@@ -0,0 +1,3 @@
sonar.projectKey=erichardson_py-eagle-mqtt_AXkgI9tRLcemhRz3NCjo
sonar.qualitygate.wait=true
sonar.projectBaseDir=Docker/src