123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- # This validator is used in special situations only. In most cases CoreWorkflow is used instead.
- # It does not run for any object which has ChecksCoreWorkflow concern.
- # Please note that all objects that may have custom attributes created via UI use CoreWorkflow.
- # This may run in Ticket::Article if custom attribute were created manually.
- # Or if there are custom modifications using this functionality
- class Validations::ObjectManager::AttributeValidator::Required < Validations::ObjectManager::AttributeValidator::Backend
- def validate
- return if record.class.include?(ChecksCoreWorkflow)
- return if !value.nil?
- return if optional_for_user?
- invalid_because_attribute(__('is required but missing'))
- end
- private
- def optional_for_user?
- return true if system_user?
- return true if required_for_permissions.blank?
- return false if required_for_permissions.include?('-all-')
- !user.permissions?(required_for_permissions)
- end
- def system_user?
- user_id.blank? || user_id == 1
- end
- def user_id
- @user_id ||= UserInfo.current_user_id
- end
- def user
- @user ||= User.lookup(id: user_id)
- end
- def required_for_permissions
- @required_for_permissions ||= begin
- attribute.screens[action]&.each_with_object([]) do |(permission, config), result|
- result.push(permission) if config[:required].present?
- end
- end
- end
- def action
- return :edit if record.persisted?
- attribute.screens.keys.find { |e| e.start_with?('create') }
- end
- end
|