Class: Projects::HooksController

Inherits:
ApplicationController show all
Defined in:
app/controllers/projects/hooks_controller.rb

Instance Method Summary collapse

Methods inherited from ApplicationController

#redirect_back_or_default

Methods included from PageLayoutHelper

#blank_container, #container_class, #fluid_layout, #header_title, #nav, #page_card_attributes, #page_card_meta_tags, #page_description, #page_image, #page_title, #sidebar

Methods included from GitlabRoutingHelper

#activity_project_path, #edit_project_path, #edit_project_url, #issue_path, #issue_url, #merge_request_path, #merge_request_url, #milestone_path, #project_builds_path, #project_commits_path, #project_files_path, #project_path, #project_pipelines_path, #project_snippet_url, #project_url, #runner_path, #runners_path, #toggle_subscription_path

Methods included from Gitlab::GonHelper

#add_gon_variables

Methods included from Gitlab::CurrentSettings

#current_application_settings, #fake_application_settings

Dynamic Method Handling

This class handles dynamic methods through the method_missing method in the class Projects::ApplicationController

Instance Method Details

#createObject


14
15
16
17
18
19
20
21
22
23
24
# File 'app/controllers/projects/hooks_controller.rb', line 14

def create
  @hook = @project.hooks.new(hook_params)
  @hook.save

  if @hook.valid?
    redirect_to namespace_project_hooks_path(@project.namespace, @project)
  else
    @hooks = @project.hooks.select(&:persisted?)
    render :index
  end
end

#destroyObject


42
43
44
45
46
# File 'app/controllers/projects/hooks_controller.rb', line 42

def destroy
  hook.destroy

  redirect_to namespace_project_hooks_path(@project.namespace, @project)
end

#indexObject


9
10
11
12
# File 'app/controllers/projects/hooks_controller.rb', line 9

def index
  @hooks = @project.hooks
  @hook = ProjectHook.new
end

#testObject


26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
# File 'app/controllers/projects/hooks_controller.rb', line 26

def test
  if !@project.empty_repo?
    status, message = TestHookService.new.execute(hook, current_user)

    if status
      flash[:notice] = 'Hook successfully executed.'
    else
      flash[:alert] = "Hook execution failed: #{message}"
    end
  else
    flash[:alert] = 'Hook execution failed. Ensure the project has commits.'
  end

  redirect_back_or_default(default: { action: 'index' })
end