mirror of
https://github.com/nestriness/nestri.git
synced 2025-12-12 16:55:37 +02:00
This adds a simple way to incorporate a centralized authentication flow. The idea is to have the user, API and SSH (for machine authentication) all in one place using `openauthjs` + `SST` We also have a database now :) > We are using InstantDB as it allows us to authenticate a use with just the email. Plus it is super simple simple to use _of course after the initial fumbles trying to design the db and relationships_
39 lines
733 B
Go
39 lines
733 B
Go
package resource
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
"os"
|
|
"reflect"
|
|
)
|
|
|
|
type resource struct {
|
|
Api struct {
|
|
Url string `json:"url"`
|
|
}
|
|
Auth struct {
|
|
Url string `json:"url"`
|
|
}
|
|
AuthFingerprintKey struct {
|
|
Value string `json:"value"`
|
|
}
|
|
}
|
|
|
|
var Resource resource
|
|
|
|
func init() {
|
|
val := reflect.ValueOf(&Resource).Elem()
|
|
for i := 0; i < val.NumField(); i++ {
|
|
field := val.Field(i)
|
|
typeField := val.Type().Field(i)
|
|
envVarName := fmt.Sprintf("SST_RESOURCE_%s", typeField.Name)
|
|
envValue, exists := os.LookupEnv(envVarName)
|
|
if !exists {
|
|
panic(fmt.Sprintf("Environment variable %s is required", envVarName))
|
|
}
|
|
if err := json.Unmarshal([]byte(envValue), field.Addr().Interface()); err != nil {
|
|
panic(err)
|
|
}
|
|
}
|
|
}
|