%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /usr/lib/node_modules/pm2/node_modules/tx2/
Upload File :
Create Path :
Current File : //usr/lib/node_modules/pm2/node_modules/tx2/API.md

## Classes

<dl>
<dt><a href="#TX2">TX2</a></dt>
<dd></dd>
</dl>

## Typedefs

<dl>
<dt><a href="#Metric">Metric</a> : <code>Object</code></dt>
<dd></dd>
<dt><a href="#Counter">Counter</a> : <code>object</code></dt>
<dd><p>Expose a metric of type: Counter.</p>
</dd>
</dl>

<a name="TX2"></a>

## TX2
**Kind**: global class  

* [TX2](#TX2)
    * [.action(action_name, [opts], fn)](#TX2.action)
    * [.event(name, data)](#TX2.event)
    * [.issue(err)](#TX2.issue)
    * [.metric(name, [function])](#TX2.metric) ⇒ [<code>Metric</code>](#Metric)
    * [.counter(name)](#TX2.counter) ⇒ [<code>Counter</code>](#Counter)

<a name="TX2.action"></a>

### TX2.action(action_name, [opts], fn)
Expose an action/function triggerable via PM2 or PM2.io

**Kind**: static method of [<code>TX2</code>](#TX2)  

| Param | Type | Description |
| --- | --- | --- |
| action_name | <code>string</code> | Name of the action |
| [opts] | <code>object</code> | Optional parameter |
| fn | <code>function</code> | Function to be called |

**Example** *(Action without arguments)*  
```js
tx2.action('run_query', (cb) => {
  cb({ success: true })
})
```
**Example** *(Action with arguments)*  
```js
tx2.action('run_query', arg1, (cb) => {
  cb({ success: arg1 })
})
```
<a name="TX2.event"></a>

### TX2.event(name, data)
Sends an Event

**Kind**: static method of [<code>TX2</code>](#TX2)  

| Param | Type | Description |
| --- | --- | --- |
| name | <code>string</code> | Name of the event |
| data | <code>object</code> | Metadata attached to the event |

**Example**  
```js
tx2.event('event-name', { multi: 'data' })
```
<a name="TX2.issue"></a>

### TX2.issue(err)
Sends an Issue

**Kind**: static method of [<code>TX2</code>](#TX2)  

| Param | Type | Description |
| --- | --- | --- |
| err | <code>string</code> \| <code>Error</code> | Error object or string to notify |

**Example**  
```js
tx2.issue(new Error('bad error')
```
<a name="TX2.metric"></a>

### TX2.metric(name, [function]) ⇒ [<code>Metric</code>](#Metric)
Expose a Metric

**Kind**: static method of [<code>TX2</code>](#TX2)  
**Returns**: [<code>Metric</code>](#Metric) - A metrics object  

| Param | Type | Description |
| --- | --- | --- |
| name | <code>string</code> | Name of the metric |
| [function] | <code>function</code> | Optional function to trigger every second to retrieve updated value |

**Example**  
```js
tx2.metric('metric_name', () => obj.value)
```
**Example**  
```js
tx2.metric('metric_name', 'unit', () => obj.value)
```
**Example**  
```js
let mn = tx2.metric('metric_name')
mn.set(20)
```
<a name="TX2.counter"></a>

### TX2.counter(name) ⇒ [<code>Counter</code>](#Counter)
Expose a Metric of type: Counter. By calling .inc() or .dec() you update that value

**Kind**: static method of [<code>TX2</code>](#TX2)  

| Param | Type | Description |
| --- | --- | --- |
| name | <code>string</code> | Name of the Metric |

<a name="Metric"></a>

## Metric : <code>Object</code>
**Kind**: global typedef  
**Properties**

| Name | Type | Description |
| --- | --- | --- |
| val | <code>function</code> | Return the current value |
| set | <code>function</code> | Set value |

<a name="Counter"></a>

## Counter : <code>object</code>
Expose a metric of type: Counter.

**Kind**: global typedef  
**Properties**

| Name | Type | Description |
| --- | --- | --- |
| inc | <code>function</code> | Increment value |
| dev | <code>function</code> | Decrement value |


Zerion Mini Shell 1.0