Merge branch 'dev_devops' of http://gitea.trustie.net/jasder/forgeplus into dev_devops
This commit is contained in:
commit
df0fcdb5ce
|
@ -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
|
end
|
||||||
|
|
||||||
def show
|
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
|
||||||
|
|
||||||
|
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_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_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={})
|
def get(endpoint, path, options={})
|
||||||
set_httparty_config(options)
|
set_request_defaults(endpoint)
|
||||||
set_private_token_header(options)
|
request(:get, endpoint, path, options)
|
||||||
validate self.class.get(path, options)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def post(path, options={})
|
def post(endpoint, path, options={})
|
||||||
set_httparty_config(options)
|
set_request_defaults(endpoint)
|
||||||
set_private_token_header(options, path)
|
request(:post, endpoint, path, options)
|
||||||
validate self.class.post(path, options)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def put(path, options={})
|
def put(endpoint, path, options={})
|
||||||
set_httparty_config(options)
|
set_request_defaults(endpoint)
|
||||||
set_private_token_header(options)
|
request(:put, endpoint, path, options)
|
||||||
validate self.class.put(path, options)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def delete(path, options={})
|
def delete(endpoint, path, options={})
|
||||||
set_httparty_config(options)
|
set_request_defaults(endpoint)
|
||||||
set_private_token_header(options)
|
request(:delete, endpoint, path, options)
|
||||||
validate self.class.delete(path, options)
|
|
||||||
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}")
|
|
||||||
|
|
||||||
if response.status != 200
|
|
||||||
raise DevOps::Drone::Error.parse(result)
|
|
||||||
end
|
|
||||||
|
|
||||||
if result['errcode'].present? && result['errcode'].to_i.nonzero?
|
|
||||||
raise DevOps::Drone::Error.parse(result)
|
|
||||||
end
|
|
||||||
|
|
||||||
result
|
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
def conn(auth={})
|
def request(method, endpoint, path, **params)
|
||||||
token = auth[:token]
|
Rails.logger.info("[drone] request: #{method} #{path} #{params.except(:secret).inspect}")
|
||||||
puts "[gitea] token: #{token}"
|
|
||||||
|
|
||||||
@client ||= begin
|
client = Faraday.new(path: domain)
|
||||||
Faraday.new(url: domain) do |req|
|
response = client.public_send(method, path, params)
|
||||||
req.request :url_encoded
|
result = JSON.parse(response.body)
|
||||||
req.headers['Content-Type'] = 'application/json'
|
|
||||||
req.response :logger # 显示日志
|
Rails.logger.info("[drone] response:#{response.status} #{result.inspect}")
|
||||||
req.adapter Faraday.default_adapter
|
|
||||||
req.authorization :Bearer, token
|
if response.status != 200
|
||||||
req.headers['Authorization']
|
raise DevOps::Drone::Error.parse(result)
|
||||||
end
|
|
||||||
end
|
end
|
||||||
@client
|
|
||||||
|
if result['errcode'].present? && result['errcode'].to_i.nonzero?
|
||||||
|
raise DevOps::Drone::Error.parse(result)
|
||||||
|
end
|
||||||
|
|
||||||
|
result
|
||||||
end
|
end
|
||||||
|
|
||||||
# Sets a PRIVATE-TOKEN header for requests.
|
# Sets a base_uri and default_params for requests.
|
||||||
# @raise [Error::MissingCredentials] if private_token not set.
|
# @raise [Error::MissingCredentials] if endpoint not set.
|
||||||
def set_private_token_header(options, path=nil)
|
def set_request_defaults(endpoint, private_token, sudo=nil)
|
||||||
unless path == '/session'
|
raise "Please set an endpoint to API" unless endpoint
|
||||||
raise Error::MissingCredentials.new("Please set a private_token for user") unless @private_token
|
|
||||||
options[:headers] = {'PRIVATE-TOKEN' => @private_token}
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# Set HTTParty configuration
|
# Checks the response code for common errors.
|
||||||
# @see https://github.com/jnunemaker/httparty
|
# Returns parsed response for successful requests.
|
||||||
def set_httparty_config(options)
|
def validate(response)
|
||||||
if self.httparty
|
# case response.code
|
||||||
options.merge!(self.httparty)
|
# when 400; raise Error::BadRequest.new error_message(response)
|
||||||
end
|
# 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
|
Loading…
Reference in New Issue