#protobuf #proto #definition #energyleaf

energyleaf-proto

Protobuf definitions for Energyleaf

11 releases (5 stable)

2.0.0 Nov 27, 2024
1.2.0 Aug 23, 2024
1.0.1 Jun 27, 2024
0.2.3 Jun 27, 2024
0.1.6 Jun 4, 2024

#1429 in Encoding

Download history 4/week @ 2024-08-26 42/week @ 2024-09-16 40/week @ 2024-09-23 3/week @ 2024-09-30 134/week @ 2024-11-25 44/week @ 2024-12-09

178 downloads per month

MIT license

5KB

Energyleaf Proto - Rust

Contains the protobuf files to interact with the energyleaf backend.

Installation

Install energyleaf-proto

  cargo add energyleaf-proto

Protocol

syntax = "proto3";

package energyleaf;

enum SensorType {
  ANALOG_ELECTRICITY = 0;
  DIGITAL_ELECTRICITY = 1;
  GAS = 2;
  WATER = 3;
}

message TokenRequest {
  string client_id = 1;
  SensorType type = 2;
  optional bool need_script = 3;
}

message TokenResponse {
  optional string access_token = 1;
  optional uint32 expires_in = 2; // in seconds (look documentation for correct value)
  uint32 status = 3; // In range of 200-299 correct, else bad
  optional string status_message = 4;
  optional string script = 5;
  optional uint32 analog_rotation_per_kwh = 6;
  optional double gas_rotation_per_kwh = 7;
}

message EnergyDataRequest {
  string access_token = 1;
  double value = 2; // kWh total in (analog has kWh consumption)
  optional double value_current = 4; // W currently
  optional double value_out = 5;     // kWh total out (e.g. pv)
  optional string timestamp = 6;
}

message GasDataRequest {
  string access_token = 1;
  double value = 2;
  optional double value_current = 3;
}

message WaterDataRequest {
  string access_token = 1;
  double value = 2;
  optional double value_current = 3;
}

message SensorDataResponse {
  uint32 status = 1;
  optional string status_message = 2;
}

// deprecated
message SensorDataRequestV2 {
  string access_token = 1;
  SensorType type = 2;
  double value = 3;
  optional double value_current = 4;
  optional double value_out = 5;
  optional uint64 timestamp = 6;
}

// deprecated
message ScriptAcceptedRequest { string access_token = 1; }

// deprecated
message ScriptAcceptedResponse {
  uint32 status = 1;
  optional string status_message = 2;
}

Dependencies

~0.2–2MB
~27K SLoC