From 7e4ceb17d25969d2ab08d3bb3dff786ed83b1fa5 Mon Sep 17 00:00:00 2001 From: helloitsian <15301476+helloitsian@users.noreply.github.com> Date: Thu, 25 Jan 2024 02:35:20 -0600 Subject: [PATCH 1/3] endpoint fix for IG accounts not connected to facebook --- src/repositories/account.repository.ts | 25 +++++++++++++++---------- 1 file changed, 15 insertions(+), 10 deletions(-) diff --git a/src/repositories/account.repository.ts b/src/repositories/account.repository.ts index 35e017f51..67bf3a113 100644 --- a/src/repositories/account.repository.ts +++ b/src/repositories/account.repository.ts @@ -26,11 +26,11 @@ export class AccountRepository extends Repository { if (!this.client.state.passwordEncryptionPubKey) { await this.client.qe.syncLoginExperiments(); } - const {encrypted, time} = this.encryptPassword(password); + const { encrypted, time } = this.encryptPassword(password); const response = await Bluebird.try(() => this.client.request.send({ method: 'POST', - url: '/api/v1/accounts/login/', + url: '/api/v1/web/accounts/login/ajax/', form: this.client.request.sign({ username, enc_password: `#PWD_INSTAGRAM:4:${time}:${encrypted}`, @@ -76,14 +76,17 @@ export class AccountRepository extends Repository { return `2${sum}`; } - public encryptPassword(password: string): { time: string, encrypted: string } { + public encryptPassword(password: string): { time: string; encrypted: string } { const randKey = crypto.randomBytes(32); const iv = crypto.randomBytes(12); - const rsaEncrypted = crypto.publicEncrypt({ - key: Buffer.from(this.client.state.passwordEncryptionPubKey, 'base64').toString(), - // @ts-ignore - padding: crypto.constants.RSA_PKCS1_PADDING, - }, randKey); + const rsaEncrypted = crypto.publicEncrypt( + { + key: Buffer.from(this.client.state.passwordEncryptionPubKey, 'base64').toString(), + // @ts-ignore + padding: crypto.constants.RSA_PKCS1_PADDING, + }, + randKey, + ); const cipher = crypto.createCipheriv('aes-256-gcm', randKey, iv); const time = Math.floor(Date.now() / 1000).toString(); cipher.setAAD(Buffer.from(time)); @@ -97,8 +100,10 @@ export class AccountRepository extends Repository { Buffer.from([1, this.client.state.passwordEncryptionKeyId]), iv, sizeBuffer, - rsaEncrypted, authTag, aesEncrypted]) - .toString('base64'), + rsaEncrypted, + authTag, + aesEncrypted, + ]).toString('base64'), }; } From 670ff6ad4c7069380cf444738be7e45579ac5cc6 Mon Sep 17 00:00:00 2001 From: helloitsian <15301476+helloitsian@users.noreply.github.com> Date: Thu, 25 Jan 2024 02:36:41 -0600 Subject: [PATCH 2/3] endpoint fix for IG accounts not connected to facebook From fc5d18a322e21e83fec29a189af1ba9c1890702a Mon Sep 17 00:00:00 2001 From: helloitsian <15301476+helloitsian@users.noreply.github.com> Date: Thu, 25 Jan 2024 16:18:39 -0600 Subject: [PATCH 3/3] converted account.twoFactorLogin to use the web ajax api so 2fa works --- src/repositories/account.repository.ts | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/src/repositories/account.repository.ts b/src/repositories/account.repository.ts index 67bf3a113..42eee2ffa 100644 --- a/src/repositories/account.repository.ts +++ b/src/repositories/account.repository.ts @@ -114,17 +114,15 @@ export class AccountRepository extends Repository { trustThisDevice: '1', verificationMethod: '1', }); - const { body } = await this.client.request.send({ - url: '/api/v1/accounts/two_factor_login/', + const { body } = await this.client.request.send({ + url: '/api/v1/web/accounts/login/ajax/two_factor/', method: 'POST', form: this.client.request.sign({ - verification_code: options.verificationCode, _csrftoken: this.client.state.cookieCsrfToken, - two_factor_identifier: options.twoFactorIdentifier, + identifier: options.twoFactorIdentifier, + verificationCode: options.verificationCode, username: options.username, - trust_this_device: options.trustThisDevice, - guid: this.client.state.uuid, - device_id: this.client.state.deviceId, + trust_signal: options.trustThisDevice === '1' ? 'true' : 'false', verification_method: options.verificationMethod, }), });