commit
09edbe02f6
@ -1,4 +1,4 @@
|
|||||||
production:
|
inocode:
|
||||||
image: "java:8"
|
image: "java:8"
|
||||||
variables:
|
variables:
|
||||||
ESPURL: "http://arduino.esp8266.com/stable/package_esp8266com_index.json"
|
ESPURL: "http://arduino.esp8266.com/stable/package_esp8266com_index.json"
|
||||||
@ -6,7 +6,7 @@ production:
|
|||||||
INSTBOARD: "esp8266:esp8266"
|
INSTBOARD: "esp8266:esp8266"
|
||||||
BOARD: "${INSTBOARD}:nodemcuv2"
|
BOARD: "${INSTBOARD}:nodemcuv2"
|
||||||
before_script:
|
before_script:
|
||||||
- apt update 2>/dev/null
|
- apt update >/dev/null
|
||||||
- cd /
|
- cd /
|
||||||
- wget --quiet "https://www.arduino.cc/download.php?f=/arduino-nightly-linux64.tar.xz" -O "arduino-nightly-linux64.tar.xz"
|
- wget --quiet "https://www.arduino.cc/download.php?f=/arduino-nightly-linux64.tar.xz" -O "arduino-nightly-linux64.tar.xz"
|
||||||
- tar axf "arduino-nightly-linux64.tar.xz"
|
- tar axf "arduino-nightly-linux64.tar.xz"
|
||||||
@ -18,3 +18,11 @@ production:
|
|||||||
- /arduino-nightly/arduino --install-library "FastLED"
|
- /arduino-nightly/arduino --install-library "FastLED"
|
||||||
- /arduino-nightly/arduino --install-library "PubSubClient"
|
- /arduino-nightly/arduino --install-library "PubSubClient"
|
||||||
- /arduino-nightly/arduino --pref "${MEMORY}" --board "${BOARD}" --verify "mqttfastledmenu.ino"
|
- /arduino-nightly/arduino --pref "${MEMORY}" --board "${BOARD}" --verify "mqttfastledmenu.ino"
|
||||||
|
|
||||||
|
yaml:
|
||||||
|
image: "python:alpine"
|
||||||
|
before_script:
|
||||||
|
- pip install "PyYAML"
|
||||||
|
script:
|
||||||
|
- cd "${CI_PROJECT_DIR}"
|
||||||
|
- python -c "from yaml import load, Loader; load(open('ha_configuration.yml'), Loader=Loader)"
|
||||||
@ -1,20 +1,17 @@
|
|||||||
# TODO : Il serait bien de pouvoir donner un nom joli sans envoyer de string
|
|
||||||
mqtt:
|
mqtt:
|
||||||
broker: "mqtt"
|
broker: "XXX"
|
||||||
port: 1883
|
port: 1883
|
||||||
client_id: "homeassistant1"
|
client_id: "homeassistant1"
|
||||||
username: "***REMOVED***"
|
username: "XXX"
|
||||||
password: "***REMOVED***"
|
password: "XXX"
|
||||||
|
|
||||||
input_select:
|
input_select:
|
||||||
strip1_effect:
|
strip1_effect:
|
||||||
name: "Choix de l'effet"
|
name: "Choix de l'effet"
|
||||||
options:
|
options:
|
||||||
- 1
|
- "cylon"
|
||||||
- 2
|
- "full"
|
||||||
- 3
|
- "error"
|
||||||
- 4
|
|
||||||
initial: 1
|
|
||||||
|
|
||||||
input_slider:
|
input_slider:
|
||||||
strip1_animation_speed:
|
strip1_animation_speed:
|
||||||
@ -24,27 +21,36 @@ input_slider:
|
|||||||
max: 150
|
max: 150
|
||||||
step: 10
|
step: 10
|
||||||
|
|
||||||
|
light:
|
||||||
|
platform: "mqtt"
|
||||||
|
name: "Test ESP"
|
||||||
|
command_topic: "strip1/switch"
|
||||||
|
state_topic: "strip1/status"
|
||||||
|
rgb_state_topic: "strip1/color/switch"
|
||||||
|
rgb_command_topic: "strip1/color/status"
|
||||||
|
brightness_state_topic: "strip1/brightness/switch"
|
||||||
|
brightness_command_topic: "strip1/brightness/status"
|
||||||
|
|
||||||
automation:
|
automation:
|
||||||
- alias: "Strip1 Effect"
|
- alias: "Strip1 Effect"
|
||||||
initial_state: True
|
|
||||||
hide_entity: False
|
hide_entity: False
|
||||||
trigger:
|
trigger:
|
||||||
- platform: state
|
- platform: "state"
|
||||||
entity_id: input_select.strip1_effect
|
entity_id: "input_select.strip1_effect"
|
||||||
action:
|
action:
|
||||||
- service: mqtt.publish
|
- service: "mqtt.publish"
|
||||||
data_template:
|
data_template:
|
||||||
topic: "strip1/seteffect"
|
topic: "strip1/effect/switch"
|
||||||
payload: '{{ trigger.to_state.state | string }}'
|
payload: '{{ trigger.to_state.state | string }}'
|
||||||
retain: True
|
retain: True
|
||||||
- alias: "Strip1 Animation Speed"
|
- alias: "Strip1 Animation Speed"
|
||||||
initial_state: True
|
|
||||||
hide_entity: False
|
hide_entity: False
|
||||||
trigger:
|
trigger:
|
||||||
- platform: state
|
- platform: "state"
|
||||||
entity_id: input_slider.strip1_animation_speed
|
entity_id: "input_slider.strip1_animation_speed"
|
||||||
action:
|
action:
|
||||||
- service: mqtt.publish
|
- service: "mqtt.publish"
|
||||||
data_template:
|
data_template:
|
||||||
topic: "strip1/setspeed"
|
topic: "strip1/speed/switch"
|
||||||
payload: '{{ trigger.to_state.state | int }}'
|
payload: '{{ trigger.to_state.state | int }}'
|
||||||
|
retain: True
|
||||||
|
|||||||
@ -9,10 +9,9 @@
|
|||||||
#define LED_SPEED_DEFAULT 120
|
#define LED_SPEED_DEFAULT 120
|
||||||
#define LED_COLOR_DEFAULT CRGB::Red
|
#define LED_COLOR_DEFAULT CRGB::Red
|
||||||
|
|
||||||
#define LED_EFFECT_OFF 1
|
#define LED_EFFECT_CYLON "cylon"
|
||||||
#define LED_EFFECT_CYLON 2
|
#define LED_EFFECT_FULLRED "full"
|
||||||
#define LED_EFFECT_FULLRED 3
|
#define LED_EFFECT_ERROR "error"
|
||||||
#define LED_EFFECT_ERROR 4
|
|
||||||
|
|
||||||
// WIFI
|
// WIFI
|
||||||
#define WIFI_SSID "XXX"
|
#define WIFI_SSID "XXX"
|
||||||
@ -24,10 +23,16 @@
|
|||||||
#define MQTT_USER "XXX"
|
#define MQTT_USER "XXX"
|
||||||
#define MQTT_PASS "XXX"
|
#define MQTT_PASS "XXX"
|
||||||
|
|
||||||
#define MQTT_LED_EFFECT "strip1/seteffect"
|
#define MQTT_LED_STATE "strip1/switch"
|
||||||
#define MQTT_LED_BRIGHTNESS "strip1/setbrightness"
|
#define MQTT_LED_COMMAND "strip1/status"
|
||||||
#define MQTT_LED_SPEED "strip1/setspeed"
|
#define MQTT_LED_EFFECT_COMMAND "strip1/effect/switch"
|
||||||
#define MQTT_LED_COLOR "strip1/setcolor"
|
#define MQTT_LED_EFFECT_STATE "strip1/effect/status"
|
||||||
|
#define MQTT_LED_BRIGHTNESS_COMMAND "strip1/brightness/switch"
|
||||||
|
#define MQTT_LED_BRIGHTNESS_STATE "strip1/brightness/status"
|
||||||
|
#define MQTT_LED_SPEED_COMMAND "strip1/speed/switch"
|
||||||
|
#define MQTT_LED_SPEED_STATE "strip1/speed/status"
|
||||||
|
#define MQTT_LED_COLOR_COMMAND "strip1/color/switch"
|
||||||
|
#define MQTT_LED_COLOR_STATE "strip1/color/status"
|
||||||
|
|
||||||
// FastLED
|
// FastLED
|
||||||
// TODO : essayer, devrait limiter le flikering
|
// TODO : essayer, devrait limiter le flikering
|
||||||
|
|||||||
@ -9,7 +9,8 @@ int brightness = LED_BRIGHTNESS_DEFAULT;
|
|||||||
int color = LED_COLOR_DEFAULT;
|
int color = LED_COLOR_DEFAULT;
|
||||||
int speed = LED_SPEED_DEFAULT;
|
int speed = LED_SPEED_DEFAULT;
|
||||||
CRGB leds[LED_NUM];
|
CRGB leds[LED_NUM];
|
||||||
int ledEffect = LED_EFFECT_OFF;
|
String ledEffect = LED_EFFECT_CYLON;
|
||||||
|
boolean ledState = false;
|
||||||
|
|
||||||
// WIFI
|
// WIFI
|
||||||
WiFiClient espClient;
|
WiFiClient espClient;
|
||||||
@ -18,7 +19,8 @@ WiFiClient espClient;
|
|||||||
char message_buff[100];
|
char message_buff[100];
|
||||||
PubSubClient client(espClient);
|
PubSubClient client(espClient);
|
||||||
|
|
||||||
void setup() {
|
void setup()
|
||||||
|
{
|
||||||
Serial.begin(SERIAL_SPEED);
|
Serial.begin(SERIAL_SPEED);
|
||||||
Serial.println("\nresetting");
|
Serial.println("\nresetting");
|
||||||
|
|
||||||
@ -29,19 +31,21 @@ void setup() {
|
|||||||
client.setServer(MQTT_SERVER, MQTT_PORT);
|
client.setServer(MQTT_SERVER, MQTT_PORT);
|
||||||
client.setCallback(callbackMQTT);
|
client.setCallback(callbackMQTT);
|
||||||
testConnectMQTT();
|
testConnectMQTT();
|
||||||
client.subscribe(MQTT_LED_EFFECT);
|
client.subscribe(MQTT_LED_COMMAND);
|
||||||
client.subscribe(MQTT_LED_BRIGHTNESS);
|
client.subscribe(MQTT_LED_EFFECT_COMMAND);
|
||||||
client.subscribe(MQTT_LED_COLOR);
|
client.subscribe(MQTT_LED_BRIGHTNESS_COMMAND);
|
||||||
client.subscribe(MQTT_LED_SPEED);
|
client.subscribe(MQTT_LED_SPEED_COMMAND);
|
||||||
|
client.subscribe(MQTT_LED_COLOR_COMMAND);
|
||||||
|
|
||||||
// LED
|
// LED
|
||||||
LEDS.addLeds<LED_CHIPSET,LED_PIN, LED_COLOR_ORDER>(leds, LED_NUM).setCorrection(TypicalSMD5050);
|
LEDS.addLeds<LED_CHIPSET,LED_PIN, LED_COLOR_ORDER>(leds, LED_NUM).setCorrection(TypicalSMD5050);
|
||||||
FastLED.setBrightness(brightness);
|
|
||||||
ledBlackAll();
|
ledBlackAll();
|
||||||
|
FastLED.setBrightness(brightness);
|
||||||
}
|
}
|
||||||
|
|
||||||
// WIFI
|
// WIFI
|
||||||
void setupWifi() {
|
void setupWifi()
|
||||||
|
{
|
||||||
Serial.print("Connexion a ");
|
Serial.print("Connexion a ");
|
||||||
Serial.print(WIFI_SSID);
|
Serial.print(WIFI_SSID);
|
||||||
WiFi.mode(WIFI_STA);
|
WiFi.mode(WIFI_STA);
|
||||||
@ -58,12 +62,17 @@ void setupWifi() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// MQTT
|
// MQTT
|
||||||
void testConnectMQTT() {
|
void testConnectMQTT()
|
||||||
|
{
|
||||||
while (!client.connected()) {
|
while (!client.connected()) {
|
||||||
Serial.print("Connexion au serveur MQTT... ");
|
Serial.print("Connexion au serveur MQTT... ");
|
||||||
if (client.connect("ESP8266Client", MQTT_USER, MQTT_PASS)) {
|
if (client.connect("ESP8266Client", MQTT_USER, MQTT_PASS)) {
|
||||||
// TODO : doit-on se reconnecter aux topics ?
|
|
||||||
Serial.println("OK");
|
Serial.println("OK");
|
||||||
|
client.subscribe(MQTT_LED_COMMAND);
|
||||||
|
client.subscribe(MQTT_LED_EFFECT_COMMAND);
|
||||||
|
client.subscribe(MQTT_LED_BRIGHTNESS_COMMAND);
|
||||||
|
client.subscribe(MQTT_LED_SPEED_COMMAND);
|
||||||
|
client.subscribe(MQTT_LED_COLOR_COMMAND);
|
||||||
} else {
|
} else {
|
||||||
Serial.print("KO, erreur : ");
|
Serial.print("KO, erreur : ");
|
||||||
Serial.print(client.state());
|
Serial.print(client.state());
|
||||||
@ -74,54 +83,44 @@ void testConnectMQTT() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Déclenche les actions à la réception d'un message
|
// Déclenche les actions à la réception d'un message
|
||||||
void callbackMQTT(char* topic, byte* payload, unsigned int length) {
|
void callbackMQTT(char* topic, byte* payload, unsigned int length)
|
||||||
if (String(topic) == MQTT_LED_EFFECT) {
|
{
|
||||||
Serial.print("Received [" + String(topic) + "] : ");
|
String stopic = String(topic);
|
||||||
|
|
||||||
Serial.print(payload[0]);
|
unsigned int i = 0;
|
||||||
Serial.print(" ~ ");
|
for(i = 0; i < length; i++) {
|
||||||
Serial.print(payload[0] - '0');
|
message_buff[i] = payload[i];
|
||||||
|
}
|
||||||
ledEffect = payload[0] - '0';
|
message_buff[i] = '\0';
|
||||||
Serial.print("[");
|
String msgString = String(message_buff);
|
||||||
Serial.print(ledEffect);
|
|
||||||
Serial.println("]");
|
Serial.print("Received [" + stopic + "] : ");
|
||||||
|
Serial.println(msgString);
|
||||||
|
|
||||||
|
if (stopic == MQTT_LED_COMMAND) {
|
||||||
|
if (msgString == "ON") {
|
||||||
|
ledState = true;
|
||||||
|
client.publish(MQTT_LED_STATE, message_buff, true);
|
||||||
|
} else {
|
||||||
|
ledState = false;
|
||||||
|
client.publish(MQTT_LED_STATE, message_buff, true);
|
||||||
|
}
|
||||||
|
} else if (stopic == MQTT_LED_EFFECT_COMMAND) {
|
||||||
// Si on ne repasse pas tout à noir, cela peut faire des effets surprenants
|
// Si on ne repasse pas tout à noir, cela peut faire des effets surprenants
|
||||||
ledBlackAll();
|
ledBlackAll();
|
||||||
} else if (String(topic) == MQTT_LED_BRIGHTNESS) {
|
ledEffect = msgString;
|
||||||
unsigned int i = 0;
|
// TODO : a vraiment tester
|
||||||
for(i = 0; i < length; i++) {
|
client.publish(MQTT_LED_EFFECT_STATE, message_buff, true);
|
||||||
message_buff[i] = payload[i];
|
} else if (stopic == MQTT_LED_BRIGHTNESS_COMMAND) {
|
||||||
}
|
|
||||||
message_buff[i] = '\0';
|
|
||||||
// TODO : il est surement possible de faire plus propre
|
|
||||||
String msgString = String(message_buff);
|
|
||||||
brightness = msgString.toInt();
|
brightness = msgString.toInt();
|
||||||
FastLED.setBrightness(brightness);
|
FastLED.setBrightness(brightness);
|
||||||
|
client.publish(MQTT_LED_BRIGHTNESS_STATE, message_buff, true);
|
||||||
Serial.print("Received [" + String(topic) + "] : ");
|
} else if (stopic == MQTT_LED_COLOR_COMMAND) {
|
||||||
Serial.println(msgString);
|
|
||||||
} else if (String(topic) == MQTT_LED_COLOR) {
|
|
||||||
unsigned int i = 0;
|
|
||||||
for(i = 0; i < length; i++) {
|
|
||||||
message_buff[i] = payload[i];
|
|
||||||
}
|
|
||||||
message_buff[i] = '\0';
|
|
||||||
String msgString = String(message_buff);
|
|
||||||
color = msgString.toInt();
|
color = msgString.toInt();
|
||||||
Serial.print("Received [" + String(topic) + "] : ");
|
client.publish(MQTT_LED_COLOR_STATE, message_buff, true);
|
||||||
Serial.println(msgString);
|
} else if (stopic == MQTT_LED_SPEED_COMMAND) {
|
||||||
} else if (String(topic) == MQTT_LED_SPEED) {
|
|
||||||
unsigned int i = 0;
|
|
||||||
for(i = 0; i < length; i++) {
|
|
||||||
message_buff[i] = payload[i];
|
|
||||||
}
|
|
||||||
message_buff[i] = '\0';
|
|
||||||
String msgString = String(message_buff);
|
|
||||||
speed = msgString.toInt();
|
speed = msgString.toInt();
|
||||||
Serial.print("Received [" + String(topic) + "] : ");
|
client.publish(MQTT_LED_SPEED_STATE, message_buff, true);
|
||||||
Serial.println(msgString);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -196,30 +195,28 @@ void loop() {
|
|||||||
testConnectMQTT();
|
testConnectMQTT();
|
||||||
client.loop();
|
client.loop();
|
||||||
|
|
||||||
EVERY_N_SECONDS(180) {
|
// TODO : à retirer je pense
|
||||||
Serial.print("MQTT Subscribe refresh");
|
//EVERY_N_SECONDS(180) {
|
||||||
client.subscribe(MQTT_LED_EFFECT);
|
// Serial.print("MQTT Subscribe refresh");
|
||||||
client.subscribe(MQTT_LED_BRIGHTNESS);
|
// client.subscribe(MQTT_LED_EFFECT_COMMAND);
|
||||||
client.subscribe(MQTT_LED_COLOR);
|
// client.subscribe(MQTT_LED_BRIGHTNESS_COMMAND);
|
||||||
client.subscribe(MQTT_LED_SPEED);
|
// client.subscribe(MQTT_LED_COLOR_COMMAND);
|
||||||
Serial.println(" done");
|
// client.subscribe(MQTT_LED_SPEED_COMMAND);
|
||||||
}
|
// Serial.println(" done");
|
||||||
|
//}
|
||||||
|
|
||||||
// LED
|
// LED
|
||||||
switch(ledEffect)
|
if (!ledState) {
|
||||||
{
|
ledBlackAll();
|
||||||
case LED_EFFECT_OFF:
|
FastLED.delay(1000);
|
||||||
ledBlackAll();
|
} else {
|
||||||
break;
|
if (ledEffect == LED_EFFECT_CYLON) {
|
||||||
case LED_EFFECT_CYLON:
|
ledCylon();
|
||||||
ledCylon();
|
} else if (ledEffect == LED_EFFECT_FULLRED) {
|
||||||
break;
|
ledFullRed();
|
||||||
case LED_EFFECT_FULLRED:
|
} else {
|
||||||
ledFullRed();
|
ledError();
|
||||||
break;
|
}
|
||||||
default:
|
|
||||||
ledError();
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user