rest

package
v4.2.0-alpha1 Latest Latest
Warning

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

Go to latest
Published: Jun 4, 2024 License: Apache-2.0 Imports: 56 Imported by: 0

Documentation

Index

Constants

View Source
const (
	TransferRetryMaxAttemptsDefault = 3
	TransferRetryMaxBackoffDefault  = time.Second * 3
)
View Source
const (
	// NoKeyringMsg warns end user when no keyring is found
	NoKeyringMsg = "" /* 132-byte string literal not displayed */

)

Variables

View Source
var (
	UploadSwitchMultipart = int64(100)
	UploadDefaultPartSize = int64(50)
	UploadMaxPartsNumber  = int64(5000)

	TransferRetryMaxAttempts = TransferRetryMaxAttemptsDefault
	TransferRetryMaxBackoff  = TransferRetryMaxBackoffDefault

	UploadPartsSteps       = int64(10 * 1024 * 1024)
	UploadPartsConcurrency = 3
	UploadSkipMD5          = false
	S3RequestTimeout       = int64(-1)
)
View Source
var (
	DryRun   bool
	PoolSize = 3
)

Functions

func ApplyUpdate

func ApplyUpdate(ctx context.Context, p *UpdatePackage, dryRun bool, pgChan chan float64, doneChan chan bool, errorChan chan error)

func BuildParams

func BuildParams(source []string, targetFolder string, targetParent bool) string

func CheckKeyring

func CheckKeyring() error

CheckKeyring simply tries a write followed by a read in the local keyring and returns nothing if it works or an error otherwise.

func CleanURL

func CleanURL(input string) (string, error)

func ClearKeyring

func ClearKeyring(c *CecConfig) error

ClearKeyring removes sensitive info from the local keychain, if they are present.

func ConfigFromKeyring

func ConfigFromKeyring(ctx context.Context, conf *CecConfig) error

ConfigFromKeyring tries to find sensitive info inside local keychain and feed the conf.

func ConfigToKeyring

func ConfigToKeyring(conf *CecConfig) error

ConfigToKeyring stores sensitive information in local keyring if any and removes it from current SDK config.

func CopyParams

func CopyParams(source []string, targetFolder string) string

func DefaultConfigDirPath

func DefaultConfigDirPath() string

func DefaultConfigFilePath

func DefaultConfigFilePath() string

func GetConfigFilePath

func GetConfigFilePath() string

func IsDebugEnabled added in v4.2.0

func IsDebugEnabled() bool

func IsForbiddenError

func IsForbiddenError(err error) bool

func IsInfoEnabled added in v4.2.0

func IsInfoEnabled() bool

func MoveParams

func MoveParams(source []string, targetFolder string) string

func RandString

func RandString(n int) string

func RenameParams

func RenameParams(source []string, targetFolder string) string

func RetrieveRemoteServerVersion

func RetrieveRemoteServerVersion(sdkConfig *cellsSdk.SdkConfig) (*common.ServerVersion, error)

RetrieveRemoteServerVersion gets the version info from the distant server. User must be authenticated (and admin ?).

func RetrieveSessionLogin added in v4.1.0

func RetrieveSessionLogin(currConf *CecConfig) (string, error)

RetrieveSessionLogin tries to get the registry of the server defined by the passed configuration and parse the result to get current user login. Typically useful when using PAT auth.

func RetryCallback

func RetryCallback(callback func() error, number int, interval time.Duration) error

RetryCallback implements boilerplate code to easily call the same function until it succeeds or a time-out is reached.

func SetConfigFilePath

func SetConfigFilePath(confPath string)

func SetLogger added in v4.2.0

func SetLogger(level zapcore.Level) (logger *zap.Logger)
func StandardizeLink(sdkConfig *cellsSdk.SdkConfig, old string) string

func Unique

func Unique(length int) string

func UpdateConfig

func UpdateConfig(newConf *CecConfig) error

func UserAgent added in v4.1.0

func UserAgent() string

func ValidURL

func ValidURL(input string) error

Types

type BarsPool

type BarsPool struct {
	*uiprogress.Progress
	// contains filtered or unexported fields
}

func NewBarsPool

func NewBarsPool(showGlobal bool, totalNodes int, refreshInterval time.Duration) *BarsPool

func (*BarsPool) Done

func (b *BarsPool) Done()

func (*BarsPool) Get

func (b *BarsPool) Get(i int, total int, name string) *uiprogress.Bar

type CecConfig

type CecConfig struct {
	*cellsSdk.SdkConfig
	Label            string `json:"label"`
	SkipKeyring      bool   `json:"skipKeyring"`
	CreatedAtVersion string `json:"createdAtVersion"`
}

CecConfig extends the default SdkConfig with custom parameters.

func CloneConfig added in v4.0.1

func CloneConfig(from *CecConfig) *CecConfig

func DefaultCecConfig added in v4.1.0

func DefaultCecConfig() *CecConfig

DefaultCecConfig simply creates a new configuration struct.

type CellsConfigStore added in v4.1.0

type CellsConfigStore struct {
	// contains filtered or unexported fields
}

CellsConfigStore implements a Cells Client specific ConfigRefresher, that also securely stores credentials: It wraps a keyring if such a tool is correctly configured and can be reached by the client.

func (*CellsConfigStore) RefreshIfRequired added in v4.1.0

func (store *CellsConfigStore) RefreshIfRequired(ctx context.Context, sdkConfig *cellsSdk.SdkConfig) (bool, error)

RefreshIfRequired retrieves latest config from the store and launches a refresh if necessary.

type ConfigList

type ConfigList struct {
	ActiveConfigID string
	Configs        map[string]*CecConfig
}

func GetConfigList

func GetConfigList() (*ConfigList, error)

GetConfigList retrieves configuration stored in the config.json file.

func (*ConfigList) GetActiveConfig

func (list *ConfigList) GetActiveConfig(ctx context.Context) (*CecConfig, error)

func (*ConfigList) GetStoredConfig added in v4.1.0

func (list *ConfigList) GetStoredConfig(ctx context.Context, id string) (*CecConfig, error)

func (*ConfigList) Remove

func (list *ConfigList) Remove(id string) error

Remove unregisters a config from the list of available configurations by its ID.

func (*ConfigList) SaveConfigFile

func (list *ConfigList) SaveConfigFile() error

SaveConfigFile saves inside the config file.

func (*ConfigList) SetActiveConfig

func (list *ConfigList) SetActiveConfig(id string) error

type CrawlNode

type CrawlNode struct {
	IsLocal bool

	IsDir       bool
	FullPath    string
	RelPath     string
	MTime       time.Time
	Size        int64
	NewFileName string

	os.FileInfo
	models.TreeNode
	// contains filtered or unexported fields
}

CrawlNode enables processing the scp command step by step.

func NewCrawler

func NewCrawler(ctx context.Context, sdkClient *SdkClient, basePath string, isLocal bool) (*CrawlNode, error)

func NewLocalBaseNode added in v4.2.0

func NewLocalBaseNode(sdkClient *SdkClient, absPath string, i os.FileInfo) *CrawlNode

NewLocalBaseNode creates the base node for crawling in case of an upload.

func NewLocalNode

func NewLocalNode(sdkClient *SdkClient, absPath, relPath string, i os.FileInfo) *CrawlNode

NewLocalNode creates while crawling local tree before transfer.

func NewRemoteNode

func NewRemoteNode(sdkClient *SdkClient, t *models.TreeNode) *CrawlNode

NewRemoteNode creates the base node for crawling in case of a download.

func NewTarget

func NewTarget(sdkClient *SdkClient, target string, isLocal, isDir, merge bool) *CrawlNode

func (*CrawlNode) CreateFolders added in v4.2.0

func (c *CrawlNode) CreateFolders(_ context.Context, target *CrawlNode, dd []*CrawlNode, pool *BarsPool) error

CreateFolders prepares a recursive scp by first creating all necessary folders under the target root folder.

func (*CrawlNode) DeleteForMerge added in v4.2.0

func (c *CrawlNode) DeleteForMerge(ctx context.Context, dd []*CrawlNode, pool *BarsPool) error

DeleteForMerge first explicitly delete problematic targets before creating folders and transferring files.

func (*CrawlNode) TransferAll added in v4.2.0

func (c *CrawlNode) TransferAll(ctx context.Context, dd []*CrawlNode, pool *BarsPool) (errs []error)

TransferAll performs the real parallel transfer of files, after they have been prepared during the Walk step.

func (*CrawlNode) Walk

func (c *CrawlNode) Walk(ctx context.Context, target *CrawlNode) (
	toTransfer, toCreate, toDelete []*CrawlNode, err error)

Walk prepares the list of single upload/download nodes that we process in a second time.

type ReaderWithProgress added in v4.2.0

type ReaderWithProgress struct {
	io.Reader
	io.Seeker
	// contains filtered or unexported fields
}

func (*ReaderWithProgress) CreateErrorChan added in v4.2.0

func (r *ReaderWithProgress) CreateErrorChan() (chan error, chan struct{})

func (*ReaderWithProgress) Read added in v4.2.0

func (r *ReaderWithProgress) Read(p []byte) (n int, err error)

func (*ReaderWithProgress) Seek added in v4.2.0

func (r *ReaderWithProgress) Seek(offset int64, whence int) (int64, error)

type SdkClient added in v4.2.0

type SdkClient struct {
	// contains filtered or unexported fields
}

SdkClient wraps the APi Client and exposes convenient methods to be called by implementing layers.

func NewSdkClient added in v4.2.0

func NewSdkClient(ctx context.Context, config *CecConfig) (*SdkClient, error)

NewSdkClient creates a new client based on the given config. TODO It has the responsibility to do the token refresh procedure when needed in case of OAuth credentials.

func (*SdkClient) ConfigureS3Logger added in v4.2.0

func (client *SdkClient) ConfigureS3Logger(ctx context.Context, s3Flags string) error

ConfigureS3Logger reset the current s3 client that is hold in the SDK client, adding a logger that is configured via the passed flags.

func (*SdkClient) CopyJob added in v4.2.0

func (client *SdkClient) CopyJob(ctx context.Context, jsonParams string) (string, error)
func (client *SdkClient) CreateSimpleFolderLink(ctx context.Context, targetNodeUuid, label string) (*models.RestShareLink, error)

func (*SdkClient) DeleteNodes added in v4.2.0

func (client *SdkClient) DeleteNodes(ctx context.Context, paths []string, permanently ...bool) (jobUUIDs []string, e error)

func (*SdkClient) GetAllBulkMeta added in v4.2.0

func (client *SdkClient) GetAllBulkMeta(ctx context.Context, path string) (nodes []*models.TreeNode, err error)

func (*SdkClient) GetApiClient added in v4.2.0

func (client *SdkClient) GetApiClient() *client.PydioCellsRestAPI

GetApiClient simply exposes the Cells REST API client that is hold by the current SDKClient.

func (*SdkClient) GetBucketName added in v4.2.0

func (client *SdkClient) GetBucketName() string

GetBucketName returns the default buck name to be used with the s3 client.

func (*SdkClient) GetCecConfig added in v4.2.0

func (client *SdkClient) GetCecConfig() *CecConfig

GetCecConfig simply exposes the current CecConfig

func (*SdkClient) GetConfig added in v4.2.0

func (client *SdkClient) GetConfig() *cellsSdk.SdkConfig

GetConfig simply exposes the current SdkConfig

func (*SdkClient) GetCurrentJobStatus added in v4.2.0

func (client *SdkClient) GetCurrentJobStatus(ctx context.Context, jobID string) (status models.JobsTaskStatus, msg string, pg float32, e error)

GetCurrentJobStatus retrieves the current task status, progress and message.

func (*SdkClient) GetFile added in v4.2.0

func (client *SdkClient) GetFile(ctx context.Context, pathToFile string) (io.Reader, int, error)

GetFile retrieves a file from the server in one big download (**no** multipart download for the time being).

func (*SdkClient) GetS3Client added in v4.2.0

func (client *SdkClient) GetS3Client() *s3.Client

GetS3Client simply exposes the S3 client that is hold by the current SDKClient.

func (*SdkClient) GetStore added in v4.2.0

func (client *SdkClient) GetStore() cellsSdk.ConfigRefresher

GetStore simply exposes the store that centralize credentials (and performs OAuth refresh).

func (*SdkClient) GetTaskStatusForJob added in v4.2.0

func (client *SdkClient) GetTaskStatusForJob(ctx context.Context, jobID string) (status models.JobsTaskStatus, msg string, pg float32, e error)

GetTaskStatusForJob retrieves the task status, progress and message.

func (*SdkClient) ListNodesPath added in v4.2.0

func (client *SdkClient) ListNodesPath(ctx context.Context, path string) ([]string, error)

func (*SdkClient) MonitorJob added in v4.2.0

func (client *SdkClient) MonitorJob(ctx context.Context, jobID string) (err error)

MonitorJob monitors a job status every second.

func (*SdkClient) MoveJob added in v4.2.0

func (client *SdkClient) MoveJob(ctx context.Context, jsonParams string) (string, error)

func (*SdkClient) PutFile added in v4.2.0

func (client *SdkClient) PutFile(
	ctx context.Context,
	pathToFile string,
	content io.ReadSeeker,
	checkExists bool,
	errChan ...chan error,
) (*s3.PutObjectOutput, error)

PutFile upload a local file to the server without using multipart upload.

func (*SdkClient) RunJob added in v4.2.0

func (client *SdkClient) RunJob(ctx context.Context, jobName string, jsonParams string) (string, error)

RunJob runs a job.

func (*SdkClient) Setup added in v4.2.0

func (client *SdkClient) Setup(ctx context.Context)

Setup prepare the client after it has been created, especially refreshes the token in case of OAuth

func (*SdkClient) StatNode added in v4.2.0

func (client *SdkClient) StatNode(ctx context.Context, pathToFile string) (*models.TreeNode, bool)

func (*SdkClient) Teardown added in v4.2.0

func (client *SdkClient) Teardown()

Teardown clean resources before terminating.

type UpdatePackage

type UpdatePackage struct {
	// Name of the application
	PackageName string `json:"PackageName,omitempty"`
	// Version of this new binary
	Version string `json:"Version,omitempty"`
	// Release date of the binary
	ReleaseDate int32 `json:"ReleaseDate,omitempty"`
	// Short human-readable description
	Label string `json:"Label,omitempty"`
	// Long human-readable description (markdown)
	Description string `json:"Description,omitempty"`
	// List or public URL of change logs
	ChangeLog string `json:"ChangeLog,omitempty"`
	// License of this package
	License string `json:"License,omitempty"`
	// Https URL where to download the binary
	BinaryURL string `json:"BinaryURL,omitempty"`
	// Checksum of the binary to verify its integrity
	BinaryChecksum string `json:"BinaryChecksum,omitempty"`
	// Signature of the binary
	BinarySignature string `json:"BinarySignature,omitempty"`
	// Hash type used for the signature
	BinaryHashType string `json:"BinaryHashType,omitempty"`
	// Size of the binary to download
	// BinarySize int64 `json:"BinarySize,omitempty"`
	BinarySize string `json:"BinarySize,omitempty"`
	// GOOS value used at build time
	BinaryOS string `json:"BinaryOS,omitempty"`
	// GOARCH value used at build time
	BinaryArch string `json:"BinaryArch,omitempty"`
	// Not used : if binary is a patch
	IsPatch bool `json:"IsPatch,omitempty"`
	// Not used : if a patch, how to patch (bsdiff support)
	PatchAlgorithm string `json:"PatchAlgorithm,omitempty"`
}

func LoadUpdates

func LoadUpdates(ctx context.Context, channel string) ([]*UpdatePackage, error)

type UpdateRequest

type UpdateRequest struct {
	// Channel name.
	Channel string `json:"Channel,omitempty"`
	// PackageName is the technical name of the currently running application.
	PackageName string `json:"PackageName,omitempty"`
	// Current version of the application
	CurrentVersion string `json:"CurrentVersion,omitempty"`
	// Current GOOS
	GOOS string `json:"GOOS,omitempty"`
	// Current GOARCH
	GOARCH string `json:"GOARCH,omitempty"`
	// Not Used : specific service to get updates for
	ServiceName string `json:"ServiceName,omitempty"`
	// For enterprise version, info about the current license
	LicenseInfo map[string]string `json:"LicenseInfo,omitempty"`
}

type UpdateResponse

type UpdateResponse struct {
	Channel string `json:"Channel,omitempty"`
	// List of available binaries
	AvailableBinaries []*UpdatePackage `json:"AvailableBinaries,omitempty"`
}

Jump to

Keyboard shortcuts

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