Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
var ErrAuthDialFailed = errors.New("dial to auth service failed")
ErrAuthDialFailed is a network or protocol error.
var ErrRegisterAccessFailed = errors.New("register access for edge services failed")
ErrRegisterAccessFailed is an internal error in the auth service.
Functions ¶
func JoinShareURL ¶
func JoinShareURL(baseURL string, accessKeyID string, bucket string, key string, options *ShareURLOptions) (string, error)
JoinShareURL creates a linksharing URL from parts. The existence or accessibility of the target is not checked, it might not exist or be inaccessible.
Example result is https://link.storjshare.io/s/l5pucy3dmvzxgs3fpfewix27l5pq/mybucket/myprefix/myobject
The baseURL is the url of the linksharing service, e.g. https://link.storjshare.io. The accessKeyID can be obtained by calling RegisterAccess. It must be associated with public visibility. The bucket is optional, leave it blank to share the entire project. The object key is also optional, if empty shares the entire bucket. It can also be a prefix, in which case it must end with a "/".
Types ¶
type Config ¶
type Config struct { // AuthServiceAddress sets a fixed DRPC server including port. // Valid is auth.storjshare.io:7777 or a third party hosted alternative. AuthServiceAddress string // CertificatePEM contains the root certificate(s) or chain(s) against which // Uplink checks the auth service. // In PEM format. // Intended to test against a self-hosted auth service or to improve security. CertificatePEM []byte // InsecureSkipVerify makes possible to connect to Authservice without TLS. Don't use in production. // // Deprecated: Use InsecureUnencryptedConnection instead. InsecureSkipVerify bool // InsecureUnencryptedConnection makes possible to connect to Authservice without TLS, // sending plaintext requests over the network and receiving plaintext responses. // Don't use in production. InsecureUnencryptedConnection bool }
Config contains configuration on how to access edge services.
func (*Config) RegisterAccess ¶
func (config *Config) RegisterAccess( ctx context.Context, access *uplink.Access, options *RegisterAccessOptions, ) (*Credentials, error)
RegisterAccess gets credentials for the Storj-hosted Gateway and linkshare service. All files accessible under the Access are then also accessible via those services. If you call this function a lot, and the use case allows it, please limit the lifetime of the credentials by setting Permission.NotAfter when creating the Access.
type Credentials ¶
type Credentials struct { // Base32 // This is also used in the linkshare url path. AccessKeyID string // Base32 SecretKey string // HTTP(S) URL to the gateway. Endpoint string }
Credentials give access to the multi-tenant gateway. These work in S3 clients.
type RegisterAccessOptions ¶
type RegisterAccessOptions struct { // Whether objects can be read without authentication. Public bool }
RegisterAccessOptions contains optional parameters for RegisterAccess.
type ShareURLOptions ¶
type ShareURLOptions struct { // This URL can then be passed to a download command or embedded on a webpage. Raw bool }
ShareURLOptions contains options how to present the data data exposed through Linksharing.