123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- class FixedTranslation < ActiveRecord::Migration[4.2]
- def up
- # return if it's a new setup
- return if !Setting.exists?(name: 'system_init_done')
- settings_update = [
- {
- 'name' => 'app_version',
- 'title' => nil,
- 'description' => 'Only used internally to propagate current web app version to clients.',
- },
- {
- 'name' => 'websocket_port',
- 'title' => 'Websocket port',
- 'description' => nil,
- },
- {
- 'name' => 'http_type',
- 'title' => 'HTTP type',
- 'description' => 'Define the http protocol of your instance.',
- },
- {
- 'name' => 'storage_provider',
- 'title' => nil,
- 'description' => '"Database" stores all attachments in the database (not recommended for storing large amounts of data). "Filesystem" stores the data in the filesystem. You can switch between the modules even on a system that is already in production without any loss of data.',
- },
- {
- 'name' => 'geo_ip_backend',
- 'title' => nil,
- 'description' => 'Defines the backend for geo IP lookups. Shows also location of an IP address if an IP address is shown.',
- },
- {
- 'name' => 'geo_calendar_backend',
- 'title' => nil,
- 'description' => 'Defines the backend for geo calendar lookups. Used for initial calendar succession.',
- },
- {
- 'name' => 'ui_client_storage',
- 'title' => nil,
- 'description' => 'Use client storage to cache data to enhance performance of application.',
- },
- {
- 'name' => 'password_min_size',
- 'title' => 'Minimum length',
- 'description' => 'Password needs to have at least a minimal number of characters.',
- },
- {
- 'name' => 'password_need_digit',
- 'title' => nil,
- 'description' => 'Password needs to contain at least one digit.',
- },
- {
- 'name' => 'password_max_login_failed',
- 'title' => 'Maximum failed logins',
- 'description' => 'Number of failed logins after account will be deactivated.',
- },
- {
- 'name' => 'ticket_hook',
- 'title' => nil,
- 'description' => 'The identifier for a ticket, e.g. Ticket#, Call#, MyTicket#. The default is Ticket#.',
- },
- {
- 'name' => 'ticket_hook_divider',
- 'title' => nil,
- 'description' => 'The divider between TicketHook and ticket number. E. g. \': \'.',
- },
- {
- 'name' => 'ticket_hook_position',
- 'title' => nil,
- 'description' => "The format of the subject.
- * **Right** means **Some Subject [Ticket#12345]**
- * **Left** means **[Ticket#12345] Some Subject**
- * **None** means **Some Subject** (without ticket number). In the last case you should enable *postmaster_follow_up_search_in* to recognize follow-ups based on email headers and/or body.",
- },
- {
- 'name' => 'customer_ticket_create_group_ids',
- 'title' => nil,
- 'description' => 'Defines groups for which a customer can create tickets via web interface. "-" means all groups are available.',
- },
- {
- 'name' => 'form_ticket_create',
- 'title' => nil,
- 'description' => 'Defines if tickets can be created via web form.',
- },
- {
- 'name' => 'ticket_subject_size',
- 'title' => nil,
- 'description' => 'Max. length of the subject in an email reply.',
- },
- {
- 'name' => 'ticket_subject_re',
- 'title' => nil,
- 'description' => 'The text at the beginning of the subject in an email reply, e.g. RE, AW, or AS.',
- },
- {
- 'name' => 'ticket_define_email_from',
- 'title' => nil,
- 'description' => 'Defines how the From field of emails (sent from answers and email tickets) should look like.',
- },
- {
- 'name' => 'ticket_define_email_from_separator',
- 'title' => nil,
- 'description' => 'Defines the separator between the agent\'s real name and the given group email address.',
- },
- {
- 'name' => 'postmaster_max_size',
- 'title' => 'Maximum Email Size',
- 'description' => 'Maximum size in MB of emails.',
- },
- {
- 'name' => 'postmaster_follow_up_search_in',
- 'title' => 'Additional follow-up detection',
- 'description' => 'By default the follow-up check is done via the subject of an email. With this setting you can add more fields for which the follow-up check will be executed.',
- },
- {
- 'name' => 'send_no_auto_response_reg_exp',
- 'title' => nil,
- 'description' => 'If this regex matches, no notification will be sent by the sender.',
- },
- {
- 'name' => 'api_token_access',
- 'title' => nil,
- 'description' => 'Enable REST API using tokens (not username/email address and password). Each user needs to create its own access tokens in user profile.',
- },
- {
- 'name' => 'monitoring_token',
- 'title' => nil,
- 'description' => 'Token for monitoring.',
- },
- {
- 'name' => 'chat',
- 'title' => nil,
- 'description' => 'Enable/disable online chat.',
- },
- {
- 'name' => 'chat_agent_idle_timeout',
- 'title' => nil,
- 'description' => 'Idle timeout in seconds until agent is set offline automatically.',
- },
- {
- 'name' => 'models_searchable',
- 'title' => 'Defines searchable models.',
- 'description' => 'Defines the searchable models.',
- },
- {
- 'name' => 'default_controller',
- 'title' => nil,
- 'description' => 'Defines the default screen.',
- },
- {
- 'name' => 'es_url',
- 'title' => nil,
- 'description' => 'Defines endpoint of Elasticsearch.',
- },
- {
- 'name' => 'es_user',
- 'title' => nil,
- 'description' => 'Defines HTTP basic auth user of Elasticsearch.',
- },
- {
- 'name' => 'es_password',
- 'title' => 'Elasticsearch Endpoint Password',
- 'description' => 'Defines HTTP basic auth password of Elasticsearch.',
- },
- {
- 'name' => 'es_index',
- 'title' => 'Elasticsearch Endpoint Index',
- 'description' => 'Defines Elasticsearch index name.',
- },
- {
- 'name' => 'es_attachment_ignore',
- 'title' => 'Elasticsearch Attachment Extensions',
- 'description' => 'Defines attachment extensions which will be ignored by Elasticsearch.',
- },
- {
- 'name' => 'es_attachment_max_size_in_mb',
- 'title' => 'Elasticsearch Attachment Size',
- 'description' => nil,
- },
- {
- 'name' => 'import_mode',
- 'title' => nil,
- 'description' => 'Puts Zammad into import mode (disables some triggers).',
- },
- {
- 'name' => 'import_backend',
- 'title' => nil,
- 'description' => 'Set backend which is being used for import.',
- },
- {
- 'name' => 'import_ignore_sla',
- 'title' => nil,
- 'description' => 'Ignore escalation/SLA information for import.',
- },
- {
- 'name' => 'import_otrs_endpoint',
- 'title' => nil,
- 'description' => 'Defines OTRS endpoint to import users, tickets, states and articles.',
- },
- {
- 'name' => 'import_otrs_endpoint_key',
- 'title' => nil,
- 'description' => 'Defines OTRS endpoint authentication key.',
- },
- {
- 'name' => 'import_otrs_user',
- 'title' => 'Import User for HTTP basic authentication',
- 'description' => 'Defines HTTP basic authentication user (only if OTRS is protected via HTTP basic auth).',
- },
- {
- 'name' => 'import_zendesk_endpoint_key',
- 'title' => nil,
- 'description' => 'Defines Zendesk endpoint authentication key.',
- },
- {
- 'name' => 'import_zendesk_endpoint_username',
- 'title' => nil,
- 'description' => 'Defines Zendesk endpoint authentication user.',
- },
- {
- 'name' => 'time_accounting_selector',
- 'title' => nil,
- 'description' => 'Enable time accounting for these tickets.',
- },
- {
- 'name' => 'tag_new',
- 'title' => nil,
- 'description' => 'Allow users to create new tags.',
- },
- {
- 'name' => 'defaults_calendar_subscriptions_tickets',
- 'title' => nil,
- 'description' => 'Defines the default calendar tickets subscription settings.',
- },
- {
- 'name' => 'translator_key',
- 'title' => 'Defines translator identifier.',
- 'description' => nil,
- },
- {
- 'name' => '0010_postmaster_filter_trusted',
- 'title' => 'Defines postmaster filter.',
- 'description' => 'Defines postmaster filter to remove X-Zammad headers from not trusted sources.',
- },
- {
- 'name' => '0012_postmaster_filter_sender_is_system_address',
- 'title' => 'Defines postmaster filter.',
- 'description' => 'Defines postmaster filter to check if email has been created by Zammad itself and will set the article sender.',
- },
- {
- 'name' => '0015_postmaster_filter_identify_sender',
- 'title' => 'Defines postmaster filter.',
- 'description' => 'Defines postmaster filter to identify sender user.',
- },
- {
- 'name' => '0020_postmaster_filter_auto_response_check',
- 'title' => 'Defines postmaster filter.',
- 'description' => 'Defines postmaster filter to identify auto responses to prevent auto replies from Zammad.',
- },
- {
- 'name' => '0030_postmaster_filter_out_of_office_check',
- 'title' => 'Defines postmaster filter.',
- 'description' => 'Defines postmaster filter to identify out-of-office emails for follow-up detection and keeping current ticket state.',
- },
- {
- 'name' => '0100_postmaster_filter_follow_up_check',
- 'title' => 'Defines postmaster filter.',
- 'description' => 'Defines postmaster filter to identify follow-ups (based on admin settings).',
- },
- {
- 'name' => '0900_postmaster_filter_bounce_check',
- 'title' => 'Defines postmaster filter.',
- 'description' => 'Defines postmaster filter to identify postmaster bounced - to handle it as follow-up of the original ticket.',
- },
- {
- 'name' => '1000_postmaster_filter_database_check',
- 'title' => 'Defines postmaster filter.',
- 'description' => 'Defines postmaster filter for filters managed via admin interface.',
- },
- {
- 'name' => '5000_postmaster_filter_icinga',
- 'title' => 'Defines postmaster filter.',
- 'description' => 'Defines postmaster filter to manage Icinga (http://www.icinga.org) emails.',
- },
- {
- 'name' => '5100_postmaster_filter_nagios',
- 'title' => 'Defines postmaster filter.',
- 'description' => 'Defines postmaster filter to manage Nagios (http://www.nagios.org) emails.',
- },
- {
- 'name' => 'icinga_integration',
- 'title' => nil,
- 'description' => 'Defines if Icinga (http://www.icinga.org) is enabled or not.',
- },
- {
- 'name' => 'icinga_sender',
- 'title' => nil,
- 'description' => 'Defines the sender email address of Icinga emails.',
- },
- {
- 'name' => 'icinga_auto_close',
- 'title' => nil,
- 'description' => 'Defines if tickets should be closed if service is recovered.',
- },
- {
- 'name' => 'icinga_auto_close_state_id',
- 'title' => nil,
- 'description' => 'Defines the state of auto closed tickets.',
- },
- {
- 'name' => 'nagios_integration',
- 'title' => nil,
- 'description' => 'Defines if Nagios (http://www.nagios.org) is enabled or not.',
- },
- {
- 'name' => 'nagios_sender',
- 'title' => nil,
- 'description' => 'Defines the sender email address of Nagios emails.',
- },
- {
- 'name' => 'nagios_auto_close',
- 'title' => nil,
- 'description' => 'Defines if tickets should be closed if service is recovered.',
- },
- {
- 'name' => 'nagios_auto_close_state_id',
- 'title' => nil,
- 'description' => 'Defines the state of auto closed tickets.',
- },
- {
- 'name' => '0100_trigger',
- 'title' => 'Defines sync transaction backend.',
- 'description' => 'Defines the transaction backend to execute triggers.',
- },
- {
- 'name' => '0100_notification',
- 'title' => 'Defines transaction backend.',
- 'description' => 'Defines the transaction backend to send agent notifications.',
- },
- {
- 'name' => '1000_signature_detection',
- 'title' => 'Defines transaction backend.',
- 'description' => 'Defines the transaction backend to detect customer signatures in emails.',
- },
- {
- 'name' => '6000_slack_webhook',
- 'title' => 'Defines transaction backend.',
- 'description' => 'Defines the transaction backend which posts messages to Slack (http://www.slack.com).',
- },
- {
- 'name' => 'slack_integration',
- 'title' => nil,
- 'description' => 'Defines if Slack (http://www.slack.org) is enabled or not.',
- },
- {
- 'name' => 'slack_config',
- 'title' => nil,
- 'description' => 'Defines the slack config.',
- },
- {
- 'name' => 'sipgate_integration',
- 'title' => nil,
- 'description' => 'Defines if sipgate.io (http://www.sipgate.io) is enabled or not.',
- },
- {
- 'name' => 'sipgate_config',
- 'title' => nil,
- 'description' => 'Defines the sipgate.io config.',
- },
- {
- 'name' => 'clearbit_integration',
- 'title' => nil,
- 'description' => 'Defines if Clearbit (http://www.clearbit.com) is enabled or not.',
- },
- {
- 'name' => 'clearbit_config',
- 'title' => nil,
- 'description' => 'Defines the Clearbit config.',
- },
- {
- 'name' => '9000_clearbit_enrichment',
- 'title' => 'Defines transaction backend.',
- 'description' => 'Defines the transaction backend which will enrich customer and organization information from Clearbit (http://www.clearbit.com).',
- },
- {
- 'name' => '9100_cti_caller_id_detection',
- 'title' => 'Defines transaction backend.',
- 'description' => 'Defines the transaction backend which detects caller IDs in objects and store them for CTI lookups.',
- },
- {
- 'name' => '9200_karma',
- 'title' => 'Defines transaction backend.',
- 'description' => 'Defines the transaction backend which creates the karma score.',
- },
- {
- 'name' => 'karma_levels',
- 'title' => 'Defines karma levels.',
- 'description' => 'Defines the karma levels.',
- },
- ]
- settings_update.each do |setting|
- fetched_setting = Setting.find_by(name: setting['name'])
- next if !fetched_setting
- if setting['title']
- fetched_setting.title = setting['title']
- end
- if setting['description']
- fetched_setting.description = setting['description']
- end
- fetched_setting.save!
- end
- Translation.sync
- end
- end
|