Native SDK Quick Reference for Node.js
This chapter is a quick reference for the following classes, which are all members of module external:"intersystems-iris-native"
-
Class Connection provides a connection to the server.
-
Class Iris provides the main functionality.
-
Class Iterator provides methods to navigate a global array.
This chapter is intended as a convenience for readers of this book, but it is not the definitive reference for the Native SDK. For the most complete and up-to-date information on these classes, see the online SDK documentation.
List of Methods by Usage
The Connection class encapsulates a connection to the server. Instances of Connection are created and connected to the server by external:"intersystems-iris-native" method createConnection().
-
close() — closes the connection.
-
createIris() — creates an instance of Iris for this connection.
-
isClosed() — returns true if the connection is closed.
-
isUsingSharedMemory() — returns true if the connection is using shared memory.
The Iris class provides most of the Native SDK functionality. Instances of Iris are created by Connection.createIris(). Methods are listed below, organized by usage:
-
getAPIVersion() — returns the version string for this version of the Native SDK.
-
getServerVersion() — returns the version string for the currently connected server.
-
increment() — increments the value of a global node by the specified amount.
-
isDefined() — checks if a global node exists, and if it contains data.
-
iterator() — returns an instance of Iterator.
-
kill() — kills the global node including any descendants.
-
get() — returns the specified node value
-
getBoolean() — returns a node value as boolean
-
getBytes() — returns a node value as an ArrayBuffer
-
getNumber() — returns a node value as a number
-
getString() — returns a node value as a string
-
lock() — performs an incremental lock on the global, returns true on success.
-
unlock() — performs an immediate or deferred unlock on the global.
-
releaseAllLocks() — releases all locks associated with the session.
-
getTLevel() — returns the current transaction level (0 if not in a transaction).
-
tCommit() — commits the current transaction and decrements the transaction level.
-
tRollback() — rolls back all open transactions in the session.
-
tRollbackOne() — rolls back the current level transaction only.
-
tStart() — starts a transaction and increments the transaction level.
-
classMethodValue() — calls a user defined ObjectScript method and gets the returned value
-
classMethodVoid() — calls a user defined ObjectScript method, ignoring any returned value
-
function() — calls a function of a user defined ObjectScript routine and gets the returned value
-
procedure() — calls a procedure of a user defined ObjectScript routine
The Iterator class provides methods to iterate over a set of nodes. Instances of Iterator are created by Iris.iterator().
-
next() — positions the iterator at the next sibling node.
-
startFrom() — sets starting position to the specified subscript.
-
reversed() — toggles iteration between forward and reverse collation order.
-
entries() — sets return type to an array containing subscript and node value.
-
keys() — sets return type to return the node subscript (key) only.
-
values() — sets return type to return the node value only.
Class Connection
Class Connection is a member of external:"intersystems-iris-native". Instances of Connection are created by intersystems-iris-native method createConnection().
intersystems-iris-native createConnection() establishes a connection to the server.
(static) createConnection(connectionInfo) → {external:"intersystems-iris-native".Connection}
parameters:
-
connectionInfo — Object containing connection properties. Valid properties of connectionInfo are:
-
host — required string containing the address of the host machine
-
port — required integer specifying the port number
-
ns — required string containing the database namespace
-
user — string containing the user name
-
pwd — string containing the password
-
sharedmemory — boolean indicating whether to use shared memory if available (default is true).
-
timeout — integer specifying the number of milliseconds to wait before the connection attempt times out (default is 10000).
-
logfile — string specifying the full path and name of a log file for this connection. If not specified, no log file will be written.
For example, the following code fragment defines all properties of connectionInfo and creates an instance of Connection named conn:
const IRISNative = require('intersystems-iris-native') let connectionInfo = { host: '127.0.0.1', port: 51773, ns: 'USER', user: '_SYSTEM', pwd: 'SYS', sharedmemory: true timeout: 5, logfile: 'C:\temp\mylogfile.log' }; const conn = IRISNative.createConnection(connectionInfo);
-
Connection.close() closes the connection to the server.
close()
Connection.createIris() returns an instance of class Iris connected to the server by this Connection.
createIris() →→ {external:"intersystems-iris-native".Iris}
Connection.isClosed() returns true if the connection is currently closed, false if the connection is currently open.
isClosed() → {boolean}
Class Iris
Class Iris is a member of external:"intersystems-iris-native". Instances of Iris are created by calling Connection.createIris().
Class Iris is the main Native SDK module, implementing global functions, function and procedure calls, locks, and transactions.
Iris.classMethodValue() calls a class method, passing 0 or more arguments and returning the called method’s return value..
classMethodValue(className, methodName, ...args) → {any}
parameters:
-
className — fully qualified name of the class to which the called method belongs.
-
methodName — name of the class method.
-
args — 0 or more method arguments of supported types (see “Calling ObjectScript Methods and Functions”). Trailing arguments may be omitted.
Iris.classMethodVoid() calls a class method, passing 0 or more arguments and returning nothing.
classMethodVoid(className, methodName, ...args)
parameters:
-
className — fully qualified name of the class to which the called method belongs.
-
methodName — name of the class method.
-
args — 0 or more method arguments of supported types (see “Calling ObjectScript Methods and Functions”). Trailing arguments may be omitted.
Iris.function() calls a function, passing 0 or more arguments and returning the called function’s return value.
function(routineName, functionName, ...args) → {any}
parameters:
-
routineName — name of the routine containing the function.
-
functionName — name of the function to call
-
args — 0 or more function arguments of supported types (see “Calling ObjectScript Methods and Functions”). Trailing arguments may be omitted.
Iris.get() returns the value of the global node. Returns false if node value is an empty string, or null if the specified node address does not have a value.
get(globalName, ...subscripts) → {any}
parameters:
-
globalName — global name
-
subscripts — array of subscripts specifying the target node
Iris.getAPIVersion() returns the Native SDK version string.
getAPIVersion() → {string}
Iris.getBoolean() returns the node value as a boolean. Returns false if node value is an empty string, or null if the specified node address does not have a value.
getBoolean(globalName, ...subscripts) → {boolean}
parameters:
-
globalName — global name
-
subscripts — array of subscripts specifying the target node
Iris.getBytes() returns the node value as an ArrayBuffer. Returns false if node value is an empty string, or null if the specified node address does not have a value.
getBytes(globalName, ...subscripts) → {ArrayBuffer}
parameters:
-
globalName — global name
-
subscripts — array of subscripts specifying the target node
Iris.getNumber() returns the node value as a number. Returns false if node value is an empty string, or null if the specified node address does not have a value.
getNumber(globalName, ...subscripts) → {number}
parameters:
-
globalName — global name
-
subscripts — array of subscripts specifying the target node
Iris.getServerVersion() returns the version string of the currently connected server.
getServerVersion() → {string}
Iris.getString() returns the node value as a string. Returns false if node value is an empty string, or null if the specified node address does not have a value.
getString(globalName, subscripts) → {string}
parameters:
-
globalName — global name
-
subscripts — array of subscripts specifying the target node
Iris.getTLevel() returns the level of the current nested transaction. Returns 1 if there is only a single transaction open. Returns 0 if there are no transactions open. This is equivalent to fetching the value of the $TLEVEL special variable. See “Transactions and Locking” for more information and examples.
getTLevel() → {number}
Iris.increment() increments the specified node by the integer value of incrementBy. If the specified node address does not have a value, then the node will be created and its value set to the value of incrementBy. Returns the new integer value of the node.
increment(incrementBy, globalName, ...subscript) → {number}
parameters:
-
incrementBy — numeric value to which to set this node (null value sets global to 0, decimal value will be truncated to an integer).
-
globalName — global name
-
subscripts — array of subscripts specifying the target node
Iris.isDefined() checks if a global exists and contains data (see $DATA). Returns 0 if the node does not exist, 1 if the global node exists and contains data. 10 if the node is valueless but has descendants. 11 if it has data and descendants. See “Testing for Child Nodes and Node Values” for more information and examples.
isDefined(globalName, ...subscript) → {number}
parameters:
-
globalName — global name
-
subscripts — array of subscripts for this node
Iris.iterator() returns an Iterator object (see “Class Iterator”) for the specified node.
iterator(globalName, ...subscript) → {external:"intersystems-iris-native".Iterator}
parameters:
-
globalName — global name
-
subscripts — array of subscripts specifying the target node
Iris.kill() kills the global node including any descendants.
kill(globalName, ...subscript)
parameters:
-
globalName — global name
-
subscripts — array of subscripts for this node
Iris.lock() locks the global, returns true on success. This method performs an incremental lock, not the implicit unlock-before-lock feature that is offered in ObjectScript.
lock(lockMode, timeout, lockReference, ...subscript) → {boolean}
parameters:
-
lockMode — one of the following strings: "S" for shared lock, "E" for escalating lock, "SE" for both, or "" for neither. An empty string is the default mode (unshared and non-escalating).
-
timeout — number of seconds to wait to acquire the lock
-
lockReference — a string starting with a circumflex (^) followed by the global name (for example, ^myGlobal, not just myGlobal).
NOTE: Unlike the globalName parameter used by most methods, the lockReference parameter must be prefixed by a circumflex. Only lock() and unlock() use lockReference instead of globalName.
-
subscripts — array of subscripts for this node
Iris.procedure() calls a procedure, passing 0 or more arguments.
procedure(routineName, procedureName, ...args)
parameters:
-
routineName — name of the routine containing the procedure.
-
procedureName — name of the procedure to call.
-
args — 0 or more procedure arguments of supported types (see “Calling ObjectScript Methods and Functions”). Trailing arguments may be omitted.
Iris.releaseAllLocks() releases all locks associated with the session.
releaseAllLocks()
Iris.set() sets the specified node to a value of any supported datatype (or "" if the value is null):
set(value, globalName, ...subscript)
parameters:
-
value — value of any supported datatype (null value sets global to "").
-
globalName — global name
-
subscripts — array of subscripts for this node
Iris.tCommit() commits the current transaction and decrements the transaction level. See “Transactions and Locking” for more information and examples.
tCommit()
Iris.tRollback() rolls back all open transactions in the session. See “Transactions and Locking” for more information and examples.
tRollback()
Iris.tRollbackOne() rolls back the current level transaction only. If this is a nested transaction, any higher-level transactions will not be rolled back. See “Transactions and Locking” for more information and examples.
tRollbackOne()
Iris.tStart() starts a transaction and increments the transaction level. See “Transactions and Locking” for more information and examples.
tStart()
Iris.unlock() unlocks the global. This method performs an incremental unlock, not the implicit unlock-before-lock feature that is also offered in ObjectScript.
unlock(lockMode, lockReference, ...subscript)
parameters:
-
lockMode — one of the following strings: "S" for shared lock, "E" for escalating lock, "SE" for both, or "" for neither. An empty string is the default mode (unshared and non-escalating).
-
lockReference — a string starting with a circumflex (^) followed by the global name (for example, ^myGlobal, not just myGlobal).
NOTE: Unlike the globalName parameter used by most methods, the lockReference parameter must be prefixed by a circumflex. Only lock() and unlock() use lockReference instead of globalName.
-
subscripts — array of subscripts for this node
Class Iterator
Class Iterator is a member of external:"intersystems-iris-native". Instances of Iterator are created by calling Iris.iterator(). See “Finding Nodes in a Global Array” for more details and examples.
Iterator.next() positions the iterator at the next sibling node in collation order and returns an object containing done and value properties. If the iterator is at end then done is true, otherwise it is false.
next() → {any}
When done is false, the return type of the value property can be set by any of the following methods:
Iterator.startFrom() sets the iterator's starting position to the specified subscript. The starting position does not have to be a valid subnode. Returns this for chaining.
startFrom(subscript) → {external:"intersystems-iris-native".Iterator}
parameter:
-
subscript — the subscript to use as a starting point. Does not have to specify an existing node.
The iterator will not point to a node until you call next() to advance to the next existing node in collating order.
Iterator.reversed() toggles iteration direction between forward and reverse collation order. By default, the iterator is set to forward iteration when it is defined. Returns this for chaining.
reversed() → {external:"intersystems-iris-native".Iterator}
Iterator.entries() specifies that next().value should be an array containing the node subscript (value(0)) and node value (value(1)). Returns this for chaining.
entries() → {external:"intersystems-iris-native".Iterator}
Iterator.keys() specifies that next().value should contain only the node subscript (key). Returns this for chaining.
keys() → {external:"intersystems-iris-native".Iterator}
Iterator.values() specifies that next().value should contain only the node value. Returns this for chaining.
values() → {external:"intersystems-iris-native".Iterator}