# Stream Ticker Price

Stream ticker price is a method to obtain the ticker price against USDC.\
(Currently Available for Ethereum Only)

### Response Schema:&#x20;

| Field     | Description                                                          |
| --------- | -------------------------------------------------------------------- |
| symbol    | The Symbol of the token or ticker.                                   |
| timestamp | The current timestamp, which will have the USDC price of the ticker. |

### Streaming Ticker Price:

Users can stream ticker price in two ways:

#### Example 1: via wscat script (For Linux based distro)

First, the user needs to run the following command in their terminal to install wscat in their system:&#x20;

```shell
npm install -g wscat 
```

After installing wscat, the user needs to create a shell script and paste the following sample code:

**Client Side Sample Socket Code** :

```shell
#!/bin/bash

echo "Price Discovery\n"
read -p "x-api-key: " YOUR_API_KEY
wscat -c wss://pricediscovery.expand.network -H authorization:secret-token -H x-api-key:$YOUR_API_KEY
```

{% hint style="info" %}
Once the file has been saved, the user needs to grant permission for it to be executed. This can be accomplished by executing the following command:
{% endhint %}

```bash
chmod +x YOUR_FILE_NAME.sh
```

After following the above steps, the user needs to run the file. This can be done by entering the filename in the console.

**Executing a query**:&#x20;

After executing the aforementioned file(shell script), the user will be prompted to input the appropriate API key.

After entering the API key, the user can subscribe to the following actions:

```shell
{"action": "streamTickerPrice"}
```

{% hint style="info" %}
Make sure you are connected to the WebSocket before you perform the following queries.&#x20;
{% endhint %}

**Applying a filter in the query**:&#x20;

Users can apply the following filters in their query:-

* symbol

**The above filters can be applied in any combination, using the following syntax**:&#x20;

```shell
{"action":"streamTickerPrice","symbol":"ticker"}
```

**Sample Query**:

```shell
{"action":"streamTickerPrice","symbol":"REQ"}
```

#### Example 2. via javascript code

First, the user needs to run the following command in their terminal to install wscat in their system:&#x20;

```shell
npm i ws
```

After installing ws, the user needs to run the following sample code on their device to start streaming:&#x20;

**Client Side Sample Socket Code** :

```javascript
const WebSocket = require('ws');
const url = 'wss://pricediscovery.expand.network';
const options = {
  headers: {
    Authorization: 'secret-token',
    'x-api-key': 'YOUR_API_KEY', // Replace this with your API Key
  }
};

const ws = new WebSocket(url, options);

ws.on('open', () => {
  console.log('WebSocket connection established.');
  const payload = {
    action: "streamTickerPrice",
    symbol: "REQ"
};
  ws.send(JSON.stringify(payload));
});


ws.on('message', (data) => {
  console.log(`Received data: ${data}`);
});

ws.on('close', () => {
  console.log('WebSocket connection closed.');
});
```

{% hint style="info" %}
The payload can be modified, depending on the action.
{% endhint %}

### Expected Output:

```json
{
    "REQ": {
        "1741351111": "0.21764357"
    }
}
```

### How to disconnect:&#x20;

To disconnect from our API, enter `ctrl-c`  in the connected console.
