Browse Source

Merge branch 'pre_trustie_server' into trustie_server

pull/346/head
yystopf 1 year ago
parent
commit
1026a5ea3d
2 changed files with 61 additions and 11 deletions
  1. +2
    -2
      app/controllers/projects_controller.rb
  2. +59
    -9
      app/services/projects/verify_auth_token_service.rb

+ 2
- 2
app/controllers/projects_controller.rb View File

@@ -314,8 +314,8 @@ class ProjectsController < ApplicationController

def simple
if !@project.common? && @project&.repository&.mirror&.waiting?
gitea_result = $gitea_client.get_repos_by_owner_repo(@project&.owner&.login, @project&.identifier)
if !gitea_result["empty"]
gitea_result = $gitea_client.get_repos_by_owner_repo(@project&.owner&.login, @project&.identifier) rescue nil
if gitea_result.present? && !gitea_result["empty"]
@project&.update_columns(gpid: gitea_result["id"])
@project&.repository&.mirror&.succeeded!
project_id = @project&.id


+ 59
- 9
app/services/projects/verify_auth_token_service.rb View File

@@ -36,16 +36,66 @@ class Projects::VerifyAuthTokenService < ApplicationService
gitlab_verify
when "gitee.com"
gitee_verify
when "gitlink.org.cn"
gitlink_verify
when "gitea.com"
gitea_verify
when "gitcode.com"
gitcode_verify
else
@success = nil
end
end

def gitcode_verify
url = "/api/v5/user"
api_url = "https://api.gitcode.com"
client = Faraday.new(url: api_url)
client.options["open_timeout"] = 100
client.options["timeout"] = 100
client.options["write_timeout"] = 100
req_params={
access_token: @token
}
response = client.public_send("get", url, req_params)
@success = true if response.status == 200
end

def gitea_verify
url = "/api/v1/user"
api_url = "https://gitea.com"
client = Faraday.new(url: api_url)
client.options["open_timeout"] = 100
client.options["timeout"] = 100
client.options["write_timeout"] = 100
req_params={
token: @token
}
response = client.public_send("get", url, req_params)
@success = true if response.status == 200
end

def gitlink_verify
url = "/api/v1/user"
api_url = "https://cdn05042023.gitlink.org.cn"
client = Faraday.new(url: api_url)
client.options["open_timeout"] = 100
client.options["timeout"] = 100
client.options["write_timeout"] = 100
req_params={
token: @token
}
response = client.public_send("get", url, req_params)
@success = true if response.status == 200
end

def gitee_verify
url = "/api/v5/repos/#{@owner}/#{@repo}"
api_url= "https://gitee.com"
client = Faraday.new(url: api_url)
client.options["open_timeout"] = 1
client.options["timeout"] = 1
client.options["write_timeout"] = 1
client.options["open_timeout"] = 100
client.options["timeout"] = 100
client.options["write_timeout"] = 100
req_params={
access_token: @token,
owner: @owner,
@@ -59,9 +109,9 @@ class Projects::VerifyAuthTokenService < ApplicationService
url = "/octocat"
api_url= "https://api.github.com"
client = Faraday.new(url: api_url)
client.options["open_timeout"] = 1
client.options["timeout"] = 1
client.options["write_timeout"] = 1
client.options["open_timeout"] = 100
client.options["timeout"] = 100
client.options["write_timeout"] = 100
client.headers["Authorization"] = "Bearer #{@token}"
response = client.public_send("get", url)
@success = true if response.status == 200
@@ -71,9 +121,9 @@ class Projects::VerifyAuthTokenService < ApplicationService
url = "/api/v4/projects"
api_url= "https://gitlab.com"
client = Faraday.new(url: api_url)
client.options["open_timeout"] = 1
client.options["timeout"] = 1
client.options["write_timeout"] = 1
client.options["open_timeout"] = 100
client.options["timeout"] = 100
client.options["write_timeout"] = 100
req_params={
private_token: @token
}


Loading…
Cancel
Save