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|