* util/tar: add archive util funcs * runtime: add store, builder options * runtime/local: update RuntimeSource func * runtime/builder/golang: use tar util * store/s3: make keys safe * runtime: add entrypoint options * runtime/builder: remove debugging * wip: integrate builder into k8s runtime * runtime/builder/golang: build for a linux architecture * runtime/kubernetes: write builds to the users namespace * runtime/local/source: fixes for mono-repo builds * runtime/local: stop checking out source (the responsibility is on the client) * runtime/builder: fix golang tests * runtime/local: fix out of bounds panic * Update * revert changes * runtime/local/source: refactor git package (wip) * runtime/kubernetes: map err not found * fix TestRunGenericRemote test * runtime/local: fix update not reassining source * Tidy go mod * runtime.Pending => runtime.Starting * store/s3: only use credentials option when set * store/s3: add tls config option
		
			
				
	
	
		
			53 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package s3
 | |
| 
 | |
| import "crypto/tls"
 | |
| 
 | |
| // Options used to configure the s3 blob store
 | |
| type Options struct {
 | |
| 	Endpoint        string
 | |
| 	Region          string
 | |
| 	AccessKeyID     string
 | |
| 	SecretAccessKey string
 | |
| 	Secure          bool
 | |
| 	TLSConfig       *tls.Config
 | |
| }
 | |
| 
 | |
| // Option configures one or more options
 | |
| type Option func(o *Options)
 | |
| 
 | |
| // Endpoint sets the endpoint option
 | |
| func Endpoint(e string) Option {
 | |
| 	return func(o *Options) {
 | |
| 		o.Endpoint = e
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // Region sets the region option
 | |
| func Region(r string) Option {
 | |
| 	return func(o *Options) {
 | |
| 		o.Region = r
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // Credentials sets the AccessKeyID and SecretAccessKey options
 | |
| func Credentials(id, secret string) Option {
 | |
| 	return func(o *Options) {
 | |
| 		o.AccessKeyID = id
 | |
| 		o.SecretAccessKey = secret
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // Insecure sets the secure option to false. It is enabled by default.
 | |
| func Insecure() Option {
 | |
| 	return func(o *Options) {
 | |
| 		o.Secure = false
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // TLSConfig sets the tls config for the client
 | |
| func TLSConfig(c *tls.Config) Option {
 | |
| 	return func(o *Options) {
 | |
| 		o.TLSConfig = c
 | |
| 	}
 | |
| }
 |