mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-25 20:07:13 +00:00 
			
		
		
		
	 9f31f3aa8a
			
		
	
	9f31f3aa8a
	
	
	
		
			
			* Add an abstract json layout to make it's easier to change json library * Fix import * Fix import sequence * Fix blank lines * Fix blank lines
		
			
				
	
	
		
			109 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			109 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2019 The Gitea Authors. All rights reserved.
 | |
| // Use of this source code is governed by a MIT-style
 | |
| // license that can be found in the LICENSE file.
 | |
| 
 | |
| package private
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"fmt"
 | |
| 	"net/http"
 | |
| 	"net/url"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models"
 | |
| 	"code.gitea.io/gitea/modules/json"
 | |
| 	"code.gitea.io/gitea/modules/setting"
 | |
| )
 | |
| 
 | |
| // KeyAndOwner is the response from ServNoCommand
 | |
| type KeyAndOwner struct {
 | |
| 	Key   *models.PublicKey `json:"key"`
 | |
| 	Owner *models.User      `json:"user"`
 | |
| }
 | |
| 
 | |
| // ServNoCommand returns information about the provided key
 | |
| func ServNoCommand(ctx context.Context, keyID int64) (*models.PublicKey, *models.User, error) {
 | |
| 	reqURL := setting.LocalURL + fmt.Sprintf("api/internal/serv/none/%d",
 | |
| 		keyID)
 | |
| 	resp, err := newInternalRequest(ctx, reqURL, "GET").Response()
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	defer resp.Body.Close()
 | |
| 	if resp.StatusCode != http.StatusOK {
 | |
| 		return nil, nil, fmt.Errorf("%s", decodeJSONError(resp).Err)
 | |
| 	}
 | |
| 
 | |
| 	var keyAndOwner KeyAndOwner
 | |
| 	if err := json.NewDecoder(resp.Body).Decode(&keyAndOwner); err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	return keyAndOwner.Key, keyAndOwner.Owner, nil
 | |
| }
 | |
| 
 | |
| // ServCommandResults are the results of a call to the private route serv
 | |
| type ServCommandResults struct {
 | |
| 	IsWiki      bool
 | |
| 	IsDeployKey bool
 | |
| 	KeyID       int64
 | |
| 	KeyName     string
 | |
| 	UserName    string
 | |
| 	UserEmail   string
 | |
| 	UserID      int64
 | |
| 	OwnerName   string
 | |
| 	RepoName    string
 | |
| 	RepoID      int64
 | |
| }
 | |
| 
 | |
| // ErrServCommand is an error returned from ServCommmand.
 | |
| type ErrServCommand struct {
 | |
| 	Results    ServCommandResults
 | |
| 	Err        string
 | |
| 	StatusCode int
 | |
| }
 | |
| 
 | |
| func (err ErrServCommand) Error() string {
 | |
| 	return err.Err
 | |
| }
 | |
| 
 | |
| // IsErrServCommand checks if an error is a ErrServCommand.
 | |
| func IsErrServCommand(err error) bool {
 | |
| 	_, ok := err.(ErrServCommand)
 | |
| 	return ok
 | |
| }
 | |
| 
 | |
| // ServCommand preps for a serv call
 | |
| func ServCommand(ctx context.Context, keyID int64, ownerName, repoName string, mode models.AccessMode, verbs ...string) (*ServCommandResults, error) {
 | |
| 	reqURL := setting.LocalURL + fmt.Sprintf("api/internal/serv/command/%d/%s/%s?mode=%d",
 | |
| 		keyID,
 | |
| 		url.PathEscape(ownerName),
 | |
| 		url.PathEscape(repoName),
 | |
| 		mode)
 | |
| 	for _, verb := range verbs {
 | |
| 		if verb != "" {
 | |
| 			reqURL += fmt.Sprintf("&verb=%s", url.QueryEscape(verb))
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	resp, err := newInternalRequest(ctx, reqURL, "GET").Response()
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	defer resp.Body.Close()
 | |
| 
 | |
| 	if resp.StatusCode != http.StatusOK {
 | |
| 		var errServCommand ErrServCommand
 | |
| 		if err := json.NewDecoder(resp.Body).Decode(&errServCommand); err != nil {
 | |
| 			return nil, err
 | |
| 		}
 | |
| 		errServCommand.StatusCode = resp.StatusCode
 | |
| 		return nil, errServCommand
 | |
| 	}
 | |
| 	var results ServCommandResults
 | |
| 	if err := json.NewDecoder(resp.Body).Decode(&results); err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	return &results, nil
 | |
| 
 | |
| }
 |