我有一个Department
模型,我使用Globalize gem翻译属性::name
和:permalink
。
:permalink
是根据部门:name
使用:before_validation
回调自动生成的。
我希望名称和固定链接是必需的,因此我在转换类中添加了验证,而不是迁移中的空约束。
class Department < ActiveRecord::Base
translates :name, :permalink, fallbacks_for_empty_translations: true
globalize_accessors
before_validation :set_permalink, on: :create
validates_associated :translations
translation_class.validates :name, presence: true, length: { maximum: 255 }
translation_class.validates :permalink, presence: true, length: { maximum: 255 }, uniqueness: { case_sensitive: false }
private
def set_permalink
I18n.available_locales.each do |l|
I18n.with_locale(l) { self.permalink = name.to_url }
end
end
end
class CreateDepartment < ActiveRecord::Migration
def up
create_table :departments do |t|
# other attributes
t.timestamps null: false
end
Department.create_translation_table! name: { type: :string, null: false }, permalink: { type: :string, null: false, index: { unique: true } }
end
def down
Department.drop_translation_table!
drop_table :departments
end
end
但是当我尝试创建一个部门时,验证失败了:
irb(main):001:0> Department.create!(name_en: 'Tools', name_fr: 'Outils')
(0.2ms) BEGIN
Department::Translation Exists (1.4ms) SELECT 1 AS one FROM "department_translations" WHERE "department_translations"."permalink" IS NULL LIMIT 1
Department::Translation Exists (0.3ms) SELECT 1 AS one FROM "department_translations" WHERE "department_translations"."permalink" IS NULL LIMIT 1
Department::Translation Exists (0.4ms) SELECT 1 AS one FROM "department_translations" WHERE "department_translations"."permalink" IS NULL LIMIT 1
Department::Translation Exists (0.3ms) SELECT 1 AS one FROM "department_translations" WHERE "department_translations"."permalink" IS NULL LIMIT 1
(0.2ms) ROLLBACK
ActiveRecord::RecordInvalid: Validation failed: Translations permalink can't be blank, Translations is invalid
但是,如果我删除永久链接的验证和非空约束,则可以保存部门并且所有翻译都存在永久链接。
我不明白为什么验证失败...如何设置验证和自动生成永久链接以便它们一起工作?
我正在使用Rails 4.2.5和Globalize 5.