Compare commits

..

109 Commits

Author SHA1 Message Date
semantic-release-bot
04dd0e76cb chore(release): 1.7.8 [skip ci]
## [1.7.8](https://gitlab.evanshome.io/erichardson/py-eagle-mqtt/compare/v1.7.7...v1.7.8) (2023-12-03)

### ci

* fix semantic versioning and docker push to local registry ([9ce6bb5](9ce6bb5798))

### Fix

* semantic versioning and docker push to local registry ([08069d6](08069d61d1))
2023-12-03 04:55:54 +00:00
08069d61d1 Fix: semantic versioning and docker push to local registry 2023-12-03 04:48:47 +00:00
9ce6bb5798 ci: fix semantic versioning and docker push to local registry 2023-12-03 04:45:28 +00:00
2944dff3e2 Update .gitlab-ci.yml file 2023-12-03 04:27:41 +00:00
56384db94f Update .gitlab-ci.yml file 2023-12-03 03:50:06 +00:00
472b3b299c Update .gitlab-ci.yml file 2023-12-03 03:41:29 +00:00
83790754f7 update npm packages and node version to latest 2023-12-03 03:28:23 +00:00
5c1882a067 Add missing commit sha tag 2023-12-03 02:52:17 +00:00
18de343fc5 replace latest with sha 2023-12-03 02:50:53 +00:00
988f36194c Update .gitlab-ci.yml file 2023-12-03 01:32:15 +00:00
30b97f27f0 Update .gitlab-ci.yml file 2023-12-03 01:29:38 +00:00
e2e01ab72a Update .gitlab-ci.yml file 2023-12-03 01:28:37 +00:00
64806b5c57 Update .gitlab-ci.yml file 2023-10-07 05:42:34 +00:00
20b84aa56d Update .gitlab-ci.yml file 2023-10-07 05:06:29 +00:00
4041346e45 Update .gitlab-ci.yml file 2023-10-07 04:59:34 +00:00
db2a632c3b Update .gitlab-ci.yml file 2023-10-07 04:58:20 +00:00
48e17c1c1c Update .gitlab-ci.yml file 2023-10-07 04:48:55 +00:00
81683091a7 Update .gitlab-ci.yml file 2023-10-07 04:44:14 +00:00
7fee43ae4c Update .gitlab-ci.yml file 2023-10-07 04:42:27 +00:00
0ff6915de4 Update .gitlab-ci.yml file 2023-10-07 04:37:31 +00:00
eb89414dc4 Update .gitlab-ci.yml file 2023-10-07 04:29:51 +00:00
490d84d47a Update .gitlab-ci.yml file 2023-10-07 04:21:51 +00:00
8cc9a078b6 Update .gitlab-ci.yml file 2023-10-07 04:18:38 +00:00
4b9699a100 Update .gitlab-ci.yml file 2023-10-07 04:16:58 +00:00
ff03988c19 Update .gitlab-ci.yml file 2023-10-07 03:28:53 +00:00
49d843cf1e Update .gitlab-ci.yml file 2023-10-07 01:58:06 +00:00
716aa84792 Update .gitlab-ci.yml file 2023-10-07 01:56:16 +00:00
6e176eb3e1 Update .gitlab-ci.yml file 2023-10-07 01:26:31 +00:00
95ed67b399 Update .gitlab-ci.yml file 2023-10-07 01:24:38 +00:00
429ae78f77 Update .gitlab-ci.yml file 2023-10-06 23:09:41 +00:00
f2cc305dc1 Update .gitlab-ci.yml file 2023-10-06 08:03:46 +00:00
b8f66b8f6a Update .gitlab-ci.yml file 2023-10-06 08:01:08 +00:00
effa72b1dc Update .gitlab-ci.yml file 2023-10-06 07:56:17 +00:00
8116bb499d Update .gitlab-ci.yml file 2023-10-06 07:51:12 +00:00
4d721d8c3a Update .gitlab-ci.yml file 2023-10-06 07:31:20 +00:00
1d498866b5 revert to 23.0.3 2023-10-06 07:14:07 +00:00
916cf6c939 Merge branch 'renovate/docker-24.x' into 'master'
chore(deps): update docker docker tag to v24

See merge request erichardson/py-eagle-mqtt!29
2023-10-06 07:10:12 +00:00
a5450163d5 chore(deps): update docker docker tag to v24 2023-10-06 07:10:12 +00:00
0f16e4ffcc Merge branch 'renovate/docker-23.x' into 'master'
chore(deps): update docker docker tag to v23.0.6

See merge request erichardson/py-eagle-mqtt!28
2023-10-06 07:09:34 +00:00
Renovate Bot
89f7296f9f chore(deps): update docker docker tag to v23.0.6 2023-05-14 11:05:57 +00:00
1ce3e0ab47 Merge branch 'renovate/docker-23.x' into 'master'
chore(deps): update docker docker tag to v23.0.3

See merge request erichardson/py-eagle-mqtt!26
2023-04-10 06:11:30 +00:00
f1d9d9123f Merge branch 'renovate/bottle-0.x' into 'master'
chore(deps): update dependency bottle to v0.12.25

See merge request erichardson/py-eagle-mqtt!27
2023-04-10 06:11:21 +00:00
Renovate Bot
4f96d02e79 chore(deps): update docker docker tag to v23.0.3 2023-04-09 11:06:02 +00:00
Renovate Bot
0a9626cdfa chore(deps): update dependency bottle to v0.12.25 2023-03-05 12:06:07 +00:00
1af8a83a83 update semantic-release/gitlab and changelog to latest versions 2023-02-11 21:04:08 +00:00
af1af22cc4 Update docker to 23.0.0 2023-02-11 20:54:57 +00:00
703d89eeac Merge branch 'renovate/docker-23.x' into 'master'
chore(deps): update docker docker tag to v23

See merge request erichardson/py-eagle-mqtt!25
2023-02-11 20:53:51 +00:00
9c652b4c57 Merge branch 'master' into 'renovate/docker-23.x'
# Conflicts:
#   .gitlab-ci.yml
2023-02-11 20:50:10 +00:00
d95b0f3390 Merge branch 'renovate/docker-20.x' into 'master'
chore(deps): update docker docker tag to v20.10.23

See merge request erichardson/py-eagle-mqtt!24
2023-02-11 20:49:40 +00:00
Renovate Bot
9c8d437bd3 chore(deps): update docker docker tag to v23 2023-02-05 12:06:01 +00:00
Renovate Bot
0704476ee7 chore(deps): update docker docker tag to v20.10.23 2023-01-22 12:06:05 +00:00
be40ee48b3 Update .gitlab-ci.yml file to comment out sonarqube 2022-12-22 01:35:18 +00:00
521c18c6b3 Merge branch 'renovate/docker-20.x' into 'master'
chore(deps): update docker docker tag to v20.10.22

See merge request erichardson/py-eagle-mqtt!22
2022-12-21 07:11:34 +00:00
e9ec14eb2e Merge branch 'renovate/python-3.x' into 'master'
chore(deps): update python docker tag to v3.11

See merge request erichardson/py-eagle-mqtt!23
2022-12-21 07:11:19 +00:00
Renovate Bot
c52fc328c8 chore(deps): update docker docker tag to v20.10.22 2022-12-18 12:03:59 +00:00
Renovate Bot
c2f99cc99f chore(deps): update python docker tag to v3.11 2022-11-24 04:16:08 +00:00
6d71c0487d Merge branch 'renovate/docker-20.x' into 'master'
chore(deps): update docker docker tag to v20.10.20

See merge request erichardson/py-eagle-mqtt!18
2022-10-24 03:24:55 +00:00
37d35ca158 Merge branch 'renovate/node-19.x' into 'master'
chore(deps): update node.js to v19

See merge request erichardson/py-eagle-mqtt!19
2022-10-24 03:24:45 +00:00
Renovate Bot
e422a78734 chore(deps): update node.js to v19 2022-10-23 11:04:29 +00:00
Renovate Bot
288311b2ad chore(deps): update docker docker tag to v20.10.20 2022-10-23 11:04:26 +00:00
288d67b2ab Merge branch 'renovate/docker-20.x' into 'master'
chore(deps): update docker docker tag to v20.10.18

See merge request erichardson/py-eagle-mqtt!17
2022-09-14 16:03:00 +00:00
Renovate Bot
13006b80a3 chore(deps): update docker docker tag to v20.10.18 2022-09-14 15:52:55 +00:00
1c53fe26eb Merge branch 'erichardson-master-patch-86083' into 'master'
Update bottle to 0.12.23

See merge request erichardson/py-eagle-mqtt!16
2022-08-05 17:50:48 +00:00
9a0ff2fa07 Update bottle to 0.12.23 2022-08-05 17:48:26 +00:00
ee7a861f9d Switch to semantic commit messages for renovate 2022-06-10 17:35:47 +00:00
60a272a042 Merge branch 'renovate/docker-20.x' into 'master'
Update dependency docker to v20.10.17

See merge request erichardson/py-eagle-mqtt!15
2022-06-10 17:34:34 +00:00
Renovate Bot
90d2a2ce64 Update dependency docker to v20.10.17 2022-06-08 07:04:14 +00:00
fa5ba06f9c Merge branch 'renovate/bottle-0.x' into 'master'
Update dependency bottle to v0.12.21

See merge request erichardson/py-eagle-mqtt!14
2022-05-28 23:06:07 +00:00
Renovate Bot
0484e9ec6e Update dependency bottle to v0.12.21 2022-05-27 07:04:37 +00:00
89b3048d0e Merge branch 'renovate/node-18.x' into 'master'
Update Node.js to v18

See merge request erichardson/py-eagle-mqtt!12
2022-05-13 04:35:46 +00:00
6bcc6936f3 Merge branch 'renovate/docker-20.x' into 'master'
Update dependency docker to v20.10.16

See merge request erichardson/py-eagle-mqtt!13
2022-05-13 04:35:10 +00:00
Renovate Bot
3fd737651d Update dependency docker to v20.10.16 2022-05-12 20:42:42 +00:00
Renovate Bot
c4d6357154 Update Node.js to v18 2022-04-21 07:04:19 +00:00
b2c68b7624 Merge branch 'renovate/docker-20.x' into 'master'
Update dependency docker to v20.10.14

See merge request erichardson/py-eagle-mqtt!11
2022-04-10 17:15:40 +00:00
Renovate Bot
1e148cb395 Update dependency docker to v20.10.14 2022-04-05 18:34:16 +00:00
b810a58c8b Merge branch 'renovate/docker-20.x' into 'master'
Update dependency docker to v20.10.13

See merge request erichardson/py-eagle-mqtt!10
2022-03-14 23:16:00 +00:00
Renovate Bot
833e42f78b Update dependency docker to v20.10.13 2022-03-11 08:04:13 +00:00
8b31b70f00 Change to rootless dind image and pin versions of dependencies 2022-02-23 01:54:08 +00:00
c22f8003db Update Trivy command format 2022-02-23 01:33:45 +00:00
c919b5de36 Merge branch 'renovate/sonarsource-sonar-scanner-cli-4.x' into 'master'
Update dependency sonarsource/sonar-scanner-cli to v4.7

See merge request erichardson/py-eagle-mqtt!9
2022-02-22 22:38:49 +00:00
Renovate Bot
27e3a515d7 Update dependency sonarsource/sonar-scanner-cli to v4.7 2022-02-22 18:04:46 +00:00
d40e077dd1 Merge branch 'renovate/docker-20.x' into 'master'
Update docker Docker tag to v20.10.12

See merge request erichardson/py-eagle-mqtt!8
2021-12-14 07:35:31 +00:00
Renovate Bot
02d8b752d5 Update docker Docker tag to v20.10.12 2021-12-14 06:04:29 +00:00
0ab4fe1e6b Add PR labels 2021-12-03 06:42:33 +00:00
85eb35443f Merge branch 'renovate/docker-20.x' into 'master'
Update docker Docker tag to v20.10.11

See merge request erichardson/py-eagle-mqtt!7
2021-12-03 06:39:52 +00:00
Renovate Bot
02faa494bd Update docker Docker tag to v20.10.11 2021-12-03 06:05:06 +00:00
0aa5abf687 Merge branch 'erichardson-master-patch-11429' into 'master'
Deleted dependabot.yml

See merge request erichardson/py-eagle-mqtt!6
2021-12-03 05:46:46 +00:00
0d0d79f8e6 Deleted dependabot.yml 2021-12-03 05:45:15 +00:00
8d2db8617d Merge branch 'renovate/configure' into 'master'
Configure Renovate

See merge request erichardson/py-eagle-mqtt!5
2021-12-02 04:53:54 +00:00
Renovate User
259b759991 Add renovate.json 2021-12-02 04:48:56 +00:00
01d415b1ef Add dependabot config 2021-12-02 01:02:16 +00:00
418eea6f1a Update paho-mqtt to 1.6.1
Update Base image to 3.10 alpine python
update builder image to docker 20.10.10
2021-11-17 19:49:52 +00:00
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
8 changed files with 185 additions and 181 deletions

View File

@@ -4,74 +4,30 @@
# See https://docs.gitlab.com/ee/ci/variables/#priority-of-environment-variables # See https://docs.gitlab.com/ee/ci/variables/#priority-of-environment-variables
stages: stages:
- test #- test
- build - build
- push_local #- push_local
- release - release
- push_dockerhub #- push_dockerhub
.docker_base:
image: docker:18.09.7-dind
services:
- docker:18.09.7-dind
variables:
DOCKER_DRIVER: overlay
DOCKER_HOST: tcp://localhost:2375/
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:
extends: image: docker:24.0.5-dind
- .docker_base
stage: build stage: build
script: services:
- docker pull $CI_REGISTRY_IMAGE:latest || true - name: docker:24.0.5-dind
- > command: ["--tls=false"]
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
push local:
extends:
- .docker_base
stage: push_local
variables: variables:
GIT_STRATEGY: none DOCKER_DRIVER: overlay2
only: DOCKER_HOST: tcp://docker:2375
- master DOCKER_TLS_CERTDIR: ""
FF_GITLAB_REGISTRY_HELPER_IMAGE: 1
script: script:
- docker pull $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA - docker login -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY
- docker tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA $CI_REGISTRY_IMAGE:latest - docker build -t $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:latest - docker push $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA
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
release: release:
image: node:13 image: node:20.10.0-alpine3.18
stage: release stage: release
only: only:
refs: refs:
@@ -81,32 +37,17 @@ release:
- /^(([0-9]+)\.)?([0-9]+)\.x/ - /^(([0-9]+)\.)?([0-9]+)\.x/
# This matches pre-releases # This matches pre-releases
- /^([0-9]+)\.([0-9]+)\.([0-9]+)(?:-([0-9A-Za-z-]+(?:\.[0-9A-Za-z-]+)*))?(?:\+[0-9A-Za-z-]+)?$/ - /^([0-9]+)\.([0-9]+)\.([0-9]+)(?:-([0-9A-Za-z-]+(?:\.[0-9A-Za-z-]+)*))?(?:\+[0-9A-Za-z-]+)?$/
except:
refs:
- tags
script: script:
- touch CHANGELOG.md - touch CHANGELOG.md
- npm install @semantic-release/gitlab @semantic-release/changelog @semantic-release/git - apk add --no-cache git
- git config user.email "ci-bot@evanshome.io"
- git config user.name "ci-bot"
- npm install @semantic-release/gitlab@12.1.1 @semantic-release/changelog@6.0.3
@semantic-release/git@10.0.1 conventional-changelog-eslint@5.0.0
- npx semantic-release - npx semantic-release
artifacts: artifacts:
paths: paths:
- CHANGELOG.md - CHANGELOG.md
sast:
stage: test
include:
- template: Security/SAST.gitlab-ci.yml
sonarqube-check:
image:
name: sonarsource/sonar-scanner-cli:latest
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

View File

@@ -1,6 +1,38 @@
plugins: plugins:
- "@semantic-release/commit-analyzer" - - "@semantic-release/commit-analyzer"
- "@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/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" - - "@semantic-release/changelog"
- changelogFile: CHANGELOG.md - changelogFile: CHANGELOG.md
- "@semantic-release/gitlab" - "@semantic-release/gitlab"

View File

@@ -1,3 +1,41 @@
## [1.7.8](https://gitlab.evanshome.io/erichardson/py-eagle-mqtt/compare/v1.7.7...v1.7.8) (2023-12-03)
### ci
* fix semantic versioning and docker push to local registry ([9ce6bb5](https://gitlab.evanshome.io/erichardson/py-eagle-mqtt/commit/9ce6bb579847fba7fd31cc7ece4bcbb0661247b8))
### Fix
* semantic versioning and docker push to local registry ([08069d6](https://gitlab.evanshome.io/erichardson/py-eagle-mqtt/commit/08069d61d135eff8c2ee5b210279589c4e4eed8f))
## [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) ## [1.7.3](https://gitlab.evanrichardsonphotography.com/erichardson/py-eagle-mqtt/compare/v1.7.2...v1.7.3) (2021-04-12)

View File

@@ -1,4 +1,4 @@
FROM python:3.9.4-alpine3.13 FROM python:3.11-alpine
LABEL maintainer="Evan Richardson (evanrich81[at]gmail.com)" LABEL maintainer="Evan Richardson (evanrich81[at]gmail.com)"
ARG BUILD_DATE ARG BUILD_DATE

View File

@@ -1,3 +1,3 @@
paho-mqtt==1.5.1 paho-mqtt==1.6.1
bottle==0.12.19 bottle==0.12.25
defusedxml==0.7.1 defusedxml==0.7.1

View File

@@ -1,10 +1,10 @@
#!/usr/bin/env python3 #!/usr/bin/env python3
# =========================================================================== #===========================================================================
# #
# Eagle posting server # Eagle posting server
# #
# =========================================================================== #===========================================================================
__doc__ = """ __doc__ = """
Starts a small web server. The Rain Forest Eagle is configured with Starts a small web server. The Rain Forest Eagle is configured with
@@ -22,116 +22,100 @@ import json
import bottle as B import bottle as B
import tHome as T import tHome as T
#===========================================================================
def meter( client, data, cfg ):
msg = {
"time" : data.TimeUnix,
"consumed" : data.Consumed, # kWh
"produced" : data.Produced, # kWh
}
# =========================================================================== return ( cfg.mqttEnergy, msg )
def meter(client, data, cfg):
msg = {
"time": data.TimeUnix,
"consumed": data.Consumed, # kWh
"produced": data.Produced, # kWh
}
return cfg.mqttEnergy, msg #===========================================================================
def instant( client, data, cfg ):
msg = {
"time" : data.TimeUnix,
"power" : data.Power * 1000, # W
}
return ( cfg.mqttPower, msg )
# =========================================================================== #===========================================================================
def instant(client, data, cfg): def price( client, data, cfg ):
msg = { msg = {
"time": data.TimeUnix, "time" : data.TimeUnix,
"power": data.Power * 1000, # W "price" : data.Price,
} "tier" : data.Tier,
}
return ( cfg.mqttPrice, msg )
return cfg.mqttPower, msg #===========================================================================
# ===========================================================================
def price(client, data, cfg):
msg = {
"time": data.TimeUnix,
"price": data.Price,
"tier": data.Tier,
}
return cfg.mqttPrice, msg
# ===========================================================================
def network(client, data, cfg):
msg = {
"status": data.Status,
"description": data.Description,
"linkstrength": data.LinkStrength
}
return cfg.mqttNetwork, msg
# ===========================================================================
handlers = { handlers = {
# "BlockPriceDetail" : #"BlockPriceDetail" :
"CurrentSummation": meter, "CurrentSummation" : meter,
# "DeviceInfo" : #"DeviceInfo" :
# "FastPollStatus" : #"FastPollStatus" :
"InstantaneousDemand": instant, "InstantaneousDemand" : instant,
# "MessageCluster" : #"MessageCluster" :
# "MeterInfo" : #"MeterInfo" :
"NetworkInfo": network, #"NetworkInfo" :
"PriceCluster": price, "PriceCluster" : price,
# "Reading" : #"Reading" :
# "ScheduleInfo" : #"ScheduleInfo" :
# "TimeCluster" : #"TimeCluster" :
} }
#===========================================================================
# =========================================================================== @B.post( '/' )
@B.post('/')
def root_post(): def root_post():
data = B.request.body.read(B.request.content_length) data = B.request.body.read( B.request.content_length )
try: try:
obj = T.eagle.parse(data) obj = T.eagle.parse( data )
except: except:
log.exception("Error parsing Eagle posted data") log.exception( "Error parsing Eagle posted data" )
return "ERROR" return "ERROR"
log.info("Read packet: %s" % obj.name) log.info( "Read packet: %s" % obj.name )
func = handlers.get(obj.name, None) func = handlers.get( obj.name, None )
if func: if func:
topic, msg = func(client, obj, cfg) topic, msg = func( client, obj, cfg )
if msg: if msg:
log.info("Publish: %s: %s" % (topic, msg)) log.info( "Publish: %s: %s" % ( topic, msg ) )
payload = json.dumps(msg) payload = json.dumps( msg )
client.publish(topic, payload) client.publish( topic, payload )
return "ok" return "ok"
#===========================================================================
# ===========================================================================
# #
# Main applications script # Main applications script
# #
# =========================================================================== #===========================================================================
p = argparse.ArgumentParser(prog=sys.argv[0], p = argparse.ArgumentParser( prog=sys.argv[0],
description="T-Home Eagle Server") description="T-Home Eagle Server" )
p.add_argument("-c", "--configDir", metavar="configDir", p.add_argument( "-c", "--configDir", metavar="configDir",
default="/etc/tHome", default="/etc/tHome",
help="Configuration file directory.") help="Configuration file directory." )
p.add_argument("-l", "--log", metavar="logFile", p.add_argument( "-l", "--log", metavar="logFile",
default=None, help="Logging file to use. Input 'stdout' " default=None, help="Logging file to use. Input 'stdout' "
"to log to the screen.") "to log to the screen." )
c = p.parse_args(sys.argv[1:]) c = p.parse_args( sys.argv[1:] )
# Parse the eagle config file. # Parse the eagle config file.
cfg = T.eagle.config.parse(c.configDir) cfg = T.eagle.config.parse( c.configDir )
log = T.eagle.config.log(cfg, c.log) log = T.eagle.config.log( cfg, c.log )
# Create the MQTT client and connect it to the broker. # Create the MQTT client and connect it to the broker.
client = T.broker.connect(c.configDir, log) client = T.broker.connect( c.configDir, log )
# Start the MQTT as a background thread. This way we can run the web # Start the MQTT as a background thread. This way we can run the web
# server as the main thread here. # server as the main thread here.
client.loop_start() client.loop_start()
log.info("Starting web server at port %d" % cfg.httpPort) log.info( "Starting web server at port %d" % cfg.httpPort )
B.run(host='0.0.0.0', port=cfg.httpPort, quiet=True) B.run( host='0.0.0.0', port=cfg.httpPort, quiet=True )

View File

@@ -23,9 +23,6 @@ mqttPrice = 'power/elec/Home/price'
#Current rate label (returns rate label from meter) #Current rate label (returns rate label from meter)
mqttRateLabel = 'power/elec/Home/ratelabel' mqttRateLabel = 'power/elec/Home/ratelabel'
#Network Info Topic (returns status, description and link strength from meter)
mqttNetwork = 'power/elec/Home/network'
#=========================================================================== #===========================================================================
# #
# Logging configuration. Env variables are allowed in the file name. # Logging configuration. Env variables are allowed in the file name.

12
renovate.json Normal file
View File

@@ -0,0 +1,12 @@
{
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
"extends": [
"config:base",
":semanticCommits"
],
"prConcurrentLimit": 5,
"labels": [
"upgrade",
"bot"
]
}