#include <WiFi.h>
#include <PubSubClient.h>

const char* ssid = "Wokwi-GUEST"; ///  wifi ssid
const char* password = "";
const char* mqtt_server = "test.mosquitto.org";// mosquitto server url
// const char* mqtt_server = "192.168.100.8";// mosquitto server url

WiFiClient espClient;
PubSubClient client(espClient);
unsigned long lastMsg = 0;

int energy = 4455;
const unsigned long eventInterval = 100000;
unsigned long previousTime = 0;
const int led = 4;

void setup_wifi() {
  delay(10);
  Serial.println();
  Serial.print("Connecting to ");
  Serial.println(ssid);

  WiFi.mode(WIFI_STA);
  WiFi.begin(ssid, password);

  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }

  randomSeed(micros());

  Serial.println("");
  Serial.println("WiFi connected");
  Serial.println("IP address: ");
  Serial.println(WiFi.localIP());
}


void callback(char* topic, byte* payload, unsigned int length) {
  Serial.print("Message arrived [");
  Serial.print(topic);
  Serial.print("] ");
  String messageTemp;
  for (int i = 0; i < length; i++) {
    Serial.print((char)payload[i]);
    messageTemp +=  (char)payload[i];
  }
  if (messageTemp == "1"){
    digitalWrite(led,HIGH);
  }
  if (messageTemp == "0"){
    digitalWrite(led,LOW);
  }


}


void reconnect() {
  while (!client.connected()) {
    Serial.print("Atvting MQTT connection...");
    String clientId = "ESP32Client-";
    clientId += String(random(0xffff), HEX);
    if (client.connect(clientId.c_str())) {
      Serial.println("Connected");
      client.publish("/iot/Publish", "Welcome");
      client.subscribe("/iot/Subscribe/001");
    } else {
      Serial.print("failed, rc=");
      Serial.print(client.state());
      Serial.println(" try again in 5 seconds");
      delay(5000);
    }
  }
}
void setup() {

  Serial.begin(115200);
  setup_wifi();
  client.setServer(mqtt_server, 1883);
  client.setCallback(callback);
  pinMode(led,OUTPUT);

}
void loop() {
  unsigned long currentTime = millis();
  if (!client.connected()) {
    reconnect();
  }
  client.loop();

  int volts = random(380,420);
  int current = random(50,120);
  
  int running_load = random(15,50);
  int frequency = 50;
  int power_factor = random(90,95);

  unsigned long now = millis();
  if (now - lastMsg > 2000) { //perintah publish data
    lastMsg = now;

    String volt = String(volts);
    client.publish("/iot/v1", volt.c_str()); // publish v topic /ThinkIOT/v

    String ampere = String(current);
    client.publish("/iot/i1", ampere.c_str());   // publish i topic /ThinkIOT/i

    String kwh = String(energy);
    client.publish("/iot/kwh1", kwh.c_str());

    String kw = String(running_load);
    client.publish("/iot/kw1", kw.c_str());

    String hz = String(frequency);
    client.publish("/iot/hz1", hz.c_str());

    String pF = String(power_factor);
    client.publish("/iot/pF1", pF.c_str());

    Serial.print("Volts: ");
    Serial.println(volt);
    Serial.print("Current: ");
    Serial.println(ampere);
    Serial.print("Energy: ");
    Serial.println(energy);
  }
   if (currentTime - previousTime >= eventInterval) {
    /* Event code */

    Serial.println("energy increase");
    energy++;
   /* Update the timing for the next time around */
    previousTime = currentTime;
  }
  
}
esp:VIN
esp:GND.2
esp:D13
esp:D12
esp:D14
esp:D27
esp:D26
esp:D25
esp:D33
esp:D32
esp:D35
esp:D34
esp:VN
esp:VP
esp:EN
esp:3V3
esp:GND.1
esp:D15
esp:D2
esp:D4
esp:RX2
esp:TX2
esp:D5
esp:D18
esp:D19
esp:D21
esp:RX0
esp:TX0
esp:D22
esp:D23
led1:A
led1:C