npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@twendt/binrpc

v3.3.2

Published

HomeMatic binary RPC protocol - xmlrpc_bin://

Downloads

10

Readme

Fork of hobbyquaker's binrpc module

This fork fixes an issue when using the Homematic app for Homey where continuous reconnects could cause the app to crash.

I recommend using the original version from hobbyquaker in all other cases.

binrpc

npm version dependencies Status Coverage Status Build Status XO code style License

HomeMatic xmlrpc_bin:// protocol server and client

For use with CCU1/2 (rfd, hs485d, Rega), Homegear and CUxD

Implements the same interface as homematic-xmlrpc, these 2 libs should be a 1:1 drop-in-replacement for each other.

Changelog

Breaking Change in v3.0.0: To be consistent with homematic-xmlrpc the RPC client isn't an event emitter anymore. All errors have to be handled through the methodCall callback.

Change in v2.1.0 To be consistent with homematic-xmlrpc you don't have to wait for the client connect event before using methodCall.

Breaking change in v2.0.0: system.multicall isn't resolved in single calls anymore. This should be done by the application itself and was removed to be consistent with homematic-xmlrpc.

Examples

Switch on the Channel LEQ0134153:1

var rpc = require('binrpc');

var rpcClient = rpc.createClient({host: '192.168.1.100', port: '2001'});

rpcClient.methodCall('setValue', ['LEQ0134153:1', 'STATE', true], function (err, res) {
    console.log('response', err, JSON.stringify(res));
});

For a full example on how to subscribe to CCU events see example.js

Further reading

API Documentation

Modules

Classes

binrpc

binrpc.createClient(options) ⇒ Client

RPC client factory

Kind: static method of binrpc

| Param | Type | Default | Description | | --- | --- | --- | --- | | options | object | | | | options.host | string | | the hostname or ip address to connect to | | options.port | number | | the port to connect to | | [options.reconnectTimeout] | number | 2500 | wait milliseconds until trying to reconnect after the socket was closed | | [options.responseTimeout] | number | 5000 | wait milliseconds for method call response | | [options.queueMaxLength] | number | 15 | maximum number of methodCalls that are allowed in the queue |

binrpc.createServer(options, onListening) ⇒ Server

RPC server factory

Kind: static method of binrpc

| Param | Type | Description | | --- | --- | --- | | options | object | | | options.host | string | ip address on which the server should listen | | options.port | number | port on which the server should listen | | onListening | function | function to be invoked in the server's listening callback |

client

client.queue : Array

The request queue. Array elements must be objects with the properties buffer and callback

Kind: instance property of client

client.queueMaxLength : number

Maximum queue length. If queue length is greater than this a methodCall will return error 'You are sending too fast'

Kind: instance property of client

client.queueRetryTimeout : number

Time in milliseconds. How long to wait for retry if a request is pending

Kind: instance property of client

client.pending : boolean

Indicates if there is a request waiting for its response

Kind: instance property of client

client.responseTimeout : number

Time in milliseconds. How long to wait for a method call response

Kind: instance property of client

client.connect()

connect

Kind: instance method of client

client.queuePush(buf, cb)

Push request to the queue

Kind: instance method of client

| Param | Type | | --- | --- | | buf | buffer | | cb | function |

client.queueShift()

Shift request from the queue and write it to the socket.

Kind: instance method of client

client.methodCall(method, params, callback)

methodCall

Kind: instance method of client

| Param | Type | Description | | --- | --- | --- | | method | string | | | params | Array | | | callback | function | optional - if omitted an empty string will be send as response |

protocol

protocol.encodeRequest(method, data) ⇒ Buffer

encode requests

Kind: static method of protocol

| Param | Type | Description | | --- | --- | --- | | method | string | throws error if not type string or if string is empty | | data | * | optional - defaults to an empty array |

protocol.encodeResponse(data) ⇒ Buffer

encode response

Kind: static method of protocol

| Param | Type | Description | | --- | --- | --- | | data | * | optional - defaults to empty string |

protocol.encodeData(obj) ⇒ Buffer

encode data

Kind: static method of protocol

| Param | Type | Description | | --- | --- | --- | | obj | * | throws TypeError if obj is undefined or null |

protocol.encodeStruct(obj) ⇒ Buffer

encode struct

Kind: static method of protocol

| Param | Type | Description | | --- | --- | --- | | obj | object | throws error if not of type object |

protocol.encodeStructKey(str) ⇒ Buffer

encode struct key

Kind: static method of protocol

| Param | Type | Description | | --- | --- | --- | | str | string | throws error if not of type string |

protocol.encodeArray(arr) ⇒ Buffer

encode array

Kind: static method of protocol

| Param | Type | Description | | --- | --- | --- | | arr | array | throws error if not instance of Array |

protocol.encodeString(str) ⇒ Buffer

encode string

Kind: static method of protocol

| Param | Type | Description | | --- | --- | --- | | str | string | throws error if not of type string |

protocol.encodeBool(b) ⇒ Buffer

encode bool

Kind: static method of protocol

| Param | Type | Description | | --- | --- | --- | | b | * | any type |

protocol.encodeInteger(i) ⇒ Buffer

encode integer

Kind: static method of protocol

| Param | Type | Description | | --- | --- | --- | | i | number | throws error if not a number or if out of range (min=-2147483648 max=2147483647) |

protocol.encodeDouble(d) ⇒ Buffer

encode double

Kind: static method of protocol

| Param | Type | Description | | --- | --- | --- | | d | number | throws error if not a number |

protocol.decodeDouble(elem) ⇒ object

decode double

Kind: static method of protocol
Returns: object - properties content and rest

| Param | Type | Description | | --- | --- | --- | | elem | Buffer | throws error if not an instance of Buffer or if length <8 |

protocol.decodeString(elem) ⇒ object

decode string

Kind: static method of protocol
Returns: object - properties content and rest

| Param | Type | Description | | --- | --- | --- | | elem | Buffer | throws error if not an instance of Buffer or if length <4 |

protocol.decodeBool(elem) ⇒ object

decode double

Kind: static method of protocol
Returns: object - properties content and rest

| Param | Type | Description | | --- | --- | --- | | elem | Buffer | throws error if not an instance of Buffer or if length <8 |

protocol.decodeInteger(elem) ⇒ object

decode integer

Kind: static method of protocol
Returns: object - properties content and rest

| Param | Type | Description | | --- | --- | --- | | elem | Buffer | throws error if not an instance of Buffer or if length <4 |

protocol.decodeArray(elem) ⇒ object

decode array

Kind: static method of protocol
Returns: object - properties content and rest

| Param | Type | Description | | --- | --- | --- | | elem | Buffer | throws error if not an instance of Buffer or if length <4 |

protocol.decodeStruct(elem) ⇒ object

decode struct

Kind: static method of protocol
Returns: object - properties content and rest

| Param | Type | Description | | --- | --- | --- | | elem | Buffer | throws error if not an instance of Buffer or if length <4 |

protocol.decodeData(data) ⇒ *

decodes binary data

Kind: static method of protocol

| Param | Type | | --- | --- | | data | Buffer |

protocol.decodeResponse(data) ⇒ *

decode response

Kind: static method of protocol

| Param | Type | Description | | --- | --- | --- | | data | Buffer | throws TypeError if data is no instance of Buffer |

protocol.decodeStrangeRequest(data) ⇒ Array

decode "strange" request

Kind: static method of protocol

| Param | Type | Description | | --- | --- | --- | | data | Buffer | throws TypeError if data is no instance of Buffer |

protocol.decodeRequest(data) ⇒ *

decode request

Kind: static method of protocol

| Param | Type | Description | | --- | --- | --- | | data | Buffer | throws TypeError if not instance of Buffer |

server

Client

Kind: global class

new Client(options)

| Param | Type | Default | Description | | --- | --- | --- | --- | | options | object | | | | options.host | string | | the hostname or ip address to connect to | | options.port | number | | the port to connect to | | [options.reconnectTimeout] | number | 2500 | wait milliseconds until trying to reconnect after the socket was closed | | [options.responseTimeout] | number | 5000 | wait milliseconds for method call response | | [options.queueMaxLength] | number | 15 | maximum number of methodCalls that are allowed in the queue |

Protocol

Kind: global class

Server

Kind: global class

new Server(options, onListening)

| Param | Type | Description | | --- | --- | --- | | options | object | | | options.host | string | ip address on which the server should listen | | options.port | number | port on which the server should listen | | onListening | function | function to be invoked in the server's listening callback |

"[method]" (error, params, callback)

Fires when RPC method call is received

Kind: event emitted by Server

| Param | Type | Description | | --- | --- | --- | | error | * | | | params | array | | | callback | function | callback awaits params err and response |

"NotFound" (method, params)

Fires if a RPC method call has no event handler. RPC response is always an empty string.

Kind: event emitted by Server

| Param | Type | | --- | --- | | method | string | | params | array |

License

The MIT License (MIT)

Copyright (c) 2014-2018 Sebastian 'hobbyquaker' Raff and Contributors

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.