allow channel to be updated via API

This commit is contained in:
Lee Lawlor 2014-07-02 11:46:04 -04:00
parent f847e29268
commit a7ba0eae18
6 changed files with 204 additions and 68 deletions

View File

@ -179,14 +179,19 @@ class ChannelsController < ApplicationController
def update def update
@channel = current_user.channels.find(params[:id]) # get the current user or find the user via their api key
@user = current_user || User.find_by_api_key(get_apikey)
@channel = @user.channels.find(params[:id])
# make updating attributes easier for updates via api
params[:channel] = params if params[:channel].blank?
if params["channel"]["video_type"].blank? && !params["channel"]["video_id"].blank? if params["channel"]["video_type"].blank? && !params["channel"]["video_id"].blank?
@channel.errors.add(:base, t(:channel_video_type_blank)) @channel.errors.add(:base, t(:channel_video_type_blank))
end end
if @channel.errors.count <= 0 if @channel.errors.count <= 0
@channel.save_tags(params[:tags][:name]) @channel.save_tags(params[:tags][:name]) if params[:tags].present?
@channel.assign_attributes(channel_params) @channel.assign_attributes(channel_params)
@channel.set_windows @channel.set_windows
@channel.save @channel.save
@ -196,7 +201,11 @@ class ChannelsController < ApplicationController
end end
flash[:notice] = t(:channel_update_success) flash[:notice] = t(:channel_update_success)
redirect_to channel_path(@channel.id) respond_to do |format|
format.json { render :json => @channel.to_json(Channel.private_options) }
format.xml { render :xml => @channel.to_xml(Channel.private_options) }
format.any { redirect_to channel_path(@channel.id) }
end
end end
def create def create

View File

@ -12,16 +12,16 @@
<% if params[:action] == 'channels' %> <% if params[:action] == 'channels' %>
<li><a href="#channels">Channels</a></li> <li><a href="#channels">Channels</a></li>
<li class="subitem"><a href="#keywords">Keywords</a></li> <li class="subitem"><a href="#keywords">Keywords & URLs</a></li>
<li class="subitem"><a href="#urls">Base URLs</a></li>
<li class="subitem"><a href="#api_keys">API Keys</a></li> <li class="subitem"><a href="#api_keys">API Keys</a></li>
<li class="subitem"><a href="#rate_limits">Rate Limits / Caching</a></li> <li class="subitem"><a href="#rate_limits">Rate Limits / Caching</a></li>
<li class="subitem"><a href="#update">Update Channel Feed</a></li> <li class="subitem"><a href="#update_feed">Update Channel Feed</a></li>
<li class="subitem"><a href="#get_feed">Get Channel Feed</a></li> <li class="subitem"><a href="#get_feed">Get Channel Feed</a></li>
<li class="subitem"><a href="#get_field">Get Channel Field Feed</a></li> <li class="subitem"><a href="#get_field">Get Channel Field Feed</a></li>
<li class="subitem"><a href="#get_status">Get Status Updates</a></li> <li class="subitem"><a href="#get_status">Get Status Updates</a></li>
<li class="subitem"><a href="#index">List Channels</a></li> <li class="subitem"><a href="#index">List Channels</a></li>
<li class="subitem"><a href="#create">Create a Channel</a></li> <li class="subitem"><a href="#create">Create a Channel</a></li>
<li class="subitem"><a href="#update">Update a Channel</a></li>
<li class="subitem"><a href="#clear">Clear a Channel</a></li> <li class="subitem"><a href="#clear">Clear a Channel</a></li>
<li class="subitem"><a href="#delete">Delete a Channel</a></li> <li class="subitem"><a href="#delete">Delete a Channel</a></li>
<li class="subitem"><a href="#importer">Importer</a></li> <li class="subitem"><a href="#importer">Importer</a></li>

View File

@ -102,7 +102,7 @@
<br><br><br><br><br><br><br><br><br><br><br><br><br><br> <br><br><br><br><br><br><br><br><br><br><br><br><br><br>
<hr /> <hr />
<%= render 'docs/channels/update' %> <%= render 'docs/channels/update_feed' %>
<hr /> <hr />
<%= render 'docs/channels/feed' %> <%= render 'docs/channels/feed' %>
@ -119,6 +119,9 @@
<hr /> <hr />
<%= render 'docs/channels/create' %> <%= render 'docs/channels/create' %>
<hr />
<%= render 'docs/channels/update' %>
<hr /> <hr />
<%= render 'docs/channels/clear' %> <%= render 'docs/channels/clear' %>

View File

@ -1,99 +1,104 @@
<div> <div>
<%= render 'response' %> <%= render 'response' %>
<h2 id="update">Update Channel Feed</h2> <h2 id="update">Update a Channel</h2>
</div> </div>
<br> <br>
To update a Channel feed, send an HTTP GET or POST to<br> To update a Channel, send an HTTP PUT to
<code><%= @ssl_api_domain %>update<span class="format format-json">.json</span><span class="format format-xml">.xml</span></code> . <br><code><%= @ssl_api_domain %>channels/<span class="customcode">CHANNEL_ID</span><span class="format format-json">.json</span><span class="format format-xml">.xml</span></code> .
<br><br> <br><br>
Valid parameters: Valid parameters:
<ul> <ul>
<li><b>api_key</b> (string) - Write API Key for this specific Channel (required). The Write API Key can optionally be sent via an X-THINGSPEAKAPIKEY HTTP header.</li> <li><b>api_key</b> (string) - User's API Key; please note that this is different than a Channel API key, and can be found in <a href="/account">your account details</a>. (required).</li>
<li><b>field1</b> (string) - Field 1 data (optional)</li> <li><b>description</b> (string) - Description of the Channel (optional)</li>
<li><b>field2</b> (string) - Field 2 data (optional)</li>
<li><b>field3</b> (string) - Field 3 data (optional)</li>
<li><b>field4</b> (string) - Field 4 data (optional)</li>
<li><b>field5</b> (string) - Field 5 data (optional)</li>
<li><b>field6</b> (string) - Field 6 data (optional)</li>
<li><b>field7</b> (string) - Field 7 data (optional)</li>
<li><b>field8</b> (string) - Field 8 data (optional)</li>
<li><b>lat</b> (decimal) - Latitude in degrees (optional)</li>
<li><b>long</b> (decimal) - Longitude in degrees (optional)</li>
<li><b>elevation</b> (integer) - Elevation in meters (optional)</li> <li><b>elevation</b> (integer) - Elevation in meters (optional)</li>
<li><b>status</b> (string) - Status update message (optional)</li> <li><b>field1</b> (string) - Field1 name (optional)</li>
<li><b>twitter</b> (string) - Twitter username linked to <a href="/docs/thingtweet">ThingTweet</a> (optional)</li> <li><b>field2</b> (string) - Field2 name (optional)</li>
<li><b>tweet</b> (string) - Twitter status update; see <a href="/docs/thingtweet#update">updating ThingTweet</a> for more info (optional)</li> <li><b>field3</b> (string) - Field3 name (optional)</li>
<li><b>created_at</b> (datetime) - Date when this feed entry was created, in the format<br>YYYY-MM-DD%20HH:NN:SS (optional)</li> <li><b>field4</b> (string) - Field4 name (optional)</li>
<li><b>field5</b> (string) - Field5 name (optional)</li>
<li><b>field6</b> (string) - Field6 name (optional)</li>
<li><b>field7</b> (string) - Field7 name (optional)</li>
<li><b>field8</b> (string) - Field8 name (optional)</li>
<li><b>latitude</b> (decimal) - Latitude in degrees (optional)</li>
<li><b>longitude</b> (decimal) - Longitude in degrees (optional)</li>
<li><b>metadata</b> (text) - Metadata for the Channel, which can include JSON, XML, or any other data (optional)</li>
<li><b>name</b> (string) - Name of the Channel (optional)</li>
<li><b>public_flag</b> (true/false) - Whether the Channel should be public, default false (optional)</li>
<li><b>tags</b> (string) - Comma-separated list of tags (optional)</li>
<li><b>url</b> (string) - Webpage URL for the Channel (optional)</li>
</ul> </ul>
<br> <br>
Example POST: Example PUT:
<pre> <pre>
POST <span class="str"><%= @ssl_api_domain %>update<span class="format format-json">.json</span><span class="format format-xml">.xml</span></span> PUT <span class="str"><%= @ssl_api_domain %>channels/<span class="customcode">4</span><span class="format format-json">.json</span><span class="format format-xml">.xml</span></span>
api_key=<span class="customcode"><%= @channel_api_key %></span> api_key=<span class="customcode"><%= @user_api_key %></span>
field1=<span class="customcode">73</span> name=<span class="customcode">Updated Channel</span>
</pre> </pre>
<br> <br>
<div class="format format-block-xl format-text"> <div class="format format-block-xxl format-text">
The response will be the entry ID of the update, for example: <code>18</code> The response will be a webpage with your updated Channel.
<br><br>
If the response is <code>0</code> then the update failed.
</div> </div>
<div class="format format-block-xl format-json"> <div class="format format-block-xxl format-json">
The response will be a JSON object of the new feed, for example: The response will be a JSON object of the updated channel, for example:
<pre class="prettyprint"> <pre class="prettyprint">
{ {
"channel_id": 3, "id": 4,
"field1": "73", "name": "Updated Channel",
"field2": null, "description": null,
"field3": null, "metadata": null,
"field4": null,
"field5": null,
"field6": null,
"field7": null,
"field8": null,
"created_at": "2014-02-25T14:13:01-05:00",
"entry_id": 320,
"status": null,
"latitude": null, "latitude": null,
"longitude": null, "longitude": null,
"created_at": "2014-03-25T13:12:50-04:00",
"elevation": null, "elevation": null,
"location":null "last_entry_id": null,
"ranking": 15,
"username": "hans",
"tags": [],
"api_keys":
[
{
"api_key": "XXXXXXXXXXXXXXXX",
"write_flag": true
}
]
} }
</pre> </pre>
</div> </div>
<div class="format format-block-xl format-xml"> <div class="format format-block-xxl format-xml">
The response will be an XML object of the new feed, for example: The response will be an XML object of the updated channel, for example:
<pre class="prettyprint"> <pre class="prettyprint">
&lt;?xml version="1.0" encoding="UTF-8"?> &lt;?xml version="1.0" encoding="UTF-8"?>
&lt;feed> &lt;channel>
&lt;channel-id type="integer">3&lt;/channel-id> &lt;id type="integer">4&lt;/id>
&lt;field1>73&lt;/field1> &lt;name>Updated Channel&lt;/name>
&lt;field2 nil="true"/> &lt;description nil="true" />
&lt;field3 nil="true"/> &lt;metadata nil="true" />
&lt;field4 nil="true"/> &lt;latitude type="decimal" nil="true" />
&lt;field5 nil="true"/> &lt;longitude type="decimal" nil="true" />
&lt;field6 nil="true"/> &lt;created-at type="dateTime">2014-03-25T20:17:44-04:00&lt;/created-at>
&lt;field7 nil="true"/> &lt;elevation nil="true" />
&lt;field8 nil="true"/> &lt;last-entry-id type="integer" nil="true" />
&lt;created-at type="dateTime">2014-02-25T14:15:42-05:00&lt;/created-at> &lt;ranking type="integer">15&lt;/ranking>
&lt;entry-id type="integer">321&lt;/entry-id> &lt;username>hans&lt;/username>
&lt;status nil="true"/> &lt;tags type="array" />
&lt;latitude type="decimal" nil="true"/> &lt;api-keys type="array">
&lt;longitude type="decimal" nil="true"/> &lt;api-key>
&lt;elevation nil="true"/> &lt;api-key>XXXXXXXXXXXXXXXX&lt;/api-key>
&lt;location nil="true"/> &lt;write-flag type="boolean">true&lt;/write-flag>
&lt;/feed> &lt;/api-key>
&lt;/api-keys>
&lt;/channel>
</pre> </pre>
</div> </div>

View File

@ -0,0 +1,100 @@
<div>
<%= render 'response' %>
<h2 id="update_feed">Update Channel Feed</h2>
</div>
<br>
To update a Channel feed, send an HTTP GET or POST to<br>
<code><%= @ssl_api_domain %>update<span class="format format-json">.json</span><span class="format format-xml">.xml</span></code> .
<br><br>
Valid parameters:
<ul>
<li><b>api_key</b> (string) - Write API Key for this specific Channel (required). The Write API Key can optionally be sent via an X-THINGSPEAKAPIKEY HTTP header.</li>
<li><b>field1</b> (string) - Field 1 data (optional)</li>
<li><b>field2</b> (string) - Field 2 data (optional)</li>
<li><b>field3</b> (string) - Field 3 data (optional)</li>
<li><b>field4</b> (string) - Field 4 data (optional)</li>
<li><b>field5</b> (string) - Field 5 data (optional)</li>
<li><b>field6</b> (string) - Field 6 data (optional)</li>
<li><b>field7</b> (string) - Field 7 data (optional)</li>
<li><b>field8</b> (string) - Field 8 data (optional)</li>
<li><b>lat</b> (decimal) - Latitude in degrees (optional)</li>
<li><b>long</b> (decimal) - Longitude in degrees (optional)</li>
<li><b>elevation</b> (integer) - Elevation in meters (optional)</li>
<li><b>status</b> (string) - Status update message (optional)</li>
<li><b>twitter</b> (string) - Twitter username linked to <a href="/docs/thingtweet">ThingTweet</a> (optional)</li>
<li><b>tweet</b> (string) - Twitter status update; see <a href="/docs/thingtweet#update">updating ThingTweet</a> for more info (optional)</li>
<li><b>created_at</b> (datetime) - Date when this feed entry was created, in the format<br>YYYY-MM-DD%20HH:NN:SS (optional)</li>
</ul>
<br>
Example POST:
<pre>
POST <span class="str"><%= @ssl_api_domain %>update<span class="format format-json">.json</span><span class="format format-xml">.xml</span></span>
api_key=<span class="customcode"><%= @channel_api_key %></span>
field1=<span class="customcode">73</span>
</pre>
<br>
<div class="format format-block-xl format-text">
The response will be the entry ID of the update, for example: <code>18</code>
<br><br>
If the response is <code>0</code> then the update failed.
</div>
<div class="format format-block-xl format-json">
The response will be a JSON object of the new feed, for example:
<pre class="prettyprint">
{
"channel_id": 3,
"field1": "73",
"field2": null,
"field3": null,
"field4": null,
"field5": null,
"field6": null,
"field7": null,
"field8": null,
"created_at": "2014-02-25T14:13:01-05:00",
"entry_id": 320,
"status": null,
"latitude": null,
"longitude": null,
"elevation": null,
"location":null
}
</pre>
</div>
<div class="format format-block-xl format-xml">
The response will be an XML object of the new feed, for example:
<pre class="prettyprint">
&lt;?xml version="1.0" encoding="UTF-8"?>
&lt;feed>
&lt;channel-id type="integer">3&lt;/channel-id>
&lt;field1>73&lt;/field1>
&lt;field2 nil="true"/>
&lt;field3 nil="true"/>
&lt;field4 nil="true"/>
&lt;field5 nil="true"/>
&lt;field6 nil="true"/>
&lt;field7 nil="true"/>
&lt;field8 nil="true"/>
&lt;created-at type="dateTime">2014-02-25T14:15:42-05:00&lt;/created-at>
&lt;entry-id type="integer">321&lt;/entry-id>
&lt;status nil="true"/>
&lt;latitude type="decimal" nil="true"/>
&lt;longitude type="decimal" nil="true"/>
&lt;elevation nil="true"/>
&lt;location nil="true"/>
&lt;/feed>
</pre>
</div>

View File

@ -143,6 +143,25 @@ describe ChannelsController do
end end
end end
describe "update channel" do
it 'updates a channel' do
post :update, {:id => @channel.id, :key => @user.api_key, :name => 'newname'}
response.should be_redirect
@channel.reload
@channel.name.should eq("newname")
channel_id = Channel.all.last.id
response.should redirect_to(channel_path(channel_id))
end
it 'returns JSON' do
post :update, {:id => @channel.id, :key => @user.api_key, :name => 'newname', :format => 'json'}
JSON.parse(response.body)['name'].should eq("newname")
end
it 'returns XML' do
post :update, {:id => @channel.id, :key => @user.api_key, :name => 'newname', :format => 'xml'}
Nokogiri::XML(response.body).css('name').text.should eq("newname")
end
end
describe "clear channel" do describe "clear channel" do
it 'clears a channel' do it 'clears a channel' do
@channel.feeds.count.should eq(1) @channel.feeds.count.should eq(1)