clients

package
v4.1.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 19, 2022 License: Apache-2.0 Imports: 13 Imported by: 3

Documentation

Overview

Package clients defines the interface for RepoClient and related structs.

Index

Constants

View Source
const HeadSHA = "HEAD"

HeadSHA is default commitSHA value used to denote git HEAD.

Variables

View Source
var ErrUnsupportedFeature = errors.New("unsupported feature")

ErrUnsupportedFeature indicates an API that is not supported by the client.

Functions

This section is empty.

Types

type BadgeLevel

type BadgeLevel uint

BadgeLevel corresponds to CII-Best-Practices badge levels. https://bestpractices.coreinfrastructure.org/en

const (
	// Unknown or non-parsable CII Best Practices badge.
	Unknown BadgeLevel = iota
	// NotFound represents when CII Best Practices returns an empty response for a project.
	NotFound
	// InProgress state of CII Best Practices badge.
	InProgress
	// Passing level for CII Best Practices badge.
	Passing
	// Silver level for CII Best Practices badge.
	Silver
	// Gold level for CII Best Practices badge.
	Gold
)

type BadgeResponse

type BadgeResponse struct {
	BadgeLevel string `json:"badge_level"`
}

BadgeResponse struct is used to read/write CII Best Practices badge data.

func ParseBadgeResponseFromJSON

func ParseBadgeResponseFromJSON(data []byte) ([]BadgeResponse, error)

ParseBadgeResponseFromJSON parses input []byte value into []BadgeResponse.

func (BadgeResponse) AsJSON

func (resp BadgeResponse) AsJSON() ([]byte, error)

AsJSON outputs BadgeResponse struct in JSON format.

type BranchProtectionRule

type BranchProtectionRule struct {
	RequiredPullRequestReviews PullRequestReviewRule
	AllowDeletions             *bool
	AllowForcePushes           *bool
	RequireLinearHistory       *bool
	EnforceAdmins              *bool
	CheckRules                 StatusChecksRule
}

BranchProtectionRule captures the settings enabled on a branch for security.

type BranchRef

type BranchRef struct {
	Name                 *string
	Protected            *bool
	BranchProtectionRule BranchProtectionRule
}

BranchRef represents a single branch reference and its protection rules.

type CIIBestPracticesClient

type CIIBestPracticesClient interface {
	GetBadgeLevel(ctx context.Context, uri string) (BadgeLevel, error)
}

CIIBestPracticesClient interface returns the BadgeLevel for a repo URL.

func BlobCIIBestPracticesClient

func BlobCIIBestPracticesClient(bucketURL string) CIIBestPracticesClient

BlobCIIBestPracticesClient returns a blob-based implementation of the interface.

func DefaultCIIBestPracticesClient

func DefaultCIIBestPracticesClient() CIIBestPracticesClient

DefaultCIIBestPracticesClient returns http-based implementation of the interface.

type CheckRun

type CheckRun struct {
	Status     string
	Conclusion string
	URL        string
	App        CheckRunApp
}

CheckRun is a single instance of a VCS CheckRun.

type CheckRunApp

type CheckRunApp struct {
	Slug string
}

CheckRunApp is the app running the Check.

type Commit

type Commit struct {
	CommittedDate          time.Time
	Message                string
	SHA                    string
	Committer              User
	AssociatedMergeRequest PullRequest
}

Commit represents a Git commit.

type Contributor

type Contributor struct {
	Company          string
	User             User
	Organizations    []User
	NumContributions int
}

Contributor represents a contributor to a repo.

type Issue

type Issue struct {
	URI               *string
	CreatedAt         *time.Time
	AuthorAssociation *RepoAssociation
	Comments          []IssueComment
}

Issue represents a thread like GitHub issue comment thread.

type IssueComment added in v4.1.0

type IssueComment struct {
	CreatedAt         *time.Time
	AuthorAssociation *RepoAssociation
}

IssueComment represents a comment on an issue.

type Label

type Label struct {
	Name string
}

Label represents a PR label.

type PullRequest

type PullRequest struct {
	Number   int
	MergedAt time.Time
	HeadSHA  string
	Author   User
	Labels   []Label
	Reviews  []Review
}

PullRequest struct represents a PR as returned by RepoClient. nolint: govet

type PullRequestReviewRule

type PullRequestReviewRule struct {
	RequiredApprovingReviewCount *int32
	DismissStaleReviews          *bool
	RequireCodeOwnerReviews      *bool
}

PullRequestReviewRule captures settings on a PullRequest.

type Release

type Release struct {
	TagName         string
	URL             string
	TargetCommitish string
	Assets          []ReleaseAsset
}

Release represents a release version of a package/repo.

type ReleaseAsset

type ReleaseAsset struct {
	Name string
	URL  string
}

ReleaseAsset is part of the Release bundle.

type Repo

type Repo interface {
	URI() string
	String() string
	Org() Repo
	IsValid() error
	Metadata() []string
	AppendMetadata(metadata ...string)
}

Repo interface uniquely identifies a repo.

type RepoAssociation added in v4.1.0

type RepoAssociation int32

RepoAssociation is how a user is associated with a repository.

const (
	// Collaborator: Author has been invited to collaborate on the repository.
	RepoAssociationCollaborator RepoAssociation = iota
	// Contributor: Author has been a contributor to the repository.
	RepoAssociationContributor
	// FirstTimer: Author has previously committed to the repository.
	RepoAssociationFirstTimer
	// FirstTimeContributor: Author has not previously committed to the repository.
	RepoAssociationFirstTimeContributor
	// Mannequin: Author is a placeholder for an unclaimed user.
	RepoAssociationMannequin
	// Member: Author is a member of the organization that owns the repository.
	RepoAssociationMember
	// None: Author has no association with the repository.
	RepoAssociationNone
	// Owner: Author is the owner of the repository.
	RepoAssociationOwner
)

Values taken from https://docs.github.com/en/graphql/reference/enums#commentauthorassociation. Additional values may be added in the future for non-Github projects.

type RepoClient

type RepoClient interface {
	InitRepo(repo Repo, commitSHA string) error
	URI() string
	IsArchived() (bool, error)
	ListFiles(predicate func(string) (bool, error)) ([]string, error)
	GetFileContent(filename string) ([]byte, error)
	ListBranches() ([]*BranchRef, error)
	GetDefaultBranch() (*BranchRef, error)
	ListCommits() ([]Commit, error)
	ListIssues() ([]Issue, error)
	ListReleases() ([]Release, error)
	ListContributors() ([]Contributor, error)
	ListSuccessfulWorkflowRuns(filename string) ([]WorkflowRun, error)
	ListCheckRunsForRef(ref string) ([]CheckRun, error)
	ListStatuses(ref string) ([]Status, error)
	Search(request SearchRequest) (SearchResponse, error)
	Close() error
}

RepoClient interface is used by Scorecard checks to access a repo.

type Review

type Review struct {
	Author *User
	State  string
}

Review represents a PR review.

type SearchRequest

type SearchRequest struct {
	Query    string
	Filename string
	Path     string
}

SearchRequest queries a repo for `Query`. If `Filename` is provided, only matching filenames are queried. If `Path` is provided, only files with matching paths are queried.

type SearchResponse

type SearchResponse struct {
	Results []SearchResult
	Hits    int
}

SearchResponse returns the results from a search request on a repo.

type SearchResult

type SearchResult struct {
	Path string
}

SearchResult represents a matching result from the search query.

type Status

type Status struct {
	State     string
	Context   string
	URL       string
	TargetURL string
}

Status for a Git object/ref.

type StatusChecksRule

type StatusChecksRule struct {
	UpToDateBeforeMerge  *bool
	RequiresStatusChecks *bool
	Contexts             []string
}

StatusChecksRule captures settings on status checks.

type User

type User struct {
	Login string
}

User represents a Git user.

type VulnerabilitiesClient

type VulnerabilitiesClient interface {
	HasUnfixedVulnerabilities(context context.Context, commit string) (VulnerabilitiesResponse, error)
}

VulnerabilitiesClient cheks for vulnerabilities in api.osv.dev.

func DefaultVulnerabilitiesClient

func DefaultVulnerabilitiesClient() VulnerabilitiesClient

DefaultVulnerabilitiesClient is a new Vulnerabilities client.

type VulnerabilitiesResponse

type VulnerabilitiesResponse struct {
	Vulns []struct {
		ID string `json:"id"`
	} `json:"vulns"`
}

VulnerabilitiesResponse is the response from the OSV API.

type WorkflowRun

type WorkflowRun struct {
	URL string
}

WorkflowRun represents VCS WorkflowRun.

Directories

Path Synopsis
Package githubrepo implements clients.RepoClient for GitHub.
Package githubrepo implements clients.RepoClient for GitHub.
roundtripper
Package roundtripper has implementations of http.RoundTripper useful to clients.RepoClient.
Package roundtripper has implementations of http.RoundTripper useful to clients.RepoClient.
roundtripper/tokens
Package tokens defines interface to access GitHub PATs.
Package tokens defines interface to access GitHub PATs.
roundtripper/tokens/server
Package main implements the GitHub token server.
Package main implements the GitHub token server.
Package localdir implements RepoClient on local source code.
Package localdir implements RepoClient on local source code.
Package mockrepo is a generated GoMock package.
Package mockrepo is a generated GoMock package.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL