mirror of
https://gitlink.org.cn/Gitlink/forgeplus.git
synced 2026-05-03 03:40:49 +08:00
ADD devops
This commit is contained in:
54
app/libs/dev_ops/drone/api.rb
Normal file
54
app/libs/dev_ops/drone/api.rb
Normal file
@@ -0,0 +1,54 @@
|
||||
class DevOps::Drone::API < DevOps::Drone::Request
|
||||
attr_reader :drone_token, :drone_url, :owner, :repo, :options
|
||||
|
||||
# drone_token:
|
||||
# owner: repo's owner name or login
|
||||
# repo: repo's identifier
|
||||
def initialize(drone_token, drone_url, owner, repo, options={})
|
||||
@drone_token = drone_token
|
||||
@drone_url = drone_url
|
||||
@owner = owner
|
||||
@repo = repo
|
||||
@options = options
|
||||
end
|
||||
|
||||
# Build List
|
||||
# GET api/repos/{owner}/{name}/builds
|
||||
# eq:
|
||||
# DevOps::Drone::API
|
||||
def builds
|
||||
request(:get, drone_url, "api/repos/#{owner}/#{repo}/builds", drone_token: drone_token)
|
||||
end
|
||||
|
||||
# Build Info
|
||||
# GET api/repos/{owner}/{name}/builds/{number}
|
||||
def build
|
||||
request(:get, "api/repos/#{owner}/#{repo}/builds/#{number}", drone_token: drone_token)
|
||||
end
|
||||
|
||||
# Update .trustie-pipeline.yml file
|
||||
# PATCH api/repos/{owner}/{name}
|
||||
def config_yml
|
||||
request(:patch, "/api/repos/#{owner}/#{repo}", drone_token: drone_token, config_path: config_path)
|
||||
end
|
||||
|
||||
# Activate user's project with Drone CI
|
||||
# POST api/repos/{owner}/{name}
|
||||
def activate
|
||||
request(:post, "/api/repos/#{owner}/#{repo}", drone_token: drone_token)
|
||||
end
|
||||
|
||||
# Build Restart
|
||||
# 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.
|
||||
def restart
|
||||
request(:post, "/api/repos/#{owner}/#{repo}/builds/#{number}", drone_token: drone_token)
|
||||
end
|
||||
|
||||
# Build Stop
|
||||
# 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.
|
||||
def stop
|
||||
request(:delete, "/api/repos/#{owner}/#{repo}/builds/#{number}", drone_token: drone_token)
|
||||
end
|
||||
end
|
||||
14
app/libs/dev_ops/drone/error.rb
Normal file
14
app/libs/dev_ops/drone/error.rb
Normal file
@@ -0,0 +1,14 @@
|
||||
class DevOps::Drone::Error < StandardError
|
||||
attr_reader :code
|
||||
|
||||
def initialize(code, message)
|
||||
super message
|
||||
@code = code
|
||||
end
|
||||
|
||||
class << self
|
||||
def parse(result)
|
||||
new(result['errcode'], result['errmsg'])
|
||||
end
|
||||
end
|
||||
end
|
||||
@@ -1,10 +1,9 @@
|
||||
# @private
|
||||
class DevOps::Drone::Request
|
||||
format :json
|
||||
headers 'Accept' => 'application/json'
|
||||
parser Proc.new { |body, _| parse(body) }
|
||||
# format :json
|
||||
# headers 'Accept' => 'application/json'
|
||||
# parser Proc.new { |body, _| parse(body) }
|
||||
|
||||
attr_accessor :private_token
|
||||
|
||||
# Converts the response body to an ObjectifiedHash.
|
||||
def self.parse(body)
|
||||
@@ -84,27 +83,63 @@
|
||||
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
|
||||
|
||||
private
|
||||
def conn(auth={})
|
||||
token = auth[:token]
|
||||
puts "[gitea] token: #{token}"
|
||||
|
||||
# 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}
|
||||
@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
|
||||
end
|
||||
@client
|
||||
end
|
||||
end
|
||||
|
||||
# Set HTTParty configuration
|
||||
# @see https://github.com/jnunemaker/httparty
|
||||
def set_httparty_config(options)
|
||||
if self.httparty
|
||||
options.merge!(self.httparty)
|
||||
# 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
|
||||
end
|
||||
end
|
||||
|
||||
def error_message(response)
|
||||
"Server responded with code #{response.code}, message: #{response.parsed_response.message}. " \
|
||||
"Request URI: #{response.request.base_uri}#{response.request.path}"
|
||||
end
|
||||
# Set HTTParty configuration
|
||||
# @see https://github.com/jnunemaker/httparty
|
||||
def set_httparty_config(options)
|
||||
if self.httparty
|
||||
options.merge!(self.httparty)
|
||||
end
|
||||
end
|
||||
|
||||
def error_message(response)
|
||||
"Server responded with code #{response.code}, message: #{response.parsed_response.message}. " \
|
||||
"Request URI: #{response.request.base_uri}#{response.request.path}"
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user