How to use the chrome-remote-interface.Version function in chrome-remote-interface

To help you get started, we’ve selected a few chrome-remote-interface examples, based on popular ways it is used in public projects.

Secure your code as it's written. Use Snyk Code to scan source code in minutes - no build needed - and fix issues immediately.

github adieuadieu / serverless-chrome / packages / serverless-plugin / integration-test / handler.js View on Github external
module.exports.test = (event, context, callback, chrome) => {
  CDP.Version()
    .then((versionInfo) => {
      callback(null, {
        statusCode: 200,
        body: JSON.stringify({
          versionInfo,
          chrome,
        }),
        // headers: {
        // 'Content-Type': 'application/json',
        // },
      })
    })
    .catch((error) => {
      callback(null, {
        statusCode: 500,
        body: JSON.stringify({
github schnerd / chrome-headless-screenshots / index.js View on Github external
async function init() {
  let client;
  try {
    // Start the Chrome Debugging Protocol
    client = await CDP();

    // Verify version
    const { Browser } = await CDP.Version();
    const browserVersion = Browser.match(/\/(\d+)/)[1];
    if (Number(browserVersion) !== 60) {
      console.warn(`This script requires Chrome 60, however you are using version ${browserVersion}. The script is not guaranteed to work and you may need to modify it.`);
    }

    // Extract used DevTools domains.
    const {DOM, Emulation, Network, Page, Runtime} = client;

    // Enable events on domains we are interested in.
    await Page.enable();
    await DOM.enable();
    await Network.enable();

    // If user agent override was specified, pass to Network domain
    if (userAgent) {
      await Network.setUserAgentOverride({userAgent});
github adieuadieu / serverless-chrome / examples / serverless-framework / src / printToPdf.js View on Github external
await sleep(100) // wait here, in case this resource has triggered more resources to load.
    requestQueue.splice(requestQueue.findIndex(item => item === data.requestId), 1)
    log('Chrome received response for:', data.requestId, data.response.url)
  })

  Page.loadEventFired((data) => {
    loaded = true
    log('Page.loadEventFired', data)
  })

  Page.domContentEventFired((data) => {
    log('Page.domContentEventFired', data)
  })

  if (config.logging) {
    Cdp.Version((err, info) => {
      console.log('CDP version info', err, info)
    })
  }

  try {
    await Promise.all([
      Network.enable(), // https://chromedevtools.github.io/devtools-protocol/tot/Network/#method-enable
      Page.enable(), // https://chromedevtools.github.io/devtools-protocol/tot/Page/#method-enable
    ])

    await Page.navigate({ url }) // https://chromedevtools.github.io/devtools-protocol/tot/Page/#method-navigate
    await loading()

    log('We think the page has finished loading. Printing PDF.')

    // https://chromedevtools.github.io/devtools-protocol/tot/Page/#method-printToPDF
github adieuadieu / serverless-chrome / examples / serverless-framework / aws / src / handlers / screencast.js View on Github external
})

  Page.screencastFrame(({ sessionId, data, metadata }) => {
    const filename = `/tmp/frame-${invokeid}-${String(metadata.timestamp).replace('.', '')}.jpg`
    framesCaptured += 1

    // log('Received screencast frame', sessionId, metadata)
    Page.screencastFrameAck({ sessionId })

    fs.writeFile(filename, data, { encoding: 'base64' }, (error) => {
      log('Page.screencastFrame writeFile:', filename, error)
    })
  })

  if (process.env.LOGGING === 'TRUE') {
    Cdp.Version((err, info) => {
      console.log('CDP version info', err, info)
    })
  }

  try {
    await Promise.all([Network.enable(), Page.enable(), DOM.enable()])

    const interactionStartTime = Date.now()

    await client.send('Overlay.enable') // this has to happen after DOM.enable()
    await client.send('Overlay.setShowFPSCounter', { show: true })

    await Page.startScreencast({
      format: 'jpeg',
      quality: options.captureQuality,
      everyNthFrame: options.captureFrameRate,
github adieuadieu / serverless-chrome / serverless-chrome-pdf / src / printToPdf.js View on Github external
const loading = async (startTime = Date.now()) => {
    console.log('loading...')
    if (!loaded && Date.now() - startTime < LOAD_TIMEOUT) {
      await sleep(100)
      await loading(startTime)
    }
  }
  console.log('here 1')
  const tab = await Cdp.New({ host: '127.0.0.1' })
  console.log('tab', tab)
  const client = await Cdp({ host: '127.0.0.1', tab /* , remote: true*/ })
  const { Network, Page } = client

  console.log('here 2')

  Cdp.Version((err, info) => {
    console.log('CDP version info', err, info)
  })

  /* client.on('event', (message) => {
    console.log('client event', message)
  })*/

  Network.requestWillBeSent((params) => {
    // console.log(params.request.url)
  })

  Page.loadEventFired(() => {
    loaded = true
  })

  console.log('here 3')
github prisma-archive / chromeless / server.js View on Github external
<title>Chromeless test page</title>


  <div class="container">
    <div class="logo"><img alt="Chromeless" src=""></div>
    <div>
      <p>This is a test page for Chromeless unit tests</p>
    </div>
  </div>


`;

CDP.Version().then(version =&gt; {
  console.log(`Detected Chrome running: ${version['User-Agent']}`);

  http.createServer((request, response) =&gt; {

    const pathname = url.parse(request.url).pathname;

    if (pathname === '/' || pathname === '/index.html') {
      response.writeHead(200, {'Content-Type': 'text/html'});
      response.write(indexHtml);
      response.end();
    }
    else {
      // Currently no other file exists
      response.writeHead(404, {'Content-Type': 'text/plain'});
      response.write('404 Not Found');
      response.end();
github tim-field / urlToPdf / url-to-pdf.js View on Github external
async function doInNewContext(action, params) {
  // connect to the DevTools special target
  const host = "localhost"
  const port = CHROME_PORT
  const { webSocketDebuggerUrl } = await Chrome.Version({
    host,
    port
  })
  const browser = await Chrome({
    host,
    port,
    target: webSocketDebuggerUrl || "/devtools/browser"
  })
  // create a new context
  const { Target } = browser
  const { browserContextId } = await Target.createBrowserContext()
  const { targetId } = await Target.createTarget({
    url: "about:blank",
    browserContextId
  })
github cyrus-and / chrome-har-capturer / lib / context.js View on Github external
async create() {
        const {host, port, cache} = this._options;
        // fetch the browser version (since Chrome 62 the browser target URL is
        // generated at runtime and can be obtained via the '/json/version'
        // endpoint, fallback to '/devtools/browser' if not present)
        const {webSocketDebuggerUrl} = await CDP.Version({host, port});
        // connect to the browser target
        const browser = await CDP({
            host, port,
            target: webSocketDebuggerUrl || BROWSER_TARGET
        });
        this._cleanup.unshift(async () => {
            await browser.close();
        });
        const {Target} = browser;
        // request a new browser context
        let browserContextId;
        if (!cache) {
            const result = await Target.createBrowserContext();
            browserContextId = result.browserContextId;
            this._cleanup.unshift(async () => {
                await Target.disposeBrowserContext(result);
github adieuadieu / serverless-chrome / packages / serverless-plugin / integration-test / src / typescript-handler.ts View on Github external
export default async function (event, context, callback, chrome) {
  CDP.Version()
    .then((versionInfo) => {
      callback(null, {
        versionInfo,
        chrome,
      })
    })
    .catch(callback)
}
github moos / chromate / src / chrome-proc.js View on Github external
version: function (options) {
    options = options || {};
    if (!options.port) {
      options.port = Chrome.settings.port;
    }
    return CDP.Version(options);
  },