Merge branch 'dev' into 'master'

Dev

See merge request !1
This commit is contained in:
Julien Cabillot 2017-03-06 10:49:19 +01:00
commit 09edbe02f6
4 changed files with 120 additions and 104 deletions

View File

@ -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)"

View File

@ -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

View File

@ -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

View File

@ -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;
} }
} }