sandboxjs
Version:
Sandbox node.js code
998 lines (743 loc) • 46.8 kB
Markdown
# sandboxjs
Sandbox node.js code like a boss.
## Key Features
* Runs code on the public [webtask.io](https://webtask.io) cluster.
* Your code is totally sandboxed from everyone else's.
* Integrated with your [wt-cli](https://npmjs.org/package/wt-cli) profiles.
* Supports returning Promises and/or invoking node-style callbacks.
## Installing it
```bash
npm install sandboxjs
# Optionally configure a default wt-cli profile
```
## Using it
**First, get a webtask token using [wt-cli](https://npmjs.org/package/wt-cli):**
```bash
# Create a new wt-cli profile
npm install -g wt-cli
wt init
# Or, if you already use wt-cli:
wt profile ls
```
```js
var Assert = require('assert');
var Sandbox = require('sandboxjs');
// You can get your webtask token using the steps above
var code = 'module.exports = function (ctx, cb) { cb(null, "hello world"); }';
var profile = Sandbox.fromToken(process.env.WEBTASK_TOKEN);
// This library lets you create a webtask and run it in one step as a shortcut:
profile.run(code, function (err, res, body) {
Assert.ifError(err);
Assert.equal(res.statusCode, 200, 'The webtask executed as expected');
Assert.equal(body, 'hello world', 'The webtask returned the expected string');
});
// Alternatively, your application might want to to create a webtask url
// with your (or your users') custom code and secrets.
profile.create(code, { secrets: { auth0: 'rocks' } }, function (err, webtask) {
Assert.ifError(err);
// Making requests to this url will run the specified custom code in a
// node.js sandbox and will give it access to your secrets in the first
// argument (`ctx`) of your exported webtask function.
// For more information on the different styles of webtask functions that
// are supported, see: https://webtask.io/docs/model
console.log(webtask.url);
});
```
### Examples
**Update the code of an existing named webtask**
```js
var Sandbox = require('sandboxjs');
var sandbox = Sandbox.init({ /* ... */ });
var webtaskName = 'my_webtask';
var webtaskCode = 'module.exports = ...';
sandbox.inspectWebtask({
name: webtaskName,
// We need to decrypt embedded secrets so that we can set them on the
// replacement named webtask
decrypt: true,
// No need to fetch code since we will be updating it anyway
fetch_code: false,
}).then(handleClaims);
function handleClaims(claims) {
// We will pull any claims from the existing webtask that are user-defined
// and set them on a new claims object. Note that some claims are *NOT*
// copied over because they are read-only claims generated by the platform.
// Common examples include: `ca`, `jti` and `iat`.
var newClaims = {
jtn: webtaskName,
dd: claims.dd,
mb: claims.mb,
pb: claims.pb,
// Instead of being an opaque, encrypted blob, this will be a javascript
// Object mapping secret key to value because we set the `decrypt`
// option on the call to `inspectWebtask`.
ectx: claims.ectx,
pctx: claims.pctx,
code: webtaskCode,
};
// Create a replacement webtask from raw claims. We use `createRaw` instead
// of `create` so that we can deal directly with the platform's claims
// instead of the more human-friendly aliases in `create`.
// This method will make a token issue request with the updated claims
// and resolve the Promise with a new `Webtask` instance based on that
// token.
return sandbox.createRaw(newClaims);
}
```
## API
## Modules
<dl>
<dt><a href="#module_sandboxjs">sandboxjs</a></dt>
<dd><p>Sandbox node.js code.</p>
</dd>
</dl>
## Classes
<dl>
<dt><a href="#CronJob">CronJob</a></dt>
<dd></dd>
<dt><a href="#Webtask">Webtask</a></dt>
<dd></dd>
</dl>
<a name="module_sandboxjs"></a>
## sandboxjs
Sandbox node.js code.
* [sandboxjs](#module_sandboxjs)
* _static_
* [.fromToken(token, options)](#module_sandboxjs.fromToken) ⇒ <code>Sandbox</code>
* [.init(options)](#module_sandboxjs.init) ⇒ <code>Sandbox</code>
* _inner_
* [~Sandbox](#module_sandboxjs..Sandbox)
* [new Sandbox(options)](#new_module_sandboxjs..Sandbox_new)
* [.clone(options)](#module_sandboxjs..Sandbox+clone)
* [.create([codeOrUrl], [options], [cb])](#module_sandboxjs..Sandbox+create) ⇒ <code>Promise</code>
* [.createRaw(claims, [cb])](#module_sandboxjs..Sandbox+createRaw) ⇒ <code>Promise</code>
* [.createUrl(options, [cb])](#module_sandboxjs..Sandbox+createUrl) ⇒ <code>Promise</code>
* [.run([codeOrUrl], [options], [cb])](#module_sandboxjs..Sandbox+run) ⇒ <code>Promise</code>
* [.createToken(options, [cb])](#module_sandboxjs..Sandbox+createToken) ⇒ <code>Promise</code>
* [.issueRequest(request, [cb])](#module_sandboxjs..Sandbox+issueRequest) ⇒ <code>Promise</code>
* [.createTokenRaw(claims, [options], [cb])](#module_sandboxjs..Sandbox+createTokenRaw) ⇒ <code>Promise</code>
* [.createLogStream(options)](#module_sandboxjs..Sandbox+createLogStream) ⇒ <code>Stream</code>
* [.getWebtask(options, [cb])](#module_sandboxjs..Sandbox+getWebtask) ⇒ <code>Promise</code>
* [.createWebtask(options, [cb])](#module_sandboxjs..Sandbox+createWebtask) ⇒ <code>Promise</code>
* [.removeWebtask(options, [cb])](#module_sandboxjs..Sandbox+removeWebtask) ⇒ <code>Promise</code>
* [.updateWebtask(options, [cb])](#module_sandboxjs..Sandbox+updateWebtask) ⇒ <code>Promise</code>
* [.listWebtasks(options, [cb])](#module_sandboxjs..Sandbox+listWebtasks) ⇒ <code>Promise</code>
* [.createCronJob(options, [cb])](#module_sandboxjs..Sandbox+createCronJob) ⇒ <code>Promise</code>
* [.removeCronJob(options, [cb])](#module_sandboxjs..Sandbox+removeCronJob) ⇒ <code>Promise</code>
* [.setCronJobState(options, [cb])](#module_sandboxjs..Sandbox+setCronJobState) ⇒ <code>Promise</code>
* [.listCronJobs([options], [cb])](#module_sandboxjs..Sandbox+listCronJobs) ⇒ <code>Promise</code>
* [.getCronJob(options, [cb])](#module_sandboxjs..Sandbox+getCronJob) ⇒ <code>Promise</code>
* [.getCronJobHistory(options, [cb])](#module_sandboxjs..Sandbox+getCronJobHistory) ⇒ <code>Promise</code>
* [.inspectToken(options, [cb])](#module_sandboxjs..Sandbox+inspectToken) ⇒ <code>Promise</code>
* [.inspectWebtask(options, [cb])](#module_sandboxjs..Sandbox+inspectWebtask) ⇒ <code>Promise</code>
* [.revokeToken(token, [cb])](#module_sandboxjs..Sandbox+revokeToken) ⇒ <code>Promise</code>
* [.listNodeModuleVersions(options, [cb])](#module_sandboxjs..Sandbox+listNodeModuleVersions) ⇒ <code>Promise</code>
* [.ensureNodeModules(options, [cb])](#module_sandboxjs..Sandbox+ensureNodeModules) ⇒ <code>Promise</code>
* [.updateStorage(options, storage, [cb])](#module_sandboxjs..Sandbox+updateStorage) ⇒ <code>Promise</code>
* [.getStorage(options, [cb])](#module_sandboxjs..Sandbox+getStorage) ⇒ <code>Promise</code>
<a name="module_sandboxjs.fromToken"></a>
### Sandbox.fromToken(token, options) ⇒ <code>Sandbox</code>
Create a Sandbox instance from a webtask token
**Kind**: static method of <code>[sandboxjs](#module_sandboxjs)</code>
**Returns**: <code>Sandbox</code> - A {@see Sandbox} instance whose url, token and container were derived from the given webtask token.
| Param | Type | Description |
| --- | --- | --- |
| token | <code>String</code> | The webtask token from which the Sandbox profile will be derived. |
| options | <code>Object</code> | The options for creating the Sandbox instance that override the derived values from the token. |
| [options.url] | <code>String</code> | The url of the webtask cluster. Defaults to the public 'webtask.it.auth0.com' cluster. |
| options.container | <code>String</code> | The container with which this Sandbox instance should be associated. Note that your Webtask token must give you access to that container or all operations will fail. |
| options.token | <code>String</code> | The Webtask Token. See: https://webtask.io/docs/api_issue. |
<a name="module_sandboxjs.init"></a>
### Sandbox.init(options) ⇒ <code>Sandbox</code>
Create a Sandbox instance
**Kind**: static method of <code>[sandboxjs](#module_sandboxjs)</code>
**Returns**: <code>Sandbox</code> - A {@see Sandbox} instance.
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | The options for creating the Sandbox instance. |
| [options.url] | <code>String</code> | The url of the webtask cluster. Defaults to the public 'webtask.it.auth0.com' cluster. |
| options.container | <code>String</code> | The container with which this Sandbox instance should be associated. Note that your Webtask token must give you access to that container or all operations will fail. |
| options.token | <code>String</code> | The Webtask Token. See: https://webtask.io/docs/api_issue. |
<a name="module_sandboxjs..Sandbox"></a>
### Sandbox~Sandbox
**Kind**: inner class of <code>[sandboxjs](#module_sandboxjs)</code>
* [~Sandbox](#module_sandboxjs..Sandbox)
* [new Sandbox(options)](#new_module_sandboxjs..Sandbox_new)
* [.clone(options)](#module_sandboxjs..Sandbox+clone)
* [.create([codeOrUrl], [options], [cb])](#module_sandboxjs..Sandbox+create) ⇒ <code>Promise</code>
* [.createRaw(claims, [cb])](#module_sandboxjs..Sandbox+createRaw) ⇒ <code>Promise</code>
* [.createUrl(options, [cb])](#module_sandboxjs..Sandbox+createUrl) ⇒ <code>Promise</code>
* [.run([codeOrUrl], [options], [cb])](#module_sandboxjs..Sandbox+run) ⇒ <code>Promise</code>
* [.createToken(options, [cb])](#module_sandboxjs..Sandbox+createToken) ⇒ <code>Promise</code>
* [.issueRequest(request, [cb])](#module_sandboxjs..Sandbox+issueRequest) ⇒ <code>Promise</code>
* [.createTokenRaw(claims, [options], [cb])](#module_sandboxjs..Sandbox+createTokenRaw) ⇒ <code>Promise</code>
* [.createLogStream(options)](#module_sandboxjs..Sandbox+createLogStream) ⇒ <code>Stream</code>
* [.getWebtask(options, [cb])](#module_sandboxjs..Sandbox+getWebtask) ⇒ <code>Promise</code>
* [.createWebtask(options, [cb])](#module_sandboxjs..Sandbox+createWebtask) ⇒ <code>Promise</code>
* [.removeWebtask(options, [cb])](#module_sandboxjs..Sandbox+removeWebtask) ⇒ <code>Promise</code>
* [.updateWebtask(options, [cb])](#module_sandboxjs..Sandbox+updateWebtask) ⇒ <code>Promise</code>
* [.listWebtasks(options, [cb])](#module_sandboxjs..Sandbox+listWebtasks) ⇒ <code>Promise</code>
* [.createCronJob(options, [cb])](#module_sandboxjs..Sandbox+createCronJob) ⇒ <code>Promise</code>
* [.removeCronJob(options, [cb])](#module_sandboxjs..Sandbox+removeCronJob) ⇒ <code>Promise</code>
* [.setCronJobState(options, [cb])](#module_sandboxjs..Sandbox+setCronJobState) ⇒ <code>Promise</code>
* [.listCronJobs([options], [cb])](#module_sandboxjs..Sandbox+listCronJobs) ⇒ <code>Promise</code>
* [.getCronJob(options, [cb])](#module_sandboxjs..Sandbox+getCronJob) ⇒ <code>Promise</code>
* [.getCronJobHistory(options, [cb])](#module_sandboxjs..Sandbox+getCronJobHistory) ⇒ <code>Promise</code>
* [.inspectToken(options, [cb])](#module_sandboxjs..Sandbox+inspectToken) ⇒ <code>Promise</code>
* [.inspectWebtask(options, [cb])](#module_sandboxjs..Sandbox+inspectWebtask) ⇒ <code>Promise</code>
* [.revokeToken(token, [cb])](#module_sandboxjs..Sandbox+revokeToken) ⇒ <code>Promise</code>
* [.listNodeModuleVersions(options, [cb])](#module_sandboxjs..Sandbox+listNodeModuleVersions) ⇒ <code>Promise</code>
* [.ensureNodeModules(options, [cb])](#module_sandboxjs..Sandbox+ensureNodeModules) ⇒ <code>Promise</code>
* [.updateStorage(options, storage, [cb])](#module_sandboxjs..Sandbox+updateStorage) ⇒ <code>Promise</code>
* [.getStorage(options, [cb])](#module_sandboxjs..Sandbox+getStorage) ⇒ <code>Promise</code>
<a name="new_module_sandboxjs..Sandbox_new"></a>
#### new Sandbox(options)
Creates an object representing a user's webtask.io credentials
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options used to configure the profile |
| options.url | <code>String</code> | The url of the webtask cluster where code will run |
| options.container | <code>String</code> | The name of the container in which code will run |
| options.token | <code>String</code> | The JWT (see: http://jwt.io) issued by webtask.io that grants rights to run code in the indicated container |
| [options.onBeforeRequest] | <code>String</code> | An array of hook functions to be invoked with a prepared request |
<a name="module_sandboxjs..Sandbox+clone"></a>
#### sandbox.clone(options)
Create a clone of this sandbox instances with one or more different parameters
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options used to configure the profile |
| [options.url] | <code>String</code> | The url of the webtask cluster where code will run |
| [options.container] | <code>String</code> | The name of the container in which code will run |
| [options.token] | <code>String</code> | The JWT (see: http://jwt.io) issued by webtask.io that grants rights to run code in the indicated container |
| [options.onBeforeRequest] | <code>String</code> | An array of hook functions to be invoked with a prepared request |
<a name="module_sandboxjs..Sandbox+create"></a>
#### sandbox.create([codeOrUrl], [options], [cb]) ⇒ <code>Promise</code>
Create a Webtask from the given options
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the token
| Param | Type | Description |
| --- | --- | --- |
| [codeOrUrl] | <code>String</code> | The code for the webtask or a url starting with http:// or https:// |
| [options] | <code>Object</code> | Options for creating the webtask |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks |
<a name="module_sandboxjs..Sandbox+createRaw"></a>
#### sandbox.createRaw(claims, [cb]) ⇒ <code>Promise</code>
Create a Webtask from the given claims
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the token
| Param | Type | Description |
| --- | --- | --- |
| claims | <code>Object</code> | Options for creating the webtask |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks |
<a name="module_sandboxjs..Sandbox+createUrl"></a>
#### sandbox.createUrl(options, [cb]) ⇒ <code>Promise</code>
Shortcut to create a Webtask and get its url from the given options
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the token
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options for creating the webtask |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks |
<a name="module_sandboxjs..Sandbox+run"></a>
#### sandbox.run([codeOrUrl], [options], [cb]) ⇒ <code>Promise</code>
Shortcut to create and run a Webtask from the given options
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the token
| Param | Type | Description |
| --- | --- | --- |
| [codeOrUrl] | <code>String</code> | The code for the webtask or a url starting with http:// or https:// |
| [options] | <code>Object</code> | Options for creating the webtask |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks |
<a name="module_sandboxjs..Sandbox+createToken"></a>
#### sandbox.createToken(options, [cb]) ⇒ <code>Promise</code>
Create a webtask token - A JWT (see: http://jwt.io) with the supplied options
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the token
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Claims to make for this token (see: https://webtask.io/docs/api_issue) |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks |
<a name="module_sandboxjs..Sandbox+issueRequest"></a>
#### sandbox.issueRequest(request, [cb]) ⇒ <code>Promise</code>
Run a prepared Superagent request through any configured
onBeforeRequest hooks.
This can be useful for enablying proxies for server-side
consumers of sandboxjs.
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - - A promise representing the fulfillment of the request
| Param | Type | Description |
| --- | --- | --- |
| request | <code>Superagent.Request</code> | Instance of a superagent request |
| [cb] | <code>function</code> | Node-style callback function |
<a name="module_sandboxjs..Sandbox+createTokenRaw"></a>
#### sandbox.createTokenRaw(claims, [options], [cb]) ⇒ <code>Promise</code>
Create a webtask token - A JWT (see: http://jwt.io) with the supplied claims
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the token
| Param | Type | Description |
| --- | --- | --- |
| claims | <code>Object</code> | Claims to make for this token (see: https://webtask.io/docs/api_issue) |
| [options] | <code>Object</code> | Optional options. Currently only options.include_webtask_url is supported. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks |
<a name="module_sandboxjs..Sandbox+createLogStream"></a>
#### sandbox.createLogStream(options) ⇒ <code>Stream</code>
Create a stream of logs from the webtask container
Note that the logs will include messages from our infrastructure.
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Stream</code> - A stream that will emit 'data' events with container logs
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Streaming options overrides |
| [options.container] | <code>String</code> | The container for which you would like to stream logs. Defaults to the current profile's container. |
<a name="module_sandboxjs..Sandbox+getWebtask"></a>
#### sandbox.getWebtask(options, [cb]) ⇒ <code>Promise</code>
Read a named webtask
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an array of Webtasks
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options |
| [options.container] | <code>String</code> | Set the webtask container. Defaults to the profile's container. |
| options.name | <code>String</code> | The name of the webtask. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="module_sandboxjs..Sandbox+createWebtask"></a>
#### sandbox.createWebtask(options, [cb]) ⇒ <code>Promise</code>
Create a named webtask
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an array of Webtasks
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options |
| [options.container] | <code>String</code> | Set the webtask container. Defaults to the profile's container. |
| options.name | <code>String</code> | The name of the webtask. |
| [options.secrets] | <code>String</code> | Set the webtask secrets. |
| [options.meta] | <code>String</code> | Set the webtask metadata. |
| [options.host] | <code>String</code> | Set the webtask hostname. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="module_sandboxjs..Sandbox+removeWebtask"></a>
#### sandbox.removeWebtask(options, [cb]) ⇒ <code>Promise</code>
Remove a named webtask from the webtask container
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an array of Webtasks
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options |
| [options.container] | <code>String</code> | Set the webtask container. Defaults to the profile's container. |
| options.name | <code>String</code> | The name of the cron job. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="module_sandboxjs..Sandbox+updateWebtask"></a>
#### sandbox.updateWebtask(options, [cb]) ⇒ <code>Promise</code>
Update an existing webtask's code, secrets or other claims
Note that this method should be used with caution as there is the potential
for a race condition where another agent updates the webtask between the time
that the webtask details and claims are resolved and when the webtask
update is issued.
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an instance of Webtask representing the updated webtask
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options |
| options.name | <code>String</code> | Name of the webtask to update |
| [options.code] | <code>String</code> | Updated code for the webtask |
| [options.url] | <code>String</code> | Updated code URL for the webtask |
| [options.secrets] | <code>String</code> | If `false`, remove existing secrets, if an object update secrets, otherwise preserve |
| [options.params] | <code>String</code> | If `false`, remove existing params, if an object update params, otherwise preserve |
| [options.host] | <code>String</code> | If `false`, remove existing host, if a string update host, otherwise preserve |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="module_sandboxjs..Sandbox+listWebtasks"></a>
#### sandbox.listWebtasks(options, [cb]) ⇒ <code>Promise</code>
List named webtasks from the webtask container
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an array of Webtasks
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options |
| [options.container] | <code>String</code> | Set the webtask container. Defaults to the profile's container. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="module_sandboxjs..Sandbox+createCronJob"></a>
#### sandbox.createCronJob(options, [cb]) ⇒ <code>Promise</code>
Create a cron job from an already-existing webtask
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with a {@see CronJob} instance.
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options for creating a cron job |
| [options.container] | <code>String</code> | The container in which the job will run. Defaults to the current profile's container. |
| options.name | <code>String</code> | The name of the cron job. |
| [options.token] | <code>String</code> | The webtask token that will be used to run the job. |
| options.schedule | <code>String</code> | The cron schedule that will be used to determine when the job will be run. |
| options.tz | <code>String</code> | The cron timezone (IANA timezone). |
| options.meta | <code>String</code> | The cron metadata (set of string key value pairs). |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="module_sandboxjs..Sandbox+removeCronJob"></a>
#### sandbox.removeCronJob(options, [cb]) ⇒ <code>Promise</code>
Remove an existing cron job
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the response from removing the job.
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options for removing the cron job |
| [options.container] | <code>String</code> | The container in which the job will run. Defaults to the current profile's container. |
| options.name | <code>String</code> | The name of the cron job. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="module_sandboxjs..Sandbox+setCronJobState"></a>
#### sandbox.setCronJobState(options, [cb]) ⇒ <code>Promise</code>
Set an existing cron job's state
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the response from removing the job.
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options for updating the cron job's state |
| [options.container] | <code>String</code> | The container in which the job will run. Defaults to the current profile's container. |
| options.name | <code>String</code> | The name of the cron job. |
| options.state | <code>String</code> | The new state of the cron job. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="module_sandboxjs..Sandbox+listCronJobs"></a>
#### sandbox.listCronJobs([options], [cb]) ⇒ <code>Promise</code>
List cron jobs associated with this profile
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an Array of {@see CronJob} instances.
| Param | Type | Description |
| --- | --- | --- |
| [options] | <code>Object</code> | Options for listing cron jobs. |
| [options.container] | <code>String</code> | The container in which the job will run. Defaults to the current profile's container. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="module_sandboxjs..Sandbox+getCronJob"></a>
#### sandbox.getCronJob(options, [cb]) ⇒ <code>Promise</code>
Get a CronJob instance associated with an existing cron job
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with a {@see CronJob} instance.
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options for retrieving the cron job. |
| [options.container] | <code>String</code> | The container in which the job will run. Defaults to the current profile's container. |
| options.name | <code>String</code> | The name of the cron job. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="module_sandboxjs..Sandbox+getCronJobHistory"></a>
#### sandbox.getCronJobHistory(options, [cb]) ⇒ <code>Promise</code>
Get the historical results of executions of an existing cron job.
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an Array of cron job results.
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options for retrieving the cron job. |
| [options.container] | <code>String</code> | The container in which the job will run. Defaults to the current profile's container. |
| options.name | <code>String</code> | The name of the cron job. |
| [options.offset] | <code>String</code> | The offset to use when paging through results. |
| [options.limit] | <code>String</code> | The limit to use when paging through results. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="module_sandboxjs..Sandbox+inspectToken"></a>
#### sandbox.inspectToken(options, [cb]) ⇒ <code>Promise</code>
Inspect an existing webtask token to resolve code and/or secrets
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the resolved webtask data.
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options for inspecting the webtask. |
| options.token | <code>Boolean</code> | The token that you would like to inspect. |
| [options.decrypt] | <code>Boolean</code> | Decrypt the webtask's secrets. |
| [options.fetch_code] | <code>Boolean</code> | Fetch the code associated with the webtask. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="module_sandboxjs..Sandbox+inspectWebtask"></a>
#### sandbox.inspectWebtask(options, [cb]) ⇒ <code>Promise</code>
Inspect an existing named webtask to resolve code and/or secrets
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the resolved webtask data.
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options for inspecting the webtask. |
| options.name | <code>Boolean</code> | The named webtask that you would like to inspect. |
| [options.decrypt] | <code>Boolean</code> | Decrypt the webtask's secrets. |
| [options.fetch_code] | <code>Boolean</code> | Fetch the code associated with the webtask. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="module_sandboxjs..Sandbox+revokeToken"></a>
#### sandbox.revokeToken(token, [cb]) ⇒ <code>Promise</code>
Revoke a webtask token
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the token
**See**: https://webtask.io/docs/api_revoke
| Param | Type | Description |
| --- | --- | --- |
| token | <code>String</code> | The token that should be revoked |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks |
<a name="module_sandboxjs..Sandbox+listNodeModuleVersions"></a>
#### sandbox.listNodeModuleVersions(options, [cb]) ⇒ <code>Promise</code>
List versions of a given node module that are available on the platform
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the token
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options |
| options.name | <code>String</code> | Name of the node module |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks |
<a name="module_sandboxjs..Sandbox+ensureNodeModules"></a>
#### sandbox.ensureNodeModules(options, [cb]) ⇒ <code>Promise</code>
Ensure that a set of modules are available on the platform
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an array of { name, version, state } objects
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options |
| options.modules | <code>Array</code> | Array of { name, version } pairs |
| options.reset | <code>Boolean</code> | Trigger a rebuild of the modules (Requires administrative token) |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks |
<a name="module_sandboxjs..Sandbox+updateStorage"></a>
#### sandbox.updateStorage(options, storage, [cb]) ⇒ <code>Promise</code>
Update the storage associated to the a webtask
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an array of Webtasks
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options |
| [options.container] | <code>String</code> | Set the webtask container. Defaults to the profile's container. |
| options.name | <code>String</code> | The name of the webtask. |
| storage | <code>Object</code> | storage |
| storage.data | <code>Object</code> | The data to be stored |
| storage.etag | <code>String</code> | Pass in an optional string to be used for optimistic concurrency control to prevent simultaneous updates of the same data. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="module_sandboxjs..Sandbox+getStorage"></a>
#### sandbox.getStorage(options, [cb]) ⇒ <code>Promise</code>
Read the storage associated to the a webtask
**Kind**: instance method of <code>[Sandbox](#module_sandboxjs..Sandbox)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an array of Webtasks
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options |
| [options.container] | <code>String</code> | Set the webtask container. Defaults to the profile's container. |
| options.name | <code>String</code> | The name of the webtask. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="CronJob"></a>
## CronJob
**Kind**: global class
* [CronJob](#CronJob)
* [new CronJob()](#new_CronJob_new)
* [.sandbox](#CronJob+sandbox)
* [.refresh([cb])](#CronJob+refresh) ⇒ <code>Promise</code>
* [.remove([cb])](#CronJob+remove) ⇒ <code>Promise</code>
* [.getHistory(options, [cb])](#CronJob+getHistory) ⇒ <code>Promise</code>
* [.inspect(options, [cb])](#CronJob+inspect) ⇒ <code>Promise</code>
* [.setJobState(options, [cb])](#CronJob+setJobState) ⇒ <code>Promise</code>
<a name="new_CronJob_new"></a>
### new CronJob()
Creates an object representing a CronJob
<a name="CronJob+sandbox"></a>
### cronJob.sandbox
**Kind**: instance property of <code>[CronJob](#CronJob)</code>
**Properties**
| Name | Description |
| --- | --- |
| sandbox | The {@see Sandbox} instance used to create this Webtask instance |
<a name="CronJob+refresh"></a>
### cronJob.refresh([cb]) ⇒ <code>Promise</code>
Refresh this job's metadata
**Kind**: instance method of <code>[CronJob](#CronJob)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the this cron job instance
| Param | Type | Description |
| --- | --- | --- |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks |
<a name="CronJob+remove"></a>
### cronJob.remove([cb]) ⇒ <code>Promise</code>
Remove this cron job from the webtask cluster
Note that this will not revoke the underlying webtask token, so the underlying webtask will remain functional.
**Kind**: instance method of <code>[CronJob](#CronJob)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the token
| Param | Type | Description |
| --- | --- | --- |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks |
<a name="CronJob+getHistory"></a>
### cronJob.getHistory(options, [cb]) ⇒ <code>Promise</code>
Get the history of this cron job
**Kind**: instance method of <code>[CronJob](#CronJob)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an Array of cron job results.
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options for retrieving the cron job. |
| [options.offset] | <code>String</code> | The offset to use when paging through results. |
| [options.limit] | <code>String</code> | The limit to use when paging through results. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="CronJob+inspect"></a>
### cronJob.inspect(options, [cb]) ⇒ <code>Promise</code>
Inspect an existing webtask to optionally get code and/or secrets
**Kind**: instance method of <code>[CronJob](#CronJob)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an Array of cron job results.
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options for inspecting the webtask. |
| [options.fetch_code] | <code>Boolean</code> | Fetch the code associated with the webtask. |
| [options.decrypt] | <code>Boolean</code> | Decrypt the webtask's secrets. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="CronJob+setJobState"></a>
### cronJob.setJobState(options, [cb]) ⇒ <code>Promise</code>
Set the cron job's state
**Kind**: instance method of <code>[CronJob](#CronJob)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an Array of cron job results.
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options for updating the webtask. |
| options.state | <code>Boolean</code> | Set the cron job's state to this. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="Webtask"></a>
## Webtask
**Kind**: global class
* [Webtask](#Webtask)
* [new Webtask()](#new_Webtask_new)
* [.claims](#Webtask+claims)
* [.token](#Webtask+token)
* [.sandbox](#Webtask+sandbox)
* [.meta](#Webtask+meta)
* [.createLogStream(options)](#Webtask+createLogStream) ⇒ <code>Stream</code>
* [.run(options, [cb])](#Webtask+run) ⇒ <code>Promise</code>
* [.createCronJob(options, [cb])](#Webtask+createCronJob) ⇒ <code>Promise</code>
* [.inspect(options, [cb])](#Webtask+inspect) ⇒ <code>Promise</code>
* [.remove([cb])](#Webtask+remove) ⇒ <code>Promise</code>
* [.revoke([cb])](#Webtask+revoke) ⇒ <code>Promise</code>
* [.update([options], [cb])](#Webtask+update) ⇒ <code>Promise</code>
* [.updateStorage(options, storage, [cb])](#Webtask+updateStorage) ⇒ <code>Promise</code>
* [.getStorage(options, [cb])](#Webtask+getStorage) ⇒ <code>Promise</code>
<a name="new_Webtask_new"></a>
### new Webtask()
Creates an object representing a Webtask
<a name="Webtask+claims"></a>
### webtask.claims
**Kind**: instance property of <code>[Webtask](#Webtask)</code>
**Properties**
| Name | Description |
| --- | --- |
| claims | The claims embedded in the Webtask's token |
<a name="Webtask+token"></a>
### webtask.token
**Kind**: instance property of <code>[Webtask](#Webtask)</code>
**Properties**
| Name | Description |
| --- | --- |
| token | The token associated with this webtask |
<a name="Webtask+sandbox"></a>
### webtask.sandbox
**Kind**: instance property of <code>[Webtask](#Webtask)</code>
**Properties**
| Name | Description |
| --- | --- |
| sandbox | The {@see Sandbox} instance used to create this Webtask instance |
<a name="Webtask+meta"></a>
### webtask.meta
**Kind**: instance property of <code>[Webtask](#Webtask)</code>
**Properties**
| Name | Description |
| --- | --- |
| meta | The metadata associated with this webtask |
<a name="Webtask+createLogStream"></a>
### webtask.createLogStream(options) ⇒ <code>Stream</code>
Create a stream of logs from the webtask container
Note that the logs will include messages from our infrastructure.
**Kind**: instance method of <code>[Webtask](#Webtask)</code>
**Returns**: <code>Stream</code> - A stream that will emit 'data' events with container logs
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Streaming options overrides |
| [options.container] | <code>String</code> | The container for which you would like to stream logs. Defaults to the current profile's container. |
<a name="Webtask+run"></a>
### webtask.run(options, [cb]) ⇒ <code>Promise</code>
Run the webtask and return the result of execution
**Kind**: instance method of <code>[Webtask](#Webtask)</code>
**Returns**: <code>Promise</code> - - A Promise that will be resolved with the response from the server.
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options used to tweak how the webtask will be invoked |
| [cb] | <code>function</code> | Optional node-style callback that will be invoked upon completion |
<a name="Webtask+createCronJob"></a>
### webtask.createCronJob(options, [cb]) ⇒ <code>Promise</code>
Schedule the webtask to run periodically
**Kind**: instance method of <code>[Webtask](#Webtask)</code>
**Returns**: <code>Promise</code> - - A Promise that will be resolved with a {@see CronJob} instance.
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options for creating the webtask |
| options.schedule | <code>Object</code> | Cron-string-formatted schedule |
| [options.name] | <code>Object</code> | The name for the cron job |
| [options.tz] | <code>Object</code> | The timezone for the cron job (IANA timezone) |
| [cb] | <code>function</code> | Optional node-style callback that will be invoked upon completion |
<a name="Webtask+inspect"></a>
### webtask.inspect(options, [cb]) ⇒ <code>Promise</code>
Inspect an existing webtask to optionally get code and/or secrets
**Kind**: instance method of <code>[Webtask](#Webtask)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the result of inspecting the token.
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options for inspecting the webtask. |
| [options.decrypt] | <code>Boolean</code> | Decrypt the webtask's secrets. |
| [options.fetch_code] | <code>Boolean</code> | Fetch the code associated with the webtask. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="Webtask+remove"></a>
### webtask.remove([cb]) ⇒ <code>Promise</code>
Remove the named webtask
**Kind**: instance method of <code>[Webtask](#Webtask)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the result of inspecting the token.
| Param | Type | Description |
| --- | --- | --- |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="Webtask+revoke"></a>
### webtask.revoke([cb]) ⇒ <code>Promise</code>
Revoke the webtask's token
**Kind**: instance method of <code>[Webtask](#Webtask)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the result of revoking the token.
| Param | Type | Description |
| --- | --- | --- |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="Webtask+update"></a>
### webtask.update([options], [cb]) ⇒ <code>Promise</code>
Update a webtask
**Kind**: instance method of <code>[Webtask](#Webtask)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with the result of revoking the token.
| Param | Type | Description |
| --- | --- | --- |
| [options] | <code>Object</code> | Options for updating a webtask (@see: Sandbox.updateWebtask) |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="Webtask+updateStorage"></a>
### webtask.updateStorage(options, storage, [cb]) ⇒ <code>Promise</code>
Update the storage associated to the a webtask
**Kind**: instance method of <code>[Webtask](#Webtask)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an array of Webtasks
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options |
| [options.container] | <code>String</code> | Set the webtask container. Defaults to the profile's container. |
| options.name | <code>String</code> | The name of the webtask. |
| storage | <code>Object</code> | storage |
| storage.data | <code>Object</code> | The data to be stored |
| storage.etag | <code>String</code> | Pass in an optional string to be used for optimistic concurrency control to prevent simultaneous updates of the same data. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
<a name="Webtask+getStorage"></a>
### webtask.getStorage(options, [cb]) ⇒ <code>Promise</code>
Read the storage associated to the a webtask
**Kind**: instance method of <code>[Webtask](#Webtask)</code>
**Returns**: <code>Promise</code> - A Promise that will be fulfilled with an array of Webtasks
| Param | Type | Description |
| --- | --- | --- |
| options | <code>Object</code> | Options |
| [options.container] | <code>String</code> | Set the webtask container. Defaults to the profile's container. |
| options.name | <code>String</code> | The name of the webtask. |
| [cb] | <code>function</code> | Optional callback function for node-style callbacks. |
## Usages
This library will be used in [wt-cli](https://github.com/auth0/wt-cli).
## Contributing
Just clone the repo, run `npm install` and then hack away.
## Issue reporting
If you have found a bug or if you have a feature request, please report them at
this repository issues section. Please do not report security vulnerabilities on
the public GitHub issue tracker. The
[Responsible Disclosure Program](https://auth0.com/whitehat) details the
procedure for disclosing security issues.
## License
MIT
## What is Auth0?
Auth0 helps you to:
* Add authentication with [multiple authentication sources](https://docs.auth0.com/identityproviders), either social like **Google, Facebook, Microsoft Account, LinkedIn, GitHub, Twitter, Box, Salesforce, amont others**, or enterprise identity systems like **Windows Azure AD, Google Apps, Active Directory, ADFS or any SAML Identity Provider**.
* Add authentication through more traditional **[username/password databases](https://docs.auth0.com/mysql-connection-tutorial)**.
* Add support for **[linking different user accounts](https://docs.auth0.com/link-accounts)** with the same user.
* Support for generating signed [Json Web Tokens](https://docs.auth0.com/jwt) to call your APIs and **flow the user identity** securely.
* Analytics of how, when and where users are logging in.
* Pull data from other sources and add it to the user profile, through [JavaScript rules](https://docs.auth0.com/rules).
## Create a free account in Auth0
1. Go to [Auth0](https://auth0.com) and click Sign Up.
2. Use Google, GitHub or Microsoft Account to login.