| @@ -1,373 +1,3 @@ | |||||
| <<<<<<< HEAD | |||||
| class RepositoriesController < ApplicationController | |||||
| include RepositoriesHelper | |||||
| include ApplicationHelper | |||||
| include OperateProjectAbilityAble | |||||
| include Repository::LanguagesPercentagable | |||||
| before_action :require_login, only: %i[edit update create_file update_file delete_file sync_mirror] | |||||
| before_action :require_profile_completed, only: [:create_file] | |||||
| before_action :load_repository | |||||
| before_action :authorizate!, except: [:sync_mirror, :tags, :commit, :archive] | |||||
| before_action :authorizate_user_can_edit_repo!, only: %i[sync_mirror] | |||||
| before_action :get_ref, only: %i[entries sub_entries top_counts file archive] | |||||
| before_action :get_latest_commit, only: %i[entries sub_entries top_counts] | |||||
| before_action :get_statistics, only: %i[top_counts] | |||||
| def files | |||||
| result = @project.educoder? ? nil : Gitea::Repository::Files::GetService.call(@owner, @project.identifier, @ref, params[:search], @owner.gitea_token) | |||||
| render json: result | |||||
| end | |||||
| # 新版项目详情 | |||||
| def detail | |||||
| @user = current_user | |||||
| @result = Repositories::DetailService.call(@owner, @repository, @user) | |||||
| @project_fork_id = @project.try(:forked_from_project_id) | |||||
| if @project_fork_id.present? | |||||
| @fork_project = Project.find_by(id: @project_fork_id) | |||||
| @fork_project_user = @fork_project.owner | |||||
| end | |||||
| rescue Exception => e | |||||
| uid_logger_error(e.message) | |||||
| tip_exception(e.message) | |||||
| end | |||||
| def show | |||||
| @user = current_user | |||||
| @repo = @project.repository | |||||
| @result = @project.forge? ? Gitea::Repository::GetService.new(@owner, @project.identifier).call : nil | |||||
| @project_fork_id = @project.try(:forked_from_project_id) | |||||
| if @project_fork_id.present? | |||||
| @fork_project = Project.find_by(id: @project_fork_id) | |||||
| @fork_project_user = @fork_project.owner | |||||
| end | |||||
| rescue Exception => e | |||||
| uid_logger_error(e.message) | |||||
| tip_exception(e.message) | |||||
| end | |||||
| def entries | |||||
| @project.increment!(:visits) | |||||
| CacheAsyncSetJob.perform_later("project_common_service", {visits: 1}, @project.id) | |||||
| if @project.educoder? | |||||
| @entries = Educoder::Repository::Entries::ListService.call(@project&.project_educoder.repo_name) | |||||
| else | |||||
| @entries = Gitea::Repository::Entries::ListService.new(@owner, @project.identifier, ref: @ref).call | |||||
| @entries = @entries.present? ? @entries.sort_by{ |hash| hash['type'] } : [] | |||||
| @path = Gitea.gitea_config[:domain]+"/#{@project.owner.login}/#{@project.identifier}/raw/branch/#{@ref}/" | |||||
| end | |||||
| end | |||||
| def top_counts | |||||
| @result = @project.educoder? ? nil : Gitea::Repository::GetService.new(@project.owner, @project.identifier).call | |||||
| end | |||||
| def sub_entries | |||||
| file_path_uri = URI.parse(URI.encode(params[:filepath].to_s.strip)) | |||||
| if @project.educoder? | |||||
| if params[:type] === 'file' | |||||
| @sub_entries = Educoder::Repository::Entries::GetService.call(@project&.project_educoder&.repo_name, file_path_uri) | |||||
| logger.info "######### sub_entries: #{@sub_entries}" | |||||
| return render_error('该文件暂未开放,敬请期待.') if @sub_entries['status'].to_i === -1 | |||||
| tmp_entries = [{ | |||||
| "content" => @sub_entries['data']['content'], | |||||
| "type" => "blob" | |||||
| }] | |||||
| @sub_entries = { | |||||
| "trees"=>tmp_entries, | |||||
| "commits" => [{}] | |||||
| } | |||||
| else | |||||
| @sub_entries = Educoder::Repository::Entries::ListService.call(@project&.project_educoder&.repo_name, {path: file_path_uri}) | |||||
| end | |||||
| else | |||||
| @path = Gitea.gitea_config[:domain]+"/#{@project.owner.login}/#{@project.identifier}/raw/branch/#{@ref}/" | |||||
| interactor = Repositories::EntriesInteractor.call(@owner, @project.identifier, file_path_uri, ref: @ref) | |||||
| if interactor.success? | |||||
| result = interactor.result | |||||
| @sub_entries = result.is_a?(Array) ? result.sort_by{ |hash| hash['type'] } : result | |||||
| else | |||||
| render_error(interactor.error) | |||||
| end | |||||
| end | |||||
| end | |||||
| def commits | |||||
| if @project.educoder? | |||||
| @hash_commit = nil | |||||
| else | |||||
| if params[:filepath].present? | |||||
| file_path_uri = URI.parse(URI.encode(params[:filepath].to_s.strip)) | |||||
| @hash_commit = Gitea::Repository::Commits::FileListService.new(@owner.login, @project.identifier, file_path_uri, | |||||
| sha: params[:sha], page: params[:page], limit: params[:limit], token: current_user&.gitea_token).call | |||||
| else | |||||
| @hash_commit = Gitea::Repository::Commits::ListService.new(@owner.login, @project.identifier, | |||||
| sha: params[:sha], page: params[:page], limit: params[:limit], token: current_user&.gitea_token).call | |||||
| end | |||||
| end | |||||
| end | |||||
| def commits_slice | |||||
| @hash_commit = Gitea::Repository::Commits::ListSliceService.call(@owner&.login, @project.identifier, | |||||
| sha: params[:sha], page: params[:page], limit: params[:limit], token: current_user&.gitea_token) | |||||
| end | |||||
| def commit | |||||
| @sha = params[:sha] | |||||
| if @project.educoder? | |||||
| @commit = {} | |||||
| @commit_diff ={} | |||||
| else | |||||
| @commit = Gitea::Repository::Commits::GetService.call(@owner.login, @repository.identifier, @sha, current_user&.gitea_token) | |||||
| @commit_diff = Gitea::Repository::Commits::GetService.call(@owner.login, @repository.identifier, @sha, current_user&.gitea_token, {diff: true}) | |||||
| end | |||||
| end | |||||
| def tags | |||||
| result = Gitea::Repository::Tags::ListService.call(current_user&.gitea_token, @owner.login, @project.identifier, {page: params[:page], limit: params[:limit]}) | |||||
| @tags = result.is_a?(Hash) && result.key?(:status) ? [] : result | |||||
| end | |||||
| def contributors | |||||
| if params[:filepath].present? | |||||
| @contributors = [] | |||||
| else | |||||
| @contributors = Gitea::Repository::Contributors::GetService.call(@owner, @repository.identifier) | |||||
| end | |||||
| end | |||||
| def edit | |||||
| return render_forbidden if !@project.manager?(current_user) && !current_user.admin? | |||||
| end | |||||
| def create_file | |||||
| interactor = Gitea::CreateFileInteractor.call(current_user.gitea_token, @owner.login, content_params) | |||||
| if interactor.success? | |||||
| @file = interactor.result | |||||
| # create_new_pr(params) | |||||
| #如果是更新流水线文件 | |||||
| if params[:pipeline_id] | |||||
| update_pipeline(params[:pipeline_id]) | |||||
| end | |||||
| else | |||||
| render_error(interactor.error) | |||||
| end | |||||
| end | |||||
| def update_pipeline(pipeline_id) | |||||
| pipeline = Ci::Pipeline.find(pipeline_id) | |||||
| if pipeline | |||||
| pipeline.update!(sync: 1) | |||||
| end | |||||
| end | |||||
| def update_file | |||||
| interactor = Gitea::UpdateFileInteractor.call(current_user.gitea_token, @owner.login, params.merge(identifier: @project.identifier)) | |||||
| if interactor.success? | |||||
| @file = interactor.result | |||||
| # TODO: 是否创建pr | |||||
| # create_new_pr(params) | |||||
| render_result(1, "更新成功") | |||||
| else | |||||
| render_error(interactor.error) | |||||
| end | |||||
| end | |||||
| def delete_file | |||||
| interactor = Gitea::DeleteFileInteractor.call(current_user.gitea_token, @owner.login, params.merge(identifier: @project.identifier)) | |||||
| if interactor.success? | |||||
| @file = interactor.result | |||||
| render_result(1, "文件删除成功") | |||||
| else | |||||
| render_error(interactor.error) | |||||
| end | |||||
| end | |||||
| def repo_hook | |||||
| end | |||||
| def sync_mirror | |||||
| return render_error("正在镜像中..") if @repository.mirror.waiting? | |||||
| @repository.sync_mirror! | |||||
| SyncMirroredRepositoryJob.perform_later(@repository.id, current_user.id) | |||||
| render_ok | |||||
| end | |||||
| def readme | |||||
| if params[:filepath].present? | |||||
| result = Gitea::Repository::Readme::DirService.call(@owner.login, @repository.identifier, params[:filepath], params[:ref], current_user&.gitea_token) | |||||
| else | |||||
| result = Gitea::Repository::Readme::GetService.call(@owner.login, @repository.identifier, params[:ref], current_user&.gitea_token) | |||||
| end | |||||
| @path = Gitea.gitea_config[:domain]+"/#{@owner.login}/#{@repository.identifier}/raw/branch/#{params[:ref]}/" | |||||
| @readme = result[:status] === :success ? result[:body] : nil | |||||
| @readme['content'] = decode64_content(@readme, @owner, @repository, params[:ref], @path) | |||||
| render json: @readme.slice("type", "encoding", "size", "name", "path", "content", "sha") | |||||
| rescue | |||||
| render json: nil | |||||
| end | |||||
| def languages | |||||
| render json: languages_precentagable | |||||
| end | |||||
| def archive | |||||
| domain = Gitea.gitea_config[:domain] | |||||
| api_url = Gitea.gitea_config[:base_url] | |||||
| archive_url = "/repos/#{@owner.login}/#{@repository.identifier}/archive/#{params[:archive]}" | |||||
| file_path = [domain, api_url, archive_url].join | |||||
| file_path = [file_path, "access_token=#{current_user&.gitea_token}"].join("?") if @repository.hidden? | |||||
| return render_not_found if !request.format.zip? && !request.format.gzip? | |||||
| redirect_to file_path | |||||
| end | |||||
| def raw | |||||
| domain = Gitea.gitea_config[:domain] | |||||
| api_url = Gitea.gitea_config[:base_url] | |||||
| url = "/repos/#{@owner.login}/#{@repository.identifier}/raw/#{params[:filepath]}?ref=#{params[:ref]}" | |||||
| file_path = [domain, api_url, url].join | |||||
| file_path = [file_path, "access_token=#{current_user&.gitea_token}"].join("&") if @repository.hidden? | |||||
| redirect_to URI.escape(file_path) | |||||
| end | |||||
| private | |||||
| def find_project | |||||
| @project = Project.find params[:id] | |||||
| render_not_found("未找到相关的仓库") unless @project | |||||
| end | |||||
| def find_project_with_includes | |||||
| @project = Project.includes(:repository, :owner, :watchers, :praise_treads).find params[:id] | |||||
| end | |||||
| def authorizate! | |||||
| return if current_user && current_user.admin? | |||||
| if @project.repository.hidden? && !@project.member?(current_user) | |||||
| render_forbidden | |||||
| end | |||||
| end | |||||
| # TODO 获取最新commit信息 | |||||
| def project_commits | |||||
| if params[:filepath].present? | |||||
| file_path_uri = URI.parse(URI.encode(params[:filepath].to_s.strip)) | |||||
| Gitea::Repository::Commits::FileListService.new(@project.owner.login, @project.identifier, file_path_uri, | |||||
| sha: get_ref, page: 1, limit: 1, token: current_user&.gitea_token).call | |||||
| else | |||||
| Gitea::Repository::Commits::ListService.new(@project.owner.login, @project.identifier, | |||||
| sha: get_ref, page: 1, limit: 1, token: current_user&.gitea_token).call | |||||
| end | |||||
| end | |||||
| def get_statistics | |||||
| @branches_count = @project.educoder? ? 0 : Gitea::Repository::Branches::ListService.new(@project.owner, @project.identifier).call&.size | |||||
| @tags_count = @project.educoder? ? 0 : Gitea::Repository::Tags::ListService.new(current_user&.gitea_token, @project.owner.login, @project.identifier).call&.size | |||||
| end | |||||
| def get_ref | |||||
| @ref = params[:ref] || @project&.default_branch | |||||
| end | |||||
| def get_latest_commit | |||||
| latest_commit = @project.educoder? ? nil : project_commits | |||||
| @latest_commit = latest_commit.present? ? latest_commit[:body][0] : nil | |||||
| @commits_count = latest_commit.present? ? latest_commit[:total_count] : 0 | |||||
| end | |||||
| def content_params | |||||
| { | |||||
| filepath: params[:filepath], | |||||
| branch: params[:branch], | |||||
| new_branch: params[:new_branch], | |||||
| content: params[:content], | |||||
| message: params[:message], | |||||
| committer: { | |||||
| email: current_user.mail, | |||||
| name: current_user.login | |||||
| }, | |||||
| identifier: @project.identifier | |||||
| } | |||||
| end | |||||
| def hook_params(hook_type, params) | |||||
| # if hook_type == "push" | |||||
| # # TODO hook返回的记录中,暂时没有文件代码数量的增减,暂时根据 commits数量来计算 | |||||
| # uploadPushInfo = { | |||||
| # "sha": params["commits"].present? ? params["commits"].last : "", | |||||
| # "branch": params["ref"].to_s.split("/").last, | |||||
| # "modification_lines": params["commits"].length | |||||
| # } | |||||
| # elsif hook_type == "pull_request" && params["action"].to_s == "closed" #合并请求合并后才会有上链操作 | |||||
| # uploadPushInfo = { | |||||
| # "branch": params["base"]["ref"].to_s.split("/").last, | |||||
| # "sha": params["pull_request"]["merge_base"], | |||||
| # "modification_lines": 1 #pull_request中没有commits数量 | |||||
| # } | |||||
| # else | |||||
| # uploadPushInfo = {} | |||||
| # end | |||||
| # uploadPushInfo | |||||
| end | |||||
| def create_new_pr(params) | |||||
| if params[:new_branch].present? && params[:new_branch] != params[:branch] | |||||
| local_params = { | |||||
| title: params[:message], #标题 | |||||
| body: params[:content], #内容 | |||||
| head: params[:new_branch], #源分支 | |||||
| base: params[:branch], #目标分支 | |||||
| milestone: 0 #里程碑,未与本地的里程碑关联 | |||||
| } | |||||
| requests_params = local_params.merge({ | |||||
| assignee: current_user.try(:login), | |||||
| assignees: [], | |||||
| labels: [], | |||||
| due_date: Time.now | |||||
| }) | |||||
| issue_params = { | |||||
| author_id: current_user.id, | |||||
| project_id: @project.id, | |||||
| subject: params[:message], | |||||
| description: params[:content], | |||||
| assigned_to_id: nil, | |||||
| fixed_version_id: nil, | |||||
| issue_tags_value: nil, | |||||
| issue_classify: "pull_request", | |||||
| issue_type: "1", | |||||
| tracker_id: 2, | |||||
| status_id: 1, | |||||
| priority_id: params[:priority_id] || "2" | |||||
| } | |||||
| @pull_issue = Issue.new(issue_params) | |||||
| if @pull_issue.save! | |||||
| local_requests = PullRequest.new(local_params.merge(user_id: current_user.try(:id), project_id: @project.id, issue_id: @pull_issue.id)) | |||||
| if local_requests.save | |||||
| gitea_request = Gitea::PullRequest::CreateService.new(current_user.try(:gitea_token), @owner.login, @project.try(:identifier), requests_params).call | |||||
| if gitea_request[:status] == :success && local_requests.update_attributes(gitea_number: gitea_request["body"]["number"], gpid: gitea_request["body"]["number"]) | |||||
| local_requests.project_trends.create(user_id: current_user.id, project_id: @project.id, action_type: "create") | |||||
| end | |||||
| end | |||||
| end | |||||
| end | |||||
| end | |||||
| end | |||||
| ======= | |||||
| class RepositoriesController < ApplicationController | class RepositoriesController < ApplicationController | ||||
| include RepositoriesHelper | include RepositoriesHelper | ||||
| include ApplicationHelper | include ApplicationHelper | ||||
| @@ -740,4 +370,3 @@ class RepositoriesController < ApplicationController | |||||
| end | end | ||||
| end | end | ||||
| >>>>>>> develop | |||||