 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Index ¶
- Constants
- Variables
- func DigestEqual(a Digest, b Digest) bool
- type Commit
- type Digest
- type DigestMismatchError
- type DigestType
- type Plugin
- type PluginData
- type PluginDataProvider
- type PluginKey
- type PluginKeyProvider
- type PluginType
- type PluginVisibility
- type UploadOption
- type UploadOptions
- type Uploader
Constants ¶
const ( // PluginVisibilityPublic says the Plugin is public on the registry. PluginVisibilityPublic = iota + 1 // PluginVisibilityPrivate says the Plugin is private on the registry. PluginVisibilityPrivate )
const ( // PluginTypeCheck says the Plugin is a check plugin. PluginTypeCheck = iota + 1 )
Variables ¶
var ( // AllDigestTypes are all known DigestTypes. AllDigestTypes = []DigestType{ DigestTypeP1, } )
var ( // AllPluginTypeStrings is all format strings without aliases. // // Sorted in the order we want to display them. AllPluginTypeStrings = []string{ "check", } )
Functions ¶
func DigestEqual ¶ added in v1.47.0
DigestEqual returns true if the given Digests are considered equal.
If both Digests are nil, this returns true.
This checks both the DigestType and Digest value.
Types ¶
type Commit ¶ added in v1.47.0
type Commit interface {
	// PluginKey returns the PluginKey for the Commit.
	PluginKey() PluginKey
	// CreateTime returns the time the Commit was created on the BSR.
	CreateTime() (time.Time, error)
	// contains filtered or unexported methods
}
    Commit represents a Commit for a Plugin on the BSR.
type Digest ¶ added in v1.47.0
type Digest interface {
	// String() prints typeString:hexValue.
	fmt.Stringer
	// Type returns the type of digest.
	//
	// Always a valid value.
	Type() DigestType
	// Value returns the digest value.
	//
	// Always non-empty.
	Value() []byte
	// contains filtered or unexported methods
}
    Digest is a digest of some content.
It consists of a DigestType and a digest value.
func NewDigest ¶ added in v1.47.0
func NewDigest(digestType DigestType, bufcasDigest bufcas.Digest) (Digest, error)
NewDigest creates a new Digest.
func ParseDigest ¶ added in v1.47.0
ParseDigest parses a Digest from its string representation.
A Digest string is of the form typeString:hexValue. The string is expected to be non-empty, If not, an error is returned.
This reverses Digest.String().
Returns an error of type *bufparse.ParseError if the string could not be parsed.
type DigestMismatchError ¶ added in v1.47.0
type DigestMismatchError struct {
	FullName       bufparse.FullName
	CommitID       uuid.UUID
	ExpectedDigest Digest
	ActualDigest   Digest
}
    DigestMismatchError is the error returned if the Digest of a downloaded Plugin or Commit does not match the expected digest in a buf.lock file.
func (*DigestMismatchError) Error ¶ added in v1.47.0
func (m *DigestMismatchError) Error() string
Error implements the error interface.
type DigestType ¶ added in v1.47.0
type DigestType int
DigestType is a type of digest.
const ( // DigestTypeP1 represents the p1 plugin digest type. // // The string value of this is "p1". DigestTypeP1 DigestType = iota + 1 )
func ParseDigestType ¶ added in v1.47.0
func ParseDigestType(s string) (DigestType, error)
ParseDigestType parses a DigestType from its string representation.
This reverses DigestType.String().
Returns an error of type *bufparse.ParseError if the string could not be parsed.
func UniqueDigestTypeForPluginKeys ¶ added in v1.48.0
func UniqueDigestTypeForPluginKeys(pluginKeys []PluginKey) (DigestType, error)
UniqueDigestTypeForPluginKeys returns the unique DigestType for the given PluginKeys.
If the PluginKeys have different DigestTypes, an error is returned. If the PluginKeys slice is empty, an error is returned.
func (DigestType) String ¶ added in v1.47.0
func (d DigestType) String() string
String prints the string representation of the DigestType.
type Plugin ¶ added in v1.7.0
type Plugin interface {
	// OpaqueID returns an unstructured ID that can uniquely identify a Plugin
	// relative to the Workspace.
	//
	// An OpaqueID's structure should not be relied upon, and is not a
	// globally-unique identifier. It's uniqueness property only applies to
	// the lifetime of the Plugin, and only within the Workspace the Plugin
	// is defined in.
	//
	// If two Plugins have the same Name and Args, they will have the same OpaqueID.
	OpaqueID() string
	// Name returns the name of the Plugin.
	//  - For local Plugins, this is the path to the executable binary.
	//  - For local Wasm Plugins, this is the path to the Wasm binary.
	//  - For remote Plugins, this is the FullName of the Plugin in the form
	//    remote/owner/name.
	//
	// This is never empty.
	Name() string
	// Args returns the arguments to invoke the Plugin.
	//
	// May be nil.
	Args() []string
	// FullName returns the full name of the Plugin.
	//
	// May be nil. Callers should not rely on this value being present.
	// However, this is always present for remote Plugins.
	//
	// Use OpaqueID as an always-present identifier.
	FullName() bufparse.FullName
	// CommitID returns the BSR ID of the Commit.
	//
	// It is up to the caller to convert this to a dashless ID when necessary.
	//
	// May be empty, that is CommitID() == uuid.Nil may be true.
	// Callers should not rely on this value being present.
	//
	// If FullName is nil, this will always be empty.
	CommitID() uuid.UUID
	// Description returns a human-readable description of the Plugin.
	//
	// This is used to construct descriptive error messages pointing to configured plugins.
	//
	// This will never be empty. If a description was not explicitly set, this falls back to
	// OpaqueID.
	Description() string
	// Digest returns the Plugin digest for the given DigestType.
	//
	// Note this is *not* a bufcas.Digest - this is a Digest.
	// bufcas.Digests are a lower-level type that just deal in terms of
	// files and content. A Digest is a specific algorithm applied to the
	// content of a Plugin.
	//
	// Will return an error if the Plugin is not a Wasm Plugin.
	Digest(DigestType) (Digest, error)
	// Data returns the bytes of the Plugin as a Wasm module.
	//
	// This is the raw bytes of the Wasm module in an uncompressed form.
	//
	// Will return an error if the Plugin is not a Wasm Plugin.
	Data() ([]byte, error)
	// IsWasm returns true if the Plugin is a Wasm Plugin.
	//
	// Plugins are either Wasm or local.
	//
	// A Wasm Plugin is a Plugin that is a Wasm module. Wasm Plugins are invoked
	// with the wasm.Runtime. The Plugin will have Data and will be able to
	// calculate Digests.
	//
	// Wasm Plugins will always have Data.
	IsWasm() bool
	// IsLocal returns true if the Plugin is a local Plugin.
	//
	// Plugins are either local or remote.
	//
	// A local Plugin is one that is built from sources from the "local context",
	// such as a Workspace. Local Plugins are important for understanding what Plugins
	// to push.
	//
	// Remote Plugins will always have FullNames.
	IsLocal() bool
	// contains filtered or unexported methods
}
    Plugin presents a BSR plugin.
func NewLocalPlugin ¶ added in v1.53.0
NewLocalPlugin returns a new Plugin for a local plugin.
The name is the path to the executable binary. The args are the arguments to invoke the Plugin. These are passed to the Plugin as command line arguments.
func NewLocalWasmPlugin ¶ added in v1.48.0
func NewLocalWasmPlugin( pluginFullName bufparse.FullName, name string, args []string, getData func() ([]byte, error), ) (Plugin, error)
NewLocalWasmPlugin returns a new Plugin for a local Wasm plugin.
The pluginFullName may be nil. The name is the path to the Wasm plugin and must end with .wasm. The args are the arguments to the Wasm plugin. These are passed to the Wasm plugin as command line arguments. The getData function is called to get the bytes of the Wasm plugin. This is the raw bytes of the Wasm module in an uncompressed form.
func NewRemoteWasmPlugin ¶ added in v1.53.0
func NewRemoteWasmPlugin( pluginFullName bufparse.FullName, args []string, commitID uuid.UUID, getData func() ([]byte, error), ) (Plugin, error)
NewRemoteWasmPlugin returns a new Plugin for a remote Wasm plugin.
The pluginFullName is the remote reference to the plugin. The args are the arguments to the remote plugin. These are passed to the remote plugin as command line arguments. The commitID is the BSR ID of the Commit. It is up to the caller to convert this to a dashless ID when necessary. The getData function is called to get the bytes of the Wasm plugin. This is the raw bytes of the Wasm module in an uncompressed form.
type PluginData ¶ added in v1.47.0
type PluginData interface {
	// PluginKey used to download this PluginData.
	//
	// The Digest from this PluginKey is used for tamper-proofing. It will be checked
	// against the actual data downloaded before Data() returns.
	PluginKey() PluginKey
	// Data returns the bytes of the Plugin as a Wasm module.
	//
	// This is the raw bytes of the Wasm module in an uncompressed form.
	Data() ([]byte, error)
	// contains filtered or unexported methods
}
    PluginData presents the raw Plugin data read by PluginKey.
A PluginData generally represents the data on a Plugin read from the BSR API or a cache.
Tamper-proofing is done as part of every function.
func NewPluginData ¶ added in v1.47.0
func NewPluginData( ctx context.Context, pluginKey PluginKey, getData func() ([]byte, error), ) (PluginData, error)
NewPluginData returns a new PluginData.
getData is expected to be lazily-loaded function where possible.
type PluginDataProvider ¶ added in v1.47.0
type PluginDataProvider interface {
	// GetPluginDatasForPluginKeys gets the PluginDatas for the PluginKeys.
	//
	// Returned PluginDatas will be in the same order as the input PluginKeys.
	//
	// The input PluginKeys are expected to be unique by FullName. The implementation
	// may error if this is not the case.
	//
	// The input PluginKeys are expected to have the same DigestType. The implementation
	// may error if this is not the case.
	//
	// If there is no error, the length of the PluginDatas returned will match the length of the PluginKeys.
	// If there is an error, no PluginDatas will be returned.
	// If any PluginKey is not found, an error with fs.ErrNotExist will be returned.
	GetPluginDatasForPluginKeys(
		context.Context,
		[]PluginKey,
	) ([]PluginData, error)
}
    PluginDataProvider provides PluginDatas.
var ( // NopPluginDataProvider is a no-op PluginDataProvider. NopPluginDataProvider PluginDataProvider = nopPluginDataProvider{} )
type PluginKey ¶ added in v1.47.0
type PluginKey interface {
	// String returns "registry/owner/name:dashlessCommitID".
	fmt.Stringer
	// FullName returns the full name of the Plugin.
	//
	// Always present.
	FullName() bufparse.FullName
	// CommitID returns the ID of the Commit.
	//
	// It is up to the caller to convert this to a dashless ID when necessary.
	//
	// Always present, that is CommitID() == uuid.Nil will always be false.
	CommitID() uuid.UUID
	// Digest returns the Plugin digest.
	//
	// Note this is *not* a bufcas.Digest - this is a Digest.
	// bufcas.Digests are a lower-level type that just deal in terms of
	// files and content. A PluginDigest is a specific algorithm applied to
	// the Plugin data.
	Digest() (Digest, error)
	// contains filtered or unexported methods
}
    PluginKey provides identifying information for a Plugin.
PluginKeys are returned from PluginKeyProviders, and represent a Plugin's complete identity. They also match to what we store in buf.lock files. PluginKeys can be used to get Plugins via a PluginProvider.
func NewPluginKey ¶ added in v1.47.0
func NewPluginKey( pluginFullName bufparse.FullName, commitID uuid.UUID, getDigest func() (Digest, error), ) (PluginKey, error)
NewPluginKey returns a new PluginKey.
The Digest will be loaded lazily if needed. Note this means that NewPluginKey does *not* validate the digest. If you need to validate the digest, call Digest() and evaluate the returned error.
type PluginKeyProvider ¶ added in v1.47.0
type PluginKeyProvider interface {
	// GetPluginKeysForPluginRefs gets the PluginKeys for the given PluginRefs.
	//
	// Returned PluginKeys will be in the same order as the input PluginRefs.
	//
	// The input PluginRefs are expected to be unique by FullName. The implementation
	// may error if this is not the case.
	//
	// If there is no error, the length of the PluginKeys returned will match the length of the Refs.
	// If there is an error, no PluginKeys will be returned.
	// If any PluginRef is not found, an error with fs.ErrNotExist will be returned.
	GetPluginKeysForPluginRefs(context.Context, []bufparse.Ref, DigestType) ([]PluginKey, error)
}
    PluginKeyProvider provides PluginKeys for bufparse.Refs.
var ( // NopPluginKeyProvider is a no-op PluginKeyProvider. NopPluginKeyProvider PluginKeyProvider = nopPluginKeyProvider{} )
func NewStaticPluginKeyProvider ¶ added in v1.48.0
func NewStaticPluginKeyProvider(pluginKeys []PluginKey) (PluginKeyProvider, error)
NewStaticPluginKeyProvider returns a new PluginKeyProvider for a static set of PluginKeys.
The set of PluginKeys must be unique by FullName. If there are duplicates, an error will be returned.
When resolving Refs, the Ref will be matched to the PluginKey by FullName. If the Ref is not found in the set of provided keys, an fs.ErrNotExist will be returned.
type PluginType ¶ added in v1.48.0
type PluginType int
PluginType is the type of a Plugin.
func ParsePluginType ¶ added in v1.48.0
func ParsePluginType(s string) (PluginType, error)
ParsePluginType parses the PluginType from the string.
type PluginVisibility ¶ added in v1.48.0
type PluginVisibility int
PluginVisibility is the visibility of a Plugin on a registry.
Only used for Upload for now.
func ParsePluginVisibility ¶ added in v1.48.0
func ParsePluginVisibility(s string) (PluginVisibility, error)
ParsePluginVisibility parses the PluginVisibility from the string.
type UploadOption ¶ added in v1.48.0
type UploadOption func(*uploadOptions)
UploadOption is an option for an Upload.
func UploadWithCreateIfNotExist ¶ added in v1.48.0
func UploadWithCreateIfNotExist(createPluginVisibility PluginVisibility, createPluginType PluginType) UploadOption
UploadWithCreateIfNotExist returns a new UploadOption that will result in the Plugins being created on the registry with the given visibility if they do not exist.
func UploadWithLabels ¶ added in v1.48.0
func UploadWithLabels(labels ...string) UploadOption
UploadWithLabels returns a new UploadOption that adds the given labels.
This can be called multiple times. The unique result set of labels will be used.
func UploadWithSourceControlURL ¶ added in v1.48.0
func UploadWithSourceControlURL(sourceControlURL string) UploadOption
UploadWithSourceControlURL returns a new UploadOption that will set the source control url for the plugin contents uploaded.
type UploadOptions ¶ added in v1.48.0
type UploadOptions interface {
	// Labels returns the unique and sorted set of labels to add. Labels
	// are set using the `--label` flag when calling `buf plugin upload`
	// and represent the labels that are set when uploading plugin data.
	Labels() []string
	// CreateIfNotExist says to create Plugins if they do not exist on the registry.
	CreateIfNotExist() bool
	// CreatePluginVisibility returns the visibility to create Plugins with.
	//
	// Will always be present if CreateIfNotExist() is true.
	CreatePluginVisibility() PluginVisibility
	// CreatePluginType returns the type to create Plugins with.
	//
	// Will always be present if CreateIfNotExist() is true.
	CreatePluginType() PluginType
	// SourceControlURL returns the source control URL set by the user for the plugin
	// contents uploaded. We set the same source control URL for all plugin contents.
	SourceControlURL() string
	// contains filtered or unexported methods
}
    UploadOptions are the possible options for upload.
This is used by Uploader implementations.
func NewUploadOptions ¶ added in v1.48.0
func NewUploadOptions(options []UploadOption) (UploadOptions, error)
NewUploadOptions returns a new UploadOptions.