Giter Club home page Giter Club logo

meross-cloud's Introduction

meross-cloud

NPM version Downloads Test and Release

This library allows to login into Meross cloud server, read the registered devices and open connections to the MQTT cloud server to get the data. The library tries to control the devices locally first (if "localHttpFirst" option is set to true), else will control via cloud server.

Disclaimer

All product and company names or logos are trademarks™ or registered® trademarks of their respective holders. Use of them does not imply any affiliation with or endorsement by them or any associated subsidiaries! This personal project is maintained in spare time and has no business goal. MEROSS is a trademark of Chengdu Meross Technology Co., Ltd.

Example

see example folder

Todo

  • Experiment with multiple MQTT connections vs only one and maybe optimize
  • Find out how reading of Fan and Childlook works :-(

Credits

The library is partially based on the Python project https://github.com/albertogeniola/MerossIot, Thank you for this great basic work on how to connect to the Meross Cloud Servers

Changelog

2.4.0 (2023-01-02)

  • (Apollon77) Added controlRollerShutterPosition that might work with Homekit versions of shutter devices
  • (Apollon77) Prevented crash case reported by Sentry

2.3.1 (2022-09-20)

  • (Apollon77) Fix garage door state control

2.3.0 (2022-09-19)

  • (Apollon77) Add support for additional MAP100 air purifier data

2.2.0 (2022-09-04)

  • (Apollon77) Add support for FilterMaintenance data of MAP100 air purifier
  • (Apollon77) Fix typings: messageId returned by many calls is a string and not a number

2.1.3 (2022-08-12)

  • (Apollon77) Prevent some crash cases reported by Sentry

2.1.2 (2022-08-12)

  • (JackReevies) Remove not needed console logging

2.1.1 (2022-07-12)

  • (Apollon77) Fix new logic

2.1.0 (2022-07-12)

  • (Apollon77) Add new option to define that GET requests are only tried locally and not resend to cloud on error.

2.0.0 (2022-06-27)

  • (Apollon77) Major change: the error event emitted on MerossCloud instance has now as first parameter the error info and second an optional device id!! Before this was partially switched

1.9.1 (2022-06-27)

  • (Apollon77) Also emit an error event if publishing an MQTT message fails

1.9.0 (2022-06-19)

  • (Apollon77) Detect MQTT reconnect issue "Server unavailable" and reinitialize the MQTT connection completely - this case is silently handled as reconnect!

1.8.1 (2022-05-31)

  • (Apollon77) Add timeout parameter to options to use as request timeout. For MQTT data requests the timeout is doubled
  • (Apollon77) Lower the MQTT timeout from 20s to 6s. Can be increased using timeout parameter again if needed

1.7.4 (2022-04-14)

  • (Apollon77) Adjust to recent API changes from Meross services

1.7.2 (2022-02-19)

  • (Apollon77) Fix pot. crash case

1.7.1 (2022-01-26)

  • (Apollon77) Fix pot. crash case

1.7.0 (2022-01-20)

  • (Apollon77) Add option to the library to try to communicate to the device locally using HTTP if the IP is known (or retrieved using getSystemAllData). If a call is not answered via HTTP within 3s the value is sent via MQTT. See above for more details
  • (Apollon77) Restructure library so that only one MQTT connection is used: Effect ist that the "connect()" and "disconnect()" methods are only activating or deactivating if messages are emitted/answered or not!
  • (Apollon77) Add Logout method. Please use to tear down a session at the end (Meross is monitoring too many open sessions)

1.6.0 (2022-01-05)

  • (Apollon77) Add support for MTS200 Wifi Thermostat

1.5.0 (2021-11-13)

  • Add support for MTS150 Thermostats
  • Add support for MRS100 RollerShutter devices
  • update typescript definitions

1.4.0 (2021-04-18)

  • add MOD100 Diffuser Spray device

1.3.6 (2020-12-05)

  • generate an unique uuid for each connection, fixes the "Server not available"

1.3.5 (2020-06-11)

  • update dependencies

1.3.4 (2020-04-12)

  • add typings (thanks to @colthreepv)
  • prevent some error cases

1.3.3 (2019-12-01)

  • handle error cases

1.3.2 (2019-11-28)

  • handle error cases

1.3.1 (2019-11-28)

  • handle error cases

1.3.0

  • more fixes for garage door opener
  • better support lights
  • reconnection fixes
  • support for hub devices

1.2.1

  • try to fix garage door opener

1.2.0

  • add read/write DND-Mode (Device LED)
  • add read SystemRuntime (Wifi Strength)

1.1.0

  • add Light Support

1.0.0

  • move to 1.0.0

0.3.2

  • (Apollon77) fix message handling and ignore messages posted by other devices

0.3.1

  • (Apollon77) add rawData event to allow better debugging

0.3.0

  • (Apollon77) Add more functions for mss310 devices

0.2.0

  • (Apollon77) implement all functionalities for adapter

0.1.0

  • (Apollon77) initial first release

meross-cloud's People

Contributors

apollon77 avatar dependabot[bot] avatar dependabot-preview[bot] avatar colthreepv avatar jackreevies avatar greenkeeper[bot] avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.