12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- module ApplicationModel::ChecksUserColumnsFillup
- extend ActiveSupport::Concern
- included do
- before_validation :fill_up_user_validate
- end
- def fill_up_user_validate
- return fill_up_user_create if new_record?
- fill_up_user_update
- end
- =begin
- set created_by_id & updated_by_id if not given based on UserInfo (current session)
- Used as before_create callback, no own use needed
- result = Model.fill_up_user_create(params)
- returns
- result = params # params with updated_by_id & created_by_id if not given based on UserInfo (current session)
- =end
- def fill_up_user_create
- if self.class.column_names.include?('updated_by_id') && UserInfo.current_user_id
- if updated_by_id && updated_by_id != UserInfo.current_user_id
- logger.info "NOTICE create - self.updated_by_id is different: #{updated_by_id}/#{UserInfo.current_user_id}"
- end
- self.updated_by_id = UserInfo.current_user_id
- end
- return true if self.class.column_names.exclude?('created_by_id')
- return true if !UserInfo.current_user_id
- if created_by_id && created_by_id != UserInfo.current_user_id
- logger.info "NOTICE create - self.created_by_id is different: #{created_by_id}/#{UserInfo.current_user_id}"
- end
- self.created_by_id = UserInfo.current_user_id
- true
- end
- =begin
- set updated_by_id if not given based on UserInfo (current session)
- Used as before_update callback, no own use needed
- result = Model.fill_up_user_update(params)
- returns
- result = params # params with updated_by_id & created_by_id if not given based on UserInfo (current session)
- =end
- def fill_up_user_update
- return true if self.class.column_names.exclude?('updated_by_id')
- return true if !UserInfo.current_user_id
- self.updated_by_id = UserInfo.current_user_id
- true
- end
- end
|