startram.go 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. package startram
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "goseg/config"
  6. "goseg/structs"
  7. "io/ioutil"
  8. "log/slog"
  9. "net/http"
  10. "os"
  11. )
  12. var (
  13. logger = slog.New(slog.NewJSONHandler(os.Stdout, nil))
  14. )
  15. func GetRegions() (map[string]structs.StartramRegion, error) {
  16. var regions map[string]structs.StartramRegion
  17. config := config.Conf()
  18. regionUrl := "https://" + config.EndpointUrl + "/v1/regions"
  19. resp, err := http.Get(regionUrl)
  20. if err != nil {
  21. errmsg := fmt.Sprintf("Unable to connect to API server: %v", err)
  22. logger.Warn(errmsg)
  23. return regions, err
  24. }
  25. body, err := ioutil.ReadAll(resp.Body)
  26. resp.Body.Close()
  27. if err != nil {
  28. errmsg := fmt.Sprintf("Error reading regions info: %v", err)
  29. logger.Warn(errmsg)
  30. return regions, err
  31. }
  32. // unmarshal values into struct
  33. err = json.Unmarshal(body, &regions)
  34. if err != nil {
  35. errmsg := fmt.Sprintf("Error unmarshalling regions json: %v", err)
  36. fmt.Println(string(body))
  37. logger.Warn(errmsg)
  38. return regions, err
  39. }
  40. return regions, nil
  41. }
  42. func Retrieve() (structs.StartramRetrieve, error) {
  43. var retrieve structs.StartramRetrieve
  44. conf := config.Conf()
  45. regionUrl := "https://" + conf.EndpointUrl + "/v1/retrieve?pubkey=" + conf.Pubkey
  46. resp, err := http.Get(regionUrl)
  47. if err != nil {
  48. errmsg := fmt.Sprintf("Unable to connect to API server: %v", err)
  49. logger.Warn(errmsg)
  50. return retrieve, err
  51. }
  52. // read response body
  53. body, err := ioutil.ReadAll(resp.Body)
  54. resp.Body.Close()
  55. if err != nil {
  56. errmsg := fmt.Sprintf("Error reading retrieve info: %v", err)
  57. logger.Warn(errmsg)
  58. return retrieve, err
  59. }
  60. // unmarshal values into struct
  61. err = json.Unmarshal(body, &retrieve)
  62. if err != nil {
  63. errmsg := fmt.Sprintf("Error unmarshalling retrieve json: %v", err)
  64. fmt.Println(string(body))
  65. logger.Warn(errmsg)
  66. return retrieve, err
  67. }
  68. // pin that ho to the global vars
  69. config.StartramConfig = retrieve
  70. logger.Info(fmt.Sprintf("StarTram info retrieved: %s", string(body)))
  71. return retrieve, nil
  72. }