Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Sequencer recovery #2519

Open
wants to merge 30 commits into
base: main
Choose a base branch
from
Open

Sequencer recovery #2519

wants to merge 30 commits into from

Conversation

dholms
Copy link
Collaborator

@dholms dholms commented May 24, 2024

Adds script to pds for performing recovery based off of the sequencer database:

  • reapply sequenced repo updates to actor stores
  • delete actor stores for accounts that have been deleted (based on account evts)
  • recreate accounts that were created during the recovery window. This involves creating a new keypair and update the user's DID

@dholms dholms marked this pull request as ready for review June 25, 2024 19:18
Comment on lines 25 to 27
export const filterDefined = <T>(arr: (T | undefined)[]): T[] => {
return arr.filter((item) => item !== undefined) as T[]
}
Copy link
Collaborator

@devinivy devinivy Jun 27, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we need to take a little extra care now to include changesets for changes to deps, so that the PDS distro will rely on a proper published version of its deps.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ended up just scrapping this util func and using a type annotation instead 👌

(most recent TS version actually fixes the need for this 👀)

Comment on lines 15 to 19
if (ctx.entrywayAdminAgent) {
await ctx.entrywayAdminAgent.api.com.atproto.admin.updateAccountSigningKey({
did,
signingKey: updateTo.did(),
})
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we'll always land in this case since entrywayAdminAgent exists when there's an entryway admin token, which fallsback to env.adminPassword, which should always be set.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it's also contingent on having an entryway cfg as well which is the main thing

Copy link
Collaborator

@devinivy devinivy left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ended up being more straightforward than I expected, nice! Made it look easy.

One idea that comes to mind is that it's a little bit of a shame the whole accounts table is processed in a single process, and it would be nice if we could break that up. I think all we would need is for the scripts to support a partitioning scheme, e.g. an option to say "run this for partition #1 of 10". Then we'd run the script in 10 processes and get a little more juice.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants