2012-03-04 14:35:15 +01:00
|
|
|
class ProjectObserver < ActiveRecord::Observer
|
2012-11-23 19:11:09 +01:00
|
|
|
def after_save(project)
|
2012-11-22 20:41:16 +01:00
|
|
|
# Move repository if namespace changed
|
2012-11-23 04:39:09 +01:00
|
|
|
if project.namespace_id_changed? and not project.new_record?
|
2012-11-24 10:46:19 +01:00
|
|
|
old_dir = Namespace.find_by_id(project.namespace_id_was).try(:path) || ''
|
|
|
|
new_dir = Namespace.find_by_id(project.namespace_id).try(:path) || ''
|
|
|
|
|
|
|
|
Gitlab::ProjectMover.new(project, old_dir, new_dir).execute
|
2012-11-22 20:41:16 +01:00
|
|
|
end
|
2012-11-24 11:25:04 +01:00
|
|
|
|
|
|
|
# Update gitolite
|
|
|
|
project.update_repository
|
2012-03-04 14:35:15 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
def after_destroy(project)
|
2012-09-11 22:24:53 +02:00
|
|
|
log_info("Project \"#{project.name}\" was removed")
|
|
|
|
|
2012-03-04 14:35:15 +01:00
|
|
|
project.destroy_repository
|
|
|
|
end
|
2012-09-11 22:24:53 +02:00
|
|
|
|
|
|
|
def after_create project
|
|
|
|
log_info("#{project.owner.name} created a new project \"#{project.name}\"")
|
|
|
|
end
|
|
|
|
|
|
|
|
protected
|
|
|
|
|
|
|
|
def log_info message
|
|
|
|
Gitlab::AppLogger.info message
|
|
|
|
end
|
2012-03-04 14:35:15 +01:00
|
|
|
end
|