| @@ -3,9 +3,37 @@ class DevOps::BuildsController < ApplicationController | |||||
| before_action :find_project | before_action :find_project | ||||
| def index | def index | ||||
| cloud_account = @repo.dev_ops_cloud_account | |||||
| result = DevOps::Drone::API.new(cloud_account.drone_token, cloud_account.drone_url, @repo.user.login, @repo.identifier).builds | |||||
| render json: result | |||||
| end | |||||
| def detail | |||||
| cloud_account = @repo.dev_ops_cloud_account | |||||
| result = DevOps::Drone::API.new(cloud_account.drone_token, cloud_account.drone_url, @repo.user.login, @repo.identifier, number: params[:number]).build | |||||
| render json: result | |||||
| end | |||||
| def restart | |||||
| cloud_account = @repo.dev_ops_cloud_account | |||||
| result = DevOps::Drone::API.new(cloud_account.drone_token, cloud_account.drone_url, @repo.user.login, @repo.identifier, number: params[:number]).restart | |||||
| render json: result | |||||
| end | end | ||||
| def show | |||||
| def delete | |||||
| cloud_account = @repo.dev_ops_cloud_account | |||||
| result = DevOps::Drone::API.new(cloud_account.drone_token, cloud_account.drone_url, @repo.user.login, @repo.identifier, number: params[:number]).stop | |||||
| render json: result | |||||
| end | |||||
| def logs | |||||
| cloud_account = @repo.dev_ops_cloud_account | |||||
| result = DevOps::Drone::API.new(cloud_account.drone_token, cloud_account.drone_url, @repo.user.login, @repo.identifier, build: params[:build], stage: params[:stage], step: sync_params[:step]).logs | |||||
| render json: result | |||||
| end | end | ||||
| private | private | ||||
| @@ -1,11 +1,11 @@ | |||||
| class SyncForgeController < ApplicationController | class SyncForgeController < ApplicationController | ||||
| # before_action :check_token | # before_action :check_token | ||||
| def create | |||||
| def create | |||||
| ActiveRecord::Base.transaction do | ActiveRecord::Base.transaction do | ||||
| params.permit! | params.permit! | ||||
| sync_params = params[:sync_params] | sync_params = params[:sync_params] | ||||
| project_user = User.where(login: sync_params[:owner_login])&.first | |||||
| project_user = User.where(login: sync_params[:owner_login])&.first | |||||
| #以前已同步的项目,那么肯定存在仓库 | #以前已同步的项目,那么肯定存在仓库 | ||||
| user_projects = Project.where(user_id: project_user.id) | user_projects = Project.where(user_id: project_user.id) | ||||
| @@ -24,12 +24,12 @@ class SyncForgeController < ApplicationController | |||||
| if has_project | if has_project | ||||
| SyncLog.sync_log("=================begin_to_update_project========") | SyncLog.sync_log("=================begin_to_update_project========") | ||||
| # project = user_projects.where(id: sync_params[:id]), identifier: sync_params[:identifier])&.first || | |||||
| # project = user_projects.where(id: sync_params[:id]), identifier: sync_params[:identifier])&.first || | |||||
| check_sync_project(project, sync_params) | check_sync_project(project, sync_params) | ||||
| else #新建项目 | else #新建项目 | ||||
| SyncLog.sync_log("=================begin_to_create_new_project========") | SyncLog.sync_log("=================begin_to_create_new_project========") | ||||
| project_params = { | project_params = { | ||||
| repository_name: sync_params[:identifier], | repository_name: sync_params[:identifier], | ||||
| user_id: project_user.id, | user_id: project_user.id, | ||||
| @@ -44,7 +44,7 @@ class SyncForgeController < ApplicationController | |||||
| new_project_score = ProjectScore.create(score_params) | new_project_score = ProjectScore.create(score_params) | ||||
| SyncLog.sync_log("=================new_project_score:#{new_project_score.try(:id)}========") | SyncLog.sync_log("=================new_project_score:#{new_project_score.try(:id)}========") | ||||
| end | end | ||||
| SyncRepositoryJob.perform_later(sync_params[:owner_login], sync_params[:identifier], sync_params[:repository], get_sudomain) if sync_params[:repository].present? | SyncRepositoryJob.perform_later(sync_params[:owner_login], sync_params[:identifier], sync_params[:repository], get_sudomain) if sync_params[:repository].present? | ||||
| check_new_project(project, sync_params) | check_new_project(project, sync_params) | ||||
| else | else | ||||
| @@ -107,7 +107,7 @@ class SyncForgeController < ApplicationController | |||||
| SyncLog.sync_log("=================sync_user_failed====#{e}") | SyncLog.sync_log("=================sync_user_failed====#{e}") | ||||
| end | end | ||||
| private | |||||
| private | |||||
| def check_sync_project(project,sync_params) | def check_sync_project(project,sync_params) | ||||
| begin | begin | ||||
| @@ -117,8 +117,8 @@ class SyncForgeController < ApplicationController | |||||
| end | end | ||||
| SyncLog.sync_log("----begin_to_check_sync_project----project_id:#{project.id}---------------") | SyncLog.sync_log("----begin_to_check_sync_project----project_id:#{project.id}---------------") | ||||
| change_project_score(project, sync_params[:project_score], sync_params[:repository]) if sync_params[:repository].present? #更新project_score | |||||
| change_project_issues(project, sync_params[:issues],project.id, gitea_main) | |||||
| change_project_score(project, sync_params[:project_score], sync_params[:repository]) if sync_params[:repository].present? #更新project_score | |||||
| change_project_issues(project, sync_params[:issues],project.id, gitea_main) | |||||
| change_project_members(project, sync_params[:members],gitea_main) | change_project_members(project, sync_params[:members],gitea_main) | ||||
| change_project_versions(project, sync_params[:project_versions],gitea_main) | change_project_versions(project, sync_params[:project_versions],gitea_main) | ||||
| change_project_watchers(project, sync_params[:project_watchers],gitea_main) | change_project_watchers(project, sync_params[:project_watchers],gitea_main) | ||||
| @@ -126,7 +126,7 @@ class SyncForgeController < ApplicationController | |||||
| rescue => e | rescue => e | ||||
| SyncLog.sync_log("=========check_sync_project_errors:#{e}===================") | SyncLog.sync_log("=========check_sync_project_errors:#{e}===================") | ||||
| end | end | ||||
| end | end | ||||
| def check_new_project(project,sync_params) | def check_new_project(project,sync_params) | ||||
| @@ -159,7 +159,7 @@ class SyncForgeController < ApplicationController | |||||
| parent_id: project.id | parent_id: project.id | ||||
| } | } | ||||
| SyncProjectsJob.perform_later(sync_projects_params,gitea_main) | SyncProjectsJob.perform_later(sync_projects_params,gitea_main) | ||||
| SyncLog.sync_log("***6. end_to_sync_parises---------------") | SyncLog.sync_log("***6. end_to_sync_parises---------------") | ||||
| end | end | ||||
| end | end | ||||
| @@ -181,7 +181,7 @@ class SyncForgeController < ApplicationController | |||||
| end | end | ||||
| end | end | ||||
| pre_project_score.save! if change_num > 0 #如果 project_score有变化则更新 | pre_project_score.save! if change_num > 0 #如果 project_score有变化则更新 | ||||
| else | |||||
| else | |||||
| ProjectScore.create!(project_scores.merge(project_id: project.id)) | ProjectScore.create!(project_scores.merge(project_id: project.id)) | ||||
| end | end | ||||
| SyncLog.sync_log("***1. end_to_sync_project_score---------------") | SyncLog.sync_log("***1. end_to_sync_project_score---------------") | ||||
| @@ -217,7 +217,7 @@ class SyncForgeController < ApplicationController | |||||
| } | } | ||||
| end | end | ||||
| end | end | ||||
| SyncProjectsJob.perform_later(sync_projects_params, gitea_main) if sync_projects_params.present? | SyncProjectsJob.perform_later(sync_projects_params, gitea_main) if sync_projects_params.present? | ||||
| SyncLog.sync_log("***2. end_to_syncissues---------------") | SyncLog.sync_log("***2. end_to_syncissues---------------") | ||||
| rescue Exception => e | rescue Exception => e | ||||
| @@ -238,7 +238,7 @@ class SyncForgeController < ApplicationController | |||||
| parent_id: project.id | parent_id: project.id | ||||
| } | } | ||||
| SyncProjectsJob.perform_later(sync_projects_params,gitea_main) | SyncProjectsJob.perform_later(sync_projects_params,gitea_main) | ||||
| end | end | ||||
| end | end | ||||
| SyncLog.sync_log("***5. begin_to_sync_watchers---------------") | SyncLog.sync_log("***5. begin_to_sync_watchers---------------") | ||||
| @@ -258,7 +258,7 @@ class SyncForgeController < ApplicationController | |||||
| } | } | ||||
| SyncProjectsJob.perform_later(sync_projects_params,gitea_main) | SyncProjectsJob.perform_later(sync_projects_params,gitea_main) | ||||
| end | end | ||||
| SyncLog.sync_log("***4. end_to_sync_versions---------------") | SyncLog.sync_log("***4. end_to_sync_versions---------------") | ||||
| end | end | ||||
| end | end | ||||
| @@ -277,12 +277,12 @@ class SyncForgeController < ApplicationController | |||||
| } | } | ||||
| SyncProjectsJob.perform_later(sync_projects_params,gitea_main) | SyncProjectsJob.perform_later(sync_projects_params,gitea_main) | ||||
| end | end | ||||
| SyncLog.sync_log("***3. end_to_sync_members---------------") | SyncLog.sync_log("***3. end_to_sync_members---------------") | ||||
| end | end | ||||
| end | end | ||||
| # def check_token | |||||
| # def check_token | |||||
| # sync_params = params[:sync_params] | # sync_params = params[:sync_params] | ||||
| # unless sync_params[:token] && sync_params[:token] == get_token | # unless sync_params[:token] && sync_params[:token] == get_token | ||||
| # render json: {message: "token_errors"} | # render json: {message: "token_errors"} | ||||
| @@ -304,4 +304,4 @@ class SyncForgeController < ApplicationController | |||||
| return gitea_main | return gitea_main | ||||
| end | end | ||||
| end | |||||
| end | |||||
| @@ -8,7 +8,7 @@ class SyncProjectsJob < ApplicationJob | |||||
| SyncLog.sync_log("==========begin to sync #{sync_params[:type]} to forge============") | SyncLog.sync_log("==========begin to sync #{sync_params[:type]} to forge============") | ||||
| SyncLog.sync_log("==========sync_params:#{sync_params}============") | SyncLog.sync_log("==========sync_params:#{sync_params}============") | ||||
| begin | |||||
| begin | |||||
| url = "#{gitea_main}/sync_forges" #trustie上的相关路由 | url = "#{gitea_main}/sync_forges" #trustie上的相关路由 | ||||
| uri = URI.parse(url) | uri = URI.parse(url) | ||||
| http = Net::HTTP.new(uri.hostname, uri.port) | http = Net::HTTP.new(uri.hostname, uri.port) | ||||
| @@ -112,7 +112,7 @@ class SyncProjectsJob < ApplicationJob | |||||
| rescue => e | rescue => e | ||||
| SyncLog.sync_log("=========***【#{target_type}】creat_had_erros:#{e}===================") | SyncLog.sync_log("=========***【#{target_type}】creat_had_erros:#{e}===================") | ||||
| end | end | ||||
| end | end | ||||
| def create_journals(target_jsons, target_type,issue_id) | def create_journals(target_jsons, target_type,issue_id) | ||||
| @@ -171,4 +171,4 @@ class SyncProjectsJob < ApplicationJob | |||||
| SyncLog.sync_log("***111222. end_to_create_target---------------") | SyncLog.sync_log("***111222. end_to_create_target---------------") | ||||
| end | end | ||||
| end | |||||
| end | |||||
| @@ -1,12 +1,12 @@ | |||||
| class DevOps::Drone::API < DevOps::Drone::Request | class DevOps::Drone::API < DevOps::Drone::Request | ||||
| attr_reader :drone_token, :drone_url, :owner, :repo, :options | |||||
| attr_reader :drone_token, :endpoint, :owner, :repo, :options | |||||
| # drone_token: | # drone_token: | ||||
| # owner: repo's owner name or login | # owner: repo's owner name or login | ||||
| # repo: repo's identifier | # repo: repo's identifier | ||||
| def initialize(drone_token, drone_url, owner, repo, options={}) | |||||
| def initialize(drone_token, endpoint, owner, repo, options={}) | |||||
| @drone_token = drone_token | @drone_token = drone_token | ||||
| @drone_url = drone_url | |||||
| @endpoint = endpoint | |||||
| @owner = owner | @owner = owner | ||||
| @repo = repo | @repo = repo | ||||
| @options = options | @options = options | ||||
| @@ -15,40 +15,59 @@ class DevOps::Drone::API < DevOps::Drone::Request | |||||
| # Build List | # Build List | ||||
| # GET api/repos/{owner}/{name}/builds | # GET api/repos/{owner}/{name}/builds | ||||
| # eq: | # eq: | ||||
| # DevOps::Drone::API | |||||
| # DevOps::Drone::API.new(cloud_account.drone_token, cloud_account.drone_url, @repo.user.login, @repo.identifier) | |||||
| def builds | def builds | ||||
| request(:get, drone_url, "api/repos/#{owner}/#{repo}/builds", drone_token: drone_token) | |||||
| get(endpoint, "api/repos/#{owner}/#{repo}/builds", drone_token: drone_token) | |||||
| end | end | ||||
| # Build Info | # Build Info | ||||
| # GET api/repos/{owner}/{name}/builds/{number} | # GET api/repos/{owner}/{name}/builds/{number} | ||||
| # eq: | |||||
| # DevOps::Drone::API.new(cloud_account.drone_token, cloud_account.endpoint, project.owner.login, project.identifier, number: number).build | |||||
| def build | def build | ||||
| request(:get, "api/repos/#{owner}/#{repo}/builds/#{number}", drone_token: drone_token) | |||||
| get(endpoint, "api/repos/#{owner}/#{repo}/builds/#{options[:number]}", drone_token: drone_token) | |||||
| end | end | ||||
| # Update .trustie-pipeline.yml file | # Update .trustie-pipeline.yml file | ||||
| # PATCH api/repos/{owner}/{name} | |||||
| # PATCH api/repos/{owner}/{name}\ | |||||
| # eq: | |||||
| # DevOps::Drone::API.new(cloud_account.drone_token, cloud_account.endpoint, project.owner.login, project.identifier, config_path: config_path).config_yml | |||||
| def config_yml | def config_yml | ||||
| request(:patch, "/api/repos/#{owner}/#{repo}", drone_token: drone_token, config_path: config_path) | |||||
| patch(endpoint, "/api/repos/#{owner}/#{repo}", drone_token: drone_token, config_path: options[:config_path]) | |||||
| end | end | ||||
| # Activate user's project with Drone CI | # Activate user's project with Drone CI | ||||
| # POST api/repos/{owner}/{name} | # POST api/repos/{owner}/{name} | ||||
| # eq: | |||||
| # DevOps::Drone::API.new(cloud_account.drone_token, cloud_account.endpoint, project.owner.login, project.identifier).avtivate | |||||
| def activate | def activate | ||||
| request(:post, "/api/repos/#{owner}/#{repo}", drone_token: drone_token) | |||||
| post(endpoint, "/api/repos/#{owner}/#{repo}", drone_token: drone_token) | |||||
| end | end | ||||
| # Build Restart | # Build Restart | ||||
| # POST api/repos/{owner}/{name}/builds/{number} | # POST api/repos/{owner}/{name}/builds/{number} | ||||
| # Restart the specified build. Please note this api requires read and write access to the repository and the request parameter {build} is not the build id but the build number. | # Restart the specified build. Please note this api requires read and write access to the repository and the request parameter {build} is not the build id but the build number. | ||||
| # eq: | |||||
| # DevOps::Drone::API.new(cloud_account.drone_token, cloud_account.drone_url, @repo.user.login, @repo.identifier, number: number).restart | |||||
| def restart | def restart | ||||
| request(:post, "/api/repos/#{owner}/#{repo}/builds/#{number}", drone_token: drone_token) | |||||
| post(endpoint, "/api/repos/#{owner}/#{repo}/builds/#{options[:number]}", drone_token: drone_token) | |||||
| end | end | ||||
| # Build Stop | # Build Stop | ||||
| # DELETE api/repos/{owner}/{name}/builds/{number} | # DELETE api/repos/{owner}/{name}/builds/{number} | ||||
| # Stop the specified build. Please note this api requires administrative privileges and the request parameter {build} is not the build id but the build number. | # Stop the specified build. Please note this api requires administrative privileges and the request parameter {build} is not the build id but the build number. | ||||
| # eq: | |||||
| # DevOps::Drone::API.new(cloud_account.drone_token, cloud_account.drone_url, @repo.user.login, @repo.identifier, number: number).stop | |||||
| def stop | def stop | ||||
| request(:delete, "/api/repos/#{owner}/#{repo}/builds/#{number}", drone_token: drone_token) | |||||
| delete(endpoint, "/api/repos/#{owner}/#{repo}/builds/#{options[:number]}", drone_token: drone_token) | |||||
| end | |||||
| # Build Logs | |||||
| # GET /api/repos/{owner}/{repo}/builds/{build}/logs/{stage}/{step} | |||||
| # Please note this api requires read access to the repository. | |||||
| # eq: | |||||
| # DevOps::Drone::API.new(cloud_account.drone_token, cloud_account.drone_url, @repo.user.login, @repo.identifier, build: build, stage: stage, step: step).logs | |||||
| def logs | |||||
| get(endpoint, "/api/repos/#{owner}/#{repo}/builds/#{options[:build]}/logs/#{options[:stage]}/#{options[:step]}", drone_token: drone_token) | |||||
| end | end | ||||
| end | end | ||||
| @@ -5,7 +5,7 @@ class DevOps::Drone::Ci | |||||
| # username: drone server's account | # username: drone server's account | ||||
| # password: drone server's password | # password: drone server's password | ||||
| # eq: | # eq: | ||||
| # DevOps::Drone::Ci.new(@cloud_account.drone_ip, @cloud_account.account, @cloud_account.visible_secret).get_token | |||||
| # DevOps::Drone::Ci.new(@cloud_account.drone_ip, @cloud_account.account, @cloud_account.visible_secret, current_user.login).get_token | |||||
| def initialize(host, username, password, gitea_username) | def initialize(host, username, password, gitea_username) | ||||
| @host = host | @host = host | ||||
| @username = username | @username = username | ||||
| @@ -1,10 +1,4 @@ | |||||
| # @private | |||||
| class DevOps::Drone::Request | class DevOps::Drone::Request | ||||
| # format :json | |||||
| # headers 'Accept' => 'application/json' | |||||
| # parser Proc.new { |body, _| parse(body) } | |||||
| # Converts the response body to an ObjectifiedHash. | # Converts the response body to an ObjectifiedHash. | ||||
| def self.parse(body) | def self.parse(body) | ||||
| body = decode(body) | body = decode(body) | ||||
| @@ -29,113 +23,70 @@ | |||||
| end | end | ||||
| end | end | ||||
| def get(path, options={}) | |||||
| set_httparty_config(options) | |||||
| set_private_token_header(options) | |||||
| validate self.class.get(path, options) | |||||
| def get(endpoint, path, options={}) | |||||
| set_request_defaults(endpoint) | |||||
| request(:get, endpoint, path, options) | |||||
| end | end | ||||
| def post(path, options={}) | |||||
| set_httparty_config(options) | |||||
| set_private_token_header(options, path) | |||||
| validate self.class.post(path, options) | |||||
| def post(endpoint, path, options={}) | |||||
| set_request_defaults(endpoint) | |||||
| request(:post, endpoint, path, options) | |||||
| end | end | ||||
| def put(path, options={}) | |||||
| set_httparty_config(options) | |||||
| set_private_token_header(options) | |||||
| validate self.class.put(path, options) | |||||
| def put(endpoint, path, options={}) | |||||
| set_request_defaults(endpoint) | |||||
| request(:put, endpoint, path, options) | |||||
| end | end | ||||
| def delete(path, options={}) | |||||
| set_httparty_config(options) | |||||
| set_private_token_header(options) | |||||
| validate self.class.delete(path, options) | |||||
| def delete(endpoint, path, options={}) | |||||
| set_request_defaults(endpoint) | |||||
| request(:delete, endpoint, path, options) | |||||
| end | end | ||||
| # Checks the response code for common errors. | |||||
| # Returns parsed response for successful requests. | |||||
| def validate(response) | |||||
| # case response.code | |||||
| # when 400; raise Error::BadRequest.new error_message(response) | |||||
| # when 401; raise Error::Unauthorized.new error_message(response) | |||||
| # when 403; raise Error::Forbidden.new error_message(response) | |||||
| # when 404; raise Error::NotFound.new error_message(response) | |||||
| # when 405; raise Error::MethodNotAllowed.new error_message(response) | |||||
| # when 406; raise Error::DataNotAccepted.new error_message(response) | |||||
| # when 409; raise Error::Conflict.new error_message(response) | |||||
| # when 500; raise Error::InternalServerError.new error_message(response) | |||||
| # when 502; raise Error::BadGateway.new error_message(response) | |||||
| # when 503; raise Error::ServiceUnavailable.new error_message(response) | |||||
| # end | |||||
| response.parsed_response | |||||
| end | |||||
| # Sets a base_uri and default_params for requests. | |||||
| # @raise [Error::MissingCredentials] if endpoint not set. | |||||
| def set_request_defaults(endpoint, private_token, sudo=nil) | |||||
| raise Error::MissingCredentials.new("Please set an endpoint to API") unless endpoint | |||||
| @private_token = private_token | |||||
| self.class.base_uri endpoint | |||||
| self.class.default_params :sudo => sudo | |||||
| self.class.default_params.delete(:sudo) if sudo.nil? | |||||
| end | |||||
| def request(method, domain, url, **params) | |||||
| Rails.logger.info("[drone] request: #{method} #{url} #{params.except(:secret).inspect}") | |||||
| client = Faraday.new(url: domain) | |||||
| response = client.public_send(method, url, params) | |||||
| result = JSON.parse(response.body) | |||||
| Rails.logger.info("[drone] response:#{response.status} #{result.inspect}") | |||||
| private | |||||
| def request(method, endpoint, path, **params) | |||||
| Rails.logger.info("[drone] request: #{method} #{path} #{params.except(:secret).inspect}") | |||||
| if response.status != 200 | |||||
| raise DevOps::Drone::Error.parse(result) | |||||
| end | |||||
| client = Faraday.new(path: domain) | |||||
| response = client.public_send(method, path, params) | |||||
| result = JSON.parse(response.body) | |||||
| if result['errcode'].present? && result['errcode'].to_i.nonzero? | |||||
| raise DevOps::Drone::Error.parse(result) | |||||
| end | |||||
| Rails.logger.info("[drone] response:#{response.status} #{result.inspect}") | |||||
| result | |||||
| end | |||||
| if response.status != 200 | |||||
| raise DevOps::Drone::Error.parse(result) | |||||
| end | |||||
| private | |||||
| def conn(auth={}) | |||||
| token = auth[:token] | |||||
| puts "[gitea] token: #{token}" | |||||
| @client ||= begin | |||||
| Faraday.new(url: domain) do |req| | |||||
| req.request :url_encoded | |||||
| req.headers['Content-Type'] = 'application/json' | |||||
| req.response :logger # 显示日志 | |||||
| req.adapter Faraday.default_adapter | |||||
| req.authorization :Bearer, token | |||||
| req.headers['Authorization'] | |||||
| end | |||||
| if result['errcode'].present? && result['errcode'].to_i.nonzero? | |||||
| raise DevOps::Drone::Error.parse(result) | |||||
| end | end | ||||
| @client | |||||
| result | |||||
| end | end | ||||
| # Sets a PRIVATE-TOKEN header for requests. | |||||
| # @raise [Error::MissingCredentials] if private_token not set. | |||||
| def set_private_token_header(options, path=nil) | |||||
| unless path == '/session' | |||||
| raise Error::MissingCredentials.new("Please set a private_token for user") unless @private_token | |||||
| options[:headers] = {'PRIVATE-TOKEN' => @private_token} | |||||
| end | |||||
| # Sets a base_uri and default_params for requests. | |||||
| # @raise [Error::MissingCredentials] if endpoint not set. | |||||
| def set_request_defaults(endpoint, private_token, sudo=nil) | |||||
| raise "Please set an endpoint to API" unless endpoint | |||||
| end | end | ||||
| # Set HTTParty configuration | |||||
| # @see https://github.com/jnunemaker/httparty | |||||
| def set_httparty_config(options) | |||||
| if self.httparty | |||||
| options.merge!(self.httparty) | |||||
| end | |||||
| # Checks the response code for common errors. | |||||
| # Returns parsed response for successful requests. | |||||
| def validate(response) | |||||
| # case response.code | |||||
| # when 400; raise Error::BadRequest.new error_message(response) | |||||
| # when 401; raise Error::Unauthorized.new error_message(response) | |||||
| # when 403; raise Error::Forbidden.new error_message(response) | |||||
| # when 404; raise Error::NotFound.new error_message(response) | |||||
| # when 405; raise Error::MethodNotAllowed.new error_message(response) | |||||
| # when 406; raise Error::DataNotAccepted.new error_message(response) | |||||
| # when 409; raise Error::Conflict.new error_message(response) | |||||
| # when 500; raise Error::InternalServerError.new error_message(response) | |||||
| # when 502; raise Error::BadGateway.new error_message(response) | |||||
| # when 503; raise Error::ServiceUnavailable.new error_message(response) | |||||
| # end | |||||
| response.parsed_response | |||||
| end | end | ||||
| def error_message(response) | def error_message(response) | ||||
| @@ -1,6 +1,7 @@ | |||||
| class DevOps::CloudAccount < ApplicationRecord | class DevOps::CloudAccount < ApplicationRecord | ||||
| belongs_to :project | belongs_to :project | ||||
| belongs_to :user | belongs_to :user | ||||
| belongs_to :repository | |||||
| def drone_host | def drone_host | ||||
| [drone_ip, ":80"].join | [drone_ip, ":80"].join | ||||
| @@ -3,6 +3,7 @@ class Repository < ApplicationRecord | |||||
| belongs_to :project, :touch => true | belongs_to :project, :touch => true | ||||
| belongs_to :user | belongs_to :user | ||||
| has_one :mirror, foreign_key: :repo_id | has_one :mirror, foreign_key: :repo_id | ||||
| has_one :dev_ops_cloud_account, foreign_key: :repo_id | |||||
| has_many :version_releases, dependent: :destroy | has_many :version_releases, dependent: :destroy | ||||
| validates :identifier, presence: true | validates :identifier, presence: true | ||||
| @@ -22,7 +22,15 @@ Rails.application.routes.draw do | |||||
| get :common | get :common | ||||
| end | end | ||||
| end | end | ||||
| resources :builds | |||||
| resources :builds, only: :index do | |||||
| collection do | |||||
| get ':number', to: 'builds#detail', as: 'detail' | |||||
| get ':number/logs/:stage/:step', to: 'builds#detail', as: 'logs' | |||||
| post ':number', to: 'builds#restart', as: 'restart' | |||||
| delete ':number', to: 'builds#delete', as: 'delete' | |||||
| end | |||||
| end | |||||
| end | end | ||||
| resources :sync_forge, only: [:create] do | resources :sync_forge, only: [:create] do | ||||
| @@ -0,0 +1,7 @@ | |||||
| class AddRepositoryRefToDevOpsCloudAccount < ActiveRecord::Migration[5.2] | |||||
| def change | |||||
| add_column :dev_ops_cloud_accounts, :repo_id, :integer | |||||
| add_index :dev_ops_cloud_accounts, :repo_id, name: 'dev_ops_cloud_accounts_repo_id_ix' | |||||
| end | |||||
| end | |||||