2023-07-13 20:26:35 +02:00
|
|
|
package env_v0_3
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/go-openapi/runtime"
|
|
|
|
httptransport "github.com/go-openapi/runtime/client"
|
|
|
|
"github.com/go-openapi/strfmt"
|
|
|
|
"github.com/openziti/zrok/build"
|
|
|
|
"github.com/openziti/zrok/environment/env_core"
|
|
|
|
"github.com/openziti/zrok/rest_client_zrok"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"net/url"
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
"regexp"
|
|
|
|
)
|
|
|
|
|
|
|
|
func (r *Root) Metadata() *env_core.Metadata {
|
|
|
|
return r.meta
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Root) HasConfig() (bool, error) {
|
|
|
|
return r.cfg != nil, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Root) Config() *env_core.Config {
|
|
|
|
return r.cfg
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Root) SetConfig(cfg *env_core.Config) error {
|
2023-07-14 15:57:40 +02:00
|
|
|
if err := assertMetadata(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-07-13 20:26:35 +02:00
|
|
|
if err := saveConfig(cfg); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
r.cfg = cfg
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Root) Client() (*rest_client_zrok.Zrok, error) {
|
|
|
|
apiEndpoint, _ := r.ApiEndpoint()
|
|
|
|
apiUrl, err := url.Parse(apiEndpoint)
|
|
|
|
if err != nil {
|
|
|
|
return nil, errors.Wrapf(err, "error parsing api endpoint '%v'", r)
|
|
|
|
}
|
|
|
|
transport := httptransport.New(apiUrl.Host, "/api/v1", []string{apiUrl.Scheme})
|
|
|
|
transport.Producers["application/zrok.v1+json"] = runtime.JSONProducer()
|
|
|
|
transport.Consumers["application/zrok.v1+json"] = runtime.JSONConsumer()
|
|
|
|
|
|
|
|
zrok := rest_client_zrok.New(transport, strfmt.Default)
|
|
|
|
v, err := zrok.Metadata.Version(nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, errors.Wrapf(err, "error getting version from api endpoint '%v': %v", apiEndpoint, err)
|
|
|
|
}
|
|
|
|
// allow reported version string to be optionally prefixed with
|
|
|
|
// "refs/heads/" or "refs/tags/"
|
|
|
|
re := regexp.MustCompile(`^(refs/(heads|tags)/)?` + build.Series)
|
|
|
|
if !re.MatchString(string(v.Payload)) {
|
|
|
|
return nil, errors.Errorf("expected a '%v' version, received: '%v'", build.Series, v.Payload)
|
|
|
|
}
|
|
|
|
|
|
|
|
return zrok, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Root) ApiEndpoint() (string, string) {
|
|
|
|
apiEndpoint := "https://api.zrok.io"
|
|
|
|
from := "binary"
|
|
|
|
|
|
|
|
if r.Config() != nil && r.Config().ApiEndpoint != "" {
|
|
|
|
apiEndpoint = r.Config().ApiEndpoint
|
|
|
|
from = "config"
|
|
|
|
}
|
|
|
|
|
|
|
|
env := os.Getenv("ZROK_API_ENDPOINT")
|
|
|
|
if env != "" {
|
|
|
|
apiEndpoint = env
|
|
|
|
from = "ZROK_API_ENDPOINT"
|
|
|
|
}
|
|
|
|
|
|
|
|
if r.IsEnabled() {
|
|
|
|
apiEndpoint = r.Environment().ApiEndpoint
|
|
|
|
from = "env"
|
|
|
|
}
|
|
|
|
|
|
|
|
return apiEndpoint, from
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Root) Environment() *env_core.Environment {
|
|
|
|
return r.env
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Root) SetEnvironment(env *env_core.Environment) error {
|
2023-07-14 15:57:40 +02:00
|
|
|
if err := assertMetadata(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-07-13 20:26:35 +02:00
|
|
|
if err := saveEnvironment(env); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
r.env = env
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Root) DeleteEnvironment() error {
|
|
|
|
ef, err := environmentFile()
|
|
|
|
if err != nil {
|
|
|
|
return errors.Wrap(err, "error getting environment file")
|
|
|
|
}
|
|
|
|
if err := os.Remove(ef); err != nil {
|
|
|
|
return errors.Wrap(err, "error removing environment file")
|
|
|
|
}
|
|
|
|
r.env = nil
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Root) IsEnabled() bool {
|
|
|
|
return r.env != nil
|
|
|
|
}
|
|
|
|
|
2023-07-17 19:51:51 +02:00
|
|
|
func (r *Root) PublicIdentityName() string {
|
2023-07-14 16:14:32 +02:00
|
|
|
return "frontend"
|
|
|
|
}
|
|
|
|
|
2023-07-17 19:51:51 +02:00
|
|
|
func (r *Root) EnvironmentIdentityName() string {
|
2023-07-14 16:14:32 +02:00
|
|
|
return "backend"
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Root) ZitiIdentityNamed(name string) (string, error) {
|
2023-07-13 20:26:35 +02:00
|
|
|
return identityFile(name)
|
|
|
|
}
|
|
|
|
|
2023-07-14 16:14:32 +02:00
|
|
|
func (r *Root) SaveZitiIdentityNamed(name, data string) error {
|
2023-07-14 15:57:40 +02:00
|
|
|
if err := assertMetadata(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-07-14 16:14:32 +02:00
|
|
|
zif, err := r.ZitiIdentityNamed(name)
|
2023-07-13 20:26:35 +02:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err := os.MkdirAll(filepath.Dir(zif), os.FileMode(0700)); err != nil {
|
|
|
|
return errors.Wrapf(err, "error creating environment path '%v'", filepath.Dir(zif))
|
|
|
|
}
|
|
|
|
if err := os.WriteFile(zif, []byte(data), os.FileMode(0600)); err != nil {
|
|
|
|
return errors.Wrapf(err, "error writing ziti identity file '%v'", zif)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2023-07-14 16:14:32 +02:00
|
|
|
func (r *Root) DeleteZitiIdentityNamed(name string) error {
|
|
|
|
zif, err := r.ZitiIdentityNamed(name)
|
2023-07-13 20:26:35 +02:00
|
|
|
if err != nil {
|
|
|
|
return errors.Wrapf(err, "error getting ziti identity file path for '%v'", name)
|
|
|
|
}
|
|
|
|
if err := os.Remove(zif); err != nil {
|
|
|
|
return errors.Wrapf(err, "error removing ziti identity file '%v'", zif)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *Root) Obliterate() error {
|
|
|
|
zrd, err := rootDir()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err := os.RemoveAll(zrd); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|