From 0e8c226b7c9d24ee881fddf2db0e7622a16e7993 Mon Sep 17 00:00:00 2001 From: Bilal Date: Tue, 15 Sep 2020 18:06:31 +0300 Subject: [PATCH] show accounts for current user on /accounts endpoint --- app/controllers/api/accounts_controller.rb | 5 +++++ app/serializers/serializable_account.rb | 21 +++++++++++++++++++++ config/routes.rb | 1 + 3 files changed, 27 insertions(+) create mode 100644 app/controllers/api/accounts_controller.rb create mode 100644 app/serializers/serializable_account.rb diff --git a/app/controllers/api/accounts_controller.rb b/app/controllers/api/accounts_controller.rb new file mode 100644 index 0000000..1521989 --- /dev/null +++ b/app/controllers/api/accounts_controller.rb @@ -0,0 +1,5 @@ +class Api::AccountsController < Api::ApiController + def show + render jsonapi: current_user.accounts + end +end diff --git a/app/serializers/serializable_account.rb b/app/serializers/serializable_account.rb new file mode 100644 index 0000000..b37c758 --- /dev/null +++ b/app/serializers/serializable_account.rb @@ -0,0 +1,21 @@ +class SerializableAccount < JSONAPI::Serializable::Resource + type "account" + + attributes :name + + attribute :users do + @object.users.map do |user| + if user.avatar.attached? + avatar = Rails.application.routes.url_helpers.rails_blob_url(user.avatar, host: AppHost.new.domain_with_port) + else + avatar = nil + end + { + email: user.email, + name: user.full_name, + role: user.account_auths.map(&:role).compact.join(", "), + avatar: avatar + } + end + end +end diff --git a/config/routes.rb b/config/routes.rb index d93745c..648354f 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -171,6 +171,7 @@ Rails.application.routes.draw do post 'user_token' => 'user_token#create' post 'users' => 'users#create' resource :profiles, only: [:show] + resource :accounts, only: [:show] resources :projects, only: [:index] do resources :broadcasts, only: [:index, :show, :update] RELEASES.each do |release|