¿Es seguro este subproceso de código?Rails 3 ActiveRecord .skip_callback thread safety
MyModel.skip_callback(:save, :before, :my_callback)
my_model_instance.update_attributes(attributes)
MyModel.set_callback(:save, :before, :my_callback)
¿Puedo usarlo de forma segura para evitar el reinicio de la misma devolución de llamada recursivamente?
Aquí es un ejemplo
class Blog < ActiveRecord::Base
after_save :update_blog_theme, :if => :active_theme_id_changed?
# ...
private
def update_blog_theme
# Reuses a previously used BlogTheme or creates a new one
blog_theme = BlogTheme.find_by_theme_id_and_blog_id(
self.active_theme_id,
self.id)
blog_theme ||= BlogTheme.create!(
:theme_id => active_theme_id,
:blog_id => self.id)
Blog.skip_callback(:save, :after, :update_blog_theme)
self.update_attributes!(:active_blog_theme_id => blog_theme.id)
Blog.set_callback(:save, :after, :update_blog_theme)
end
end
Parece hacky, ¿por qué no puedes usar before_save o before_create? – apneadiving
¿cuáles son los requisitos finales? – Anatoly
no hay requisitos aquí, no estoy usando este código, y quizás nunca lo haga, pero encontré esta solución en Internet y me pregunté si era seguro usarla en multiprocesamiento – mcasimir