From 15ea1b5fb302217a26caa40f050cc5c3a3e00321 Mon Sep 17 00:00:00 2001 From: Lluis Date: Mon, 5 Feb 2024 23:12:18 +0100 Subject: [PATCH] singleton borwser api --- services/browser-api.js | 71 +++++++++++++++++++++++++++++++++++++++++ services/browser.js | 16 ++-------- 2 files changed, 74 insertions(+), 13 deletions(-) create mode 100644 services/browser-api.js diff --git a/services/browser-api.js b/services/browser-api.js new file mode 100644 index 0000000..db965c0 --- /dev/null +++ b/services/browser-api.js @@ -0,0 +1,71 @@ +const puppeteer = require('puppeteer-core') +const config = require('../config') + +class PuppeteerApi { + + browser = null + page = null + svgImage = null + constructor() { + } + + getSvgImage() { + return this.svgImage + } + + async newBrowser() { + return await puppeteer.connect({ browserWSEndpoint: `wss://${config.browserlessUrl}` }) + } + + async getBrowser() { + + if (!this.browser) { + this.browser = await this.newBrowser() + } + + return this.browser + } + + async getPage() { + if (!this.page) { + this.page = await this.newPage() + await this.handleStart() + } + return this.page + + } + + async newPage() { + const browser = await this.getBrowser() + return await browser.newPage() + } + + async handBack(page) { + // close the page or even reuse it?. + await page.close() + + // you could add logic for closing the whole browser instance depending what + // you want. + } + + async handleStart() { + await this.page.setViewport({ width: 1920, height: 1080 }) + await this.page.goto("https://www.twitch.tv/" + config.twitch.channels, { waitUntil: 'networkidle0' }) + + await this.page.$eval('button[data-a-target="consent-banner-accept"]', el => el.click()).catch(() => {}) + await this.page.$eval('button[data-a-target="content-classification-gate-overlay-start-watching-button"]', el => el.click()).catch(() => {}) + await this.page.waitForSelector('div.persistent-player') + await this.page.$eval('.video-player__default-player', el => el.remove()) + this.svgImage = await this.page.$('div.persistent-player') + } + + + async shutdown() { + await this.browser.close() + } + + +} + +const browserApi = new PuppeteerApi() +module.exports = browserApi diff --git a/services/browser.js b/services/browser.js index 66adf7e..ca029ed 100644 --- a/services/browser.js +++ b/services/browser.js @@ -1,27 +1,17 @@ -const config = require('../config') -const puppeteer = require("puppeteer-core") +const browserApi = require('./browser-api.js') require('mathjs') async function getScreenshot() { try { - const browser = await puppeteer.connect({ browserWSEndpoint: `wss://${config.browserlessUrl}` }) - const page = await browser.newPage() + const page = await browserApi.getPage() - await page.setViewport({ width: 1920, height: 1080 }) - await page.goto("https://www.twitch.tv/" + config.twitch.channels, { waitUntil: 'networkidle0' }) - await page.$eval('button[data-a-target="consent-banner-accept"]', el => el.click()).catch(() => {}) - await page.$eval('button[data-a-target="content-classification-gate-overlay-start-watching-button"]', el => el.click()).catch(() => {}) - await page.waitForSelector('div.persistent-player') - await page.$eval('.video-player__default-player', el => el.remove()) - const svgImage = await page.$('div.persistent-player') const name = Math.random().toString(36).substring(2,8) - const bufferImage = await svgImage.screenshot({ + const bufferImage = await browserApi.getSvgImage().screenshot({ path: `public/images/${name}.png`, omitBackground: true }) - await browser.close() return {buffer: bufferImage, fileName: `${name}.png` } } catch (error) {