Helper script for changing expiry of git pat (#34234)

* Helper script for changing expiry of git pat

* Validation fail for invalid date

GitOrigin-RevId: 6786d4e808e0e4e87ef1293f4c22236257948128
This commit is contained in:
Liam O'Brien
2026-06-03 11:08:17 +01:00
committed by Copybot
parent a2f72adf67
commit f1282ee5cd
@@ -0,0 +1,124 @@
import minimist from 'minimist'
import { db, ObjectId } from '../../app/src/infrastructure/mongodb.mjs'
import { scriptRunner } from '../lib/ScriptRunner.mjs'
// Test helper: move a personal access token's accessTokenExpiresAt EARLIER, to
// simulate an expiring-soon or already-expired token when manually testing the
// expiry-notification flow (notify_expiring_tokens.mjs / git-bridge messaging).
//
// This script can only ever back-date a token: it refuses to set an expiry that
// is later than the token's current one. Moving an expiry forward would extend
// the life of a token that should be dead, so that direction is disallowed.
//
// Pass --dry-run to report what would change without writing.
async function main() {
const opts = parseArgs()
const token = await db.oauthAccessTokens.findOne({
_id: new ObjectId(opts.tokenId),
})
if (token == null) {
console.error(`No oauthAccessToken found with _id ${opts.tokenId}`)
process.exit(1)
}
const currentExpiry = token.accessTokenExpiresAt
if (!(currentExpiry instanceof Date) || isNaN(currentExpiry.getTime())) {
console.error(
`Token ${opts.tokenId} has no valid accessTokenExpiresAt ` +
`(found: ${JSON.stringify(currentExpiry)}). ` +
'This script only operates on tokens with an expiry, such as PATs.'
)
process.exit(1)
}
if (opts.expiry >= currentExpiry) {
console.error(
`Refusing to move expiry forward: requested ${opts.expiry.toISOString()} ` +
`is not earlier than current ${currentExpiry.toISOString()}. ` +
'This script only back-dates token expiry.'
)
process.exit(1)
}
if (opts.dryRun) {
console.warn(
`[dry run] would back-date token ${opts.tokenId} expiry from ` +
`${currentExpiry.toISOString()} to ${opts.expiry.toISOString()}`
)
return
}
await db.oauthAccessTokens.updateOne(
{ _id: token._id },
{ $set: { accessTokenExpiresAt: opts.expiry } }
)
console.warn(
`Back-dated token ${opts.tokenId} expiry from ` +
`${currentExpiry.toISOString()} to ${opts.expiry.toISOString()}`
)
}
function parseArgs() {
const args = minimist(process.argv.slice(2), {
boolean: ['help', 'dry-run'],
})
if (args.help) {
usage()
process.exit(0)
}
if (args._.length !== 0) {
usage()
process.exit(1)
}
const tokenId = args['token-id']
if (tokenId == null) {
console.error('Missing --token-id option')
process.exit(1)
}
if (!ObjectId.isValid(tokenId)) {
console.error(`Invalid --token-id: ${tokenId}`)
process.exit(1)
}
if (args['expiry-date'] == null) {
console.error('Missing --expiry-date option')
process.exit(1)
}
const expiry = new Date(args['expiry-date'])
if (isNaN(expiry.getTime())) {
console.error(`Invalid --expiry-date: ${args['expiry-date']}`)
process.exit(1)
}
return {
tokenId,
expiry,
dryRun: args['dry-run'],
}
}
function usage() {
console.error(`Usage: backdate_token_expiry.mjs [OPTS...]
Moves a personal access token's expiry EARLIER, to simulate an expiring or
expired token when testing the expiry-notification flow. Only ever back-dates;
refuses to move an expiry forward.
Options:
--token-id _id of the oauthAccessToken to back-date
--expiry-date New expiry, earlier than the current one (e.g. 2026-06-01T00:00:00Z)
--dry-run Report the change without writing
--help Show this message
`)
}
try {
await scriptRunner(main)
process.exit(0)
} catch (error) {
console.error(error)
process.exit(1)
}