diff options
author | 2024-10-18 11:59:05 +0800 | |
---|---|---|
committer | 2024-10-17 20:59:05 -0700 | |
commit | 0adbcc3a04aafc203d8303048e4ab82918463b2b (patch) | |
tree | 14426bd998be18cef047e7abf4bf8b10bf04bb7c /internal/api | |
parent | 7fdb450446aded0f95f490a0fee275e3dfdf507b (diff) | |
download | v2-0adbcc3a04aafc203d8303048e4ab82918463b2b.tar.gz v2-0adbcc3a04aafc203d8303048e4ab82918463b2b.tar.zst v2-0adbcc3a04aafc203d8303048e4ab82918463b2b.zip |
feat(api): add endpoint for user integration status
Diffstat (limited to 'internal/api')
-rw-r--r-- | internal/api/api.go | 1 | ||||
-rw-r--r-- | internal/api/api_integration_test.go | 26 | ||||
-rw-r--r-- | internal/api/user.go | 19 |
3 files changed, 46 insertions, 0 deletions
diff --git a/internal/api/api.go b/internal/api/api.go index 48d13039..19d5ba62 100644 --- a/internal/api/api.go +++ b/internal/api/api.go @@ -37,6 +37,7 @@ func Serve(router *mux.Router, store *storage.Storage, pool *worker.Pool) { sr.HandleFunc("/users/{userID:[0-9]+}", handler.updateUser).Methods(http.MethodPut) sr.HandleFunc("/users/{userID:[0-9]+}", handler.removeUser).Methods(http.MethodDelete) sr.HandleFunc("/users/{userID:[0-9]+}/mark-all-as-read", handler.markUserAsRead).Methods(http.MethodPut) + sr.HandleFunc("/users/integrations/status", handler.getIntegrationsStatus).Methods(http.MethodGet) sr.HandleFunc("/users/{username}", handler.userByUsername).Methods(http.MethodGet) sr.HandleFunc("/me", handler.currentUser).Methods(http.MethodGet) sr.HandleFunc("/categories", handler.createCategory).Methods(http.MethodPost) diff --git a/internal/api/api_integration_test.go b/internal/api/api_integration_test.go index fe172ce5..8bbb777a 100644 --- a/internal/api/api_integration_test.go +++ b/internal/api/api_integration_test.go @@ -2483,6 +2483,32 @@ func TestSaveEntryEndpoint(t *testing.T) { } } +func TestFetchIntegrationsStatusEndpoint(t *testing.T) { + testConfig := newIntegrationTestConfig() + if !testConfig.isConfigured() { + t.Skip(skipIntegrationTestsMessage) + } + + adminClient := miniflux.NewClient(testConfig.testBaseURL, testConfig.testAdminUsername, testConfig.testAdminPassword) + + regularTestUser, err := adminClient.CreateUser(testConfig.genRandomUsername(), testConfig.testRegularPassword, false) + if err != nil { + t.Fatal(err) + } + defer adminClient.DeleteUser(regularTestUser.ID) + + regularUserClient := miniflux.NewClient(testConfig.testBaseURL, regularTestUser.Username, testConfig.testRegularPassword) + + hasIntegrations, err := regularUserClient.FetchIntegrationsStatus() + if err != nil { + t.Fatalf("Failed to fetch integrations status: %v", err) + } + + if hasIntegrations { + t.Fatalf("New user should not have integrations configured") + } +} + func TestFetchContentEndpoint(t *testing.T) { testConfig := newIntegrationTestConfig() if !testConfig.isConfigured() { diff --git a/internal/api/user.go b/internal/api/user.go index 71d70e9c..112c19a2 100644 --- a/internal/api/user.go +++ b/internal/api/user.go @@ -130,6 +130,25 @@ func (h *handler) markUserAsRead(w http.ResponseWriter, r *http.Request) { json.NoContent(w, r) } +func (h *handler) getIntegrationsStatus(w http.ResponseWriter, r *http.Request) { + userID := request.UserID(r) + + if _, err := h.store.UserByID(userID); err != nil { + json.NotFound(w, r) + return + } + + hasIntegrations := h.store.HasSaveEntry(userID) + + response := struct { + HasIntegrations bool `json:"has_integrations"` + }{ + HasIntegrations: hasIntegrations, + } + + json.OK(w, r, response) +} + func (h *handler) users(w http.ResponseWriter, r *http.Request) { if !request.IsAdminUser(r) { json.Forbidden(w, r) |