diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2016-09-27 16:58:23 +0200 |
---|---|---|
committer | Eugen Rochko <eugen@zeonfederated.com> | 2016-09-27 16:59:08 +0200 |
commit | 4f9b7432dd4d323ac6cc4efceeae2efaffe62e7d (patch) | |
tree | acae9e59bd6971885f7cb7b7ed45c4c9d1af4fca /app/views/api/v1/statuses | |
parent | 3f75f522856954690d92358107e78bafd0db0baa (diff) |
Fix #52 - Add API versioning (v1)
Diffstat (limited to 'app/views/api/v1/statuses')
-rw-r--r-- | app/views/api/v1/statuses/context.rabl | 13 | ||||
-rw-r--r-- | app/views/api/v1/statuses/home.rabl | 2 | ||||
-rw-r--r-- | app/views/api/v1/statuses/mentions.rabl | 2 | ||||
-rw-r--r-- | app/views/api/v1/statuses/show.rabl | 31 |
4 files changed, 48 insertions, 0 deletions
diff --git a/app/views/api/v1/statuses/context.rabl b/app/views/api/v1/statuses/context.rabl new file mode 100644 index 000000000..e9176dc29 --- /dev/null +++ b/app/views/api/v1/statuses/context.rabl @@ -0,0 +1,13 @@ +object false + +node :ancestors do + @ancestors.map do |status| + partial('api/v1/statuses/show', object: status) + end +end + +node :descendants do + @descendants.map do |status| + partial('api/v1/statuses/show', object: status) + end +end diff --git a/app/views/api/v1/statuses/home.rabl b/app/views/api/v1/statuses/home.rabl new file mode 100644 index 000000000..0a0ed13c5 --- /dev/null +++ b/app/views/api/v1/statuses/home.rabl @@ -0,0 +1,2 @@ +collection @statuses +extends('api/v1/statuses/show') diff --git a/app/views/api/v1/statuses/mentions.rabl b/app/views/api/v1/statuses/mentions.rabl new file mode 100644 index 000000000..0a0ed13c5 --- /dev/null +++ b/app/views/api/v1/statuses/mentions.rabl @@ -0,0 +1,2 @@ +collection @statuses +extends('api/v1/statuses/show') diff --git a/app/views/api/v1/statuses/show.rabl b/app/views/api/v1/statuses/show.rabl new file mode 100644 index 000000000..3595bafb4 --- /dev/null +++ b/app/views/api/v1/statuses/show.rabl @@ -0,0 +1,31 @@ +object @status +attributes :id, :created_at, :in_reply_to_id + +node(:uri) { |status| TagManager.instance.uri_for(status) } +node(:content) { |status| Formatter.instance.format(status) } +node(:url) { |status| TagManager.instance.url_for(status) } +node(:reblogs_count) { |status| status.reblogs_count } +node(:favourites_count) { |status| status.favourites_count } +node(:favourited) { |status| current_account.favourited?(status) } +node(:reblogged) { |status| current_account.reblogged?(status) } + +child :reblog => :reblog do + extends('api/v1/statuses/show') +end + +child :account do + extends('api/v1/accounts/show') +end + +child :media_attachments, object_root: false do + attributes :id, :remote_url, :type + + node(:url) { |media| full_asset_url(media.file.url) } + node(:preview_url) { |media| full_asset_url(media.file.url(:small)) } +end + +child :mentions, object_root: false do + node(:url) { |mention| TagManager.instance.url_for(mention.account) } + node(:acct) { |mention| mention.account.acct } + node(:id) { |mention| mention.account_id } +end |