123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196 |
- # Copyright (C) 2012-2014 Zammad Foundation, http://zammad-foundation.org/
- class OrganizationsController < ApplicationController
- before_filter :authentication_check
- =begin
- Format:
- JSON
- Example:
- {
- "id":1,
- "name":"Znuny GmbH",
- "note":"",
- "active":true,
- "shared":true,
- "updated_at":"2012-09-14T17:51:53Z",
- "created_at":"2012-09-14T17:51:53Z",
- "created_by_id":2,
- }
- =end
- =begin
- Resource:
- GET /api/v1/organizations.json
- Response:
- [
- {
- "id": 1,
- "name": "some_name1",
- ...
- },
- {
- "id": 2,
- "name": "some_name2",
- ...
- }
- ]
- Test:
- curl http://localhost/api/v1/organizations.json -v -u #{login}:#{password}
- =end
- def index
- # only allow customer to fetch his own organization
- organizations = []
- if is_role('Customer') && !is_role('Admin') && !is_role('Agent')
- if current_user.organization_id
- organizations = Organization.where( :id => current_user.organization_id )
- end
- else
- organizations = Organization.all
- end
- render :json => organizations
- end
- =begin
- Resource:
- GET /api/v1/organizations/#{id}.json
- Response:
- {
- "id": 1,
- "name": "name_1",
- ...
- }
- Test:
- curl http://localhost/api/v1/organizations/#{id}.json -v -u #{login}:#{password}
- =end
- def show
- # only allow customer to fetch his own organization
- if is_role('Customer') && !is_role('Admin') && !is_role('Agent')
- if !current_user.organization_id
- render :json => {}
- return
- end
- if params[:id].to_i != current_user.organization_id
- response_access_deny
- return
- end
- end
- if params[:full]
- full = Organization.full( params[:id] )
- render :json => full
- return
- end
- model_show_render(Organization, params)
- end
- =begin
- Resource:
- POST /api/v1/organizations.json
- Payload:
- {
- "name": "some_name",
- "active": true,
- "note": "some note",
- "shared": true
- }
- Response:
- {
- "id": 1,
- "name": "some_name",
- ...
- }
- Test:
- curl http://localhost/api/v1/organizations.json -v -u #{login}:#{password} -H "Content-Type: application/json" -X POST -d '{"name": "some_name","active": true,"shared": true,"note": "some note"}'
- =end
- def create
- return if deny_if_not_role('Agent')
- model_create_render(Organization, params)
- end
- =begin
- Resource:
- PUT /api/v1/organizations/{id}.json
- Payload:
- {
- "id": 1
- "name": "some_name",
- "active": true,
- "note": "some note",
- "shared": true
- }
- Response:
- {
- "id": 1,
- "name": "some_name",
- ...
- }
- Test:
- curl http://localhost/api/v1/organizations.json -v -u #{login}:#{password} -H "Content-Type: application/json" -X PUT -d '{"id": 1,"name": "some_name","active": true,"shared": true,"note": "some note"}'
- =end
- def update
- return if deny_if_not_role('Agent')
- model_update_render(Organization, params)
- end
- =begin
- Resource:
- Response:
- Test:
- =end
- def destroy
- return if deny_if_not_role('Agent')
- model_destory_render(Organization, params)
- end
- # GET /api/v1/organizations/history/1
- def history
- # permissin check
- if !is_role('Admin') && !is_role('Agent')
- response_access_deny
- return
- end
- # get organization data
- organization = Organization.find( params[:id] )
- # get history of organization
- history = organization.history_get(true)
- # return result
- render :json => history
- end
- end
|