about summary refs log tree commit diff
path: root/src/state/queries
diff options
context:
space:
mode:
authorPaul Frazee <pfrazee@gmail.com>2023-11-30 16:13:23 -0800
committerPaul Frazee <pfrazee@gmail.com>2023-11-30 16:13:23 -0800
commit85b2b390df579d718ae061f53f7853a18bc0ca65 (patch)
tree4c3190ffd9b5341c1f0c554b5d3ff2f1d8671264 /src/state/queries
parentdcbceb5d9fcac7b82a2dc68587d7d667618b2eb9 (diff)
parent1755c2e538026e6c3a3b6134ab9b81f6173a2a82 (diff)
downloadvoidsky-85b2b390df579d718ae061f53f7853a18bc0ca65.tar.zst
Merge branch 'mozzius-invite-code-warning' into main
Diffstat (limited to 'src/state/queries')
-rw-r--r--src/state/queries/invites.ts21
1 files changed, 20 insertions, 1 deletions
diff --git a/src/state/queries/invites.ts b/src/state/queries/invites.ts
index c42ba29d5..367917af5 100644
--- a/src/state/queries/invites.ts
+++ b/src/state/queries/invites.ts
@@ -3,6 +3,7 @@ import {useQuery} from '@tanstack/react-query'
 
 import {getAgent} from '#/state/session'
 import {STALE} from '#/state/queries'
+import {cleanError} from '#/lib/strings/errors'
 
 function isInviteAvailable(invite: ComAtprotoServerDefs.InviteCode): boolean {
   return invite.available - invite.uses.length > 0 && !invite.disabled
@@ -17,7 +18,24 @@ export function useInviteCodesQuery() {
     staleTime: STALE.HOURS.ONE,
     queryKey: ['inviteCodes'],
     queryFn: async () => {
-      const res = await getAgent().com.atproto.server.getAccountInviteCodes({})
+      const res = await getAgent()
+        .com.atproto.server.getAccountInviteCodes({})
+        .catch(e => {
+          if (cleanError(e) === 'Bad token scope') {
+            return null
+          } else {
+            throw e
+          }
+        })
+
+      if (res === null) {
+        return {
+          disabled: true,
+          all: [],
+          available: [],
+          used: [],
+        }
+      }
 
       if (!res.data?.codes) {
         throw new Error(`useInviteCodesQuery: no codes returned`)
@@ -27,6 +45,7 @@ export function useInviteCodesQuery() {
       const used = res.data.codes.filter(code => !isInviteAvailable(code))
 
       return {
+        disabled: false,
         all: [...available, ...used],
         available,
         used,