Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/eed3si9n/repatch-twitter
a plugin for Dispatch to use Twitter API
https://github.com/eed3si9n/repatch-twitter
Last synced: 2 months ago
JSON representation
a plugin for Dispatch to use Twitter API
- Host: GitHub
- URL: https://github.com/eed3si9n/repatch-twitter
- Owner: eed3si9n
- Created: 2013-05-11T22:55:26.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2014-05-11T20:26:15.000Z (over 10 years ago)
- Last Synced: 2024-10-04T16:43:45.383Z (3 months ago)
- Language: Scala
- Homepage: http://eed3si9n.com/howto-write-a-dispatch-plugin
- Size: 572 KB
- Stars: 11
- Watchers: 6
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
repatch-twitter
===============repatch-twitter is a Dispatch 0.11 plugin for [Twitter API][twitterapi].
- [API doc](http://eed3si9n.github.io/repatch-twitter/latest/api/)
license
-------- [MIT License](http://opensource.org/licenses/MIT)
setup
-----```scala
resolvers += Resolver.sonatypeRepo("public")// libraryDependencies += "com.eed3si9n" %% "repatch-twitter-core" % "dispatch0.11.0_0.1.0"
libraryDependencies += "com.eed3si9n" %% "repatch-twitter-core" % "dispatch0.11.1_0.1.0"
```authentication
--------------`repatch.twitter.request.AbstractClient` abstracts the OAuth authentication to use Twitter API. `OAuthClient` implements it.
```scala
scala> import dispatch._, Defaults._
import dispatch._
import Defaults._scala> import com.ning.http.client.oauth._
import com.ning.http.client.oauth._scala> import repatch.twitter.request._
import repatch.twitter.request._scala> val consumer = new ConsumerKey("abcd", "secret")
consumer: com.ning.http.client.oauth.ConsumerKey = {Consumer key, key="abcd", secret="secret"}scala> val accessToken = new RequestToken("xyz", "secret")
accessToken: com.ning.http.client.oauth.RequestToken = { key="xyz", secret="secret"}scala> val client = OAuthClient(consumer, accessToken)
client: repatch.twitter.request.OAuthClient =
```There's `ProperitesClient` that can load the consumer key and the access token from the given file name:
```scala
scala> val prop = new java.io.File(System.getProperty("user.home"), ".foo.properties")
prop: java.io.File = /Users/you/.foo.propertiesscala> val client = PropertiesClient(prop)
client: repatch.twitter.request.OAuthClient =
```search
------### [GET search/tweets](https://dev.twitter.com/docs/api/1.1/get/search/tweets)
Here's how you can search for tweets:
```scala
scala> val x = http(client(Search("#scala").geocode_mi(40.7142, -74.0064, 10).count(2)) OK
as.repatch.twitter.response.Search)
x2: dispatch.Future[repatch.twitter.response.Search] = scala.concurrent.impl.Promise$DefaultPromise@6bc9806dscala> val search = x()
search: repatch.twitter.response.Search = Search(List(Tweet(330931826879234049,Rocking the contravariance. Hard. #nerd...
```In the above, `repatch.twitter.request.Search` is a request builder, supporting methods such as `geocode_mi` and `count`, which return `Search`. Using `as.repatch.twitter.response.Search` converter returns `repatch.twitter.response.Search`. Alternatively, you can return json, and parse individual fields as follows:
```scala
scala> val x = http(client(Search("#scala").geocode_mi(40.7142, -74.0064, 10).count(2)) OK as.json4s.Json)
x: dispatch.Future[org.json4s.JValue] = scala.concurrent.impl.Promise$DefaultPromise@3252d2descala> val json = x()
json: org.json4s.JValue =
JObject(List((statuses,JArray(List(JObject(List((metadata,JObject(List((result_...scala> {
import repatch.twitter.response.Search._
import repatch.twitter.response.Tweet._
for {
t <- statuses(json)
} yield(id_str(t), text(t))
}
res0: List[(String, String)] = List((330931826879234049,Rocking the contravariance. Hard. #nerd #scala), (330877539461500928,RT @mhamrah: Excellent article on structuring distributed systems with #rabbitmq. Thanks @heroku Scaling Out with #Scala and #Akka http://t…))
```timelines
---------### [GET statuses/home_timeline](https://dev.twitter.com/docs/api/1.1/get/statuses/home_timeline)
Here's how to get your timeline.
```scala
scala> val x = http(client(Status.home_timeline) OK as.repatch.twitter.response.Tweets)
x: dispatch.Future[repatch.twitter.response.Statuses] = scala.concurrent.impl.Promise$DefaultPromise@41ad625ascala> x()
res0: List[repatch.twitter.response.Tweet] =
List(Tweet(331691122629951489,Partially applying a function that has an implicit parameter http://t.co/CwWQAkkBAN,....
```### [GET statuses/mentions_timeline](https://dev.twitter.com/docs/api/1.1/get/statuses/mentions_timeline)
> Returns the 20 most recent mentions.
```scala
scala> val timeline = http(client(Status.mentions_timeline) OK as.repatch.twitter.response.Tweets)
timeline: dispatch.Future[List[repatch.twitter.response.Tweet]] = scala.concurrent.impl.Promise$DefaultPromise@53a5af37scala> timeline()
res0: List[repatch.twitter.response.Tweet] =
List(Tweet(333386163618455553,@eed3si9n I keep seeing pros and cons...
```### [GET statuses/user_timeline](https://dev.twitter.com/docs/api/1.1/get/statuses/user_timeline)
> Returns a collection of the most recent Tweets posted by the user indicated by the `screen_name` or `user_id` parameters.
```scala
scala> val timeline = http(client(Status.user_timeline("twitterapi")) OK as.repatch.twitter.response.Tweets)
timeline: dispatch.Future[List[repatch.twitter.response.Tweet]] = scala.concurrent.impl.Promise$DefaultPromise@40878d74scala> timeline()
res0: List[repatch.twitter.response.Tweet] =
List(Tweet(330369772619452416,We're extending API v1 Retirement...
```### [GET statuses/retweets_of_me](https://dev.twitter.com/docs/api/1.1/get/statuses/retweets_of_me)
> Returns the most recent tweets authored by the authenticating user that have been retweeted by others.
```scala
scala> val timeline = http(client(Status.retweets_of_me) OK as.repatch.twitter.response.Tweets)
timeline: dispatch.Future[List[repatch.twitter.response.Tweet]] = scala.concurrent.impl.Promise$DefaultPromise@14128779
```tweets
------### [POST statuses/update](https://dev.twitter.com/docs/api/1.1/post/statuses/update)
Send a tweet.
```scala
scala> val x = http(client(Status.update("testing from REPL"))
OK as.repatch.twitter.response.Tweet)
x: dispatch.Future[repatch.twitter.response.Tweet = scala.concurrent.impl.Promise$DefaultPromise@65056d18
```To reply to a tweet, call `in_reply_to_status_id(id)` method on `Status.Update` class.
### [POST statuses/retweet/:id](https://dev.twitter.com/docs/api/1.1/post/statuses/retweet/%3Aid)
> Retweets a tweet.
```scala
scala> val rt = http(client(Status.retweet(res0.id)) OK as.repatch.twitter.response.Tweet)
rt: dispatch.Future[repatch.twitter.response.Tweet] = scala.concurrent.impl.Promise$DefaultPromise@6758cd8scala> rt()
res7: repatch.twitter.response.Tweet = Tweet(333519011696484352,RT @PLT_Hulk: ...
```### [GET statuses/retweets/:id](https://dev.twitter.com/docs/api/1.1/get/statuses/retweets/%3Aid)
> Returns up to 100 of the first retweets of a given tweet.
```scala
scala> val rts = http(client(Status.retweets(BigInt("317744323254943744"))) OK
as.repatch.twitter.response.Tweets)
rts: dispatch.Future[List[repatch.twitter.response.Tweet]] = scala.concurrent.impl.Promise$DefaultPromise@98fd639scala> rts()
res4: List[repatch.twitter.response.Tweet] =
List(Tweet(317776021933916160,RT @eed3si9n: scala> :k Monad // Finds locally imported types.
```### [GET statuses/show/:id](https://dev.twitter.com/docs/api/1.1/get/statuses/show/%3Aid)
> Returns a single Tweet, specified by the id parameter.
```scala
scala> val x = http(client(Status.show(BigInt("317744323254943744"))) OK
as.repatch.twitter.response.Tweet)
x: dispatch.Future[repatch.twitter.response.Tweet] = scala.concurrent.impl.Promise$DefaultPromise@4c603a77scala> x()
res2: repatch.twitter.response.Tweet =
Tweet(317744323254943744,scala> :k Monad // Finds locally imported types
```### [POST statuses/destroy/:id](https://dev.twitter.com/docs/api/1.1/post/statuses/destroy/%3Aid)
> Destroys the status specified by the required ID parameter.
```scala
scala> x()
res0: repatch.twitter.response.Tweet = Tweet(333505115287846913, ...scala> val deleted = http(client(Status.destroy(res0.id)) OK as.repatch.twitter.response.Tweet)
deleted: dispatch.Future[repatch.twitter.response.Tweet] = scala.concurrent.impl.Promise$DefaultPromise@a852084scala> deleted()
res3: repatch.twitter.response.Tweet = Tweet(333505115287846913, ...
```favorites
---------### [GET favorites/list](https://dev.twitter.com/docs/api/1.1/get/favorites/list)
> Returns the 20 most recent Tweets favorited by the authenticating or specified user.
```scala
scala> val myfavs = http(client(Favorite.list) OK as.repatch.twitter.response.Tweets)
favs: dispatch.Future[List[repatch.twitter.response.Tweet]] = scala.concurrent.impl.Promise$DefaultPromise@4482d3a3scala> myfavs()
res0: List[repatch.twitter.response.Tweet] = List(Tweet(331773677295239169scala> val favs = http(client(Favorite.list("PLT_HULK")) OK as.repatch.twitter.response.Tweets)
favs: dispatch.Future[List[repatch.twitter.response.Tweet]] = scala.concurrent.impl.Promise$DefaultPromise@366ec9d4scala> favs()
res1: List[repatch.twitter.response.Tweet] = List(Tweet(246253900770983937,@PLT_Hulk is angry lately.,...
```### [POST favorites/create](https://dev.twitter.com/docs/api/1.1/post/favorites/create)
> Favorites the status specified in the ID parameter as the authenticating user.
```scala
scala> val fav = http(client(Favorite(res0.id)) OK as.repatch.twitter.response.Tweet)
fav: dispatch.Future[repatch.twitter.response.Tweet] = scala.concurrent.impl.Promise$DefaultPromise@12810908scala> fav()
res1: repatch.twitter.response.Tweet = Tweet(333297803155611649,
```### [POST favorites/destroy](https://dev.twitter.com/docs/api/1.1/post/favorites/destroy)
> Un-favorites the status specified in the ID parameter as the authenticating user.
```scala
scala> val unfav = http(client(Favorite.destroy(res0.id)) OK as.repatch.twitter.response.Tweet)
unfav: dispatch.Future[repatch.twitter.response.Tweet] = scala.concurrent.impl.Promise$DefaultPromise@7f3e93cbscala> unfav()
res1: repatch.twitter.response.Tweet = Tweet(333297803155611649
```streaming
---------### [POST statuses/filter](https://dev.twitter.com/docs/api/1.1/post/statuses/filter)
> Returns public statuses that match one or more filter predicates.
```scala
scala> http(client(PublicStream.track("scala")) >
as.repatch.twitter.response.stream.TweetOrJson {
case Right(tweet) => println(tweet)
case Left(json) => println(json)
})
res0: dispatch.Future[Unit] = scala.concurrent.impl.Promise$DefaultPromise@3f77f4eascala> Tweet(333804083792191488,Looking for a Hoogle like to Scala? ....
```### [GET user](https://dev.twitter.com/docs/api/1.1/get/user)
> Streams messages for a single user, as described in User streams.
```scala
scala> http(client(UserStream()) > as.repatch.twitter.response.stream.TweetOrJson {
case Right(tweet) => println(tweet)
case Left(json) => println(json)
})
res0: dispatch.Future[Unit] = scala.concurrent.impl.Promise$DefaultPromise@451094e7
```friends & followers
-------------------### [GET friends/ids](https://dev.twitter.com/docs/api/1.1/get/friends/ids)
> Returns a cursored collection of user IDs for every user the specified user is following.
```scala
scala> val x = http(client(Friend.ids) OK as.json4s.Json)
x: dispatch.Future[org.json4s.JValue] = scala.concurrent.impl.Promise$DefaultPromise@72d53ac7scala> {
import repatch.twitter.response.Friend._
val json = x()
ids(json)
}
res0: List[BigInt] = List(812340000, ...
```### [GET followers/ids](https://dev.twitter.com/docs/api/1.1/get/followers/ids)
> Returns a cursored collection of user IDs for every user following the specified user.
```scala
scala> val x = http(client(Follower.ids) OK as.json4s.Json)
x: dispatch.Future[org.json4s.JValue] = scala.concurrent.impl.Promise$DefaultPromise@7449d884scala> {
import repatch.twitter.response.Follower._
val json = x()
ids(json)
}
res0: List[BigInt] = List(1234567, ...
```### [POST friendships/create](https://dev.twitter.com/docs/api/1.1/post/friendships/create)
> Allows the authenticating users to follow the user specified in the ID parameter.
```scala
scala> val u = http(client(Friendship("twitterapi")) OK as.repatch.twitter.response.User)
u: dispatch.Future[repatch.twitter.response.User] = scala.concurrent.impl.Promise$DefaultPromise@50e3fa1dscala> u()
res0: repatch.twitter.response.User = User(6253282,twitterapi,...
```### [POST friendships/destroy](https://dev.twitter.com/docs/api/1.1/post/friendships/destroy)
> Allows the authenticating user to unfollow the user specified in the ID parameter.
```scala
scala> val u = http(client(Friendship.destroy("twitterapi")) OK as.repatch.twitter.response.User)
u: dispatch.Future[repatch.twitter.response.User] = scala.concurrent.impl.Promise$DefaultPromise@487793dbscala> u()
res0: repatch.twitter.response.User = User(6253282,twitterapi,...
```users
-----### [GET users/show](https://dev.twitter.com/docs/api/1.1/get/users/show)
> Returns a variety of information about the user specified by the required user_id or screen_name parameter.
```scala
scala> val u = http(client(User.show("twitterapi")) OK as.repatch.twitter.response.User)
u: dispatch.Future[repatch.twitter.response.User] = scala.concurrent.impl.Promise$DefaultPromise@3aff776scala> u().status map {_.text}
res0: Option[String] = Some(We have deprecated HTTP 1.0 support for the Streaming API: https://t.co/JfieFem8Kf)
```[twitterapi]: https://dev.twitter.com/docs/api/1.1