ServerInterface¶
-
class
jetstream.serverinterface.
ServerInterface
(api_interface, sync_interface, logging_interface)¶
Method Summary¶
auth |
Authenticates a user. |
authAsync |
Authenticates a user. |
authToken |
Authenticates using a shared token. |
createAPIToken |
Creates an API token to allow restricted login access. |
deleteAPIToken |
Deletes the specified api token. |
deleteSandboxMapping |
Deletes the sandbox mappings for a user. |
duAsync |
Submits a request to retrieve the total size, in bytes, for all files in the specified remote path, as visible to the connected server. |
echo |
Sends the (optionally) given text to the server, and returns it from the server. |
garbageCollect |
Initiates an immediate garbage collection on the connected server. |
getAPIToken |
Returns a structure describing an API token. |
getAPITokens |
Returns information for all known api tokens. |
getEventLog |
Returns the JetStream event log. |
getRequestResult |
Returns the result for an asynchronous request. |
getRequestStatus |
Returns the status for an asynchronous request. |
getSandboxMappings |
Gets the sandbox mappings for all users. |
getServerInfo |
Returns information about the connected server, including its name and API version. |
getThirdPartyLicenses |
Returns the licenses for third-party software components used by JetStream. |
lsAsync |
Submits a request to retrieve a list of remote files, as visible to the connected server. |
lsRootsAsync |
Submits a request to retrieve a list of the root folders, as visible to the connected server. |
mkdirAsync |
Submits a request to create a new directory on the connected server, creating all parent directories as needed. |
mvAsync |
Submits a request to move or rename a path on the connected server. |
recvDiscoverPacketAsync |
Creates a request to wait for an incoming receiver discovery packet. |
rmAsync |
Submits a request to remove a path on the connected server. |
sendDiscoverPacketAsync |
Sends a discovery packet to a waiting server. |
setLicenseKeyAsync |
Submits a request to set the license key for the server. |
setSandboxMapping |
Sets the sandbox mappings for a user. |
sleep |
Sleep for specified number of milliseconds. |
superuser |
Gives a user permission to access and modify all data. |
terminate |
Terminate the server. |
updateBandwidthLimits |
Sets limits on incoming and outgoing bandwidth utilization. |
updateGarbageCollectSettings |
Updates garbage collection. |
Method Documentation¶
-
ServerInterface.
auth
(userName, password)¶ Authenticates a user.
Helper method for
authAsync()
to make the call synchronous.Parameters: - userName (string) – Name of the user on the JetStream server.
- password (string) – Password for the user above. Pass in getpass.getpass() if you wish to input the password interactively.
Returns: None
Raises: CommandError
– On auth failure
-
ServerInterface.
authAsync
(userName=None, password=None, token=None, tokenSession=None)¶ Authenticates a user.
If the JetStream server is running as root or daemon, you must call either
auth()
orauthAsync()
after callingconnect()
, before any other method is called (exceptgetServerInfo()
)Parameters: - userName (string) – Name of the user on the JetStream server. Must be None if
token
is set. - password (string) – Password for the user or token.
- token (string) – Shared token. Must be None if
userName
is set. - tokenSession (string) – Shared token session. If
token
is set, this parameter specifies the optional session. Sharing a session between two token authed connections allows them to share data such as transfers. IftokenSession
is not specified, one will be generated automatically. The current token session is returned bygetServerInfo()
.
Returns: Returns a Request Structure containing a
requestId
for this request. UsegetRequestStatus()
orgetRequestResult()
to monitor the status of the request.getRequestResult()
will returnNone
on success, or raise aCommandError
.Return type: dict
Tip
Use
getpass.getpass()
to prompt for thepassword
parameter interactively.- userName (string) – Name of the user on the JetStream server. Must be None if
-
ServerInterface.
authToken
(token, password=None, tokenSession=None)¶ Authenticates using a shared token.
Helper method for
authAsync()
to make the call synchronous.Parameters: - token (string) – Shared token as generated by
createSharedToken()
- password (string) – Password for the token above. Pass in getpass.getpass() if you wish to input the password interactively.
- tokenSession (string) – Shared token session. If
token
is set, this parameter specifies the optional session. Sharing a session between two token authed connections allows them to share data such as transfers. IftokenSession
is not specified, one will be generated automatically. The current token session is returned bygetServerInfo()
.
Returns: None
Raises: CommandError
– On auth failure- token (string) – Shared token as generated by
-
ServerInterface.
createAPIToken
(path=None, password=None, timeLimitSeconds=None, description=None, permissions=None)¶ Creates an API token to allow restricted login access.
Createa an API token with optional password that can be used to log into the server. When logged in, the token will impersonate the user that created it, and all file operations will occur as that user. Permissions and sandbox path access, however, can be restricted so that the token user does not have all the same rights as the original user.
Common use cases include creating a token with access only to a specific directory (shared folder), or creating a token for use in scripting so that the user’s credentials remain private. Tokens are time limited, and can be revoked at any time, so can be used as a type of simple user management. Keep in mind, however, that file permissions are still restricted to the original user.
The returned structure provides a ‘token’ string which may be be used by clients to log on.
Parameters: - path – (optional) If provided, the token user will only have access to the given path. If not provided, then the token user will have access to all paths/drives/sandboxes as the user.
- password (str) – (optional) A password required to auth this token.
- timeLimitSeconds – (optional) Number of seconds from now before this token expires.
- description – (optional) A description of what this token represents.
Returns: Return type: dict
See also
New in version 2.4.0.
-
ServerInterface.
deleteAPIToken
(token)¶ Deletes the specified api token.
An api token may be deleted at any time, even if it is currently being used as part of a transfer or log in session. The active transfer will continue and will not be terminated.
Parameters: token (str, dict) – An API Token or Token Structure. Returns: None Raises: CommandError
– The api token was not found.New in version 2.4.0.
-
ServerInterface.
deleteSandboxMapping
(userName)¶ Deletes the sandbox mappings for a user.
Sandbox mappings can only be modified by a superuser.
Warning
Deleted sandbox mapping only take effect for new user sessions. Existing user sessions will not be affected.
See Sandboxing in JetStream Server Documentation.
Parameters: userName (string) – The user name of the user to sandbox. Note that the user name may be left blank to indicates the system sandbox. Returns: None Raises: CommandError
– If the user is not granted superuser privileges, or no sandbox exists for the user.New in version 1.5.0.
-
ServerInterface.
duAsync
(path)¶ Submits a request to retrieve the total size, in bytes, for all files in the specified remote path, as visible to the connected server.
The result is provided as a dictionary with a single key:
du
: The total size, in bytes, collected from the specified path.
Parameters: path (string) – The remote path to enumerate on the connected server. Returns: Returns a Request Structure containing a requestId
for this request. UsegetRequestStatus()
orgetRequestResult()
to monitor the status of the request.Return type: dict
-
ServerInterface.
echo
(text=None)¶ Sends the (optionally) given text to the server, and returns it from the server.
Tip
This method can be used to check if the API connection is still active.
Parameters: text (string) – Optional text to be echoed by the server. Returns: None if not input text given, or the given text. Return type: None, str
-
ServerInterface.
garbageCollect
(force=False)¶ Initiates an immediate garbage collection on the connected server.
A periodic garbage collection is automatically performed on the server. This causes an immediate garbage collection, with the option to override the allowed grace period.
A garbage collection can only be initiated by a superuser.
Parameters: force – (optional) If set, disregards the grace period for items that are ready to be garbage collected and discard immediately. Default is False. Raises: CommandError
– If the user is not granted superuser privileges.New in version 1.8.0.
-
ServerInterface.
getAPIToken
(token)¶ Returns a structure describing an API token.
Parameters: token (str, dict) – An API Token or Token Structure. Returns: Token Structure Return type: dict Raises: CommandError
– The api token was not found.See also
New in version 2.4.0.
-
ServerInterface.
getAPITokens
(limit=None)¶ Returns information for all known api tokens.
Parameters: limit (int) – (optional) The maximum number of results to retrieve. If not specified, all available api tokens are returned. Returns: A list of api token structures, each describing an api token. Return type: list See also
New in version 2.4.0.
-
ServerInterface.
getEventLog
(eventName=None, before=None, after=None, limit=None)¶ Returns the JetStream event log.
The log is retrieved chronologically, ordered oldest event to newest. Optional parameters may be provided to filter which events are retrieved.
Parameters: - eventName (str) – (optional) Filters the results to include only this event type. If None, retrieve all events.
- before (int) – (optional) Filters the results to include only events before this time. If None, retrieve all entries to the end of the log.
- after (int) – (optional) Filters the results to include only events after this time. If None, retrieve all entries from the start of the log.
- limit (int) – (optional) The maximum number of log entries to retrieve. If None, retrieve all entries.
Returns: Dictionary with an
eventLog
key containing a list of event log structures.Return type: dict
Example
>>> api.server.getEventLog() {'eventLog': [{'_event': 'serverStarted', '_timestamp': 1485547699055816}, {'_event': 'destinationCreated', '_timestamp': 1485547708422759, 'destinationId': '127.0.0.1:8886'} ] }
-
ServerInterface.
getRequestResult
(requestId)¶ Returns the result for an asynchronous request.
API methods whose name ends with
Async
represent asynchronous requests. These methods are sent a request which must be processed by the destination server, and return arequestId
.getRequestResult()
returns the result from an asynchronous request, where the request is identified with itsrequestId
.If the request is not yet complete, this blocks until the result is available.
If a request fails,
getRequestResult()
will yieldNone
. UsegetRequestStatus()
to determine the cause of the failure.Note
Allowing the results from asynchronous requests to be retrieved at an arbitrary time means that the result must be cached on the server. To avoid resource exhaustion, requests are set to expire after a period a time. Once expired, a request is no longer available.
Parameters: requestId (int, dict) – A request ID or Request Structure.
Returns: A dictionary describing the result from the request. The structure of the result varies depending on which API method initiated the request.
Return type: dict, None
Raises: CommandError
– The request was not found, either expired, or never issued.CommandError
– If the API method that initiated this request resulted in an error.
-
ServerInterface.
getRequestStatus
(requestId)¶ Returns the status for an asynchronous request.
API methods whose name ends with
Async
represent asynchronous requests. These methods are sent a request which must be processed by the destination server, and return arequestId
.getRequestStatus()
returns the current status for an asynchronous request, where the request is identified with itsrequestId
. When an asynchronous request is complete, its result is available togetRequestResult()
.Note
Allowing the results from asynchronous requests to be retrieved at an arbitrary time means that the result must be cached on the server. To avoid resource exhaustion, requests are set to expire after a period a time. Once expired, a request is no longer available.
The
status
field in the result indicates whether the request was successful. It may be one of three values:pending
: The request has not yet been processed.success
: The request was successful.error
: An unrecoverable error has terminated the request.
You may use the
pending
status to implement your own asynchronous poll behavior while your script waits for the request to be processed.If the status is
error
then theerrorMessage
field contains a description of the error.Parameters: requestId (int, dict) – A request ID, as returned from any of the Async
methods. Also allowed is the full dict from anAsync
method. The request ID is extracted from therequestId
key.Returns: Request Structure Return type: dict Raises: CommandError
– The request was not found, either expired, or never issued.
-
ServerInterface.
getSandboxMappings
()¶ Gets the sandbox mappings for all users.
Sandbox mappings can only be accessed by a superuser.
See Sandboxing in JetStream Server Documentation.
Returns: Returns a dictionary that maps user names to sandbox mappings, where a sandbox mapping is a dictionary that maps sandbox names to sandbox paths. Return type: dict Raises: CommandError
– If the user is not granted superuser privileges.New in version 1.5.0.
-
ServerInterface.
getServerInfo
()¶ Returns information about the connected server, including its name and API version.
Tip
This method does not require authentication.
Returns: Server Information Structure Return type: dict
-
ServerInterface.
getThirdPartyLicenses
()¶ Returns the licenses for third-party software components used by JetStream.
Returns: Library name, license text. Return type: dict
-
ServerInterface.
lsAsync
(path, directory=False)¶ Submits a request to retrieve a list of remote files, as visible to the connected server.
The result is provided as a dictionary with two keys:
path
: The path to the directory being listed.files
: The stats for the requested files.
Each item in the “file” list is a dictionary containing the following keys:
name
: The name of the file. To build the full path, join the parentpath
with this name.type
: Whether this file is a regular file (4
), a directory (2
) or a symlink (5
).size
: The size, in bytes, of a regular file. For a directory or symlink, this will be 0 (zero).mtime
: The file’s last modification time as a UNIX Time (seconds since Epoch). Usetime.ctime
to convert to a human readable form.mtimeus
: The file’s last modification time in microseconds since Epoch (see Timestamps).access
: Combined read (1 << 2
), write (1 << 1
) and execute (1 << 0
) bits that describes the current user’s access to this file.
Parameters: - path (string) – The remote path to list on the connected server.
- directory (bool) – (optional) If True, the specified path is a directory, and the result should return information about the directory itself, rather than the content of the directory.
Returns: Returns a Request Structure containing a
requestId
for this request. UsegetRequestStatus()
orgetRequestResult()
to monitor the status of the request.Return type: dict
Changed in version 2.3.0: Added
mtimeus
.
-
ServerInterface.
lsRootsAsync
()¶ Submits a request to retrieve a list of the root folders, as visible to the connected server.
The result is provided as a dictionary with two keys:
path
: Representing the parent of the root folder, this will be an empty string.files
: The stats for each root folder.
Each item in the “file” list is a dictionary containing the following keys:
name
: The name of the root folder.type
:10
, combining drive (8
) and directory (2
).size
:0
(zero).mtime
: The folder’s last modification time. Usetime.ctime
to convert to a human readable form.access
: Combined read (1 << 2
), write (1 << 1
) and execute (1 << 0
) bits that describes the current user’s access to this root.
Returns: Returns a Request Structure containing a requestId
for this request. UsegetRequestStatus()
orgetRequestResult()
to monitor the status of the request.Return type: dict
-
ServerInterface.
mkdirAsync
(path)¶ Submits a request to create a new directory on the connected server, creating all parent directories as needed.
Tip
This will not fail if the requested directory already exists.
Parameters: path (string) – The remote path to create on the connected server. Returns: Returns a Request Structure containing a requestId
for this request. UsegetRequestStatus()
orgetRequestResult()
to monitor the status of the request.getRequestResult()
will returnNone
on success, or raise aCommandError
.Return type: dict New in version 1.3.0.
Changed in version 1.8.0: Removed
parents
parameter. Parent directories are always created.
-
ServerInterface.
mvAsync
(path, newPath)¶ Submits a request to move or rename a path on the connected server.
Parameters: - path (string) – The remote path to create on the connected server.
- newPath (string) – The new name for the path.
Returns: Returns a Request Structure containing a
requestId
for this request. UsegetRequestStatus()
orgetRequestResult()
to monitor the status of the request.getRequestResult()
will returnNone
on success, or raise aCommandError
.Return type: dict
New in version 1.5.0.
-
ServerInterface.
recvDiscoverPacketAsync
(timeoutSeconds=None)¶ Creates a request to wait for an incoming receiver discovery packet.
A JetStream server may not know its address and port as visible to another. This function creates a token called a
discover id
and then waits for another server to send it a special packet that contains this data. Upon receipt, this server can derive the address of the server that sent the data. The server whose address is being discovered should send thediscover id
usingsendDiscoverPacketAsync()
.Parameters: timeoutSeconds (float) – (optional) The number of seconds to wait for an incoming discover packet. If unused, a default timeout is used. Returns: Returns a Request Structure containing a requestId
for this request. UsegetRequestStatus()
orgetRequestResult()
to monitor the status of the request. The dict additionally contains adiscoverId
key for use withsendDiscoverPacketAsync()
. Ultimately, the result from the async function will be a Discover Packet Structure.getRequestResult()
will return dictionary Discover Packet Structure.Return type: dict Example
# Server A wants to transfer data to B, but does not know B's public address. # We do, however, have API access to both server A and B, and we know A's public address. # Server A can "discover" B's address as follows: # 1. Ask server A to listen for a discover packet. >>> recvRequest = A.server.recvDiscoverPacketAsync() >>> discoverId = recvRequest['discoverId'] # 2. Ask server B to send a discover packet using the return value form recvDiscoverPacketAsync. >>> sendRequest = B.server.sendDiscoverPacketAsync(discoverId, A_addr, A_port) >>> B.server.getRequestResult(sendRequest) {'discoverPacketSent': True} # 3. Wait for the discovery packet to be received or a timeout. On success, returns the address of B. >>> A.server.getRequestResult(recvRequest) {'port': 54946, 'address': '10.96.64.60'}
-
ServerInterface.
rmAsync
(path)¶ Submits a request to remove a path on the connected server. If the path refers to a directory, all files and directories under that path will be removed.
Parameters: path (string) – The remote path to remove on the connected server. Returns: Returns a Request Structure containing a requestId
for this request. UsegetRequestStatus()
orgetRequestResult()
to monitor the status of the request.getRequestResult()
will returnNone
on success, or raise aCommandError
.Return type: dict New in version 1.5.0.
-
ServerInterface.
sendDiscoverPacketAsync
(discoverId, destinationAddress, destinationPort=None)¶ Sends a discovery packet to a waiting server.
A JetStream server may not know its address and port as visible to another. This function sends a special packet to another server to allow that server to discover this server’s receiving address and port. This function must be used in conjunction with
recvDiscoverPacketAsync()
. See that function for a usage example.Parameters: - discoverId (int, dict) – A discover id as returned by
recvDiscoverPacketAsync()
. Also allowed is the full dict fromrecvDiscoverPacketAsync()
. The discover ID is extracted from thediscoverId
key. - destinationAddress (str) – The host name or IP of the server that called
recvDiscoverPacketAsync()
. - destinationPort (int) – (optional) The port of the serer that called
recvDiscoverPacketAsync()
.
Returns: Returns a Request Structure containing a
requestId
for this request. UsegetRequestStatus()
orgetRequestResult()
to monitor the status of the request.Return type: dict
Note
A discovery packet may be lost, so it is prudent to send several packets before concluding that the connection failed.
- discoverId (int, dict) – A discover id as returned by
-
ServerInterface.
setLicenseKeyAsync
(key, validate=None)¶ Submits a request to set the license key for the server.
The license key can only be modified by a superuser.
Parameters: - key (string) – The new license key.
- validate (bool) – Only set the license after validating the key with the license server.
Returns: None
Raises: CommandError
– If the user is not granted superuser privileges.New in version 2.1.0.
-
ServerInterface.
setSandboxMapping
(userName, sandboxRoots)¶ Sets the sandbox mappings for a user.
Sandbox mappings can only be modified by a superuser.
A sandbox mapping is a dictionary that maps sandbox names to sandbox roots for a particular user. This sandbox names provide the roots paths available to the user (see
lsRootsAsync()
). All sandbox root paths are accessed by prefixing paths with the sandbox name followed by a colon.Note
New sandbox mapping only take effect for new user sessions.
See Sandboxing in JetStream Server Documentation.
Parameters: - userName (string) – The user name of the user to sandbox. Note that the user name may be left blank
to indicates the system sandbox. Any user who does not have a specific sandbox mapping will inherit
the sandbox mapping from the system sandbox. The system sandbox may contain placeholders such as
%u
. - sandboxRoots (dict) – A dictionary of sandbox names to sandbox root paths. Sandbox names may be left
blank to indicate a root of
/
. If sandbox roots is False, then the user is not sandboxed.
Returns: None
Raises: CommandError
– If the user is not granted superuser privileges, a sandbox path is empty, or a sandbox name contains illegal characters.New in version 1.5.0.
- userName (string) – The user name of the user to sandbox. Note that the user name may be left blank
to indicates the system sandbox. Any user who does not have a specific sandbox mapping will inherit
the sandbox mapping from the system sandbox. The system sandbox may contain placeholders such as
-
ServerInterface.
sleep
(milliseconds)¶ Sleep for specified number of milliseconds.
-
ServerInterface.
superuser
()¶ Gives a user permission to access and modify all data.
Only a user who has successfully called
auth()
with superuser eligible credentials will be granted superuser privileges. Users are eligible for superuser privileges if they share the same credentials as the user who started the server or have been listed as eligible during server configuration.Returns: None Raises: CommandError
– If the user is not granted superuser privileges.
-
ServerInterface.
terminate
()¶ Terminate the server.
The user must be a superuser before shutting down the server.
-
ServerInterface.
updateBandwidthLimits
(incomingLimitActive=None, incomingRateLimit=None, incomingMaxConnections=None, borrowOutgoing=None, outgoingLimitActive=None, outgoingRateLimit=None, borrowIncoming=None)¶ Sets limits on incoming and outgoing bandwidth utilization.
All parameters are optional. Any parameters which are unspecified or set to None will be unchanged.
Bandwidth limits can only be modified by a superuser.
Note
Bandwidth limits specified on the server command-line during startup become locked and cannot be changed. Attempting to update locked limits using this method will fail.
Warning
Compatibility note: When bandwidth control settings are enabled via the API or command line parameters on a JetStream server, clients prior to version 1.6.0 (API 22) will not be able to communicate with this server.
Parameters: - incomingLimitActive (bool) – Apply limits to incoming data.
- incomingRateLimit (float) – The maximum rate that data will be received, in kilobits/second.
- incomingMaxConnections (int) – The maximum number of incoming connections permitted.
- borrowOutgoing (bool) – If there is an outgoing rate limit, allow unused outgoing bandwidth to be added to the incoming rate limit.
- outgoingLimitActive (bool) – Apply limits to outgoing data.
- outgoingRateLimit (float) – The maximum rate that data will be sent, in kilobits/second.
- borrowIncoming (bool) – If there is an incoming rate limit, allow unused incoming bandwidth to be added to the outgoing rate limit.
Returns: None
Raises: CommandError
– If the user is not granted superuser privileges, or if bandwidth changes are disallowed.New in version 1.6.0.
-
ServerInterface.
updateGarbageCollectSettings
(intervalSeconds=None, timeLimitSeconds=None)¶ Updates garbage collection.
All parameters are optional. Any parameters which are unspecified or set to None will be unchanged.
Garbage collection can only be modified by a superuser.
Parameters: - intervalSeconds (int) – The time, in seconds, between each garbage collection. Allowed range is from 60 (1 minute) to 2147483647 (about 68 years).
- timeLimitSeconds (int) – The grace period, in seconds, to allow for items that are ready to be garbage collected. If 0, all eligible items will be discarded immediately. If non-zero, keep items that have been ready for garbage collection for less time than specified. Allowed range is from 0 to 2147483647 (about 68 years).
Returns: Return type: dict
Raises: CommandError
– If the user is not granted superuser privileges.New in version 1.8.0.