Add sync server to status -v #176 so that self-hosted users can easily confirm they're using the self-hosted server

This commit is contained in:
David Dworken 2024-02-11 11:53:50 -08:00
parent e91eeb1f04
commit 703e8184ac
No known key found for this signature in database
2 changed files with 16 additions and 11 deletions

View File

@ -33,6 +33,9 @@ func printOnlineStatus(config *hctx.ClientConfig) {
fmt.Println("Sync Mode: Disabled") fmt.Println("Sync Mode: Disabled")
} else { } else {
fmt.Println("Sync Mode: Enabled") fmt.Println("Sync Mode: Enabled")
if lib.GetServerHostname() != lib.DefaultServerHostname {
fmt.Println("Sync Server: " + lib.GetServerHostname())
}
if config.HaveMissedUploads || len(config.PendingDeletionRequests) > 0 { if config.HaveMissedUploads || len(config.PendingDeletionRequests) > 0 {
fmt.Println("Sync Status: Unsynced (device is offline?)") fmt.Println("Sync Status: Unsynced (device is offline?)")
fmt.Printf(" HaveMissedUploads=%v MissedUploadTimestamp=%v len(PendingDeletionRequests)=%v\n", config.HaveMissedUploads, config.MissedUploadTimestamp, len(config.PendingDeletionRequests)) fmt.Printf(" HaveMissedUploads=%v MissedUploadTimestamp=%v len(PendingDeletionRequests)=%v\n", config.HaveMissedUploads, config.MissedUploadTimestamp, len(config.PendingDeletionRequests))

View File

@ -443,11 +443,13 @@ func readFileToIterator(path string) Seq2[string, error] {
} }
} }
func getServerHostname() string { const DefaultServerHostname = "https://api.hishtory.dev"
func GetServerHostname() string {
if server := os.Getenv("HISHTORY_SERVER"); server != "" { if server := os.Getenv("HISHTORY_SERVER"); server != "" {
return server return server
} }
return "https://api.hishtory.dev" return DefaultServerHostname
} }
func httpClient() *http.Client { func httpClient() *http.Client {
@ -459,7 +461,7 @@ func ApiGet(ctx context.Context, path string) ([]byte, error) {
return nil, fmt.Errorf("simulated network error: dial tcp: lookup api.hishtory.dev") return nil, fmt.Errorf("simulated network error: dial tcp: lookup api.hishtory.dev")
} }
start := time.Now() start := time.Now()
req, err := http.NewRequest("GET", getServerHostname()+path, nil) req, err := http.NewRequest("GET", GetServerHostname()+path, nil)
if err != nil { if err != nil {
return nil, fmt.Errorf("failed to create GET: %w", err) return nil, fmt.Errorf("failed to create GET: %w", err)
} }
@ -468,15 +470,15 @@ func ApiGet(ctx context.Context, path string) ([]byte, error) {
req.Header.Set("X-Hishtory-User-Id", data.UserId(hctx.GetConf(ctx).UserSecret)) req.Header.Set("X-Hishtory-User-Id", data.UserId(hctx.GetConf(ctx).UserSecret))
resp, err := httpClient().Do(req) resp, err := httpClient().Do(req)
if err != nil { if err != nil {
return nil, fmt.Errorf("failed to GET %s%s: %w", getServerHostname(), path, err) return nil, fmt.Errorf("failed to GET %s%s: %w", GetServerHostname(), path, err)
} }
defer resp.Body.Close() defer resp.Body.Close()
if resp.StatusCode != 200 { if resp.StatusCode != 200 {
return nil, fmt.Errorf("failed to GET %s%s: status_code=%d", getServerHostname(), path, resp.StatusCode) return nil, fmt.Errorf("failed to GET %s%s: status_code=%d", GetServerHostname(), path, resp.StatusCode)
} }
respBody, err := io.ReadAll(resp.Body) respBody, err := io.ReadAll(resp.Body)
if err != nil { if err != nil {
return nil, fmt.Errorf("failed to read response body from GET %s%s: %w", getServerHostname(), path, err) return nil, fmt.Errorf("failed to read response body from GET %s%s: %w", GetServerHostname(), path, err)
} }
duration := time.Since(start) duration := time.Since(start)
hctx.GetLogger().Infof("ApiGet(%#v): %s\n", path, duration.String()) hctx.GetLogger().Infof("ApiGet(%#v): %s\n", path, duration.String())
@ -488,7 +490,7 @@ func ApiPost(ctx context.Context, path, contentType string, reqBody []byte) ([]b
return nil, fmt.Errorf("simulated network error: dial tcp: lookup api.hishtory.dev") return nil, fmt.Errorf("simulated network error: dial tcp: lookup api.hishtory.dev")
} }
start := time.Now() start := time.Now()
req, err := http.NewRequest("POST", getServerHostname()+path, bytes.NewBuffer(reqBody)) req, err := http.NewRequest("POST", GetServerHostname()+path, bytes.NewBuffer(reqBody))
if err != nil { if err != nil {
return nil, fmt.Errorf("failed to create POST: %w", err) return nil, fmt.Errorf("failed to create POST: %w", err)
} }
@ -498,18 +500,18 @@ func ApiPost(ctx context.Context, path, contentType string, reqBody []byte) ([]b
req.Header.Set("X-Hishtory-User-Id", data.UserId(hctx.GetConf(ctx).UserSecret)) req.Header.Set("X-Hishtory-User-Id", data.UserId(hctx.GetConf(ctx).UserSecret))
resp, err := httpClient().Do(req) resp, err := httpClient().Do(req)
if err != nil { if err != nil {
return nil, fmt.Errorf("failed to POST %s: %w", getServerHostname()+path, err) return nil, fmt.Errorf("failed to POST %s: %w", GetServerHostname()+path, err)
} }
defer resp.Body.Close() defer resp.Body.Close()
if resp.StatusCode != 200 { if resp.StatusCode != 200 {
return nil, fmt.Errorf("failed to POST %s: status_code=%d", getServerHostname()+path, resp.StatusCode) return nil, fmt.Errorf("failed to POST %s: status_code=%d", GetServerHostname()+path, resp.StatusCode)
} }
respBody, err := io.ReadAll(resp.Body) respBody, err := io.ReadAll(resp.Body)
if err != nil { if err != nil {
return nil, fmt.Errorf("failed to read response body from POST %s: %w", getServerHostname()+path, err) return nil, fmt.Errorf("failed to read response body from POST %s: %w", GetServerHostname()+path, err)
} }
duration := time.Since(start) duration := time.Since(start)
hctx.GetLogger().Infof("ApiPost(%#v): %s\n", getServerHostname()+path, duration.String()) hctx.GetLogger().Infof("ApiPost(%#v): %s\n", GetServerHostname()+path, duration.String())
return respBody, nil return respBody, nil
} }