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