- 
                Notifications
    You must be signed in to change notification settings 
- Fork 321
How to: post data to your dashboard and widgets
When you install Smashing, it will be listening for HTTP POST requests that can be used to update the dashboard and widgets.
Look at config.ru for a line that looks like set :auth_token, 'YOUR_AUTH_TOKEN'.
You should change that value to a custom token value to be used by clients
securely.
Let's use the default dashboard and widgets that come installed with Smashing by default.
You can update any of the values with an HTTP POST request similar to the following.
curl -X POST -H 'Content-Type: application/json' -d '{ "auth_token": "YOUR_AUTH_TOKEN", "value": 9999 }' http://localhost:3030/widgets/synergyNow breaking down the command.
- 
curlis the command used, you can use any other command line utility, or a GUI, or code in Shell, Python, etc
- 
-X POSTdefines this is an HTTP POST request
- 
H 'Content-Type: application/jsonsets the HTTP request content type header
- 
-d '{ "auth_token": "YOUR_AUTH_TOKEN", "value": 9999 }'specifies the data of the request, which is a JSON document. Theauth_token, as mentioned above, is the default value which you probably want to alter. The "value" matches what is sent in thejobs/sample.rbjob.
- 
http://localhost:3030/widgets/synergyis the URL used in the post, which contains the prefixhttp://localhost:3030/widgets/followed by the widget name, which also matches the value fromjobs/sample.rbjob.
You should be able to craft the message format according to your widget
data. You can look at the job Ruby file, and find the send_event
call. The format of the data for a widget will be detailed there.
Besides sending data to widgets, you can also post to a
dashboard with the URL http://localhost:3030/dashboards/:id
where :id must match your dashboard name.
curl -X POST -H 'Content-Type: application/json' -d '{ "auth_token": "YOUR_AUTH_TOKEN", "event": "reload" }' http://localhost:3030/dashboards/sampleNow breaking down the command.
- 
curlis the command used, you can use any other command line utility, or a GUI, or code in Shell, Python, etc
- 
-X POSTdefines this is an HTTP POST request
- 
H 'Content-Type: application/jsonsets the HTTP request content type header
- 
-d '{ "auth_token": "YOUR_AUTH_TOKEN", "event": "reload" }'specifies the data of the request, which is a JSON document. Theauth_token, as mentioned above, is the default value which you probably want to alter. The "event" is handled by the dashboard and forces a reload of the page.
- 
http://localhost:3030/dashboards/sampleis the URL used in the post, which contains the prefixhttp://localhost:3030/dashboards/followed by the dashboard name, which also matches the value from the dashboard URL.
The reload event is handled the CoffeeScript code
that is serving the dashboard. You can have a look at the source code and
add new events and their handlers.
If you would like to look at the code handling the requests, look
at this file
and search for post '/.
You should notice that in the end it uses send_event just like
Smashing jobs.
- Home
- Dashing Workshop
- Installation
- Widgets
- Configuration
- Security
- Troubleshooting
- Deploying dashboards
- How Tos
- How to: post data to your dashboard and widgets
- How to: Define a data model and store history data to database
- How to: Prevent a job from overlapping with itself
- How to: Send HTML data to your widgets
- How to: Send mysql data to your widgets
- How to: Setup a Graph
- How to: Store data to and display from database
- How to: Update a Dashboard using a spreadsheet
- How to: update dashboard in Django
- How to: Update font awesome fonts from version 3 to 4
- How to: Use New Relic with Dashing
- How to: precompile assets
 
- Development