class ProjectObserver < ActiveRecord::Observer
  def after_create(project)
    GitlabShellWorker.perform_async(
      :add_repository,
      project.path_with_namespace
    )

    log_info("#{project.owner.name} created a new project \"#{project.name_with_namespace}\"")
  end

  def after_update(project)
    project.send_move_instructions if project.namespace_id_changed?
  end

  def after_destroy(project)
    GitlabShellWorker.perform_async(
      :remove_repository,
      project.path_with_namespace
    )

    project.satellite.destroy

    log_info("Project \"#{project.name}\" was removed")
  end

  protected

  def log_info message
    Gitlab::AppLogger.info message
  end
end