From 394a288bb490748651b76658f9e423ecb8a0b1e9 Mon Sep 17 00:00:00 2001 From: Ryan Bonial Date: Fri, 30 Aug 2024 14:31:46 -0600 Subject: [PATCH 1/3] (feat) Listen for authorization expiry message --- .../message-transports/bifurTransport.ts | 29 +++++++++++++++++-- .../presence/message-transports/transport.ts | 1 + .../store/_legacy/presence/presence-store.ts | 11 ++++++- 3 files changed, 38 insertions(+), 3 deletions(-) diff --git a/packages/sanity/src/core/store/_legacy/presence/message-transports/bifurTransport.ts b/packages/sanity/src/core/store/_legacy/presence/message-transports/bifurTransport.ts index 2ab7828ac7c..1a26807ca45 100644 --- a/packages/sanity/src/core/store/_legacy/presence/message-transports/bifurTransport.ts +++ b/packages/sanity/src/core/store/_legacy/presence/message-transports/bifurTransport.ts @@ -29,6 +29,7 @@ type RollCallEvent = { type IncomingBifurEvent = RollCallEvent | BifurStateMessage | BifurDisconnectMessage const handleIncomingMessage = (event: IncomingBifurEvent): TransportEvent => { + // console.log('ws incoming event', event) if (event.type === 'rollCall') { return { type: 'rollCall', @@ -56,14 +57,34 @@ const handleIncomingMessage = (event: IncomingBifurEvent): Transport } } + // if (event.type === 'subscription') { + // return { + // type: 'subscription', + // userId: event.i, + // sessionId: event.m.session, + // timestamp: new Date().toISOString(), + // } + // } + throw new Error(`Got unknown presence event: ${JSON.stringify(event)}`) } export const createBifurTransport = (bifur: BifurClient, sessionId: string): Transport => { - const incomingEvents$: Observable = bifur + const incomingPresenceEvents$: Observable = bifur .listen>('presence') .pipe(map(handleIncomingMessage)) + const incomingAuthorizationEvents$: Observable = bifur + .listen>('authorization') + .pipe(map(handleIncomingMessage)) + + const testIncomingAuthorizationEvents$: Observable = bifur + .listen>('authorization') + .subscribe((event) => { + // eslint-disable-next-line no-console + console.log('[++++++]Authorization event', event) + }) + const dispatchMessage = (message: TransportMessage): Observable => { if (message.type === 'rollCall') { return bifur.request('presence_rollcall', {session: sessionId}) @@ -82,5 +103,9 @@ export const createBifurTransport = (bifur: BifurClient, sessionId: string): Tra return EMPTY } - return [incomingEvents$.pipe(share()), dispatchMessage] + return [ + incomingPresenceEvents$.pipe(share()), + incomingAuthorizationEvents$.pipe(share()), + dispatchMessage, + ] } diff --git a/packages/sanity/src/core/store/_legacy/presence/message-transports/transport.ts b/packages/sanity/src/core/store/_legacy/presence/message-transports/transport.ts index 9cf52052d5d..54c629f4643 100644 --- a/packages/sanity/src/core/store/_legacy/presence/message-transports/transport.ts +++ b/packages/sanity/src/core/store/_legacy/presence/message-transports/transport.ts @@ -47,6 +47,7 @@ export type TransportEvent = StateEvent | RollCallEvent | DisconnectEvent // This is the interface a transport must implement export type Transport = [ + Observable, Observable, (message: TransportMessage) => Observable, ] diff --git a/packages/sanity/src/core/store/_legacy/presence/presence-store.ts b/packages/sanity/src/core/store/_legacy/presence/presence-store.ts index ab1e2de08f2..517edb2a15e 100644 --- a/packages/sanity/src/core/store/_legacy/presence/presence-store.ts +++ b/packages/sanity/src/core/store/_legacy/presence/presence-store.ts @@ -121,7 +121,10 @@ export function __tmp_wrap_presenceStore(context: { }): PresenceStore { const {bifur, connectionStatusStore, userStore} = context - const [presenceEvents$, sendMessage] = createBifurTransport(bifur, SESSION_ID) + const [presenceEvents$, authorizationEvents$, sendMessage] = createBifurTransport( + bifur, + SESSION_ID, + ) const currentLocation$ = new BehaviorSubject([]) const locationChange$ = currentLocation$.pipe(distinctUntilChanged()) @@ -143,6 +146,12 @@ export function __tmp_wrap_presenceStore(context: { filter((event: RollCallEvent) => event.sessionId !== SESSION_ID), ) + // const authExpireNotifications$ = authorizationEvents$.pipe( + // filter((event: TransportEvent): event is RollCallEvent => event === 'rollCall'), + // // do not respond to my own rollcall requests + // filter((event: RollCallEvent) => event.sessionId !== SESSION_ID), + // ) + const REPORT_MIN_INTERVAL = 30000 // Interval to report my own location at From 178b4d4f1d5a247741006d774f6364fbd6436229 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 4 Sep 2024 09:56:13 -0400 Subject: [PATCH 2/3] chore(deps): update dependency @sanity/pkg-utils to v6.11.0 (#7441) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> --- package.json | 2 +- packages/sanity/package.json | 2 +- pnpm-lock.yaml | 390 ++++++++++++++++++----------------- 3 files changed, 207 insertions(+), 187 deletions(-) diff --git a/package.json b/package.json index d9dd7feb037..8c2779f2635 100644 --- a/package.json +++ b/package.json @@ -110,7 +110,7 @@ "@sanity/eslint-config-i18n": "1.0.0", "@sanity/eslint-config-studio": "^4.0.0", "@sanity/mutate": "^0.8.0", - "@sanity/pkg-utils": "6.10.10", + "@sanity/pkg-utils": "6.11.0", "@sanity/prettier-config": "^1.0.2", "@sanity/test": "0.0.1-alpha.1", "@sanity/tsdoc": "1.0.90", diff --git a/packages/sanity/package.json b/packages/sanity/package.json index 6a34f839336..c2060c006d2 100644 --- a/packages/sanity/package.json +++ b/packages/sanity/package.json @@ -273,7 +273,7 @@ "@repo/package.config": "workspace:*", "@sanity/codegen": "3.57.0", "@sanity/generate-help-url": "^3.0.0", - "@sanity/pkg-utils": "6.10.10", + "@sanity/pkg-utils": "6.11.0", "@sanity/tsdoc": "1.0.90", "@sanity/ui-workshop": "^1.2.11", "@sentry/types": "^8.12.0", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 098ea97f894..ece56f8fc6b 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -58,8 +58,8 @@ importers: specifier: ^0.8.0 version: 0.8.0(debug@4.3.6) '@sanity/pkg-utils': - specifier: 6.10.10 - version: 6.10.10(@types/babel__core@7.20.5)(@types/node@18.19.44)(debug@4.3.6)(typescript@5.5.4) + specifier: 6.11.0 + version: 6.11.0(@types/babel__core@7.20.5)(@types/node@18.19.44)(debug@4.3.6)(typescript@5.5.4) '@sanity/prettier-config': specifier: ^1.0.2 version: 1.0.2(prettier@3.3.3) @@ -801,7 +801,7 @@ importers: version: 3.0.1 '@rollup/plugin-node-resolve': specifier: ^15.2.3 - version: 15.2.3(rollup@4.21.0) + version: 15.2.3(rollup@4.21.2) '@sanity/eslint-config-studio': specifier: ^4.0.0 version: 4.0.0(eslint@8.57.0)(typescript@5.5.4) @@ -978,7 +978,7 @@ importers: version: 7.25.3 '@babel/types': specifier: ^7.23.9 - version: 7.25.2 + version: 7.25.6 debug: specifier: ^4.3.4 version: 4.3.6(supports-color@9.4.0) @@ -1718,8 +1718,8 @@ importers: specifier: ^3.0.0 version: 3.0.0 '@sanity/pkg-utils': - specifier: 6.10.10 - version: 6.10.10(@types/babel__core@7.20.5)(@types/node@18.19.44)(debug@4.3.6)(typescript@5.5.4) + specifier: 6.11.0 + version: 6.11.0(@types/babel__core@7.20.5)(@types/node@18.19.44)(debug@4.3.6)(typescript@5.5.4) '@sanity/tsdoc': specifier: 1.0.90 version: 1.0.90(@types/babel__core@7.20.5)(@types/node@18.19.44)(debug@4.3.6)(react-dom@18.3.1(react@18.3.1))(react-is@18.3.1)(react@18.3.1)(sanity@packages+sanity)(styled-components@6.1.13(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(terser@5.31.6) @@ -2601,8 +2601,8 @@ packages: resolution: {integrity: sha512-HefgyP1x754oGCsKmV5reSmtV7IXj/kpaE1XYY+D9G5PvKKoFfSbiS4M77MdjuwlZKDIKFCffq9rPU+H/s3ZdQ==} engines: {node: '>=6.9.0'} - '@babel/types@7.25.2': - resolution: {integrity: sha512-YTnYtra7W9e6/oAZEHj0bJehPRUlLH9/fbpT5LfB0NhQXyALCRkRs3zH9v07IYhkgpqX6Z78FnuccZr/l4Fs4Q==} + '@babel/types@7.25.6': + resolution: {integrity: sha512-/l42B1qxpG6RdfYf343Uw1vmDjeNhneUXtzhojE7pDgfpEypmRhI6j1kr17XCVv4Cgl9HdAiQY2x0GwKm7rWCw==} engines: {node: '>=6.9.0'} '@bcoe/v8-coverage@0.2.3': @@ -3621,15 +3621,15 @@ packages: '@microsoft/api-extractor-model@7.29.4': resolution: {integrity: sha512-LHOMxmT8/tU1IiiiHOdHFF83Qsi+V8d0kLfscG4EvQE9cafiR8blOYr8SfkQKWB1wgEilQgXJX3MIA4vetDLZw==} - '@microsoft/api-extractor-model@7.29.5': - resolution: {integrity: sha512-axMwj4pgtYH6/IclP9ly33laSwTym1kBwSUcoHElc2LYAE5NNlhGT78ucEpIZtqEZaGgA8yxGXIyS17XCC2Iuw==} + '@microsoft/api-extractor-model@7.29.6': + resolution: {integrity: sha512-gC0KGtrZvxzf/Rt9oMYD2dHvtN/1KPEYsrQPyMKhLHnlVuO/f4AFN3E4toqZzD2pt4LhkKoYmL2H9tX3yCOyRw==} '@microsoft/api-extractor@7.47.5': resolution: {integrity: sha512-edKt4dFO2t25xmI2FX2rsP5liIgwKW1yuQImA0JM+5YGHCoo51GEQ7j+On17SvVpRJnuqLE/QVgtjIQ1Hpg98w==} hasBin: true - '@microsoft/api-extractor@7.47.6': - resolution: {integrity: sha512-saI7n319+PdJ8PAePr14LWeIPOW2fHSr3KZfYFqJ2VUpIc1TTSh6ATFZfLPWI1LK7eZHun8+FpNsuxonyvxTgQ==} + '@microsoft/api-extractor@7.47.7': + resolution: {integrity: sha512-fNiD3G55ZJGhPOBPMKD/enozj8yxJSYyVJWxRWdcUtw842rvthDHJgUWq9gXQTensFlMHv2wGuCjjivPv53j0A==} hasBin: true '@microsoft/tsdoc-config@0.17.0': @@ -4160,83 +4160,83 @@ packages: rollup: optional: true - '@rollup/rollup-android-arm-eabi@4.21.0': - resolution: {integrity: sha512-WTWD8PfoSAJ+qL87lE7votj3syLavxunWhzCnx3XFxFiI/BA/r3X7MUM8dVrH8rb2r4AiO8jJsr3ZjdaftmnfA==} + '@rollup/rollup-android-arm-eabi@4.21.2': + resolution: {integrity: sha512-fSuPrt0ZO8uXeS+xP3b+yYTCBUd05MoSp2N/MFOgjhhUhMmchXlpTQrTpI8T+YAwAQuK7MafsCOxW7VrPMrJcg==} cpu: [arm] os: [android] - '@rollup/rollup-android-arm64@4.21.0': - resolution: {integrity: sha512-a1sR2zSK1B4eYkiZu17ZUZhmUQcKjk2/j9Me2IDjk1GHW7LB5Z35LEzj9iJch6gtUfsnvZs1ZNyDW2oZSThrkA==} + '@rollup/rollup-android-arm64@4.21.2': + resolution: {integrity: sha512-xGU5ZQmPlsjQS6tzTTGwMsnKUtu0WVbl0hYpTPauvbRAnmIvpInhJtgjj3mcuJpEiuUw4v1s4BimkdfDWlh7gA==} cpu: [arm64] os: [android] - '@rollup/rollup-darwin-arm64@4.21.0': - resolution: {integrity: sha512-zOnKWLgDld/svhKO5PD9ozmL6roy5OQ5T4ThvdYZLpiOhEGY+dp2NwUmxK0Ld91LrbjrvtNAE0ERBwjqhZTRAA==} + '@rollup/rollup-darwin-arm64@4.21.2': + resolution: {integrity: sha512-99AhQ3/ZMxU7jw34Sq8brzXqWH/bMnf7ZVhvLk9QU2cOepbQSVTns6qoErJmSiAvU3InRqC2RRZ5ovh1KN0d0Q==} cpu: [arm64] os: [darwin] - '@rollup/rollup-darwin-x64@4.21.0': - resolution: {integrity: sha512-7doS8br0xAkg48SKE2QNtMSFPFUlRdw9+votl27MvT46vo44ATBmdZdGysOevNELmZlfd+NEa0UYOA8f01WSrg==} + '@rollup/rollup-darwin-x64@4.21.2': + resolution: {integrity: sha512-ZbRaUvw2iN/y37x6dY50D8m2BnDbBjlnMPotDi/qITMJ4sIxNY33HArjikDyakhSv0+ybdUxhWxE6kTI4oX26w==} cpu: [x64] os: [darwin] - '@rollup/rollup-linux-arm-gnueabihf@4.21.0': - resolution: {integrity: sha512-pWJsfQjNWNGsoCq53KjMtwdJDmh/6NubwQcz52aEwLEuvx08bzcy6tOUuawAOncPnxz/3siRtd8hiQ32G1y8VA==} + '@rollup/rollup-linux-arm-gnueabihf@4.21.2': + resolution: {integrity: sha512-ztRJJMiE8nnU1YFcdbd9BcH6bGWG1z+jP+IPW2oDUAPxPjo9dverIOyXz76m6IPA6udEL12reYeLojzW2cYL7w==} cpu: [arm] os: [linux] - '@rollup/rollup-linux-arm-musleabihf@4.21.0': - resolution: {integrity: sha512-efRIANsz3UHZrnZXuEvxS9LoCOWMGD1rweciD6uJQIx2myN3a8Im1FafZBzh7zk1RJ6oKcR16dU3UPldaKd83w==} + '@rollup/rollup-linux-arm-musleabihf@4.21.2': + resolution: {integrity: sha512-flOcGHDZajGKYpLV0JNc0VFH361M7rnV1ee+NTeC/BQQ1/0pllYcFmxpagltANYt8FYf9+kL6RSk80Ziwyhr7w==} cpu: [arm] os: [linux] - '@rollup/rollup-linux-arm64-gnu@4.21.0': - resolution: {integrity: sha512-ZrPhydkTVhyeGTW94WJ8pnl1uroqVHM3j3hjdquwAcWnmivjAwOYjTEAuEDeJvGX7xv3Z9GAvrBkEzCgHq9U1w==} + '@rollup/rollup-linux-arm64-gnu@4.21.2': + resolution: {integrity: sha512-69CF19Kp3TdMopyteO/LJbWufOzqqXzkrv4L2sP8kfMaAQ6iwky7NoXTp7bD6/irKgknDKM0P9E/1l5XxVQAhw==} cpu: [arm64] os: [linux] - '@rollup/rollup-linux-arm64-musl@4.21.0': - resolution: {integrity: sha512-cfaupqd+UEFeURmqNP2eEvXqgbSox/LHOyN9/d2pSdV8xTrjdg3NgOFJCtc1vQ/jEke1qD0IejbBfxleBPHnPw==} + '@rollup/rollup-linux-arm64-musl@4.21.2': + resolution: {integrity: sha512-48pD/fJkTiHAZTnZwR0VzHrao70/4MlzJrq0ZsILjLW/Ab/1XlVUStYyGt7tdyIiVSlGZbnliqmult/QGA2O2w==} cpu: [arm64] os: [linux] - '@rollup/rollup-linux-powerpc64le-gnu@4.21.0': - resolution: {integrity: sha512-ZKPan1/RvAhrUylwBXC9t7B2hXdpb/ufeu22pG2psV7RN8roOfGurEghw1ySmX/CmDDHNTDDjY3lo9hRlgtaHg==} + '@rollup/rollup-linux-powerpc64le-gnu@4.21.2': + resolution: {integrity: sha512-cZdyuInj0ofc7mAQpKcPR2a2iu4YM4FQfuUzCVA2u4HI95lCwzjoPtdWjdpDKyHxI0UO82bLDoOaLfpZ/wviyQ==} cpu: [ppc64] os: [linux] - '@rollup/rollup-linux-riscv64-gnu@4.21.0': - resolution: {integrity: sha512-H1eRaCwd5E8eS8leiS+o/NqMdljkcb1d6r2h4fKSsCXQilLKArq6WS7XBLDu80Yz+nMqHVFDquwcVrQmGr28rg==} + '@rollup/rollup-linux-riscv64-gnu@4.21.2': + resolution: {integrity: sha512-RL56JMT6NwQ0lXIQmMIWr1SW28z4E4pOhRRNqwWZeXpRlykRIlEpSWdsgNWJbYBEWD84eocjSGDu/XxbYeCmwg==} cpu: [riscv64] os: [linux] - '@rollup/rollup-linux-s390x-gnu@4.21.0': - resolution: {integrity: sha512-zJ4hA+3b5tu8u7L58CCSI0A9N1vkfwPhWd/puGXwtZlsB5bTkwDNW/+JCU84+3QYmKpLi+XvHdmrlwUwDA6kqw==} + '@rollup/rollup-linux-s390x-gnu@4.21.2': + resolution: {integrity: sha512-PMxkrWS9z38bCr3rWvDFVGD6sFeZJw4iQlhrup7ReGmfn7Oukrr/zweLhYX6v2/8J6Cep9IEA/SmjXjCmSbrMQ==} cpu: [s390x] os: [linux] - '@rollup/rollup-linux-x64-gnu@4.21.0': - resolution: {integrity: sha512-e2hrvElFIh6kW/UNBQK/kzqMNY5mO+67YtEh9OA65RM5IJXYTWiXjX6fjIiPaqOkBthYF1EqgiZ6OXKcQsM0hg==} + '@rollup/rollup-linux-x64-gnu@4.21.2': + resolution: {integrity: sha512-B90tYAUoLhU22olrafY3JQCFLnT3NglazdwkHyxNDYF/zAxJt5fJUB/yBoWFoIQ7SQj+KLe3iL4BhOMa9fzgpw==} cpu: [x64] os: [linux] - '@rollup/rollup-linux-x64-musl@4.21.0': - resolution: {integrity: sha512-1vvmgDdUSebVGXWX2lIcgRebqfQSff0hMEkLJyakQ9JQUbLDkEaMsPTLOmyccyC6IJ/l3FZuJbmrBw/u0A0uCQ==} + '@rollup/rollup-linux-x64-musl@4.21.2': + resolution: {integrity: sha512-7twFizNXudESmC9oneLGIUmoHiiLppz/Xs5uJQ4ShvE6234K0VB1/aJYU3f/4g7PhssLGKBVCC37uRkkOi8wjg==} cpu: [x64] os: [linux] - '@rollup/rollup-win32-arm64-msvc@4.21.0': - resolution: {integrity: sha512-s5oFkZ/hFcrlAyBTONFY1TWndfyre1wOMwU+6KCpm/iatybvrRgmZVM+vCFwxmC5ZhdlgfE0N4XorsDpi7/4XQ==} + '@rollup/rollup-win32-arm64-msvc@4.21.2': + resolution: {integrity: sha512-9rRero0E7qTeYf6+rFh3AErTNU1VCQg2mn7CQcI44vNUWM9Ze7MSRS/9RFuSsox+vstRt97+x3sOhEey024FRQ==} cpu: [arm64] os: [win32] - '@rollup/rollup-win32-ia32-msvc@4.21.0': - resolution: {integrity: sha512-G9+TEqRnAA6nbpqyUqgTiopmnfgnMkR3kMukFBDsiyy23LZvUCpiUwjTRx6ezYCjJODXrh52rBR9oXvm+Fp5wg==} + '@rollup/rollup-win32-ia32-msvc@4.21.2': + resolution: {integrity: sha512-5rA4vjlqgrpbFVVHX3qkrCo/fZTj1q0Xxpg+Z7yIo3J2AilW7t2+n6Q8Jrx+4MrYpAnjttTYF8rr7bP46BPzRw==} cpu: [ia32] os: [win32] - '@rollup/rollup-win32-x64-msvc@4.21.0': - resolution: {integrity: sha512-2jsCDZwtQvRhejHLfZ1JY6w6kEuEtfF9nzYsZxzSlNVKDX+DpsDJ+Rbjkm74nvg2rdx0gwBS+IMdvwJuq3S9pQ==} + '@rollup/rollup-win32-x64-msvc@4.21.2': + resolution: {integrity: sha512-6UUxd0+SKomjdzuAcp+HAmxw1FlGBnl1v2yEPSabtx4lBfdXHDVsW7+lQkgz9cNFJGY3AWR7+V8P5BqkD9L9nA==} cpu: [x64] os: [win32] @@ -4251,8 +4251,8 @@ packages: '@types/node': optional: true - '@rushstack/node-core-library@5.6.0': - resolution: {integrity: sha512-3ixIcEHseqU1sbnvoQkvxvfTYWbi1IIhnq/vexJcex7j6D8lnQCiYnd/E2oXbUH0Zv48CjtfslC/2MVFd71mpg==} + '@rushstack/node-core-library@5.7.0': + resolution: {integrity: sha512-Ff9Cz/YlWu9ce4dmqNBZpA45AEya04XaBFIjV7xTVeEf+y/kTjEasmozqFELXlNG4ROdevss75JrrZ5WgufDkQ==} peerDependencies: '@types/node': '*' peerDependenciesMeta: @@ -4270,8 +4270,8 @@ packages: '@types/node': optional: true - '@rushstack/terminal@0.13.4': - resolution: {integrity: sha512-h7g2RuffpqBCDKOijlUmvQ0b2O9kpIOK9TWCX9IR+2kvudp6MdtCYDu29zeqweWwCSWUnuAaUfB5HT88s0YCiw==} + '@rushstack/terminal@0.14.0': + resolution: {integrity: sha512-juTKMAMpTIJKudeFkG5slD8Z/LHwNwGZLtU441l/u82XdTBfsP+LbGKJLCNwP5se+DMCT55GB8x9p6+C4UL7jw==} peerDependencies: '@types/node': '*' peerDependenciesMeta: @@ -4281,8 +4281,8 @@ packages: '@rushstack/ts-command-line@4.22.4': resolution: {integrity: sha512-QoyhbWfyF9Ixg5DWdPzxO3h2RmJ7i5WH9b7qLzD5h5WFya/ZqicjdPrVwQiGtrFvAbBj8jhcC9DhbzU9xAk78g==} - '@rushstack/ts-command-line@4.22.5': - resolution: {integrity: sha512-eFm+5DJboPHAy3epLNQtmG+hDlBzS950g26nZPbciMQeXmZ5shGGNe6ERjV77wnr5IuxfLhYGJ4ZjPy8Z56MBA==} + '@rushstack/ts-command-line@4.22.6': + resolution: {integrity: sha512-QSRqHT/IfoC5nk9zn6+fgyqOPXHME0BfchII9EUPR19pocsNp/xSbeBCbD3PIR2Lg+Q5qk7OFqk1VhWPMdKHJg==} '@sanity/asset-utils@1.3.0': resolution: {integrity: sha512-uyIOtGA4Duf+68I3BSbYHY5P+WGftn3QtNJD2Pn7h9WPGYsSrWViIPebE9yRN8N0NHhYj+hDQXaMpVdjG7r+zA==} @@ -4428,15 +4428,15 @@ packages: '@sanity/mutator@3.37.2': resolution: {integrity: sha512-F0MvseVtgPBaPxNZtSidF6BQeygviYThgmhRbjZ89AhlRhWiLODvLakdogFmwD1NEQ0tpKn+8m0pQIOHgt2C3w==} - '@sanity/pkg-utils@6.10.10': - resolution: {integrity: sha512-kPqa5/uR/BtEGnuzkQhKX5aPdKKYUhFiDn3h1cYomUN75qREKonPkhOtckO17vtJ+lh1tbO+bSxauLP/UN8sDA==} + '@sanity/pkg-utils@6.10.9': + resolution: {integrity: sha512-6kSRmDM6bkGMkaGV8EB18mAdaItx0mn++bzPK9ztQQ3VTW3k1MlKiYgalqjT1E/jUGylb5cv+fWaGAxxQ8lQfQ==} engines: {node: '>=18.17.0'} hasBin: true peerDependencies: typescript: 5.4.x || 5.5.x - '@sanity/pkg-utils@6.10.9': - resolution: {integrity: sha512-6kSRmDM6bkGMkaGV8EB18mAdaItx0mn++bzPK9ztQQ3VTW3k1MlKiYgalqjT1E/jUGylb5cv+fWaGAxxQ8lQfQ==} + '@sanity/pkg-utils@6.11.0': + resolution: {integrity: sha512-QvHensutKr4juGsU3L97KxcCeBRwqvJVVnDldycf5I4Ftl4g8DEROyB1oWU+5JCV1L47TQKxOtlnDcuq3fK1sg==} engines: {node: '>=18.17.0'} hasBin: true peerDependencies: @@ -5433,6 +5433,9 @@ packages: babel-plugin-react-compiler@0.0.0-experimental-938cd9a-20240601: resolution: {integrity: sha512-t+uBHxbfxq2z4j83ZYgOsV0dlSaRgPfhrYB5+CMv6ByXUAv5wm7m7YLFx67fWKrG3eDhq3+KH1OMeFypuDLkUA==} + babel-plugin-react-compiler@0.0.0-experimental-e68eda9-20240829: + resolution: {integrity: sha512-H7e+R9ze2Ftdbh4W7C1oUIdWSn4xQEcRQDM2vVG2LBA8qiyvnnSR5L6+e06/J3fYHjFEkgdL96FsdOM7TNW2AA==} + babel-plugin-styled-components@2.1.4: resolution: {integrity: sha512-Xgp9g+A/cG47sUyRwwYxGM4bR/jDRg5N6it/8+HxCnbT5XNKSKDT9xm4oag/osgqjC2It/vH0yXsomOG6k558g==} peerDependencies: @@ -7233,6 +7236,9 @@ packages: git-url-parse@14.1.0: resolution: {integrity: sha512-8xg65dTxGHST3+zGpycMMFZcoTzAdZ2dOtu4vmgIfkTFnVHBxHMzBC2L1k8To7EmrSiHesT8JgPLT91VKw1B5g==} + git-url-parse@15.0.0: + resolution: {integrity: sha512-5reeBufLi+i4QD3ZFftcJs9jC26aULFLBU23FeKM/b1rI0K6ofIeAblmDVO7Ht22zTDE9+CkJ3ZVb0CgJmz3UQ==} + git-user-info@2.0.3: resolution: {integrity: sha512-G4ffrtck6AhUvJBmaWiq50viL9Zt3l1G/Qv0tV8BTKJZcJYnKWKGW8m7JvPrhzrPwh+Pwuq88pzERGlrLuOWng==} engines: {node: '>=12.0.0'} @@ -10013,8 +10019,8 @@ packages: engines: {node: '>=14.18.0', npm: '>=8.0.0'} hasBin: true - rollup@4.21.0: - resolution: {integrity: sha512-vo+S/lfA2lMS7rZ2Qoubi6I5hwZwzXeUIctILZLbHI+laNtvhhOIon2S1JksA5UEDQ7l3vberd0fxK44lTYjbQ==} + rollup@4.21.2: + resolution: {integrity: sha512-e3TapAgYf9xjdLvKQCkQTnbTKd4a6jwlpQSJJFokHGaX2IVjoEqkIIhiQfqsi0cdwlOD+tQGuOd5AJkc5RngBw==} engines: {node: '>=18.0.0', npm: '>=8.0.0'} hasBin: true @@ -11511,7 +11517,7 @@ snapshots: '@babel/parser': 7.25.3 '@babel/template': 7.25.0 '@babel/traverse': 7.25.3 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 convert-source-map: 2.0.0 debug: 4.3.6(supports-color@9.4.0) gensync: 1.0.0-beta.2 @@ -11530,7 +11536,7 @@ snapshots: '@babel/generator@7.2.0': dependencies: - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 jsesc: 2.5.2 lodash: 4.17.21 source-map: 0.5.7 @@ -11538,19 +11544,19 @@ snapshots: '@babel/generator@7.25.0': dependencies: - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 '@jridgewell/gen-mapping': 0.3.5 '@jridgewell/trace-mapping': 0.3.25 jsesc: 2.5.2 '@babel/helper-annotate-as-pure@7.24.7': dependencies: - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 '@babel/helper-builder-binary-assignment-operator-visitor@7.24.7': dependencies: '@babel/traverse': 7.25.3 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 transitivePeerDependencies: - supports-color @@ -11596,21 +11602,21 @@ snapshots: '@babel/helper-member-expression-to-functions@7.24.8': dependencies: '@babel/traverse': 7.25.3 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 transitivePeerDependencies: - supports-color '@babel/helper-module-imports@7.24.7': dependencies: '@babel/traverse': 7.25.3 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 transitivePeerDependencies: - supports-color '@babel/helper-module-imports@7.24.7(supports-color@5.5.0)': dependencies: '@babel/traverse': 7.25.3(supports-color@5.5.0) - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 transitivePeerDependencies: - supports-color @@ -11626,7 +11632,7 @@ snapshots: '@babel/helper-optimise-call-expression@7.24.7': dependencies: - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 '@babel/helper-plugin-utils@7.24.8': {} @@ -11651,14 +11657,14 @@ snapshots: '@babel/helper-simple-access@7.24.7': dependencies: '@babel/traverse': 7.25.3 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 transitivePeerDependencies: - supports-color '@babel/helper-skip-transparent-expression-wrappers@7.24.7': dependencies: '@babel/traverse': 7.25.3 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 transitivePeerDependencies: - supports-color @@ -11672,14 +11678,14 @@ snapshots: dependencies: '@babel/template': 7.25.0 '@babel/traverse': 7.25.3 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 transitivePeerDependencies: - supports-color '@babel/helpers@7.25.0': dependencies: '@babel/template': 7.25.0 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 '@babel/highlight@7.24.7': dependencies: @@ -11690,7 +11696,7 @@ snapshots: '@babel/parser@7.25.3': dependencies: - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 '@babel/plugin-bugfix-firefox-class-in-computed-class-key@7.25.3(@babel/core@7.25.2)': dependencies: @@ -12149,7 +12155,7 @@ snapshots: '@babel/helper-module-imports': 7.24.7 '@babel/helper-plugin-utils': 7.24.8 '@babel/plugin-syntax-jsx': 7.24.7(@babel/core@7.25.2) - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 transitivePeerDependencies: - supports-color @@ -12325,7 +12331,7 @@ snapshots: dependencies: '@babel/core': 7.25.2 '@babel/helper-plugin-utils': 7.24.8 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 esutils: 2.0.3 '@babel/preset-react@7.24.7(@babel/core@7.25.2)': @@ -12370,7 +12376,7 @@ snapshots: dependencies: '@babel/code-frame': 7.24.7 '@babel/parser': 7.25.3 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 '@babel/traverse@7.25.3': dependencies: @@ -12378,7 +12384,7 @@ snapshots: '@babel/generator': 7.25.0 '@babel/parser': 7.25.3 '@babel/template': 7.25.0 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 debug: 4.3.6(supports-color@9.4.0) globals: 11.12.0 transitivePeerDependencies: @@ -12390,13 +12396,13 @@ snapshots: '@babel/generator': 7.25.0 '@babel/parser': 7.25.3 '@babel/template': 7.25.0 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 debug: 4.3.6(supports-color@5.5.0) globals: 11.12.0 transitivePeerDependencies: - supports-color - '@babel/types@7.25.2': + '@babel/types@7.25.6': dependencies: '@babel/helper-string-parser': 7.24.8 '@babel/helper-validator-identifier': 7.24.7 @@ -13385,11 +13391,11 @@ snapshots: transitivePeerDependencies: - '@types/node' - '@microsoft/api-extractor-model@7.29.5(@types/node@18.19.44)': + '@microsoft/api-extractor-model@7.29.6(@types/node@18.19.44)': dependencies: '@microsoft/tsdoc': 0.15.0 '@microsoft/tsdoc-config': 0.17.0 - '@rushstack/node-core-library': 5.6.0(@types/node@18.19.44) + '@rushstack/node-core-library': 5.7.0(@types/node@18.19.44) transitivePeerDependencies: - '@types/node' @@ -13411,15 +13417,15 @@ snapshots: transitivePeerDependencies: - '@types/node' - '@microsoft/api-extractor@7.47.6(@types/node@18.19.44)': + '@microsoft/api-extractor@7.47.7(@types/node@18.19.44)': dependencies: - '@microsoft/api-extractor-model': 7.29.5(@types/node@18.19.44) + '@microsoft/api-extractor-model': 7.29.6(@types/node@18.19.44) '@microsoft/tsdoc': 0.15.0 '@microsoft/tsdoc-config': 0.17.0 - '@rushstack/node-core-library': 5.6.0(@types/node@18.19.44) + '@rushstack/node-core-library': 5.7.0(@types/node@18.19.44) '@rushstack/rig-package': 0.5.3 - '@rushstack/terminal': 0.13.4(@types/node@18.19.44) - '@rushstack/ts-command-line': 4.22.5(@types/node@18.19.44) + '@rushstack/terminal': 0.14.0(@types/node@18.19.44) + '@rushstack/ts-command-line': 4.22.6(@types/node@18.19.44) lodash: 4.17.21 minimatch: 3.0.8 resolve: 1.22.8 @@ -13822,11 +13828,11 @@ snapshots: dependencies: '@octokit/openapi-types': 18.1.1 - '@optimize-lodash/rollup-plugin@5.0.0(rollup@4.21.0)': + '@optimize-lodash/rollup-plugin@5.0.0(rollup@4.21.2)': dependencies: '@optimize-lodash/transform': 3.0.4 - '@rollup/pluginutils': 5.1.0(rollup@4.21.0) - rollup: 4.21.0 + '@rollup/pluginutils': 5.1.0(rollup@4.21.2) + rollup: 4.21.2 '@optimize-lodash/transform@3.0.4': dependencies: @@ -13956,120 +13962,120 @@ snapshots: react-lifecycles-compat: 3.0.4 react-style-proptype: 3.2.2 - '@rollup/plugin-alias@5.1.0(rollup@4.21.0)': + '@rollup/plugin-alias@5.1.0(rollup@4.21.2)': dependencies: slash: 4.0.0 optionalDependencies: - rollup: 4.21.0 + rollup: 4.21.2 - '@rollup/plugin-babel@6.0.4(@babel/core@7.25.2)(@types/babel__core@7.20.5)(rollup@4.21.0)': + '@rollup/plugin-babel@6.0.4(@babel/core@7.25.2)(@types/babel__core@7.20.5)(rollup@4.21.2)': dependencies: '@babel/core': 7.25.2 '@babel/helper-module-imports': 7.24.7 - '@rollup/pluginutils': 5.1.0(rollup@4.21.0) + '@rollup/pluginutils': 5.1.0(rollup@4.21.2) optionalDependencies: '@types/babel__core': 7.20.5 - rollup: 4.21.0 + rollup: 4.21.2 transitivePeerDependencies: - supports-color - '@rollup/plugin-commonjs@26.0.1(rollup@4.21.0)': + '@rollup/plugin-commonjs@26.0.1(rollup@4.21.2)': dependencies: - '@rollup/pluginutils': 5.1.0(rollup@4.21.0) + '@rollup/pluginutils': 5.1.0(rollup@4.21.2) commondir: 1.0.1 estree-walker: 2.0.2 glob: 10.4.5 is-reference: 1.2.1 magic-string: 0.30.11 optionalDependencies: - rollup: 4.21.0 + rollup: 4.21.2 - '@rollup/plugin-json@6.1.0(rollup@4.21.0)': + '@rollup/plugin-json@6.1.0(rollup@4.21.2)': dependencies: - '@rollup/pluginutils': 5.1.0(rollup@4.21.0) + '@rollup/pluginutils': 5.1.0(rollup@4.21.2) optionalDependencies: - rollup: 4.21.0 + rollup: 4.21.2 - '@rollup/plugin-node-resolve@15.2.3(rollup@4.21.0)': + '@rollup/plugin-node-resolve@15.2.3(rollup@4.21.2)': dependencies: - '@rollup/pluginutils': 5.1.0(rollup@4.21.0) + '@rollup/pluginutils': 5.1.0(rollup@4.21.2) '@types/resolve': 1.20.2 deepmerge: 4.3.1 is-builtin-module: 3.2.1 is-module: 1.0.0 resolve: 1.22.8 optionalDependencies: - rollup: 4.21.0 + rollup: 4.21.2 - '@rollup/plugin-replace@5.0.7(rollup@4.21.0)': + '@rollup/plugin-replace@5.0.7(rollup@4.21.2)': dependencies: - '@rollup/pluginutils': 5.1.0(rollup@4.21.0) + '@rollup/pluginutils': 5.1.0(rollup@4.21.2) magic-string: 0.30.11 optionalDependencies: - rollup: 4.21.0 + rollup: 4.21.2 - '@rollup/plugin-terser@0.4.4(rollup@4.21.0)': + '@rollup/plugin-terser@0.4.4(rollup@4.21.2)': dependencies: serialize-javascript: 6.0.2 smob: 1.5.0 terser: 5.31.6 optionalDependencies: - rollup: 4.21.0 + rollup: 4.21.2 - '@rollup/pluginutils@5.1.0(rollup@4.21.0)': + '@rollup/pluginutils@5.1.0(rollup@4.21.2)': dependencies: '@types/estree': 1.0.5 estree-walker: 2.0.2 picomatch: 2.3.1 optionalDependencies: - rollup: 4.21.0 + rollup: 4.21.2 - '@rollup/rollup-android-arm-eabi@4.21.0': + '@rollup/rollup-android-arm-eabi@4.21.2': optional: true - '@rollup/rollup-android-arm64@4.21.0': + '@rollup/rollup-android-arm64@4.21.2': optional: true - '@rollup/rollup-darwin-arm64@4.21.0': + '@rollup/rollup-darwin-arm64@4.21.2': optional: true - '@rollup/rollup-darwin-x64@4.21.0': + '@rollup/rollup-darwin-x64@4.21.2': optional: true - '@rollup/rollup-linux-arm-gnueabihf@4.21.0': + '@rollup/rollup-linux-arm-gnueabihf@4.21.2': optional: true - '@rollup/rollup-linux-arm-musleabihf@4.21.0': + '@rollup/rollup-linux-arm-musleabihf@4.21.2': optional: true - '@rollup/rollup-linux-arm64-gnu@4.21.0': + '@rollup/rollup-linux-arm64-gnu@4.21.2': optional: true - '@rollup/rollup-linux-arm64-musl@4.21.0': + '@rollup/rollup-linux-arm64-musl@4.21.2': optional: true - '@rollup/rollup-linux-powerpc64le-gnu@4.21.0': + '@rollup/rollup-linux-powerpc64le-gnu@4.21.2': optional: true - '@rollup/rollup-linux-riscv64-gnu@4.21.0': + '@rollup/rollup-linux-riscv64-gnu@4.21.2': optional: true - '@rollup/rollup-linux-s390x-gnu@4.21.0': + '@rollup/rollup-linux-s390x-gnu@4.21.2': optional: true - '@rollup/rollup-linux-x64-gnu@4.21.0': + '@rollup/rollup-linux-x64-gnu@4.21.2': optional: true - '@rollup/rollup-linux-x64-musl@4.21.0': + '@rollup/rollup-linux-x64-musl@4.21.2': optional: true - '@rollup/rollup-win32-arm64-msvc@4.21.0': + '@rollup/rollup-win32-arm64-msvc@4.21.2': optional: true - '@rollup/rollup-win32-ia32-msvc@4.21.0': + '@rollup/rollup-win32-ia32-msvc@4.21.2': optional: true - '@rollup/rollup-win32-x64-msvc@4.21.0': + '@rollup/rollup-win32-x64-msvc@4.21.2': optional: true '@rushstack/eslint-patch@1.10.4': {} @@ -14087,7 +14093,7 @@ snapshots: optionalDependencies: '@types/node': 18.19.44 - '@rushstack/node-core-library@5.6.0(@types/node@18.19.44)': + '@rushstack/node-core-library@5.7.0(@types/node@18.19.44)': dependencies: ajv: 8.13.0 ajv-draft-04: 1.0.0(ajv@8.13.0) @@ -14112,9 +14118,9 @@ snapshots: optionalDependencies: '@types/node': 18.19.44 - '@rushstack/terminal@0.13.4(@types/node@18.19.44)': + '@rushstack/terminal@0.14.0(@types/node@18.19.44)': dependencies: - '@rushstack/node-core-library': 5.6.0(@types/node@18.19.44) + '@rushstack/node-core-library': 5.7.0(@types/node@18.19.44) supports-color: 8.1.1 optionalDependencies: '@types/node': 18.19.44 @@ -14128,9 +14134,9 @@ snapshots: transitivePeerDependencies: - '@types/node' - '@rushstack/ts-command-line@4.22.5(@types/node@18.19.44)': + '@rushstack/ts-command-line@4.22.6(@types/node@18.19.44)': dependencies: - '@rushstack/terminal': 0.13.4(@types/node@18.19.44) + '@rushstack/terminal': 0.14.0(@types/node@18.19.44) '@types/argparse': 1.0.38 argparse: 1.0.10 string-argv: 0.3.2 @@ -14371,21 +14377,21 @@ snapshots: transitivePeerDependencies: - supports-color - '@sanity/pkg-utils@6.10.10(@types/babel__core@7.20.5)(@types/node@18.19.44)(debug@4.3.6)(typescript@5.5.4)': + '@sanity/pkg-utils@6.10.9(@types/babel__core@7.20.5)(@types/node@18.19.44)(debug@4.3.6)(typescript@5.5.4)': dependencies: '@babel/core': 7.25.2 '@babel/preset-typescript': 7.24.7(@babel/core@7.25.2) - '@babel/types': 7.25.2 - '@microsoft/api-extractor': 7.47.6(@types/node@18.19.44) + '@babel/types': 7.25.6 + '@microsoft/api-extractor': 7.47.5(@types/node@18.19.44) '@microsoft/tsdoc-config': 0.17.0 - '@optimize-lodash/rollup-plugin': 5.0.0(rollup@4.21.0) - '@rollup/plugin-alias': 5.1.0(rollup@4.21.0) - '@rollup/plugin-babel': 6.0.4(@babel/core@7.25.2)(@types/babel__core@7.20.5)(rollup@4.21.0) - '@rollup/plugin-commonjs': 26.0.1(rollup@4.21.0) - '@rollup/plugin-json': 6.1.0(rollup@4.21.0) - '@rollup/plugin-node-resolve': 15.2.3(rollup@4.21.0) - '@rollup/plugin-replace': 5.0.7(rollup@4.21.0) - '@rollup/plugin-terser': 0.4.4(rollup@4.21.0) + '@optimize-lodash/rollup-plugin': 5.0.0(rollup@4.21.2) + '@rollup/plugin-alias': 5.1.0(rollup@4.21.2) + '@rollup/plugin-babel': 6.0.4(@babel/core@7.25.2)(@types/babel__core@7.20.5)(rollup@4.21.2) + '@rollup/plugin-commonjs': 26.0.1(rollup@4.21.2) + '@rollup/plugin-json': 6.1.0(rollup@4.21.2) + '@rollup/plugin-node-resolve': 15.2.3(rollup@4.21.2) + '@rollup/plugin-replace': 5.0.7(rollup@4.21.2) + '@rollup/plugin-terser': 0.4.4(rollup@4.21.2) '@sanity/browserslist-config': 1.0.3 babel-plugin-react-compiler: 0.0.0-experimental-938cd9a-20240601 browserslist: 4.23.3 @@ -14408,8 +14414,8 @@ snapshots: prompts: 2.4.2 recast: 0.23.9 rimraf: 4.4.1 - rollup: 4.21.0 - rollup-plugin-esbuild: 6.1.1(esbuild@0.23.1)(rollup@4.21.0) + rollup: 4.21.2 + rollup-plugin-esbuild: 6.1.1(esbuild@0.23.1)(rollup@4.21.2) rxjs: 7.8.1 treeify: 1.1.0 typescript: 5.5.4 @@ -14422,23 +14428,23 @@ snapshots: - debug - supports-color - '@sanity/pkg-utils@6.10.9(@types/babel__core@7.20.5)(@types/node@18.19.44)(debug@4.3.6)(typescript@5.5.4)': + '@sanity/pkg-utils@6.11.0(@types/babel__core@7.20.5)(@types/node@18.19.44)(debug@4.3.6)(typescript@5.5.4)': dependencies: '@babel/core': 7.25.2 '@babel/preset-typescript': 7.24.7(@babel/core@7.25.2) - '@babel/types': 7.25.2 - '@microsoft/api-extractor': 7.47.5(@types/node@18.19.44) + '@babel/types': 7.25.6 + '@microsoft/api-extractor': 7.47.7(@types/node@18.19.44) '@microsoft/tsdoc-config': 0.17.0 - '@optimize-lodash/rollup-plugin': 5.0.0(rollup@4.21.0) - '@rollup/plugin-alias': 5.1.0(rollup@4.21.0) - '@rollup/plugin-babel': 6.0.4(@babel/core@7.25.2)(@types/babel__core@7.20.5)(rollup@4.21.0) - '@rollup/plugin-commonjs': 26.0.1(rollup@4.21.0) - '@rollup/plugin-json': 6.1.0(rollup@4.21.0) - '@rollup/plugin-node-resolve': 15.2.3(rollup@4.21.0) - '@rollup/plugin-replace': 5.0.7(rollup@4.21.0) - '@rollup/plugin-terser': 0.4.4(rollup@4.21.0) + '@optimize-lodash/rollup-plugin': 5.0.0(rollup@4.21.2) + '@rollup/plugin-alias': 5.1.0(rollup@4.21.2) + '@rollup/plugin-babel': 6.0.4(@babel/core@7.25.2)(@types/babel__core@7.20.5)(rollup@4.21.2) + '@rollup/plugin-commonjs': 26.0.1(rollup@4.21.2) + '@rollup/plugin-json': 6.1.0(rollup@4.21.2) + '@rollup/plugin-node-resolve': 15.2.3(rollup@4.21.2) + '@rollup/plugin-replace': 5.0.7(rollup@4.21.2) + '@rollup/plugin-terser': 0.4.4(rollup@4.21.2) '@sanity/browserslist-config': 1.0.3 - babel-plugin-react-compiler: 0.0.0-experimental-938cd9a-20240601 + babel-plugin-react-compiler: 0.0.0-experimental-e68eda9-20240829 browserslist: 4.23.3 cac: 6.7.14 chalk: 4.1.2 @@ -14447,7 +14453,7 @@ snapshots: esbuild-register: 3.6.0(esbuild@0.23.1) find-config: 1.0.0 get-latest-version: 5.1.0(debug@4.3.6) - git-url-parse: 14.1.0 + git-url-parse: 15.0.0 globby: 11.1.0 jsonc-parser: 3.3.1 mkdirp: 3.0.1 @@ -14459,8 +14465,8 @@ snapshots: prompts: 2.4.2 recast: 0.23.9 rimraf: 4.4.1 - rollup: 4.21.0 - rollup-plugin-esbuild: 6.1.1(esbuild@0.23.1)(rollup@4.21.0) + rollup: 4.21.2 + rollup-plugin-esbuild: 6.1.1(esbuild@0.23.1)(rollup@4.21.2) rxjs: 7.8.1 treeify: 1.1.0 typescript: 5.5.4 @@ -15075,14 +15081,14 @@ snapshots: '@types/babel__core@7.20.5': dependencies: '@babel/parser': 7.25.3 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 '@types/babel__generator': 7.6.8 '@types/babel__template': 7.4.4 '@types/babel__traverse': 7.20.6 '@types/babel__generator@7.6.8': dependencies: - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 '@types/babel__register@7.17.3': dependencies: @@ -15091,11 +15097,11 @@ snapshots: '@types/babel__template@7.4.4': dependencies: '@babel/parser': 7.25.3 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 '@types/babel__traverse@7.20.6': dependencies: - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 '@types/caseless@0.12.5': {} @@ -15871,7 +15877,7 @@ snapshots: babel-plugin-jest-hoist@29.6.3: dependencies: '@babel/template': 7.25.0 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 '@types/babel__core': 7.20.5 '@types/babel__traverse': 7.20.6 @@ -15908,7 +15914,7 @@ snapshots: babel-plugin-react-compiler@0.0.0-experimental-334f00b-20240725: dependencies: '@babel/generator': 7.2.0 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 chalk: 4.1.2 invariant: 2.2.4 pretty-format: 24.9.0 @@ -15918,7 +15924,17 @@ snapshots: babel-plugin-react-compiler@0.0.0-experimental-938cd9a-20240601: dependencies: '@babel/generator': 7.2.0 - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 + chalk: 4.1.2 + invariant: 2.2.4 + pretty-format: 24.9.0 + zod: 3.23.8 + zod-validation-error: 2.1.0(zod@3.23.8) + + babel-plugin-react-compiler@0.0.0-experimental-e68eda9-20240829: + dependencies: + '@babel/generator': 7.2.0 + '@babel/types': 7.25.6 chalk: 4.1.2 invariant: 2.2.4 pretty-format: 24.9.0 @@ -18216,6 +18232,10 @@ snapshots: dependencies: git-up: 7.0.0 + git-url-parse@15.0.0: + dependencies: + git-up: 7.0.0 + git-user-info@2.0.3: dependencies: git-config-path: 1.0.1 @@ -19276,7 +19296,7 @@ snapshots: '@babel/generator': 7.25.0 '@babel/plugin-syntax-jsx': 7.24.7(@babel/core@7.25.2) '@babel/plugin-syntax-typescript': 7.24.7(@babel/core@7.25.2) - '@babel/types': 7.25.2 + '@babel/types': 7.25.6 '@jest/expect-utils': 29.7.0 '@jest/transform': 29.7.0 '@jest/types': 29.6.3 @@ -21520,14 +21540,14 @@ snapshots: dependencies: glob: 10.4.5 - rollup-plugin-esbuild@6.1.1(esbuild@0.23.1)(rollup@4.21.0): + rollup-plugin-esbuild@6.1.1(esbuild@0.23.1)(rollup@4.21.2): dependencies: - '@rollup/pluginutils': 5.1.0(rollup@4.21.0) + '@rollup/pluginutils': 5.1.0(rollup@4.21.2) debug: 4.3.6(supports-color@9.4.0) es-module-lexer: 1.5.4 esbuild: 0.23.1 get-tsconfig: 4.7.6 - rollup: 4.21.0 + rollup: 4.21.2 transitivePeerDependencies: - supports-color @@ -21535,26 +21555,26 @@ snapshots: optionalDependencies: fsevents: 2.3.3 - rollup@4.21.0: + rollup@4.21.2: dependencies: '@types/estree': 1.0.5 optionalDependencies: - '@rollup/rollup-android-arm-eabi': 4.21.0 - '@rollup/rollup-android-arm64': 4.21.0 - '@rollup/rollup-darwin-arm64': 4.21.0 - '@rollup/rollup-darwin-x64': 4.21.0 - '@rollup/rollup-linux-arm-gnueabihf': 4.21.0 - '@rollup/rollup-linux-arm-musleabihf': 4.21.0 - '@rollup/rollup-linux-arm64-gnu': 4.21.0 - '@rollup/rollup-linux-arm64-musl': 4.21.0 - '@rollup/rollup-linux-powerpc64le-gnu': 4.21.0 - '@rollup/rollup-linux-riscv64-gnu': 4.21.0 - '@rollup/rollup-linux-s390x-gnu': 4.21.0 - '@rollup/rollup-linux-x64-gnu': 4.21.0 - '@rollup/rollup-linux-x64-musl': 4.21.0 - '@rollup/rollup-win32-arm64-msvc': 4.21.0 - '@rollup/rollup-win32-ia32-msvc': 4.21.0 - '@rollup/rollup-win32-x64-msvc': 4.21.0 + '@rollup/rollup-android-arm-eabi': 4.21.2 + '@rollup/rollup-android-arm64': 4.21.2 + '@rollup/rollup-darwin-arm64': 4.21.2 + '@rollup/rollup-darwin-x64': 4.21.2 + '@rollup/rollup-linux-arm-gnueabihf': 4.21.2 + '@rollup/rollup-linux-arm-musleabihf': 4.21.2 + '@rollup/rollup-linux-arm64-gnu': 4.21.2 + '@rollup/rollup-linux-arm64-musl': 4.21.2 + '@rollup/rollup-linux-powerpc64le-gnu': 4.21.2 + '@rollup/rollup-linux-riscv64-gnu': 4.21.2 + '@rollup/rollup-linux-s390x-gnu': 4.21.2 + '@rollup/rollup-linux-x64-gnu': 4.21.2 + '@rollup/rollup-linux-x64-musl': 4.21.2 + '@rollup/rollup-win32-arm64-msvc': 4.21.2 + '@rollup/rollup-win32-ia32-msvc': 4.21.2 + '@rollup/rollup-win32-x64-msvc': 4.21.2 fsevents: 2.3.3 rrweb-cssom@0.6.0: {} @@ -22884,7 +22904,7 @@ snapshots: dependencies: esbuild: 0.21.5 postcss: 8.4.41 - rollup: 4.21.0 + rollup: 4.21.2 optionalDependencies: '@types/node': 18.19.44 fsevents: 2.3.3 From b0dc1a09d03312ff0caef368f5a9728125d542ad Mon Sep 17 00:00:00 2001 From: Ryan Bonial Date: Fri, 20 Sep 2024 12:13:07 -0600 Subject: [PATCH 3/3] Add authorization subscription to presence store --- .../message-transports/bifurTransport.ts | 40 ++++++++++++------- .../presence/message-transports/transport.ts | 17 +++++++- .../store/_legacy/presence/presence-store.ts | 4 ++ 3 files changed, 44 insertions(+), 17 deletions(-) diff --git a/packages/sanity/src/core/store/_legacy/presence/message-transports/bifurTransport.ts b/packages/sanity/src/core/store/_legacy/presence/message-transports/bifurTransport.ts index 1a26807ca45..3c0193f8e31 100644 --- a/packages/sanity/src/core/store/_legacy/presence/message-transports/bifurTransport.ts +++ b/packages/sanity/src/core/store/_legacy/presence/message-transports/bifurTransport.ts @@ -26,7 +26,17 @@ type RollCallEvent = { session: string } -type IncomingBifurEvent = RollCallEvent | BifurStateMessage | BifurDisconnectMessage +type ExpireEvent = { + type: 'expires' + event: 'expires' + at: string +} + +type IncomingBifurEvent = + | RollCallEvent + | BifurStateMessage + | BifurDisconnectMessage + | ExpireEvent const handleIncomingMessage = (event: IncomingBifurEvent): TransportEvent => { // console.log('ws incoming event', event) @@ -57,14 +67,13 @@ const handleIncomingMessage = (event: IncomingBifurEvent): Transport } } - // if (event.type === 'subscription') { - // return { - // type: 'subscription', - // userId: event.i, - // sessionId: event.m.session, - // timestamp: new Date().toISOString(), - // } - // } + if (event.event === 'expires') { + return { + type: 'authorizationExpire', + expiresAt: event.at, + timestamp: new Date().toISOString(), + } + } throw new Error(`Got unknown presence event: ${JSON.stringify(event)}`) } @@ -78,12 +87,13 @@ export const createBifurTransport = (bifur: BifurClient, sessionId: string): Tra .listen>('authorization') .pipe(map(handleIncomingMessage)) - const testIncomingAuthorizationEvents$: Observable = bifur - .listen>('authorization') - .subscribe((event) => { - // eslint-disable-next-line no-console - console.log('[++++++]Authorization event', event) - }) + // const testIncomingAuthorizationEvents$: Observable = bifur + // .listen>('authorization') + // .pipe(map(handleIncomingMessage)) + // .subscribe((event) => { + // // eslint-disable-next-line no-console + // console.log('[++++++]Authorization event', event) + // }) const dispatchMessage = (message: TransportMessage): Observable => { if (message.type === 'rollCall') { diff --git a/packages/sanity/src/core/store/_legacy/presence/message-transports/transport.ts b/packages/sanity/src/core/store/_legacy/presence/message-transports/transport.ts index 54c629f4643..9f956acf24e 100644 --- a/packages/sanity/src/core/store/_legacy/presence/message-transports/transport.ts +++ b/packages/sanity/src/core/store/_legacy/presence/message-transports/transport.ts @@ -42,8 +42,21 @@ export interface RollCallEvent extends RollCallMessage { userId: string } -export type TransportMessage = DisconnectMessage | StateMessage | RollCallMessage -export type TransportEvent = StateEvent | RollCallEvent | DisconnectEvent +export interface AuthorizationExpireMessage { + type: 'authorizationExpire' +} + +export interface AuthorizationExpireEvent extends AuthorizationExpireMessage { + expiresAt: string + timestamp: string +} + +export type TransportMessage = + | DisconnectMessage + | StateMessage + | RollCallMessage + | AuthorizationExpireMessage +export type TransportEvent = StateEvent | RollCallEvent | DisconnectEvent | AuthorizationExpireEvent // This is the interface a transport must implement export type Transport = [ diff --git a/packages/sanity/src/core/store/_legacy/presence/presence-store.ts b/packages/sanity/src/core/store/_legacy/presence/presence-store.ts index 517edb2a15e..842de975699 100644 --- a/packages/sanity/src/core/store/_legacy/presence/presence-store.ts +++ b/packages/sanity/src/core/store/_legacy/presence/presence-store.ts @@ -126,6 +126,10 @@ export function __tmp_wrap_presenceStore(context: { SESSION_ID, ) + authorizationEvents$.subscribe((event) => { + // console.log('[++++++]Authorization event', event) + }) + const currentLocation$ = new BehaviorSubject([]) const locationChange$ = currentLocation$.pipe(distinctUntilChanged())