2016-11-13 21:16:17 +00:00
|
|
|
# Copyright (C) 2012-2016 Zammad Foundation, http://zammad-foundation.org/
|
2016-11-01 16:16:04 +00:00
|
|
|
|
|
|
|
class ApplicationsController < ApplicationController
|
2017-02-15 12:29:25 +00:00
|
|
|
prepend_before_action { authentication_check(permission: 'admin.api') }
|
2016-11-01 16:16:04 +00:00
|
|
|
|
|
|
|
def index
|
|
|
|
all = Doorkeeper::Application.all
|
|
|
|
if params[:full]
|
|
|
|
assets = {}
|
|
|
|
item_ids = []
|
|
|
|
all.each { |item|
|
|
|
|
item_ids.push item.id
|
|
|
|
if !assets[:Application]
|
|
|
|
assets[:Application] = {}
|
|
|
|
end
|
2016-11-13 21:16:17 +00:00
|
|
|
application = item.attributes
|
|
|
|
application[:clients] = Doorkeeper::AccessToken.where(application_id: item.id).count
|
|
|
|
assets[:Application][item.id] = application
|
2016-11-01 16:16:04 +00:00
|
|
|
}
|
|
|
|
render json: {
|
|
|
|
record_ids: item_ids,
|
|
|
|
assets: assets,
|
|
|
|
}, status: :ok
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
render json: all, status: :ok
|
|
|
|
end
|
|
|
|
|
2016-11-13 21:16:17 +00:00
|
|
|
def token
|
|
|
|
access_token = Doorkeeper::AccessToken.create!(application_id: params[:id], resource_owner_id: current_user.id)
|
|
|
|
render json: { token: access_token.token }, status: :ok
|
|
|
|
end
|
|
|
|
|
2016-11-01 16:16:04 +00:00
|
|
|
def show
|
|
|
|
application = Doorkeeper::Application.find(params[:id])
|
|
|
|
render json: application, status: :ok
|
|
|
|
end
|
|
|
|
|
|
|
|
def create
|
|
|
|
application = Doorkeeper::Application.new(clean_params)
|
|
|
|
application.save!
|
|
|
|
render json: application, status: :ok
|
|
|
|
end
|
|
|
|
|
|
|
|
def update
|
|
|
|
application = Doorkeeper::Application.find(params[:id])
|
|
|
|
application.update_attributes!(clean_params)
|
|
|
|
render json: application, status: :ok
|
|
|
|
end
|
|
|
|
|
|
|
|
def destroy
|
|
|
|
application = Doorkeeper::Application.find(params[:id])
|
|
|
|
application.destroy!
|
|
|
|
render json: {}, status: :ok
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def clean_params
|
2017-09-08 08:28:34 +00:00
|
|
|
params_data = params.permit!.to_h
|
2016-11-01 16:16:04 +00:00
|
|
|
params_data.delete('application')
|
|
|
|
params_data.delete('action')
|
|
|
|
params_data.delete('controller')
|
|
|
|
params_data.delete('id')
|
|
|
|
params_data.delete('uid')
|
|
|
|
params_data.delete('secret')
|
|
|
|
params_data.delete('created_at')
|
2016-11-13 21:16:17 +00:00
|
|
|
params_data.delete('updated_at')
|
2016-11-01 16:16:04 +00:00
|
|
|
params_data
|
|
|
|
end
|
|
|
|
end
|