Compare commits

..

4 Commits

Author SHA1 Message Date
26b955a1e8 Add networking block 2021-05-01 23:01:36 -07: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
4 changed files with 114 additions and 75 deletions

View File

@@ -93,3 +93,20 @@ sast:
stage: test stage: test
include: include:
- template: Security/SAST.gitlab-ci.yml - 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

@@ -22,6 +22,7 @@ import json
import bottle as B import bottle as B
import tHome as T import tHome as T
# =========================================================================== # ===========================================================================
def meter(client, data, cfg): def meter(client, data, cfg):
msg = { msg = {
@@ -30,7 +31,8 @@ def meter( client, data, cfg ):
"produced": data.Produced, # kWh "produced": data.Produced, # kWh
} }
return ( cfg.mqttEnergy, msg ) return cfg.mqttEnergy, msg
# =========================================================================== # ===========================================================================
def instant(client, data, cfg): def instant(client, data, cfg):
@@ -39,7 +41,8 @@ def instant( client, data, cfg ):
"power": data.Power * 1000, # W "power": data.Power * 1000, # W
} }
return ( cfg.mqttPower, msg ) return cfg.mqttPower, msg
# =========================================================================== # ===========================================================================
def price(client, data, cfg): def price(client, data, cfg):
@@ -48,7 +51,18 @@ def price( client, data, cfg ):
"price": data.Price, "price": data.Price,
"tier": data.Tier, "tier": data.Tier,
} }
return ( cfg.mqttPrice, msg ) 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 = {
@@ -59,13 +73,14 @@ handlers = {
"InstantaneousDemand": instant, "InstantaneousDemand": instant,
# "MessageCluster" : # "MessageCluster" :
# "MeterInfo" : # "MeterInfo" :
#"NetworkInfo" : "NetworkInfo": network,
"PriceCluster": price, "PriceCluster": price,
# "Reading" : # "Reading" :
# "ScheduleInfo" : # "ScheduleInfo" :
# "TimeCluster" : # "TimeCluster" :
} }
# =========================================================================== # ===========================================================================
@B.post('/') @B.post('/')
@@ -90,6 +105,7 @@ def root_post():
return "ok" return "ok"
# =========================================================================== # ===========================================================================
# #
# Main applications script # Main applications script

View File

@@ -23,6 +23,9 @@ 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.

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