mirror of
https://github.com/cheveguerra/whatsapp-web.js.git
synced 2026-04-20 04:29:15 +00:00
feat: use specific whatsapp web version
This commit is contained in:
@@ -6,6 +6,7 @@ const moduleRaid = require('@pedroslopez/moduleraid/moduleraid');
|
|||||||
|
|
||||||
const Util = require('./util/Util');
|
const Util = require('./util/Util');
|
||||||
const InterfaceController = require('./util/InterfaceController');
|
const InterfaceController = require('./util/InterfaceController');
|
||||||
|
const { getIndexForVersion } = require('./util/VersionResolver');
|
||||||
const { WhatsWebURL, DefaultOptions, Events, WAState } = require('./util/Constants');
|
const { WhatsWebURL, DefaultOptions, Events, WAState } = require('./util/Constants');
|
||||||
const { ExposeStore, LoadUtils } = require('./util/Injected');
|
const { ExposeStore, LoadUtils } = require('./util/Injected');
|
||||||
const ChatFactory = require('./factories/ChatFactory');
|
const ChatFactory = require('./factories/ChatFactory');
|
||||||
@@ -108,6 +109,7 @@ class Client extends EventEmitter {
|
|||||||
this.pupPage = page;
|
this.pupPage = page;
|
||||||
|
|
||||||
await this.authStrategy.afterBrowserInitialized();
|
await this.authStrategy.afterBrowserInitialized();
|
||||||
|
await this.initVersionOverride();
|
||||||
|
|
||||||
await page.goto(WhatsWebURL, {
|
await page.goto(WhatsWebURL, {
|
||||||
waitUntil: 'load',
|
waitUntil: 'load',
|
||||||
@@ -562,6 +564,22 @@ class Client extends EventEmitter {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async initVersionOverride() {
|
||||||
|
const version = this.options.webVersion;
|
||||||
|
await this.pupPage.setRequestInterception(true);
|
||||||
|
this.pupPage.on('request', async (req) => {
|
||||||
|
if(req.url() === WhatsWebURL) {
|
||||||
|
req.respond({
|
||||||
|
status: 200,
|
||||||
|
contentType: 'text/html',
|
||||||
|
body: await getIndexForVersion(version)
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
req.continue();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Closes the client
|
* Closes the client
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ exports.DefaultOptions = {
|
|||||||
headless: true,
|
headless: true,
|
||||||
defaultViewport: null
|
defaultViewport: null
|
||||||
},
|
},
|
||||||
|
webVersion: '2.2244.6',
|
||||||
authTimeoutMs: 0,
|
authTimeoutMs: 0,
|
||||||
qrMaxRetries: 0,
|
qrMaxRetries: 0,
|
||||||
takeoverOnConflict: false,
|
takeoverOnConflict: false,
|
||||||
|
|||||||
16
src/util/VersionResolver.js
Normal file
16
src/util/VersionResolver.js
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
const fetch = require('node-fetch');
|
||||||
|
|
||||||
|
const VERSION_ARCHIVE_URL = 'https://archive.wwebjs.dev/web-index';
|
||||||
|
|
||||||
|
class VersionResolveError extends Error { }
|
||||||
|
|
||||||
|
const getIndexForVersion = async (version) => {
|
||||||
|
const cachedRes = await fetch(`${VERSION_ARCHIVE_URL}/${version}`);
|
||||||
|
if(!cachedRes.ok) throw new VersionResolveError(`Couldn't load app for version ${version} from the archive`);
|
||||||
|
return cachedRes.text();
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
VersionResolveError,
|
||||||
|
getIndexForVersion
|
||||||
|
};
|
||||||
Reference in New Issue
Block a user