mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 08:58:24 +00:00 
			
		
		
		
	Move serv hook functionality & drop GitLogger (#6993)
* Move hook functionality internally * Internalise serv logic * Remove old internal paths * finally remove the gitlogger * Disallow push on archived repositories * fix lint error * Update modules/private/key.go * Update routers/private/hook.go * Update routers/private/hook.go * Update routers/private/hook.go * Updated routers/private/serv.go * Fix LFS Locks over SSH * rev-list needs to be run by the hook process * fixup * Improve git test * Ensure that the lfs files are created with a different prefix * Reduce the replication in git_test.go * slight refactor * Remove unnecessary "/" * Restore ensureAnonymousClone * Restore ensureAnonymousClone * Run rev-list on server side * Try passing in the alternative directories instead * Mark test as skipped * Improve git test * Ensure that the lfs files are created with a different prefix * Reduce the replication in git_test.go * Remove unnecessary "/"
This commit is contained in:
		| @@ -5,127 +5,15 @@ | ||||
| package private | ||||
|  | ||||
| import ( | ||||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
|  | ||||
| 	"code.gitea.io/gitea/models" | ||||
| 	"code.gitea.io/gitea/modules/log" | ||||
| 	"code.gitea.io/gitea/modules/setting" | ||||
| ) | ||||
|  | ||||
| // UpdateDeployKeyUpdated update deploy key updates | ||||
| func UpdateDeployKeyUpdated(keyID int64, repoID int64) error { | ||||
| 	reqURL := setting.LocalURL + fmt.Sprintf("api/internal/repositories/%d/keys/%d/update", repoID, keyID) | ||||
| 	log.GitLogger.Trace("UpdateDeployKeyUpdated: %s", reqURL) | ||||
|  | ||||
| 	resp, err := newInternalRequest(reqURL, "POST").Response() | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	defer resp.Body.Close() | ||||
|  | ||||
| 	// All 2XX status codes are accepted and others will return an error | ||||
| 	if resp.StatusCode/100 != 2 { | ||||
| 		return fmt.Errorf("Failed to update deploy key: %s", decodeJSONError(resp).Err) | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // GetDeployKey check if repo has deploy key | ||||
| func GetDeployKey(keyID, repoID int64) (*models.DeployKey, error) { | ||||
| 	reqURL := setting.LocalURL + fmt.Sprintf("api/internal/repositories/%d/keys/%d", repoID, keyID) | ||||
| 	log.GitLogger.Trace("GetDeployKey: %s", reqURL) | ||||
|  | ||||
| 	resp, err := newInternalRequest(reqURL, "GET").Response() | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	defer resp.Body.Close() | ||||
|  | ||||
| 	switch resp.StatusCode { | ||||
| 	case 404: | ||||
| 		return nil, nil | ||||
| 	case 200: | ||||
| 		var dKey models.DeployKey | ||||
| 		if err := json.NewDecoder(resp.Body).Decode(&dKey); err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		return &dKey, nil | ||||
| 	default: | ||||
| 		return nil, fmt.Errorf("Failed to get deploy key: %s", decodeJSONError(resp).Err) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // HasDeployKey check if repo has deploy key | ||||
| func HasDeployKey(keyID, repoID int64) (bool, error) { | ||||
| 	reqURL := setting.LocalURL + fmt.Sprintf("api/internal/repositories/%d/has-keys/%d", repoID, keyID) | ||||
| 	log.GitLogger.Trace("HasDeployKey: %s", reqURL) | ||||
|  | ||||
| 	resp, err := newInternalRequest(reqURL, "GET").Response() | ||||
| 	if err != nil { | ||||
| 		return false, err | ||||
| 	} | ||||
| 	defer resp.Body.Close() | ||||
|  | ||||
| 	if resp.StatusCode == 200 { | ||||
| 		return true, nil | ||||
| 	} | ||||
| 	return false, nil | ||||
| } | ||||
|  | ||||
| // GetPublicKeyByID  get public ssh key by his ID | ||||
| func GetPublicKeyByID(keyID int64) (*models.PublicKey, error) { | ||||
| 	reqURL := setting.LocalURL + fmt.Sprintf("api/internal/ssh/%d", keyID) | ||||
| 	log.GitLogger.Trace("GetPublicKeyByID: %s", reqURL) | ||||
|  | ||||
| 	resp, err := newInternalRequest(reqURL, "GET").Response() | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	defer resp.Body.Close() | ||||
|  | ||||
| 	if resp.StatusCode != 200 { | ||||
| 		return nil, fmt.Errorf("Failed to get repository: %s", decodeJSONError(resp).Err) | ||||
| 	} | ||||
|  | ||||
| 	var pKey models.PublicKey | ||||
| 	if err := json.NewDecoder(resp.Body).Decode(&pKey); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return &pKey, nil | ||||
| } | ||||
|  | ||||
| // GetUserByKeyID get user attached to key | ||||
| func GetUserByKeyID(keyID int64) (*models.User, error) { | ||||
| 	reqURL := setting.LocalURL + fmt.Sprintf("api/internal/ssh/%d/user", keyID) | ||||
| 	log.GitLogger.Trace("GetUserByKeyID: %s", reqURL) | ||||
|  | ||||
| 	resp, err := newInternalRequest(reqURL, "GET").Response() | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	defer resp.Body.Close() | ||||
|  | ||||
| 	if resp.StatusCode != 200 { | ||||
| 		return nil, fmt.Errorf("Failed to get user: %s", decodeJSONError(resp).Err) | ||||
| 	} | ||||
|  | ||||
| 	var user models.User | ||||
| 	if err := json.NewDecoder(resp.Body).Decode(&user); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	return &user, nil | ||||
| } | ||||
|  | ||||
| // UpdatePublicKeyUpdated update public key updates | ||||
| func UpdatePublicKeyUpdated(keyID int64) error { | ||||
| // UpdatePublicKeyInRepo update public key and if necessary deploy key updates | ||||
| func UpdatePublicKeyInRepo(keyID, repoID int64) error { | ||||
| 	// Ask for running deliver hook and test pull request tasks. | ||||
| 	reqURL := setting.LocalURL + fmt.Sprintf("api/internal/ssh/%d/update", keyID) | ||||
| 	log.GitLogger.Trace("UpdatePublicKeyUpdated: %s", reqURL) | ||||
|  | ||||
| 	reqURL := setting.LocalURL + fmt.Sprintf("api/internal/ssh/%d/update/%d", keyID, repoID) | ||||
| 	resp, err := newInternalRequest(reqURL, "POST").Response() | ||||
| 	if err != nil { | ||||
| 		return err | ||||
|   | ||||
		Reference in New Issue
	
	Block a user