123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271 |
- # Copyright (C) 2012-2024 Zammad Foundation, https://zammad-foundation.org/
- class TemplatesController < ApplicationController
- prepend_before_action :authenticate_and_authorize!
- =begin
- Format:
- JSON
- Example:
- {
- "id": 1,
- "name": "some template",
- "user_id": null,
- "options": {
- "ticket.title": {
- "value": "some title"
- },
- "ticket.customer_id": {
- "value": "2",
- "value_completion": "Nicole Braun <nicole.braun@zammad.org>"
- }
- },
- "updated_at": "2012-09-14T17:51:53Z",
- "created_at": "2012-09-14T17:51:53Z",
- "updated_by_id": 2,
- "created_by_id": 2
- }
- =end
- =begin
- Resource:
- GET /api/v1/templates.json
- Response:
- [
- {
- "id": 1,
- "name": "some_name1",
- ...
- },
- {
- "id": 2,
- "name": "some_name2",
- ...
- }
- ]
- Test:
- curl http://localhost/api/v1/templates.json -v -u #{login}:#{password}
- =end
- def index
- model_index_render(policy_scope(Template), params)
- end
- =begin
- Resource:
- GET /api/v1/templates/#{id}.json
- Response:
- {
- "id": 1,
- "name": "name_1",
- ...
- }
- Test:
- curl http://localhost/api/v1/templates/#{id}.json -v -u #{login}:#{password}
- =end
- def show
- model_show_render(policy_scope(Template), params)
- end
- =begin
- Resource:
- POST /api/v1/templates.json
- Payload:
- {
- "name": "some name",
- "options": {
- "ticket.title": {
- "value": "some title"
- },
- "ticket.customer_id": {
- "value": "2",
- "value_completion": "Nicole Braun <nicole.braun@zammad.org>"
- }
- }
- }
- Response:
- {
- "id": 1,
- "name": "some_name",
- ...
- }
- Test:
- curl http://localhost/api/v1/templates.json -v -u #{login}:#{password} -H "Content-Type: application/json" -X POST -d '{"name": "some_name", "options": {"ticket.title": {"value": "some title"},"ticket.customer_id": {"value": "2", "value_completion": "Nicole Braun <nicole.braun@zammad.org>"}}}'
- =end
- def create
- template_create_render(params)
- end
- =begin
- Resource:
- PUT /api/v1/templates/{id}.json
- Payload:
- {
- "name": "some name",
- "options": {
- "ticket.title": {
- "value": "some title"
- },
- "ticket.customer_id": {
- "value": "2",
- "value_completion": "Nicole Braun <nicole.braun@zammad.org>"
- }
- }
- }
- Response:
- {
- "id": 1,
- "name": "some_name",
- ...
- }
- Test:
- curl http://localhost/api/v1/templates/1.json -v -u #{login}:#{password} -H "Content-Type: application/json" -X PUT -d '{"name": "some_name", "options": {"ticket.title": {"value": "some title"},"ticket.customer_id": {"value": "2", "value_completion": "Nicole Braun <nicole.braun@zammad.org>"}}}'
- =end
- def update
- template_update_render(params)
- end
- =begin
- Resource:
- DELETE /api/v1/templates/{id}.json
- Response:
- {}
- Test:
- curl http://localhost/api/v1/templates.json -v -u #{login}:#{password} -H "Content-Type: application/json" -X DELETE
- =end
- def destroy
- model_destroy_render(Template, params)
- end
- private
- def old_options?(options)
- has_new_options = false
- options.each_key do |key|
- if key.starts_with?(%r{(ticket|article)\.})
- has_new_options = true
- end
- break if has_new_options
- end
- !has_new_options
- end
- def migrate_options(options)
- old_options = options.clone
- new_options = {}
- article_attribute_list = %w[body form_id]
- # Implements a compatibility layer for templates, by converting `options` to a newer format:
- # options: {
- # 'ticket.field_1': { value: 'value_1' },
- # 'ticket.field_2': { value: 'value_2', value_completion: 'value_completion_2' },
- # }
- old_options.each do |key, value|
- new_key = "ticket.#{key}"
- if article_attribute_list.include?(key)
- new_key = "article.#{key}"
- end
- new_options[new_key] = { value: value }
- if old_options.key?("#{key}_completion")
- new_options[new_key]['value_completion'] = old_options["#{key}_completion"]
- old_options.delete("#{key}_completion")
- end
- end
- new_options
- end
- def template_prepare_params(params)
- clean_params = Template.association_name_to_id_convert(params)
- clean_params = Template.param_cleanup(clean_params, true)
- if Template.included_modules.include?(ChecksCoreWorkflow)
- clean_params[:screen] = 'create'
- end
- if old_options?(clean_params[:options])
- clean_params[:options] = migrate_options(clean_params[:options])
- ActiveSupport::Deprecation.warn 'Usage of the old format for template options with unprefixed keys and simple values is deprecated.'
- end
- clean_params
- end
- def template_create_render(params)
- clean_params = template_prepare_params(params)
- template = Template.new(clean_params)
- template.associations_from_param(params)
- template.save!
- if response_expand?
- render json: template.attributes_with_association_names, status: :created
- return
- end
- if response_full?
- render json: template.class.full(template.id), status: :created
- return
- end
- model_create_render_item(template)
- end
- def template_update_render(params)
- template = Template.find(params[:id])
- clean_params = template_prepare_params(params)
- template.with_lock do
- template.associations_from_param(params)
- template.update!(clean_params)
- end
- if response_expand?
- render json: template.attributes_with_association_names, status: :ok
- return
- end
- if response_full?
- render json: template.class.full(template.id), status: :ok
- return
- end
- model_update_render_item(template)
- end
- end
|