shrub/lib/twitter.hoon
2015-12-20 13:16:39 -08:00

545 lines
14 KiB
Plaintext

:: A Twitter API library.
::
:::: /hoon+twitter+lib
::
/? 314
/- twitter
=+ twit:^twitter
!:
:::: functions
::
|%
++ fass :: rewrite path
|= a/path
%- trip
%^ gsub '-' '_'
%+ reel a
|= {p/@t q/@t}
(cat 3 '/' (cat 3 p q))
::
++ gsub :: replace chars
|= {a/@t b/@t t/@t}
^- @t
?~ t t
%+ add (lsh 3 1 $(t (rsh 3 1 t)))
=+ c=(mod t (bex 8))
?:(=(a c) b c)
::
++ oauth :: OAuth 1.0 header
|= $: med/meth
url/tape
pas/(list tape)
key/keys
zet/@
ken/@
==
^- @t
=+ non=(turn (rip 2 (shaw zet 128 ken)) |=(a/@ ~(x ne a)))
=+ tim=(slag 2 (scow %ui (unt zet)))
=+ sky=(crip :(weld (urle (trip sec.con.key)) "&" (urle (trip sec.acc.key))))
=+ ^= bas
^- tape
=+ ^= hds
%- reel :_ |=({p/tape q/tape} :(weld p "&" q))
%- sort :_ aor
%- weld :- pas
^- (list tape)
:~ :(weld "oauth_consumer_key=" (trip tok.con.key))
:(weld "oauth_nonce=" non)
:(weld "oauth_signature_method=HMAC-SHA1")
:(weld "oauth_timestamp=" tim)
:(weld "oauth_token=" (trip tok.acc.key))
:(weld "oauth_version=1.0")
==
;: weld
(trip (cuss (trip `@t`med))) "&"
(urle url) "&"
(urle (scag (dec (lent hds)) `tape`hds))
==
=+ sig=`tape`(sifo (swap 3 (hmac (swap 3 sky) (crip bas))))
%- crip
;: weld "OAuth "
"oauth_consumer_key=" "\"" (trip tok.con.key) "\", "
"oauth_nonce=" "\"" non "\", "
"oauth_signature=" "\"" (urle sig) "\", "
"oauth_signature_method=\"HMAC-SHA1\", "
"oauth_timestamp=" "\"" tim "\", "
"oauth_token=" "\"" (trip tok.acc.key) "\", "
"oauth_version=1.0"
==
::
++ valve :: produce request
|= $: med/meth
{rus/tape quy/quay}
key/keys
est/time
eny/@
==
^- hiss
=+ url="https://api.twitter.com+1.1{rus}.json"
=+ req=|=(a/tape (scan a auri:epur))
=+ ^= help
|= quy/(list {tape tape})
^- (list tape)
%+ turn quy
|= a/{p/tape q/tape}
:(weld (urle p.a) "=" (urle q.a))
=+ tan=(turn quy |=({p/@t q/@t} [(trip p) (trip q)]))
=+ har=(help (turn tan |=(p/{p/tape q/tape} [p.p (urle q.p)])))
=+ hab=(help tan)
=+ lav=(reel har |=({p/tape q/tape} :(weld p "&" q)))
=+ voy=?:(=(0 (lent lav)) ~ (scag (dec (lent lav)) `tape`lav))
=+ vab=(reel hab |=({p/tape q/tape} :(weld p "&" q)))
=+ vur=(crip ?:(=(0 (lent vab)) ~ (scag (dec (lent vab)) `tape`vab)))
=+ ^= head
%- ~(gas by *math)
:~ ['authorization' [(oauth med url hab key est eny) ~]]
['content-type' ['application+x-www-form-urlencoded' ~]]
==
?: =(%get med)
?~ voy
[(req url) med head ~]
[(req :(weld url "?" voy)) med head ~]
[(req url) med head (some [(met 3 vur) vur])]
--
!:
:::: library
::
|%
++ twip :: response printers
|%
++ mean
|= {msg/@t num/@ud} ^- tank
rose+[": " `~]^~[leaf+"Error {<num>}" leaf+(trip msg)]
--
++ twir :: response parsers
|%
++ fasp |*({a/@tas b/*} [(gsub '-' '_' a) b])
++ user (cook crip (plus ;~(pose aln cab)))
++ mean (ot errors+(ar (ot message+so code+ni ~)) ~):jo
++ stat
=+ jo
^- $+(json (unit {id/@u who/@ta now/@da txt/@t}))
%- ot
:~ id+ni
user+(ot (fasp screen-name+(su user)) ~)
(fasp created-at+da)
text+so
==
++ usel
=+ jo
^- $+(json (unit (list who/@ta)))
=- (ot users+(ar -) ~)
(ot (fasp screen-name+(su user)) ~)
--
++ twit
=> |% :: request structures
++ dev @t :: device name
++ gat @t :: grant type
++ lat @t :: latitude
++ lid (list tid)
++ lon @t :: longitude
++ lsc (list scr)
++ lst (list @t)
++ nam @t :: location name
++ pla @t :: place-id
++ scr @t :: screen name
++ slu @t :: category name
++ tid @u
++ tok @t :: oauth token
++ url @t :: callback url
::
++ at {$access-token p/tok}
++ de {$device p/dev}
++ fo {$follow p/lid}
++ gr {$grant-type p/gat}
++ id {$id p/tid}
++ ii {$'!inline' p/@t}
++ is {$id p/lid}
++ la {$lat p/lat}
++ lo {$long p/lon}
++ na {$name p/lid}
++ oa {$oauth-callback p/url}
++ os {$source-screen-name p/scr}
++ pl {$place-id p/pla}
++ qq {$q p/@t}
++ sc {$screen-name p/scr}
++ sd ?(ui sc)
++ ss {$screen-name p/lsc}
++ sl {$slug p/slu}
++ si {$source-id p/tid}
++ st {$status p/@t}
++ te {$text p/@t}
++ ti {$target-id p/tid}
++ ts {$target-screen-name p/scr}
++ tr {$track p/lst}
++ ur {$url p/url}
++ ui {$user-id p/tid}
++ us {$user-id p/lid}
--
|_ {key/keys est/time eny/@uw}
++ lutt |=(@ `@t`(rsh 3 2 (scot %ui +<)))
++ llsc
|= (list scr)
(roll +< |=({p/scr q/@t} (cat 3 (cat 3 q ',') p)))
::
++ llst
|= (list @t)
(roll +< |=({p/@t q/@t} (cat 3 (cat 3 q ',') p)))
::
++ llid
|= (list tid)
(roll +< |=({p/tid q/@t} (cat 3 (cat 3 q ',') (lutt p))))
::
++ mold :: construct request
|* {med/meth pax/path a/$+(* *)}
|= {args/a quy/quay}
(valve med (cowl pax args quy) key est eny)
::
++ cowl :: handle parameters
|= $: pax/path
ban/(list {p/@t q/?(@ (list @))})
quy/quay
==
^- {path quay}
?~ ban
[(fass pax) quy]
?: =('!inline' p.i.ban)
?@ q.i.ban
[(fass (welp pax /[`@t`q.i.ban])) quy]
!!
:- (fass pax)
%+ welp quy
%+ turn `(list {p/@t q/?(@ (list @))})`ban
|= {p/@t q/?(@ (list @))}
^- {@t @t}
:- (gsub '-' '_' p)
?@ q
?- p
?($id $source-id $target-id $user-id) (lutt q)
@ `@t`q
==
?- p
?($follow $id $name $user-id) (llid q)
$track (llst q)
$screen-name (llsc q)
* !!
==
::
++ stat-ment
(mold %get /statuses+mentions-timeline $~)
::
++ stat-user
(mold %get /statuses+user-timeline {sd $~})
::
++ stat-home
(mold %get /statuses+home-timeline $~)
::
++ stat-retw
(mold %get /statuses+retweets-of-me $~)
::
++ stat-rets-iddd
(mold %get /statuses+retweets {ii $~})
::
++ stat-show
(mold %get /statuses+show {id $~})
::
++ stat-dest-iddd
(mold %post /statuses+destroy {ii $~})
::
++ stat-upda
(mold %post /statuses+update {st $~})
::
++ stat-retw-iddd
(mold %post /statuses+retweet {ii $~})
::
++ stat-oemb-iddd
(mold %get /statuses+oembed {id $~})
::
++ stat-oemb-urll
(mold %get /statuses+oembed {ur $~})
::
++ stat-retw-idss
(mold %get /statuses+retweeters+ids {id $~})
::
++ sear-twee
(mold %get /search+tweets {qq $~})
::
++ stat-filt-foll
(mold %post /statuses+filter {?(fo tr) $~})
::
++ stat-samp
(mold %get /statuses+sample $~)
::
++ stat-fire
(mold %get /statuses+firehose $~)
::
++ user
(mold %get /user $~)
::
++ site
(mold %get /site {fo $~})
::
++ dire
(mold %get /direct-messages $~)
::
++ dire-sent
(mold %get /direct-messages+sent $~)
::
++ dire-show
(mold %get /direct-messages+show {id $~})
::
++ dire-dest
(mold %post /direct-messages+destroy {id $~})
::
++ dire-neww
(mold %post /direct-messages+new {sd te $~})
::
++ frie-nore-idss
(mold %get /friendships+no-retweets+ids $~)
::
++ frie-idss
(mold %get /friends+ids {sd $~})
::
++ foll-idss
(mold %get /followers+ids {sd $~})
::
++ frie-inco
(mold %get /friendships+incoming $~)
::
++ frie-outg
(mold %get /friendships+outgoing $~)
::
++ frie-crea
(mold %post /friendships+create {sd $~})
::
++ frie-dest
(mold %post /friendships+destroy {sd $~})
::
++ frie-upda
(mold %post /friendships+update {sd $~})
::
++ frie-show
(mold %get /friendships+show {?(si os) ?(ti ts) $~})
::
++ frie-list
(mold %get /friends+list {sd $~})
::
++ foll-list
(mold %get /followers+list {sd $~})
::
++ frie-look
(mold %get /friendships+lookup {?(us ss) $~})
::
++ acco-sett-gett
(mold %get /account+settings $~)
::
++ acco-veri
(mold %get /account+verify-credentials $~)
::
++ acco-sett-post
(mold %post /account+settings $~)
::
++ acco-upda-deli
(mold %post /account+update-delivery-device {de $~})
::
++ acco-upda-prof
(mold %post /account+update-profile $~)
::
++ acco-upda-prof-back
(mold %post /account+update-profile-background-image $~)
::
++ acco-upda-prof-colo
(mold %post /account+update-profile-colors $~)
::
++ bloc-list
(mold %get /blocks+list $~)
::
++ bloc-idss
(mold %get /blocks+ids $~)
::
++ bloc-crea
(mold %post /blocks+create {sd $~})
::
++ bloc-dest
(mold %post /blocks+destroy {sd $~})
::
++ user-look
(mold %get /users+lookup {?(us ss) $~})
::
++ user-show
(mold %get /users+show {sd $~})
::
++ user-sear
(mold %get /users+search {qq $~})
::
++ user-cont-tees
(mold %get /users+contributees {sd $~})
::
++ user-cont-tors
(mold %get /users+contributors {sd $~})
::
++ acco-remo
(mold %post /account+remove-profile-banner $~)
::
++ user-prof
(mold %get /users+profile-banner {sd $~})
::
++ mute-user-crea
(mold %post /mutes+users+create {sd $~})
::
++ mute-user-dest
(mold %post /mutes+users+destroy {sd $~})
::
++ mute-user-idss
(mold %get /mutes+users+ids $~)
::
++ mute-user-list
(mold %get /mutes+users+list $~)
::
++ user-sugg-slug
(mold %get /users+suggestions {sl $~})
::
++ user-sugg
(mold %get /users+suggestions $~)
::
++ favo-list
(mold %get /favorites+list $~)
::
++ favo-dest
(mold %post /favorites+destroy {id $~})
::
++ favo-crea
(mold %post /favorites+create {id $~})
::
++ list-list
(mold %get /lists+list $~)
::
++ list-stat
(mold %get /lists+statuses $~)
::
++ list-memb-dest
(mold %post /lists+members+destroy $~)
::
++ list-memb-hips
(mold %get /lists+memberships {sd $~})
::
++ list-subs-bers
(mold %get /lists+subscribers $~)
::
++ list-subs-crea
(mold %post /lists+subscribers+create $~)
::
++ list-subs-show
(mold %get /lists+subscribers+show {sd $~})
::
++ list-subs-dest
(mold %post /lists+subscribers+destroy $~)
::
++ list-memb-crea-alll
(mold %post /lists+members+create-all {?(us ss) $~})
::
++ list-memb-show
(mold %get /lists+members+show {sd $~})
::
++ list-memb-bers
(mold %get /lists+members $~)
::
++ list-memb-crea
(mold %post /lists+members+create {sd $~})
::
++ list-dest
(mold %post /lists+destroy $~)
::
++ list-upda
(mold %post /lists+update $~)
::
++ list-crea
(mold %post /lists+create {na $~})
::
++ list-show
(mold %get /lists+show $~)
::
++ list-subs-ions
(mold %get /lists+subscriptions {sd $~})
::
++ list-memb-dest-alll
(mold %post /lists+members+destroy-all {?(us ss) $~})
::
++ list-owne
(mold %get /lists+ownerships {sd $~})
::
++ save-list
(mold %get /saved-searches+list $~)
::
++ save-show-iddd
(mold %get /saved-searches+show {ii $~})
::
++ save-crea
(mold %post /saved-searches+create {qq $~})
::
++ save-dest-iddd
(mold %post /saved-searches+destroy {ii $~})
::
++ geoo-iddd-plac
(mold %get /geo+id {ii $~})
::
++ geoo-reve
(mold %get /geo+reverse-geocode {la lo $~})
::
++ geoo-sear
(mold %get /geo+search $~)
::
++ geoo-simi
(mold %get /geo+similar-places {la lo na $~})
::
++ tren-plac
(mold %get /trends+place {id $~})
::
++ tren-avai
(mold %get /trends+available $~)
::
++ tren-clos
(mold %get /trends+closest {la lo $~})
::
++ user-repo
(mold %post /users+report-spam {sd $~})
::
++ oaut-auth-cate
(mold %get /oauth+authenticate $~)
::
++ oaut-auth-rize
(mold %get /oauth+authorize $~)
::
++ oaut-acce
(mold %post /oauth+access-token $~)
::
++ oaut-requ
(mold %post /oauth+request-token {oa $~})
::
++ oaut-toke
(mold %post /oauth2/token {gr $~})
::
++ oaut-inva
(mold %post /oauth2/invalidate-token {at $~})
::
++ help-conf
(mold %get /help+configuration $~)
::
++ help-lang
(mold %get /help+languages $~)
::
++ help-priv
(mold %get /help+privacy $~)
::
++ help-toss
(mold %get /help+tos $~)
::
++ appl-rate
(mold %get /application+rate-limit-status $~)
::
++ stat-look
(mold %get /statuses+lookup {us $~})
--
--