class Twitter::Client
@@STATUS_URIS = {
:get => '/statuses/show.json',
:post => '/statuses/update.json',
:delete => '/statuses/destroy.json',
}
# Provides access to individual statuses via Twitter's Status APIs
#
# action can be of the following values:
# * :get to retrieve status content. Assumes value given responds to :to_i message in meaningful way to yield intended status id.
# * :post to publish a new status
# * :delete to remove an existing status. Assumes value given responds to :to_i message in meaningful way to yield intended status id.
#
# value should be set to:
# * the status identifier for :get case
# * the status text message for :post case
# * none necessary for :delete case
#
# Examples:
# twitter.status(:get, 107786772)
# twitter.status(:post, "New Ruby open source project Twitter4R version 0.2.0 released.")
# twitter.status(:delete, 107790712)
#
# An ArgumentError will be raised if an invalid action
# is given. Valid actions are:
# * +:get+
# * +:post+
# * +:delete+
def status(action, value = nil)
return self.timeline_for(action, value || {}) if :replies == action
raise ArgumentError, "Invalid status action: #{action}" unless @@STATUS_URIS.keys.member?(action)
return nil unless value
uri = @@STATUS_URIS[action]
response = nil
case action
when :get
response = http_connect {|conn| create_http_get_request(uri, :id => value.to_i) }
when :post
response = http_connect({:status => value, :source => @@config.source}.to_http_str) {|conn| create_http_post_request(uri) }
when :delete
response = http_connect {|conn| create_http_delete_request(uri, :id => value.to_i) }
end
bless_model(Twitter::Status.unmarshal(response.body))
end
end