@atproto/pds 0.4.104 → 0.4.105
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +22 -0
- package/dist/account-manager/{index.d.ts → account-manager.d.ts} +26 -35
- package/dist/account-manager/account-manager.d.ts.map +1 -0
- package/dist/account-manager/{index.js → account-manager.js} +52 -207
- package/dist/account-manager/account-manager.js.map +1 -0
- package/dist/account-manager/helpers/account.d.ts +3 -3
- package/dist/account-manager/helpers/device-account.d.ts +15 -15
- package/dist/account-manager/helpers/device-account.d.ts.map +1 -1
- package/dist/account-manager/helpers/device-account.js +2 -1
- package/dist/account-manager/helpers/device-account.js.map +1 -1
- package/dist/account-manager/helpers/token.d.ts +98 -98
- package/dist/account-manager/oauth-store.d.ts +58 -0
- package/dist/account-manager/oauth-store.d.ts.map +1 -0
- package/dist/account-manager/oauth-store.js +417 -0
- package/dist/account-manager/oauth-store.js.map +1 -0
- package/dist/actor-store/record/reader.d.ts +3 -3
- package/dist/actor-store/repo/reader.d.ts +2 -0
- package/dist/actor-store/repo/reader.d.ts.map +1 -1
- package/dist/actor-store/repo/reader.js +9 -0
- package/dist/actor-store/repo/reader.js.map +1 -1
- package/dist/actor-store/repo/sql-repo-reader.d.ts +1 -1
- package/dist/actor-store/repo/transactor.d.ts.map +1 -1
- package/dist/actor-store/repo/transactor.js +13 -4
- package/dist/actor-store/repo/transactor.js.map +1 -1
- package/dist/api/com/atproto/admin/deleteAccount.d.ts.map +1 -1
- package/dist/api/com/atproto/admin/deleteAccount.js +2 -3
- package/dist/api/com/atproto/admin/deleteAccount.js.map +1 -1
- package/dist/api/com/atproto/admin/updateAccountHandle.d.ts.map +1 -1
- package/dist/api/com/atproto/admin/updateAccountHandle.js +2 -6
- package/dist/api/com/atproto/admin/updateAccountHandle.js.map +1 -1
- package/dist/api/com/atproto/identity/resolveHandle.d.ts.map +1 -1
- package/dist/api/com/atproto/identity/resolveHandle.js +2 -36
- package/dist/api/com/atproto/identity/resolveHandle.js.map +1 -1
- package/dist/api/com/atproto/identity/updateHandle.d.ts.map +1 -1
- package/dist/api/com/atproto/identity/updateHandle.js +1 -7
- package/dist/api/com/atproto/identity/updateHandle.js.map +1 -1
- package/dist/api/com/atproto/server/activateAccount.d.ts.map +1 -1
- package/dist/api/com/atproto/server/activateAccount.js +2 -18
- package/dist/api/com/atproto/server/activateAccount.js.map +1 -1
- package/dist/api/com/atproto/server/createAccount.d.ts.map +1 -1
- package/dist/api/com/atproto/server/createAccount.js +5 -7
- package/dist/api/com/atproto/server/createAccount.js.map +1 -1
- package/dist/api/com/atproto/server/createSession.js +1 -1
- package/dist/api/com/atproto/server/createSession.js.map +1 -1
- package/dist/api/com/atproto/server/deleteAccount.d.ts.map +1 -1
- package/dist/api/com/atproto/server/deleteAccount.js +2 -3
- package/dist/api/com/atproto/server/deleteAccount.js.map +1 -1
- package/dist/api/com/atproto/server/getSession.js +1 -1
- package/dist/api/com/atproto/server/getSession.js.map +1 -1
- package/dist/api/com/atproto/server/refreshSession.js +1 -1
- package/dist/api/com/atproto/server/refreshSession.js.map +1 -1
- package/dist/api/com/atproto/sync/getRecord.d.ts.map +1 -1
- package/dist/api/com/atproto/sync/getRecord.js.map +1 -1
- package/dist/api/com/atproto/sync/getRepoStatus.js +1 -1
- package/dist/api/com/atproto/sync/getRepoStatus.js.map +1 -1
- package/dist/api/com/atproto/sync/listRepos.js +1 -1
- package/dist/api/com/atproto/sync/listRepos.js.map +1 -1
- package/dist/api/com/atproto/sync/subscribeRepos.d.ts.map +1 -1
- package/dist/api/com/atproto/sync/subscribeRepos.js +2 -10
- package/dist/api/com/atproto/sync/subscribeRepos.js.map +1 -1
- package/dist/app-view.d.ts +14 -0
- package/dist/app-view.d.ts.map +1 -0
- package/dist/app-view.js +36 -0
- package/dist/app-view.js.map +1 -0
- package/dist/auth-routes.d.ts +1 -1
- package/dist/auth-routes.d.ts.map +1 -1
- package/dist/auth-routes.js +9 -3
- package/dist/auth-routes.js.map +1 -1
- package/dist/auth-verifier.d.ts +1 -1
- package/dist/auth-verifier.d.ts.map +1 -1
- package/dist/config/config.d.ts +3 -2
- package/dist/config/config.d.ts.map +1 -1
- package/dist/config/config.js +17 -7
- package/dist/config/config.js.map +1 -1
- package/dist/config/env.d.ts +4 -0
- package/dist/config/env.d.ts.map +1 -1
- package/dist/config/env.js +5 -0
- package/dist/config/env.js.map +1 -1
- package/dist/context.d.ts +4 -4
- package/dist/context.d.ts.map +1 -1
- package/dist/context.js +24 -18
- package/dist/context.js.map +1 -1
- package/dist/handle/index.d.ts +0 -7
- package/dist/handle/index.d.ts.map +1 -1
- package/dist/handle/index.js +4 -58
- package/dist/handle/index.js.map +1 -1
- package/dist/image/image-url.d.ts +8 -0
- package/dist/image/image-url.d.ts.map +1 -0
- package/dist/image/image-url.js +26 -0
- package/dist/image/image-url.js.map +1 -0
- package/dist/lexicon/index.d.ts +6 -0
- package/dist/lexicon/index.d.ts.map +1 -1
- package/dist/lexicon/index.js +12 -0
- package/dist/lexicon/index.js.map +1 -1
- package/dist/lexicon/lexicons.d.ts +304 -130
- package/dist/lexicon/lexicons.d.ts.map +1 -1
- package/dist/lexicon/lexicons.js +168 -67
- package/dist/lexicon/lexicons.js.map +1 -1
- package/dist/lexicon/types/app/bsky/embed/video.d.ts +1 -0
- package/dist/lexicon/types/app/bsky/embed/video.d.ts.map +1 -1
- package/dist/lexicon/types/app/bsky/embed/video.js.map +1 -1
- package/dist/lexicon/types/com/atproto/identity/defs.d.ts +17 -0
- package/dist/lexicon/types/com/atproto/identity/defs.d.ts.map +1 -0
- package/dist/lexicon/types/com/atproto/identity/defs.js +16 -0
- package/dist/lexicon/types/com/atproto/identity/defs.js.map +1 -0
- package/dist/lexicon/types/com/atproto/identity/refreshIdentity.d.ts +39 -0
- package/dist/lexicon/types/com/atproto/identity/refreshIdentity.d.ts.map +1 -0
- package/dist/lexicon/types/com/atproto/identity/refreshIdentity.js +7 -0
- package/dist/lexicon/types/com/atproto/identity/refreshIdentity.js.map +1 -0
- package/dist/lexicon/types/com/atproto/identity/resolveDid.d.ts +40 -0
- package/dist/lexicon/types/com/atproto/identity/resolveDid.d.ts.map +1 -0
- package/dist/lexicon/types/com/atproto/identity/resolveDid.js +7 -0
- package/dist/lexicon/types/com/atproto/identity/resolveDid.js.map +1 -0
- package/dist/lexicon/types/com/atproto/identity/resolveHandle.d.ts +1 -0
- package/dist/lexicon/types/com/atproto/identity/resolveHandle.d.ts.map +1 -1
- package/dist/lexicon/types/com/atproto/identity/resolveIdentity.d.ts +36 -0
- package/dist/lexicon/types/com/atproto/identity/resolveIdentity.d.ts.map +1 -0
- package/dist/lexicon/types/com/atproto/identity/resolveIdentity.js +7 -0
- package/dist/lexicon/types/com/atproto/identity/resolveIdentity.js.map +1 -0
- package/dist/lexicon/types/com/atproto/sync/subscribeRepos.d.ts +1 -30
- package/dist/lexicon/types/com/atproto/sync/subscribeRepos.d.ts.map +1 -1
- package/dist/lexicon/types/com/atproto/sync/subscribeRepos.js +0 -27
- package/dist/lexicon/types/com/atproto/sync/subscribeRepos.js.map +1 -1
- package/dist/mailer/index.d.ts +5 -5
- package/dist/mailer/index.d.ts.map +1 -1
- package/dist/mailer/index.js +6 -5
- package/dist/mailer/index.js.map +1 -1
- package/dist/read-after-write/viewer.d.ts +1 -1
- package/dist/read-after-write/viewer.d.ts.map +1 -1
- package/dist/repo/types.d.ts +6 -2
- package/dist/repo/types.d.ts.map +1 -1
- package/dist/repo/types.js.map +1 -1
- package/dist/scripts/rebuild-repo.d.ts.map +1 -1
- package/dist/scripts/rebuild-repo.js +2 -1
- package/dist/scripts/rebuild-repo.js.map +1 -1
- package/dist/sequencer/db/schema.d.ts +1 -1
- package/dist/sequencer/db/schema.d.ts.map +1 -1
- package/dist/sequencer/events.d.ts +29 -41
- package/dist/sequencer/events.d.ts.map +1 -1
- package/dist/sequencer/events.js +24 -58
- package/dist/sequencer/events.js.map +1 -1
- package/dist/sequencer/sequencer.d.ts +2 -3
- package/dist/sequencer/sequencer.d.ts.map +1 -1
- package/dist/sequencer/sequencer.js +5 -17
- package/dist/sequencer/sequencer.js.map +1 -1
- package/package.json +15 -15
- package/src/account-manager/{index.ts → account-manager.ts} +107 -307
- package/src/account-manager/helpers/device-account.ts +1 -0
- package/src/account-manager/oauth-store.ts +494 -0
- package/src/actor-store/repo/reader.ts +11 -0
- package/src/actor-store/repo/transactor.ts +15 -4
- package/src/api/com/atproto/admin/deleteAccount.ts +2 -3
- package/src/api/com/atproto/admin/updateAccountHandle.ts +7 -8
- package/src/api/com/atproto/identity/resolveHandle.ts +2 -11
- package/src/api/com/atproto/identity/updateHandle.ts +4 -7
- package/src/api/com/atproto/server/activateAccount.ts +4 -18
- package/src/api/com/atproto/server/createAccount.ts +10 -11
- package/src/api/com/atproto/server/createSession.ts +1 -1
- package/src/api/com/atproto/server/deleteAccount.ts +2 -3
- package/src/api/com/atproto/server/getSession.ts +1 -1
- package/src/api/com/atproto/server/refreshSession.ts +1 -1
- package/src/api/com/atproto/sync/getRecord.ts +0 -1
- package/src/api/com/atproto/sync/getRepoStatus.ts +1 -1
- package/src/api/com/atproto/sync/listRepos.ts +1 -1
- package/src/api/com/atproto/sync/subscribeRepos.ts +2 -9
- package/src/app-view.ts +24 -0
- package/src/auth-routes.ts +9 -3
- package/src/auth-verifier.ts +1 -1
- package/src/config/config.ts +25 -13
- package/src/config/env.ts +12 -0
- package/src/context.ts +44 -24
- package/src/handle/index.ts +6 -52
- package/src/image/image-url.ts +16 -0
- package/src/lexicon/index.ts +36 -0
- package/src/lexicon/lexicons.ts +183 -67
- package/src/lexicon/types/app/bsky/embed/video.ts +1 -0
- package/src/lexicon/types/com/atproto/identity/defs.ts +30 -0
- package/src/lexicon/types/com/atproto/identity/refreshIdentity.ts +52 -0
- package/src/lexicon/types/com/atproto/identity/resolveDid.ts +52 -0
- package/src/lexicon/types/com/atproto/identity/resolveHandle.ts +1 -0
- package/src/lexicon/types/com/atproto/identity/resolveIdentity.ts +48 -0
- package/src/lexicon/types/com/atproto/sync/subscribeRepos.ts +0 -59
- package/src/mailer/index.ts +7 -5
- package/src/read-after-write/viewer.ts +1 -1
- package/src/repo/types.ts +7 -2
- package/src/scripts/rebuild-repo.ts +4 -1
- package/src/sequencer/db/schema.ts +1 -8
- package/src/sequencer/events.ts +29 -75
- package/src/sequencer/sequencer.ts +9 -23
- package/tests/account-deletion.test.ts +3 -5
- package/tests/oauth.test.ts +286 -71
- package/tests/sequencer.test.ts +18 -27
- package/tests/sync/subscribe-repos.test.ts +67 -45
- package/tsconfig.build.tsbuildinfo +1 -1
- package/dist/account-manager/index.d.ts.map +0 -1
- package/dist/account-manager/index.js.map +0 -1
- package/dist/actor-store/repo/util.d.ts +0 -5
- package/dist/actor-store/repo/util.d.ts.map +0 -1
- package/dist/actor-store/repo/util.js +0 -25
- package/dist/actor-store/repo/util.js.map +0 -1
- package/dist/oauth/provider.d.ts +0 -10
- package/dist/oauth/provider.d.ts.map +0 -1
- package/dist/oauth/provider.js +0 -38
- package/dist/oauth/provider.js.map +0 -1
- package/src/actor-store/repo/util.ts +0 -22
- package/src/oauth/provider.ts +0 -59
package/src/lexicon/lexicons.ts
CHANGED
@@ -637,6 +637,32 @@ export const schemaDict = {
|
|
637
637
|
},
|
638
638
|
},
|
639
639
|
},
|
640
|
+
ComAtprotoIdentityDefs: {
|
641
|
+
lexicon: 1,
|
642
|
+
id: 'com.atproto.identity.defs',
|
643
|
+
defs: {
|
644
|
+
identityInfo: {
|
645
|
+
type: 'object',
|
646
|
+
required: ['did', 'handle', 'didDoc'],
|
647
|
+
properties: {
|
648
|
+
did: {
|
649
|
+
type: 'string',
|
650
|
+
format: 'did',
|
651
|
+
},
|
652
|
+
handle: {
|
653
|
+
type: 'string',
|
654
|
+
format: 'handle',
|
655
|
+
description:
|
656
|
+
"The validated handle of the account; or 'handle.invalid' if the handle did not bi-directionally match the DID document.",
|
657
|
+
},
|
658
|
+
didDoc: {
|
659
|
+
type: 'unknown',
|
660
|
+
description: 'The complete DID document for the identity.',
|
661
|
+
},
|
662
|
+
},
|
663
|
+
},
|
664
|
+
},
|
665
|
+
},
|
640
666
|
ComAtprotoIdentityGetRecommendedDidCredentials: {
|
641
667
|
lexicon: 1,
|
642
668
|
id: 'com.atproto.identity.getRecommendedDidCredentials',
|
@@ -676,6 +702,54 @@ export const schemaDict = {
|
|
676
702
|
},
|
677
703
|
},
|
678
704
|
},
|
705
|
+
ComAtprotoIdentityRefreshIdentity: {
|
706
|
+
lexicon: 1,
|
707
|
+
id: 'com.atproto.identity.refreshIdentity',
|
708
|
+
defs: {
|
709
|
+
main: {
|
710
|
+
type: 'procedure',
|
711
|
+
description:
|
712
|
+
'Request that the server re-resolve an identity (DID and handle). The server may ignore this request, or require authentication, depending on the role, implementation, and policy of the server.',
|
713
|
+
input: {
|
714
|
+
encoding: 'application/json',
|
715
|
+
schema: {
|
716
|
+
type: 'object',
|
717
|
+
required: ['identifier'],
|
718
|
+
properties: {
|
719
|
+
identifier: {
|
720
|
+
type: 'string',
|
721
|
+
format: 'at-identifier',
|
722
|
+
},
|
723
|
+
},
|
724
|
+
},
|
725
|
+
},
|
726
|
+
output: {
|
727
|
+
encoding: 'application/json',
|
728
|
+
schema: {
|
729
|
+
type: 'ref',
|
730
|
+
ref: 'lex:com.atproto.identity.defs#identityInfo',
|
731
|
+
},
|
732
|
+
},
|
733
|
+
errors: [
|
734
|
+
{
|
735
|
+
name: 'HandleNotFound',
|
736
|
+
description:
|
737
|
+
'The resolution process confirmed that the handle does not resolve to any DID.',
|
738
|
+
},
|
739
|
+
{
|
740
|
+
name: 'DidNotFound',
|
741
|
+
description:
|
742
|
+
'The DID resolution process confirmed that there is no current DID.',
|
743
|
+
},
|
744
|
+
{
|
745
|
+
name: 'DidDeactivated',
|
746
|
+
description:
|
747
|
+
'The DID previously existed, but has been deactivated.',
|
748
|
+
},
|
749
|
+
],
|
750
|
+
},
|
751
|
+
},
|
752
|
+
},
|
679
753
|
ComAtprotoIdentityRequestPlcOperationSignature: {
|
680
754
|
lexicon: 1,
|
681
755
|
id: 'com.atproto.identity.requestPlcOperationSignature',
|
@@ -687,13 +761,61 @@ export const schemaDict = {
|
|
687
761
|
},
|
688
762
|
},
|
689
763
|
},
|
764
|
+
ComAtprotoIdentityResolveDid: {
|
765
|
+
lexicon: 1,
|
766
|
+
id: 'com.atproto.identity.resolveDid',
|
767
|
+
defs: {
|
768
|
+
main: {
|
769
|
+
type: 'query',
|
770
|
+
description:
|
771
|
+
'Resolves DID to DID document. Does not bi-directionally verify handle.',
|
772
|
+
parameters: {
|
773
|
+
type: 'params',
|
774
|
+
required: ['did'],
|
775
|
+
properties: {
|
776
|
+
did: {
|
777
|
+
type: 'string',
|
778
|
+
format: 'did',
|
779
|
+
description: 'DID to resolve.',
|
780
|
+
},
|
781
|
+
},
|
782
|
+
},
|
783
|
+
output: {
|
784
|
+
encoding: 'application/json',
|
785
|
+
schema: {
|
786
|
+
type: 'object',
|
787
|
+
required: ['didDoc'],
|
788
|
+
properties: {
|
789
|
+
didDoc: {
|
790
|
+
type: 'unknown',
|
791
|
+
description: 'The complete DID document for the identity.',
|
792
|
+
},
|
793
|
+
},
|
794
|
+
},
|
795
|
+
},
|
796
|
+
errors: [
|
797
|
+
{
|
798
|
+
name: 'DidNotFound',
|
799
|
+
description:
|
800
|
+
'The DID resolution process confirmed that there is no current DID.',
|
801
|
+
},
|
802
|
+
{
|
803
|
+
name: 'DidDeactivated',
|
804
|
+
description:
|
805
|
+
'The DID previously existed, but has been deactivated.',
|
806
|
+
},
|
807
|
+
],
|
808
|
+
},
|
809
|
+
},
|
810
|
+
},
|
690
811
|
ComAtprotoIdentityResolveHandle: {
|
691
812
|
lexicon: 1,
|
692
813
|
id: 'com.atproto.identity.resolveHandle',
|
693
814
|
defs: {
|
694
815
|
main: {
|
695
816
|
type: 'query',
|
696
|
-
description:
|
817
|
+
description:
|
818
|
+
'Resolves an atproto handle (hostname) to a DID. Does not necessarily bi-directionally verify against the the DID document.',
|
697
819
|
parameters: {
|
698
820
|
type: 'params',
|
699
821
|
required: ['handle'],
|
@@ -718,6 +840,59 @@ export const schemaDict = {
|
|
718
840
|
},
|
719
841
|
},
|
720
842
|
},
|
843
|
+
errors: [
|
844
|
+
{
|
845
|
+
name: 'HandleNotFound',
|
846
|
+
description:
|
847
|
+
'The resolution process confirmed that the handle does not resolve to any DID.',
|
848
|
+
},
|
849
|
+
],
|
850
|
+
},
|
851
|
+
},
|
852
|
+
},
|
853
|
+
ComAtprotoIdentityResolveIdentity: {
|
854
|
+
lexicon: 1,
|
855
|
+
id: 'com.atproto.identity.resolveIdentity',
|
856
|
+
defs: {
|
857
|
+
main: {
|
858
|
+
type: 'query',
|
859
|
+
description:
|
860
|
+
'Resolves an identity (DID or Handle) to a full identity (DID document and verified handle).',
|
861
|
+
parameters: {
|
862
|
+
type: 'params',
|
863
|
+
required: ['identifier'],
|
864
|
+
properties: {
|
865
|
+
identifier: {
|
866
|
+
type: 'string',
|
867
|
+
format: 'at-identifier',
|
868
|
+
description: 'Handle or DID to resolve.',
|
869
|
+
},
|
870
|
+
},
|
871
|
+
},
|
872
|
+
output: {
|
873
|
+
encoding: 'application/json',
|
874
|
+
schema: {
|
875
|
+
type: 'ref',
|
876
|
+
ref: 'lex:com.atproto.identity.defs#identityInfo',
|
877
|
+
},
|
878
|
+
},
|
879
|
+
errors: [
|
880
|
+
{
|
881
|
+
name: 'HandleNotFound',
|
882
|
+
description:
|
883
|
+
'The resolution process confirmed that the handle does not resolve to any DID.',
|
884
|
+
},
|
885
|
+
{
|
886
|
+
name: 'DidNotFound',
|
887
|
+
description:
|
888
|
+
'The DID resolution process confirmed that there is no current DID.',
|
889
|
+
},
|
890
|
+
{
|
891
|
+
name: 'DidDeactivated',
|
892
|
+
description:
|
893
|
+
'The DID previously existed, but has been deactivated.',
|
894
|
+
},
|
895
|
+
],
|
721
896
|
},
|
722
897
|
},
|
723
898
|
},
|
@@ -3816,9 +3991,6 @@ export const schemaDict = {
|
|
3816
3991
|
'lex:com.atproto.sync.subscribeRepos#sync',
|
3817
3992
|
'lex:com.atproto.sync.subscribeRepos#identity',
|
3818
3993
|
'lex:com.atproto.sync.subscribeRepos#account',
|
3819
|
-
'lex:com.atproto.sync.subscribeRepos#handle',
|
3820
|
-
'lex:com.atproto.sync.subscribeRepos#migrate',
|
3821
|
-
'lex:com.atproto.sync.subscribeRepos#tombstone',
|
3822
3994
|
'lex:com.atproto.sync.subscribeRepos#info',
|
3823
3995
|
],
|
3824
3996
|
},
|
@@ -4022,68 +4194,6 @@ export const schemaDict = {
|
|
4022
4194
|
},
|
4023
4195
|
},
|
4024
4196
|
},
|
4025
|
-
handle: {
|
4026
|
-
type: 'object',
|
4027
|
-
description: 'DEPRECATED -- Use #identity event instead',
|
4028
|
-
required: ['seq', 'did', 'handle', 'time'],
|
4029
|
-
properties: {
|
4030
|
-
seq: {
|
4031
|
-
type: 'integer',
|
4032
|
-
},
|
4033
|
-
did: {
|
4034
|
-
type: 'string',
|
4035
|
-
format: 'did',
|
4036
|
-
},
|
4037
|
-
handle: {
|
4038
|
-
type: 'string',
|
4039
|
-
format: 'handle',
|
4040
|
-
},
|
4041
|
-
time: {
|
4042
|
-
type: 'string',
|
4043
|
-
format: 'datetime',
|
4044
|
-
},
|
4045
|
-
},
|
4046
|
-
},
|
4047
|
-
migrate: {
|
4048
|
-
type: 'object',
|
4049
|
-
description: 'DEPRECATED -- Use #account event instead',
|
4050
|
-
required: ['seq', 'did', 'migrateTo', 'time'],
|
4051
|
-
nullable: ['migrateTo'],
|
4052
|
-
properties: {
|
4053
|
-
seq: {
|
4054
|
-
type: 'integer',
|
4055
|
-
},
|
4056
|
-
did: {
|
4057
|
-
type: 'string',
|
4058
|
-
format: 'did',
|
4059
|
-
},
|
4060
|
-
migrateTo: {
|
4061
|
-
type: 'string',
|
4062
|
-
},
|
4063
|
-
time: {
|
4064
|
-
type: 'string',
|
4065
|
-
format: 'datetime',
|
4066
|
-
},
|
4067
|
-
},
|
4068
|
-
},
|
4069
|
-
tombstone: {
|
4070
|
-
type: 'object',
|
4071
|
-
description: 'DEPRECATED -- Use #account event instead',
|
4072
|
-
required: ['seq', 'did', 'time'],
|
4073
|
-
properties: {
|
4074
|
-
seq: {
|
4075
|
-
type: 'integer',
|
4076
|
-
},
|
4077
|
-
did: {
|
4078
|
-
type: 'string',
|
4079
|
-
format: 'did',
|
4080
|
-
},
|
4081
|
-
time: {
|
4082
|
-
type: 'string',
|
4083
|
-
format: 'datetime',
|
4084
|
-
},
|
4085
|
-
},
|
4086
|
-
},
|
4087
4197
|
info: {
|
4088
4198
|
type: 'object',
|
4089
4199
|
required: ['name'],
|
@@ -5583,8 +5693,10 @@ export const schemaDict = {
|
|
5583
5693
|
properties: {
|
5584
5694
|
video: {
|
5585
5695
|
type: 'blob',
|
5696
|
+
description:
|
5697
|
+
'The mp4 video file. May be up to 100mb, formerly limited to 50mb.',
|
5586
5698
|
accept: ['video/mp4'],
|
5587
|
-
maxSize:
|
5699
|
+
maxSize: 100000000,
|
5588
5700
|
},
|
5589
5701
|
captions: {
|
5590
5702
|
type: 'array',
|
@@ -14394,11 +14506,15 @@ export const ids = {
|
|
14394
14506
|
ComAtprotoAdminUpdateAccountPassword:
|
14395
14507
|
'com.atproto.admin.updateAccountPassword',
|
14396
14508
|
ComAtprotoAdminUpdateSubjectStatus: 'com.atproto.admin.updateSubjectStatus',
|
14509
|
+
ComAtprotoIdentityDefs: 'com.atproto.identity.defs',
|
14397
14510
|
ComAtprotoIdentityGetRecommendedDidCredentials:
|
14398
14511
|
'com.atproto.identity.getRecommendedDidCredentials',
|
14512
|
+
ComAtprotoIdentityRefreshIdentity: 'com.atproto.identity.refreshIdentity',
|
14399
14513
|
ComAtprotoIdentityRequestPlcOperationSignature:
|
14400
14514
|
'com.atproto.identity.requestPlcOperationSignature',
|
14515
|
+
ComAtprotoIdentityResolveDid: 'com.atproto.identity.resolveDid',
|
14401
14516
|
ComAtprotoIdentityResolveHandle: 'com.atproto.identity.resolveHandle',
|
14517
|
+
ComAtprotoIdentityResolveIdentity: 'com.atproto.identity.resolveIdentity',
|
14402
14518
|
ComAtprotoIdentitySignPlcOperation: 'com.atproto.identity.signPlcOperation',
|
14403
14519
|
ComAtprotoIdentitySubmitPlcOperation:
|
14404
14520
|
'com.atproto.identity.submitPlcOperation',
|
@@ -13,6 +13,7 @@ const id = 'app.bsky.embed.video'
|
|
13
13
|
|
14
14
|
export interface Main {
|
15
15
|
$type?: 'app.bsky.embed.video'
|
16
|
+
/** The mp4 video file. May be up to 100mb, formerly limited to 50mb. */
|
16
17
|
video: BlobRef
|
17
18
|
captions?: Caption[]
|
18
19
|
/** Alt text description of the video, for accessibility. */
|
@@ -0,0 +1,30 @@
|
|
1
|
+
/**
|
2
|
+
* GENERATED CODE - DO NOT MODIFY
|
3
|
+
*/
|
4
|
+
import { ValidationResult, BlobRef } from '@atproto/lexicon'
|
5
|
+
import { CID } from 'multiformats/cid'
|
6
|
+
import { validate as _validate } from '../../../../lexicons'
|
7
|
+
import { $Typed, is$typed as _is$typed, OmitKey } from '../../../../util'
|
8
|
+
|
9
|
+
const is$typed = _is$typed,
|
10
|
+
validate = _validate
|
11
|
+
const id = 'com.atproto.identity.defs'
|
12
|
+
|
13
|
+
export interface IdentityInfo {
|
14
|
+
$type?: 'com.atproto.identity.defs#identityInfo'
|
15
|
+
did: string
|
16
|
+
/** The validated handle of the account; or 'handle.invalid' if the handle did not bi-directionally match the DID document. */
|
17
|
+
handle: string
|
18
|
+
/** The complete DID document for the identity. */
|
19
|
+
didDoc: { [_ in string]: unknown }
|
20
|
+
}
|
21
|
+
|
22
|
+
const hashIdentityInfo = 'identityInfo'
|
23
|
+
|
24
|
+
export function isIdentityInfo<V>(v: V) {
|
25
|
+
return is$typed(v, id, hashIdentityInfo)
|
26
|
+
}
|
27
|
+
|
28
|
+
export function validateIdentityInfo<V>(v: V) {
|
29
|
+
return validate<IdentityInfo & V>(v, id, hashIdentityInfo)
|
30
|
+
}
|
@@ -0,0 +1,52 @@
|
|
1
|
+
/**
|
2
|
+
* GENERATED CODE - DO NOT MODIFY
|
3
|
+
*/
|
4
|
+
import express from 'express'
|
5
|
+
import { ValidationResult, BlobRef } from '@atproto/lexicon'
|
6
|
+
import { CID } from 'multiformats/cid'
|
7
|
+
import { validate as _validate } from '../../../../lexicons'
|
8
|
+
import { $Typed, is$typed as _is$typed, OmitKey } from '../../../../util'
|
9
|
+
import { HandlerAuth, HandlerPipeThrough } from '@atproto/xrpc-server'
|
10
|
+
import type * as ComAtprotoIdentityDefs from './defs.js'
|
11
|
+
|
12
|
+
const is$typed = _is$typed,
|
13
|
+
validate = _validate
|
14
|
+
const id = 'com.atproto.identity.refreshIdentity'
|
15
|
+
|
16
|
+
export interface QueryParams {}
|
17
|
+
|
18
|
+
export interface InputSchema {
|
19
|
+
identifier: string
|
20
|
+
}
|
21
|
+
|
22
|
+
export type OutputSchema = ComAtprotoIdentityDefs.IdentityInfo
|
23
|
+
|
24
|
+
export interface HandlerInput {
|
25
|
+
encoding: 'application/json'
|
26
|
+
body: InputSchema
|
27
|
+
}
|
28
|
+
|
29
|
+
export interface HandlerSuccess {
|
30
|
+
encoding: 'application/json'
|
31
|
+
body: OutputSchema
|
32
|
+
headers?: { [key: string]: string }
|
33
|
+
}
|
34
|
+
|
35
|
+
export interface HandlerError {
|
36
|
+
status: number
|
37
|
+
message?: string
|
38
|
+
error?: 'HandleNotFound' | 'DidNotFound' | 'DidDeactivated'
|
39
|
+
}
|
40
|
+
|
41
|
+
export type HandlerOutput = HandlerError | HandlerSuccess | HandlerPipeThrough
|
42
|
+
export type HandlerReqCtx<HA extends HandlerAuth = never> = {
|
43
|
+
auth: HA
|
44
|
+
params: QueryParams
|
45
|
+
input: HandlerInput
|
46
|
+
req: express.Request
|
47
|
+
res: express.Response
|
48
|
+
resetRouteRateLimits: () => Promise<void>
|
49
|
+
}
|
50
|
+
export type Handler<HA extends HandlerAuth = never> = (
|
51
|
+
ctx: HandlerReqCtx<HA>,
|
52
|
+
) => Promise<HandlerOutput> | HandlerOutput
|
@@ -0,0 +1,52 @@
|
|
1
|
+
/**
|
2
|
+
* GENERATED CODE - DO NOT MODIFY
|
3
|
+
*/
|
4
|
+
import express from 'express'
|
5
|
+
import { ValidationResult, BlobRef } from '@atproto/lexicon'
|
6
|
+
import { CID } from 'multiformats/cid'
|
7
|
+
import { validate as _validate } from '../../../../lexicons'
|
8
|
+
import { $Typed, is$typed as _is$typed, OmitKey } from '../../../../util'
|
9
|
+
import { HandlerAuth, HandlerPipeThrough } from '@atproto/xrpc-server'
|
10
|
+
|
11
|
+
const is$typed = _is$typed,
|
12
|
+
validate = _validate
|
13
|
+
const id = 'com.atproto.identity.resolveDid'
|
14
|
+
|
15
|
+
export interface QueryParams {
|
16
|
+
/** DID to resolve. */
|
17
|
+
did: string
|
18
|
+
}
|
19
|
+
|
20
|
+
export type InputSchema = undefined
|
21
|
+
|
22
|
+
export interface OutputSchema {
|
23
|
+
/** The complete DID document for the identity. */
|
24
|
+
didDoc: { [_ in string]: unknown }
|
25
|
+
}
|
26
|
+
|
27
|
+
export type HandlerInput = undefined
|
28
|
+
|
29
|
+
export interface HandlerSuccess {
|
30
|
+
encoding: 'application/json'
|
31
|
+
body: OutputSchema
|
32
|
+
headers?: { [key: string]: string }
|
33
|
+
}
|
34
|
+
|
35
|
+
export interface HandlerError {
|
36
|
+
status: number
|
37
|
+
message?: string
|
38
|
+
error?: 'DidNotFound' | 'DidDeactivated'
|
39
|
+
}
|
40
|
+
|
41
|
+
export type HandlerOutput = HandlerError | HandlerSuccess | HandlerPipeThrough
|
42
|
+
export type HandlerReqCtx<HA extends HandlerAuth = never> = {
|
43
|
+
auth: HA
|
44
|
+
params: QueryParams
|
45
|
+
input: HandlerInput
|
46
|
+
req: express.Request
|
47
|
+
res: express.Response
|
48
|
+
resetRouteRateLimits: () => Promise<void>
|
49
|
+
}
|
50
|
+
export type Handler<HA extends HandlerAuth = never> = (
|
51
|
+
ctx: HandlerReqCtx<HA>,
|
52
|
+
) => Promise<HandlerOutput> | HandlerOutput
|
@@ -0,0 +1,48 @@
|
|
1
|
+
/**
|
2
|
+
* GENERATED CODE - DO NOT MODIFY
|
3
|
+
*/
|
4
|
+
import express from 'express'
|
5
|
+
import { ValidationResult, BlobRef } from '@atproto/lexicon'
|
6
|
+
import { CID } from 'multiformats/cid'
|
7
|
+
import { validate as _validate } from '../../../../lexicons'
|
8
|
+
import { $Typed, is$typed as _is$typed, OmitKey } from '../../../../util'
|
9
|
+
import { HandlerAuth, HandlerPipeThrough } from '@atproto/xrpc-server'
|
10
|
+
import type * as ComAtprotoIdentityDefs from './defs.js'
|
11
|
+
|
12
|
+
const is$typed = _is$typed,
|
13
|
+
validate = _validate
|
14
|
+
const id = 'com.atproto.identity.resolveIdentity'
|
15
|
+
|
16
|
+
export interface QueryParams {
|
17
|
+
/** Handle or DID to resolve. */
|
18
|
+
identifier: string
|
19
|
+
}
|
20
|
+
|
21
|
+
export type InputSchema = undefined
|
22
|
+
export type OutputSchema = ComAtprotoIdentityDefs.IdentityInfo
|
23
|
+
export type HandlerInput = undefined
|
24
|
+
|
25
|
+
export interface HandlerSuccess {
|
26
|
+
encoding: 'application/json'
|
27
|
+
body: OutputSchema
|
28
|
+
headers?: { [key: string]: string }
|
29
|
+
}
|
30
|
+
|
31
|
+
export interface HandlerError {
|
32
|
+
status: number
|
33
|
+
message?: string
|
34
|
+
error?: 'HandleNotFound' | 'DidNotFound' | 'DidDeactivated'
|
35
|
+
}
|
36
|
+
|
37
|
+
export type HandlerOutput = HandlerError | HandlerSuccess | HandlerPipeThrough
|
38
|
+
export type HandlerReqCtx<HA extends HandlerAuth = never> = {
|
39
|
+
auth: HA
|
40
|
+
params: QueryParams
|
41
|
+
input: HandlerInput
|
42
|
+
req: express.Request
|
43
|
+
res: express.Response
|
44
|
+
resetRouteRateLimits: () => Promise<void>
|
45
|
+
}
|
46
|
+
export type Handler<HA extends HandlerAuth = never> = (
|
47
|
+
ctx: HandlerReqCtx<HA>,
|
48
|
+
) => Promise<HandlerOutput> | HandlerOutput
|
@@ -22,9 +22,6 @@ export type OutputSchema =
|
|
22
22
|
| $Typed<Sync>
|
23
23
|
| $Typed<Identity>
|
24
24
|
| $Typed<Account>
|
25
|
-
| $Typed<Handle>
|
26
|
-
| $Typed<Migrate>
|
27
|
-
| $Typed<Tombstone>
|
28
25
|
| $Typed<Info>
|
29
26
|
| { $type: string }
|
30
27
|
export type HandlerError = ErrorFrame<'FutureCursor' | 'ConsumerTooSlow'>
|
@@ -150,62 +147,6 @@ export function validateAccount<V>(v: V) {
|
|
150
147
|
return validate<Account & V>(v, id, hashAccount)
|
151
148
|
}
|
152
149
|
|
153
|
-
/** DEPRECATED -- Use #identity event instead */
|
154
|
-
export interface Handle {
|
155
|
-
$type?: 'com.atproto.sync.subscribeRepos#handle'
|
156
|
-
seq: number
|
157
|
-
did: string
|
158
|
-
handle: string
|
159
|
-
time: string
|
160
|
-
}
|
161
|
-
|
162
|
-
const hashHandle = 'handle'
|
163
|
-
|
164
|
-
export function isHandle<V>(v: V) {
|
165
|
-
return is$typed(v, id, hashHandle)
|
166
|
-
}
|
167
|
-
|
168
|
-
export function validateHandle<V>(v: V) {
|
169
|
-
return validate<Handle & V>(v, id, hashHandle)
|
170
|
-
}
|
171
|
-
|
172
|
-
/** DEPRECATED -- Use #account event instead */
|
173
|
-
export interface Migrate {
|
174
|
-
$type?: 'com.atproto.sync.subscribeRepos#migrate'
|
175
|
-
seq: number
|
176
|
-
did: string
|
177
|
-
migrateTo: string | null
|
178
|
-
time: string
|
179
|
-
}
|
180
|
-
|
181
|
-
const hashMigrate = 'migrate'
|
182
|
-
|
183
|
-
export function isMigrate<V>(v: V) {
|
184
|
-
return is$typed(v, id, hashMigrate)
|
185
|
-
}
|
186
|
-
|
187
|
-
export function validateMigrate<V>(v: V) {
|
188
|
-
return validate<Migrate & V>(v, id, hashMigrate)
|
189
|
-
}
|
190
|
-
|
191
|
-
/** DEPRECATED -- Use #account event instead */
|
192
|
-
export interface Tombstone {
|
193
|
-
$type?: 'com.atproto.sync.subscribeRepos#tombstone'
|
194
|
-
seq: number
|
195
|
-
did: string
|
196
|
-
time: string
|
197
|
-
}
|
198
|
-
|
199
|
-
const hashTombstone = 'tombstone'
|
200
|
-
|
201
|
-
export function isTombstone<V>(v: V) {
|
202
|
-
return is$typed(v, id, hashTombstone)
|
203
|
-
}
|
204
|
-
|
205
|
-
export function validateTombstone<V>(v: V) {
|
206
|
-
return validate<Tombstone & V>(v, id, hashTombstone)
|
207
|
-
}
|
208
|
-
|
209
150
|
export interface Info {
|
210
151
|
$type?: 'com.atproto.sync.subscribeRepos#info'
|
211
152
|
name: 'OutdatedCursor' | (string & {})
|
package/src/mailer/index.ts
CHANGED
@@ -6,6 +6,8 @@ import { ServerConfig } from '../config'
|
|
6
6
|
import { mailerLogger } from '../logger'
|
7
7
|
import * as templates from './templates'
|
8
8
|
|
9
|
+
// @TODO Add support for i18n
|
10
|
+
|
9
11
|
export class ServerMailer {
|
10
12
|
constructor(
|
11
13
|
public readonly transporter: Transporter<SMTPTransport.SentMessageInfo>,
|
@@ -23,35 +25,35 @@ export class ServerMailer {
|
|
23
25
|
params: { handle: string; token: string },
|
24
26
|
mailOpts: Mail.Options,
|
25
27
|
) {
|
26
|
-
|
28
|
+
await this.sendTemplate('resetPassword', params, {
|
27
29
|
subject: 'Password Reset Requested',
|
28
30
|
...mailOpts,
|
29
31
|
})
|
30
32
|
}
|
31
33
|
|
32
34
|
async sendAccountDelete(params: { token: string }, mailOpts: Mail.Options) {
|
33
|
-
|
35
|
+
await this.sendTemplate('deleteAccount', params, {
|
34
36
|
subject: 'Account Deletion Requested',
|
35
37
|
...mailOpts,
|
36
38
|
})
|
37
39
|
}
|
38
40
|
|
39
41
|
async sendConfirmEmail(params: { token: string }, mailOpts: Mail.Options) {
|
40
|
-
|
42
|
+
await this.sendTemplate('confirmEmail', params, {
|
41
43
|
subject: 'Email Confirmation',
|
42
44
|
...mailOpts,
|
43
45
|
})
|
44
46
|
}
|
45
47
|
|
46
48
|
async sendUpdateEmail(params: { token: string }, mailOpts: Mail.Options) {
|
47
|
-
|
49
|
+
await this.sendTemplate('updateEmail', params, {
|
48
50
|
subject: 'Email Update Requested',
|
49
51
|
...mailOpts,
|
50
52
|
})
|
51
53
|
}
|
52
54
|
|
53
55
|
async sendPlcOperation(params: { token: string }, mailOpts: Mail.Options) {
|
54
|
-
|
56
|
+
await this.sendTemplate('plcOperation', params, {
|
55
57
|
subject: 'PLC Update Operation Requested',
|
56
58
|
...mailOpts,
|
57
59
|
})
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { AtUri, INVALID_HANDLE } from '@atproto/syntax'
|
2
2
|
import { createServiceAuthHeaders } from '@atproto/xrpc-server'
|
3
|
-
import { AccountManager } from '../account-manager'
|
3
|
+
import { AccountManager } from '../account-manager/account-manager'
|
4
4
|
import { ActorStoreReader } from '../actor-store/actor-store-reader'
|
5
5
|
import { BskyAppView } from '../bsky-app-view'
|
6
6
|
import { ImageUrlBuilder } from '../image/image-url-builder'
|
package/src/repo/types.ts
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
import { CID } from 'multiformats/cid'
|
2
2
|
import { RepoRecord } from '@atproto/lexicon'
|
3
|
-
import {
|
3
|
+
import { BlockMap, CommitData, WriteOpAction } from '@atproto/repo'
|
4
4
|
import { AtUri } from '@atproto/syntax'
|
5
5
|
|
6
6
|
export type ValidationStatus = 'valid' | 'unknown' | undefined
|
@@ -51,12 +51,17 @@ export type CommitOp = {
|
|
51
51
|
|
52
52
|
export type CommitDataWithOps = CommitData & {
|
53
53
|
ops: CommitOp[]
|
54
|
-
blobs: CidSet
|
55
54
|
prevData: CID | null
|
56
55
|
}
|
57
56
|
|
58
57
|
export type PreparedWrite = PreparedCreate | PreparedUpdate | PreparedDelete
|
59
58
|
|
59
|
+
export type SyncEvtData = {
|
60
|
+
cid: CID
|
61
|
+
rev: string
|
62
|
+
blocks: BlockMap
|
63
|
+
}
|
64
|
+
|
60
65
|
export class InvalidRecordError extends Error {}
|
61
66
|
|
62
67
|
export class BadCommitSwapError extends Error {
|
@@ -77,7 +77,10 @@ export const rebuildRepo = async (ctx: AppContext, args: string[]) => {
|
|
77
77
|
}
|
78
78
|
})
|
79
79
|
await ctx.accountManager.updateRepoRoot(did, commit.cid, rev)
|
80
|
-
await ctx.
|
80
|
+
const syncData = await ctx.actorStore.read(did, (store) =>
|
81
|
+
store.repo.getSyncEventData(),
|
82
|
+
)
|
83
|
+
await ctx.sequencer.sequenceSyncEvt(did, syncData)
|
81
84
|
}
|
82
85
|
|
83
86
|
const promptContinue = async (): Promise<boolean> => {
|