forked from dbusjs/node-dbus-next
-
Notifications
You must be signed in to change notification settings - Fork 3
/
index.js
71 lines (65 loc) · 2.74 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
const constants = require('./lib/constants');
const MessageBus = require('./lib/bus');
const errors = require('./lib/errors');
const {Variant} = require('./lib//variant');
const {Message} = require('./lib/message-type.js');
const iface = require('./lib/service/interface');
const createConnection = require('./lib/connection.js');
let createClient = function(params) {
let connection = createConnection(params || {});
return new MessageBus(connection);
};
/**
* Create a new {@link MessageBus} client on the DBus system bus to connect to
* interfaces or request service names. Connects to the socket specified by the
* `DBUS_SYSTEM_BUS_ADDRESS` environment variable or
* `unix:path=/var/run/dbus/system_bus_socket`.
*
* @param {object} [options] - Options for `MessageBus` creation.
* @param {object} [options.negotiateUnixFd] - Whether this bus should support the negotiation of Unix file descriptors.
*/
module.exports.systemBus = function(opts) {
if(!opts)
opts = {};
return createClient({
negotiateUnixFd: opts.negotiateUnixFd,
busAddress:
process.env.DBUS_SYSTEM_BUS_ADDRESS ||
'unix:path=/var/run/dbus/system_bus_socket'
});
};
/**
* Create a new {@link MessageBus} client on the DBus session bus to connect to
* interfaces or request service names.
*
* @param {object} [options] - Options for `MessageBus` creation.
* @param {object} [options.busAddress] - The socket path for the session bus.
* @param {object} [options.negotiateUnixFd] - Whether this bus should support the negotiation of Unix file descriptors.
* Defaults to finding the bus address in the manner specified in the DBus
* specification. The bus address will first be read from the
* `DBUS_SESSION_BUS_ADDRESS` environment variable and when that is not
* available, found from the `$HOME/.dbus` directory.
*/
module.exports.sessionBus = function(opts) {
return createClient(opts);
};
/**
* Use JSBI as a polyfill for long integer types ('x' and 't') in the client
* and the service. This is required for Node verisons that do not support the
* native `BigInt` class which is used by default for these types (version <
* 10.8.0).
*
* @function
* @param {boolean} compat - pass `true` to use JSBI.
*/
module.exports.setBigIntCompat = require('./lib/library-options').setBigIntCompat
module.exports.NameFlag = constants.NameFlag;
module.exports.RequestNameReply = constants.RequestNameReply;
module.exports.ReleaseNameReply = constants.ReleaseNameReply;
module.exports.MessageType = constants.MessageType;
module.exports.MessageFlag = constants.MessageFlag;
module.exports.interface = iface;
module.exports.Variant = Variant;
module.exports.Message = Message;
module.exports.validators = require('./lib/validators');
module.exports.DBusError = errors.DBusError;