class ProjectsController < ApplicationController PROJECTS_PER_PAGE = 100 before_filter :authenticate_user!, except: [:build, :badge, :index, :show] before_filter :project, only: [:build, :integration, :show, :badge, :edit, :update, :destroy] before_filter :authorize_access_project!, except: [:build, :gitlab, :badge, :index, :show, :new, :create] before_filter :authorize_manage_project!, only: [:edit, :integration, :update, :destroy] before_filter :authenticate_token!, only: [:build] before_filter :no_cache, only: [:badge] protect_from_forgery except: :build layout 'project', except: [:index, :gitlab] def index @projects = Project.ordered_by_last_commit_date.public_only.page(params[:page]) unless current_user end def gitlab current_user.reset_cache if params[:reset_cache] @page = (params[:page] || 1).to_i @per_page = PROJECTS_PER_PAGE @gl_projects = current_user.gitlab_projects(params[:search], @page, @per_page) @projects = Project.where(gitlab_id: @gl_projects.map(&:id)).ordered_by_last_commit_date @total_count = @gl_projects.size @gl_projects.reject! { |gl_project| @projects.map(&:gitlab_id).include?(gl_project.id) } rescue Network::UnauthorizedError raise rescue @error = 'Failed to fetch GitLab projects' end def show unless @project.public unless current_user redirect_to(new_user_sessions_path(return_to: request.fullpath)) and return end unless current_user.can_access_project?(@project.gitlab_id) page_404 and return end end @ref = params[:ref] @commits = @project.commits @commits = @commits.where(ref: @ref) if @ref @commits = @commits.order('id DESC').page(params[:page]).per(20) end def integration end def create @project = CreateProjectService.new.execute(current_user, params[:project], project_url(":project_id")) if @project.persisted? redirect_to project_path(@project, show_guide: true), notice: 'Project was successfully created.' else redirect_to :back, alert: 'Cannot save project' end end def edit end def update if project.update_attributes(project_params) EventService.new.change_project_settings(current_user, project) redirect_to :back, notice: 'Project was successfully updated.' else render action: "edit" end end def destroy project.destroy Network.new.disable_ci(project.gitlab_id, current_user.private_token) EventService.new.remove_project(current_user, project) redirect_to projects_url end def build @commit = CreateCommitService.new.execute(@project, params.dup) if @commit && @commit.valid? head 201 else head 400 end end # Project status badge # Image with build status for sha or ref def badge image = ImageForBuildService.new.execute(@project, params) send_file image.path, filename: image.name, disposition: 'inline' end protected def project @project ||= Project.find(params[:id]) end def no_cache response.headers["Cache-Control"] = "no-cache, no-store, max-age=0, must-revalidate" response.headers["Pragma"] = "no-cache" response.headers["Expires"] = "Fri, 01 Jan 1990 00:00:00 GMT" end def project_params params.require(:project).permit(:name, :path, :timeout, :token, :timeout_in_minutes, :default_ref, :gitlab_url, :always_build, :polling_interval, :public, :ssh_url_to_repo, :gitlab_id, :allow_git_fetch, :skip_refs, :email_recipients, :email_add_pusher, :email_only_broken_builds, :coverage_regex, :shared_runners_enabled, { jobs_attributes: [:id, :name, :build_branches, :build_tags, :tag_list, :commands, :refs, :_destroy, :job_type] }) end end