@helium/helium-admin-cli 0.9.19 → 0.9.20-next.23

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.
Files changed (55) hide show
  1. package/lib/cjs/add-expiration-to-delegations.js +52 -26
  2. package/lib/cjs/add-expiration-to-delegations.js.map +1 -1
  3. package/lib/cjs/backfill-vote-markers.js +189 -0
  4. package/lib/cjs/backfill-vote-markers.js.map +1 -0
  5. package/lib/cjs/dump-vote-markers.js +304 -0
  6. package/lib/cjs/dump-vote-markers.js.map +1 -0
  7. package/lib/cjs/fix-claimed-epochs.js +91 -0
  8. package/lib/cjs/fix-claimed-epochs.js.map +1 -0
  9. package/lib/cjs/release-iot-mobile-positions.js +91 -0
  10. package/lib/cjs/release-iot-mobile-positions.js.map +1 -0
  11. package/lib/cjs/unrug-hotspots.js +167 -0
  12. package/lib/cjs/unrug-hotspots.js.map +1 -0
  13. package/lib/cjs/update-matching-destinations.js +116 -0
  14. package/lib/cjs/update-matching-destinations.js.map +1 -0
  15. package/lib/cjs/update-mathing-destinations.js +103 -0
  16. package/lib/cjs/update-mathing-destinations.js.map +1 -0
  17. package/lib/cjs/update-proxy-config.js +128 -0
  18. package/lib/cjs/update-proxy-config.js.map +1 -0
  19. package/lib/esm/src/add-expiration-to-delegations.js +53 -27
  20. package/lib/esm/src/add-expiration-to-delegations.js.map +1 -1
  21. package/lib/esm/src/backfill-vote-markers.js +148 -0
  22. package/lib/esm/src/backfill-vote-markers.js.map +1 -0
  23. package/lib/esm/src/dump-vote-markers.js +256 -0
  24. package/lib/esm/src/dump-vote-markers.js.map +1 -0
  25. package/lib/esm/src/fix-claimed-epochs.js +50 -0
  26. package/lib/esm/src/fix-claimed-epochs.js.map +1 -0
  27. package/lib/esm/src/release-iot-mobile-positions.js +50 -0
  28. package/lib/esm/src/release-iot-mobile-positions.js.map +1 -0
  29. package/lib/esm/src/unrug-hotspots.js +126 -0
  30. package/lib/esm/src/unrug-hotspots.js.map +1 -0
  31. package/lib/esm/src/update-matching-destinations.js +75 -0
  32. package/lib/esm/src/update-matching-destinations.js.map +1 -0
  33. package/lib/esm/src/update-mathing-destinations.js +62 -0
  34. package/lib/esm/src/update-mathing-destinations.js.map +1 -0
  35. package/lib/esm/src/update-proxy-config.js +87 -0
  36. package/lib/esm/src/update-proxy-config.js.map +1 -0
  37. package/lib/esm/tsconfig.esm.tsbuildinfo +1 -1
  38. package/lib/types/src/add-expiration-to-delegations.d.ts.map +1 -1
  39. package/lib/types/src/backfill-vote-markers.d.ts +2 -0
  40. package/lib/types/src/backfill-vote-markers.d.ts.map +1 -0
  41. package/lib/types/src/dump-vote-markers.d.ts +2 -0
  42. package/lib/types/src/dump-vote-markers.d.ts.map +1 -0
  43. package/lib/types/src/fix-claimed-epochs.d.ts +2 -0
  44. package/lib/types/src/fix-claimed-epochs.d.ts.map +1 -0
  45. package/lib/types/src/release-iot-mobile-positions.d.ts +2 -0
  46. package/lib/types/src/release-iot-mobile-positions.d.ts.map +1 -0
  47. package/lib/types/src/unrug-hotspots.d.ts +2 -0
  48. package/lib/types/src/unrug-hotspots.d.ts.map +1 -0
  49. package/lib/types/src/update-matching-destinations.d.ts +2 -0
  50. package/lib/types/src/update-matching-destinations.d.ts.map +1 -0
  51. package/lib/types/src/update-mathing-destinations.d.ts +2 -0
  52. package/lib/types/src/update-mathing-destinations.d.ts.map +1 -0
  53. package/lib/types/src/update-proxy-config.d.ts +2 -0
  54. package/lib/types/src/update-proxy-config.d.ts.map +1 -0
  55. package/package.json +14 -13
@@ -0,0 +1,128 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
26
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
27
+ return new (P || (P = Promise))(function (resolve, reject) {
28
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
29
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
30
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
31
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
32
+ });
33
+ };
34
+ var __importDefault = (this && this.__importDefault) || function (mod) {
35
+ return (mod && mod.__esModule) ? mod : { "default": mod };
36
+ };
37
+ Object.defineProperty(exports, "__esModule", { value: true });
38
+ exports.run = void 0;
39
+ const anchor = __importStar(require("@coral-xyz/anchor"));
40
+ const nft_proxy_sdk_1 = require("@helium/nft-proxy-sdk");
41
+ const web3_js_1 = require("@solana/web3.js");
42
+ const sdk_1 = __importDefault(require("@sqds/sdk"));
43
+ const fs_1 = __importDefault(require("fs"));
44
+ const os_1 = __importDefault(require("os"));
45
+ const yargs_1 = __importDefault(require("yargs/yargs"));
46
+ const utils_1 = require("./utils");
47
+ function run(args = process.argv) {
48
+ return __awaiter(this, void 0, void 0, function* () {
49
+ const yarg = (0, yargs_1.default)(args).options({
50
+ wallet: {
51
+ alias: "k",
52
+ describe: "Anchor wallet keypair",
53
+ default: `${os_1.default.homedir()}/.config/solana/id.json`,
54
+ },
55
+ url: {
56
+ alias: "u",
57
+ default: "http://127.0.0.1:8899",
58
+ describe: "The solana url",
59
+ },
60
+ name: {
61
+ required: true,
62
+ type: "string",
63
+ describe: "Name of the proxy config to be updated",
64
+ },
65
+ maxProxyTime: {
66
+ required: false,
67
+ describe: "New max proxy time",
68
+ type: "string",
69
+ default: null,
70
+ },
71
+ proxySeasonsFile: {
72
+ type: "string",
73
+ default: `${__dirname}/../../proxy-seasons.json`,
74
+ },
75
+ executeTransaction: {
76
+ type: "boolean",
77
+ },
78
+ multisig: {
79
+ type: "string",
80
+ describe: "Address of the squads multisig to be authority. If not provided, your wallet will be the authority",
81
+ },
82
+ authorityIndex: {
83
+ type: "number",
84
+ describe: "Authority index for squads. Defaults to 1",
85
+ default: 1,
86
+ },
87
+ });
88
+ const argv = yield yarg.argv;
89
+ process.env.ANCHOR_WALLET = argv.wallet;
90
+ process.env.ANCHOR_PROVIDER_URL = argv.url;
91
+ anchor.setProvider(anchor.AnchorProvider.local(argv.url));
92
+ const provider = anchor.getProvider();
93
+ const wallet = new anchor.Wallet((0, utils_1.loadKeypair)(argv.wallet));
94
+ const proxySeasonsFile = fs_1.default.readFileSync(argv.proxySeasonsFile, "utf8");
95
+ const seasons = JSON.parse(proxySeasonsFile).map((s) => ({
96
+ start: new anchor.BN(Math.floor(Date.parse(s.start) / 1000)),
97
+ end: new anchor.BN(Math.floor(Date.parse(s.end) / 1000)),
98
+ }));
99
+ const program = yield (0, nft_proxy_sdk_1.init)(provider);
100
+ const instructions = [];
101
+ const proxyConfig = (0, nft_proxy_sdk_1.proxyConfigKey)(argv.name)[0];
102
+ const proxyConfigAcc = yield program.account.proxyConfigV0.fetch(proxyConfig);
103
+ instructions.push(yield program.methods
104
+ .updateProxyConfigV0({
105
+ maxProxyTime: argv.maxProxyTime ? new anchor.BN(argv.maxProxyTime) : null,
106
+ seasons,
107
+ })
108
+ .accounts({
109
+ proxyConfig,
110
+ authority: proxyConfigAcc.authority,
111
+ })
112
+ .instruction());
113
+ const squads = sdk_1.default.endpoint(process.env.ANCHOR_PROVIDER_URL, wallet, {
114
+ commitmentOrConfig: "finalized",
115
+ });
116
+ yield (0, utils_1.sendInstructionsOrSquads)({
117
+ provider,
118
+ instructions,
119
+ executeTransaction: argv.executeTransaction,
120
+ squads,
121
+ multisig: argv.multisig ? new web3_js_1.PublicKey(argv.multisig) : undefined,
122
+ authorityIndex: argv.authorityIndex,
123
+ signers: [],
124
+ });
125
+ });
126
+ }
127
+ exports.run = run;
128
+ //# sourceMappingURL=update-proxy-config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"update-proxy-config.js","sourceRoot":"","sources":["../../src/update-proxy-config.ts"],"names":[],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import * as anchor from "@coral-xyz/anchor";
2
2
  import { daoKey, init as initHsd, subDaoEpochInfoKey } from "@helium/helium-sub-daos-sdk";
3
3
  import { init as initProxy } from "@helium/nft-proxy-sdk";
4
- import { batchParallelInstructionsWithPriorityFee, HNT_MINT } from "@helium/spl-utils";
4
+ import { batchInstructionsToTxsWithPriorityFee, bulkSendTransactions, HNT_MINT } from "@helium/spl-utils";
5
5
  import { init as initVsr } from "@helium/voter-stake-registry-sdk";
6
6
  import { PublicKey, SystemProgram, SYSVAR_CLOCK_PUBKEY } from "@solana/web3.js";
7
7
  import { min } from "bn.js";
@@ -43,39 +43,65 @@ export async function run(args = process.argv) {
43
43
  const instructions = [];
44
44
  const delegations = await hsdProgram.account.delegatedPositionV0.all();
45
45
  const needsMigration = delegations.filter(d => d.account.expirationTs.isZero());
46
- const positionKeys = needsMigration.map(d => d.account.position);
47
- const coder = hsdProgram.coder.accounts;
46
+ const positionKeys = needsMigration.map((d) => d.account.position);
47
+ const coder = vsrProgram.coder.accounts;
48
48
  const positionAccs = (await getMultipleAccounts({
49
49
  connection: provider.connection,
50
50
  keys: positionKeys,
51
- })).map(a => coder.decode("positionV0", a.data));
51
+ })).map((a) => a ? coder.decode("PositionV0", a.data) : null);
52
52
  const currTs = await getSolanaUnixTimestamp(provider);
53
53
  const currTsBN = new anchor.BN(currTs.toString());
54
- const proxyEndTs = proxyConfig.seasons.find(s => currTsBN.gt(s.start))?.end;
55
- for (const [delegation, position] of zip(needsMigration, positionAccs)) {
56
- const subDao = delegation.account.subDao;
57
- instructions.push(await hsdProgram.methods
58
- .addExpirationTs()
59
- .accountsStrict({
60
- payer: wallet.publicKey,
61
- position: delegation.account.position,
62
- delegatedPosition: delegation.publicKey,
63
- registrar: registrarK,
64
- dao,
65
- subDao: delegation.account.subDao,
66
- oldClosingTimeSubDaoEpochInfo: subDaoEpochInfoKey(subDao, position.lockup.endTs)[0],
67
- closingTimeSubDaoEpochInfo: subDaoEpochInfoKey(subDao, min(position.lockup.endTs, proxyEndTs))[0],
68
- genesisEndSubDaoEpochInfo: subDaoEpochInfoKey(subDao, position.genesisEnd)[0],
69
- proxyConfig: registrar.proxyConfig,
70
- systemProgram: SystemProgram.programId,
71
- })
72
- .instruction());
54
+ const proxyEndTs = proxyConfig.seasons
55
+ .reverse()
56
+ .find((s) => currTsBN.gte(s.start))?.end;
57
+ console.log(`Processing ${needsMigration.length} delegations`);
58
+ // Process in batches of 10
59
+ const batchSize = 10;
60
+ for (let i = 0; i < needsMigration.length; i += batchSize) {
61
+ // Log progress every 100 positions
62
+ if (i > 0 && i % 100 === 0) {
63
+ console.log(`Processed ${i} delegations`);
64
+ }
65
+ const batch = needsMigration.slice(i, i + batchSize);
66
+ const batchPositions = positionAccs.slice(i, i + batchSize);
67
+ await Promise.all(batch.map(async (delegation, j) => {
68
+ const position = batchPositions[j];
69
+ if (!position) {
70
+ console.log(`Position not found for ${delegation.account.position.toBase58()}`);
71
+ return;
72
+ }
73
+ const subDao = delegation.account.subDao;
74
+ const positionTokenAccount = (await provider.connection.getTokenLargestAccounts(position.mint)).value[0].address;
75
+ instructions.push(await hsdProgram.methods
76
+ .extendExpirationTsV0()
77
+ .accountsStrict({
78
+ payer: wallet.publicKey,
79
+ position: delegation.account.position,
80
+ delegatedPosition: delegation.publicKey,
81
+ registrar: registrarK,
82
+ mint: position.mint,
83
+ authority: wallet.publicKey,
84
+ positionTokenAccount,
85
+ dao,
86
+ subDao: delegation.account.subDao,
87
+ oldClosingTimeSubDaoEpochInfo: subDaoEpochInfoKey(subDao, delegation.account.expirationTs.isZero()
88
+ ? position.lockup.endTs
89
+ : min(position.lockup.endTs, delegation.account.expirationTs))[0],
90
+ closingTimeSubDaoEpochInfo: subDaoEpochInfoKey(subDao, min(position.lockup.endTs, proxyEndTs))[0],
91
+ genesisEndSubDaoEpochInfo: subDaoEpochInfoKey(subDao, position.genesisEnd.lt(currTsBN) ?
92
+ min(position.lockup.endTs, proxyEndTs) : position.genesisEnd)[0],
93
+ proxyConfig: registrar.proxyConfig,
94
+ systemProgram: SystemProgram.programId,
95
+ })
96
+ .instruction());
97
+ }));
73
98
  }
74
- await batchParallelInstructionsWithPriorityFee(provider, instructions, {
75
- onProgress: (status) => {
76
- console.log(status);
77
- },
99
+ console.log(`Finished processing ${needsMigration.length} delegations`);
100
+ const transactions = await batchInstructionsToTxsWithPriorityFee(provider, instructions, {
101
+ useFirstEstimateForAll: true,
102
+ computeUnitLimit: 400000,
78
103
  });
104
+ await bulkSendTransactions(provider, transactions, console.log, 10, [], 100);
79
105
  }
80
106
  async function getMultipleAccounts({ connection, keys, }) {
81
107
  const batchSize = 100;
@@ -1 +1 @@
1
- {"version":3,"file":"add-expiration-to-delegations.js","sourceRoot":"","sources":["../../../src/add-expiration-to-delegations.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"add-expiration-to-delegations.js","sourceRoot":"","sources":["../../../src/add-expiration-to-delegations.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,148 @@
1
+ import AWS from "aws-sdk";
2
+ import fs from "fs";
3
+ import * as pg from "pg";
4
+ import { ARRAY, BOOLEAN, DECIMAL, INTEGER, Model, STRING, Sequelize, } from "sequelize";
5
+ import yargs from "yargs/yargs";
6
+ export async function run(args = process.argv) {
7
+ const yarg = yargs(args).options({
8
+ outputPath: {
9
+ type: "string",
10
+ describe: "The path to the output file",
11
+ default: "vote-markers.json",
12
+ },
13
+ pgUser: {
14
+ default: "postgres",
15
+ },
16
+ pgPassword: {
17
+ type: "string",
18
+ },
19
+ pgDatabase: {
20
+ type: "string",
21
+ },
22
+ pgHost: {
23
+ default: "localhost",
24
+ },
25
+ pgPort: {
26
+ default: "5432",
27
+ },
28
+ awsRegion: {
29
+ default: "us-east-1",
30
+ },
31
+ noSsl: {
32
+ type: "boolean",
33
+ default: false,
34
+ },
35
+ voteMarkerJson: {
36
+ type: "string",
37
+ describe: "The path to the vote marker json file",
38
+ required: true,
39
+ },
40
+ });
41
+ const argv = await yarg.argv;
42
+ const voteMarkers = JSON.parse(fs.readFileSync(argv.voteMarkerJson, "utf8"));
43
+ const host = argv.pgHost;
44
+ const port = Number(argv.pgPort);
45
+ const database = new Sequelize({
46
+ host,
47
+ dialect: "postgres",
48
+ port,
49
+ logging: false,
50
+ dialectModule: pg,
51
+ username: argv.pgUser,
52
+ database: argv.pgDatabase,
53
+ pool: {
54
+ max: 10,
55
+ min: 5,
56
+ acquire: 60000,
57
+ idle: 10000,
58
+ validate: (client) => {
59
+ try {
60
+ client.query("SELECT 1");
61
+ return true;
62
+ }
63
+ catch (err) {
64
+ return false;
65
+ }
66
+ },
67
+ },
68
+ hooks: {
69
+ beforeConnect: async (config) => {
70
+ const isRds = host.includes("rds.amazonaws.com");
71
+ let password = argv.pgPassword;
72
+ if (isRds && !password) {
73
+ const signer = new AWS.RDS.Signer({
74
+ region: process.env.AWS_REGION,
75
+ hostname: process.env.PGHOST,
76
+ port,
77
+ username: process.env.PGUSER,
78
+ });
79
+ password = await new Promise((resolve, reject) => signer.getAuthToken({}, (err, token) => {
80
+ if (err) {
81
+ return reject(err);
82
+ }
83
+ resolve(token);
84
+ }));
85
+ config.dialectOptions = {
86
+ ssl: {
87
+ require: false,
88
+ rejectUnauthorized: false,
89
+ },
90
+ };
91
+ }
92
+ config.password = password;
93
+ },
94
+ },
95
+ });
96
+ class VoteMarker extends Model {
97
+ }
98
+ VoteMarker.init({
99
+ address: {
100
+ type: STRING,
101
+ primaryKey: true,
102
+ },
103
+ voter: {
104
+ type: STRING,
105
+ primaryKey: true,
106
+ },
107
+ registrar: {
108
+ type: STRING,
109
+ primaryKey: true,
110
+ },
111
+ proposal: {
112
+ type: STRING,
113
+ primaryKey: true,
114
+ },
115
+ mint: {
116
+ type: STRING,
117
+ primaryKey: true,
118
+ },
119
+ choices: {
120
+ type: ARRAY(INTEGER),
121
+ },
122
+ weight: {
123
+ type: DECIMAL.UNSIGNED,
124
+ },
125
+ bumpSeed: {
126
+ type: INTEGER,
127
+ },
128
+ deprecatedRelinquished: {
129
+ type: BOOLEAN,
130
+ },
131
+ proxyIndex: {
132
+ type: INTEGER,
133
+ },
134
+ rentRefund: {
135
+ type: STRING,
136
+ },
137
+ }, {
138
+ sequelize: database,
139
+ modelName: "vote_marker",
140
+ tableName: "vote_markers",
141
+ underscored: true,
142
+ updatedAt: false,
143
+ });
144
+ await VoteMarker.bulkCreate(voteMarkers, {
145
+ ignoreDuplicates: true, // ON CONFLICT DO NOTHING
146
+ });
147
+ }
148
+ //# sourceMappingURL=backfill-vote-markers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"backfill-vote-markers.js","sourceRoot":"","sources":["../../../src/backfill-vote-markers.ts"],"names":[],"mappings":"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"}