Skip to main content

Communication with Lektrico's chargers

Project description

LEKTRI.CO

LektricoWifi

This is a package for communicating with Lektrico's chargers (1P7K, 3P22K) and devices (EM, 3EM) when they are in your wifi network.

You have to know the IP of your device.

What is this package offering:

  1. Identify your device by IP

type, serial_number, board_revision

  1. Ready the device's parameters

currents, voltages, powers, errors, ...

see the output in the examples below

  1. Command the device

commands for charger:

  • start charging: send_charge_start
  • stop charging: send_charge_stop
  • reset the device: send_reset
  • enable/disable authorisation: set_auth with bool parameter
  • set leds brightness: set_led_max_brightness with int parameter 10->100
  • set the dynamic current: set_dynamic_current with int parameter 0 or 6->32
  • set the user current: set_user_current with int parameter 6->32
  • lock/unlock the device: set_charger_locked with bool parameter

commands for em:

  • set the load balancing mode (OFF, POWER, HYBRID, GREEN): set_load_balancing_mode with int parameter 0->3
  • reset the device: send_reset

How to use it:

  1. Find the IP of your Lektrico device in your local wifi network

  2. Install it in your python project's environment

    pip install lektricowifi==0.0.25

  3. Install the required library

    pip install aiohttp

  4. Python example for charger: (python 3.11.0)

     import asyncio
     from lektricowifi import Device
     from lektricowifi.models import Info, Settings
     
     async def main():
         """Example of communicating with a Lektrico charger."""
         
         # use your device's IP!
         async with Device("192.168.100.11") as device:
         
             # identify your device's type
             settings: Settings = await device.device_config()
             print(settings)
             """output:  Settings(type='1p7k', serial_number=500006, board_revision='E')"""
             print(settings.type)
             """output:  1p7k"""
             
             # read your device's parameters
             info: Info = await device.device_info(Device.TYPE_1P7K)
             print(info)
             """output:  InfoForCharger(current_l1=0.0, current_l2=0.0, current_l3=0.0, 
             voltage_l1=0.0, voltage_l2=0.0, voltage_l3=0.0, fw_version='1.45_beta', 
             charger_state='Available', session_energy=0.0, charging_time=0, 
             instant_power=0.0, temperature=39.8, dynamic_current=32, require_auth=False, 
             install_current=6, led_max_brightness=100, total_charged_energy=18.0, 
             has_active_errors=False, state_e_activated=False, overtemp=False, 
             critical_temp=False, overcurrent=False, meter_fault=False, 
             undervoltage_error=False, overvoltage_error=False, rcd_error=False, 
             cp_diode_failure=False, contactor_failure=False, user_current=32, 
             current_limit_reason='Installation current')"""
     
             # command the charger to start charging
             answer: bool = await device.send_charge_start()
             print(answer)
             """output:  {'id': 57130362, 'src': '1p7k_500006', 'dst': 'HASS', 'result': True}"""
     
      
     if __name__ == "__main__":
         loop = asyncio.new_event_loop()
         asyncio.set_event_loop(loop)
         loop.run_until_complete(main())
    
  5. Python example for em device: (python 3.11.0)

     import asyncio
     from lektricowifi import Device, LBMode
     from lektricowifi.models import Info, Settings
    
     async def main():
         """Example of communicating with a Lektrico device."""
         
         # use your device's IP!
         async with Device("192.168.100.201") as device:  
            
             # identify your device's type
             settings: Settings = await device.device_config()
             print(settings) 
             """output:  Settings(type='em', serial_number=810172, board_revision='A')"""
             print(settings.type)
             """output:  em"""
     
             # read your device's parameters
             info: Info = await device.device_info(Device.TYPE_EM)
             print(info)
             """output:  InfoForM2W(current_l1=0.0, current_l2=0.0, current_l3=0.0, 
             voltage_l1=230.968, voltage_l2=230.968, voltage_l3=0.1,fw_version='1.15', 
             power_l1=0.0, power_l2=0.0, power_l3=0.0, breaker_curent=32, power_factor_l1=0.0, 
             power_factor_l2=0.0, power_factor_l3=0.0, lb_mode=0)"""
     
             # command the em to change the load balancing mode
             answer: bool = await device.set_load_balancing_mode(LBMode.GREEN.value)
             print(answer)
             """output:  {'id': 32647575, 'src': 'm2w_810172', 'dst': 'HASS', 'result': True}"""
     
      
     if __name__ == "__main__":
         loop = asyncio.new_event_loop()
         asyncio.set_event_loop(loop)
         loop.run_until_complete(main())
    

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

lektricowifi-0.0.37.tar.gz (11.0 kB view details)

Uploaded Source

Built Distribution

lektricowifi-0.0.37-py3-none-any.whl (8.9 kB view details)

Uploaded Python 3

File details

Details for the file lektricowifi-0.0.37.tar.gz.

File metadata

  • Download URL: lektricowifi-0.0.37.tar.gz
  • Upload date:
  • Size: 11.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for lektricowifi-0.0.37.tar.gz
Algorithm Hash digest
SHA256 d25d29f3137744f5443812ac5b1620d9f5c6597c352d869cac8a960b46fa9b0a
MD5 ab26f16eb28b410cf8743b92726d19f4
BLAKE2b-256 1cf77ebd784951201ff5341caf4ed202b4ca3063c29d584555c65c38b5e78bd9

See more details on using hashes here.

File details

Details for the file lektricowifi-0.0.37-py3-none-any.whl.

File metadata

File hashes

Hashes for lektricowifi-0.0.37-py3-none-any.whl
Algorithm Hash digest
SHA256 b29d6e2dcec7756aa6d3bd7cabca607cb6720ef0904ef6a977e4ef0df00f3aef
MD5 7d45953bfd153b17fc5613595bbd9889
BLAKE2b-256 a0d51e6b2d6983306a54f37d920ec2f2daaf323b49b6b158c97e07384540d978

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page