How to use chrome-remote-interface - 10 common examples

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 adieuadieu / serverless-chrome / serverless-chrome-pdf / src / printToPdf.js View on Github external
}

  let result
  let loaded = false

  const loading = async (startTime = Date.now()) =&gt; {
    console.log('loading...')
    if (!loaded &amp;&amp; Date.now() - startTime &lt; 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) =&gt; {
    console.log('CDP version info', err, info)
  })

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

  Network.requestWillBeSent((params) =&gt; {
    // console.log(params.request.url)
  })
github artlimes / meteor-chrome-headless-spiderable / lib / server.js View on Github external
Meteor.setTimeout(() => {
    console.log("going to visit",url);
    console.log(url);
    const chromeParams = {};
    if (Spiderable.useLocalChrome) {
      chromeParams.port = chrome.port;
    } else {
      chromeParams.host = Spiderable.chromeIp;
      chromeParams.port = Spiderable.chromePort;
    }

    CDP(chromeParams, (protocol) => {
      // Extract the parts of the DevTools protocol we need for the task.
      // See API docs: https://chromedevtools.github.io/debugger-protocol-viewer/
      const {Page, Runtime} = protocol;
      // First, need to enable the domains we're going to use.
      Promise.all([
        Page.enable(),
        Runtime.enable()
      ]).then(() => {
        Page.navigate({url});


        // Wait for window.onload before doing stuff.
        Page.loadEventFired(() => {
          succeeded = true;
          checkIfReady(Runtime, () => {
            getHtmlContent(Runtime).then((result) => {
github adieuadieu / serverless-chrome / examples / serverless-framework / aws / src / handlers / screencast.js View on Github external
await Page.stopScreencast()

    log('We think the page has finished doing what it do. Rendering video.')
    log(`Interaction took ${Date.now() - interactionStartTime}ms to finish.`)
  } catch (error) {
    console.error(error)
  }

  // @TODO: handle this better —
  // If you don't close the tab, an a subsequent Page.navigate() is unable to load the url,
  // you'll end up printing a PDF of whatever was loaded in the tab previously
  // (e.g. a previous URL) _unless_ you Cdp.New() each time. But still good to close to
  // clear up memory in Chrome
  try {
    log('trying to close tab', tab)
    await Cdp.Close({ id: tab.id })
  } catch (error) {
    log('unable to close tab', tab, error)
  }

  await client.close()

  const renderVideo = async () => {
    await new Promise((resolve, reject) => {
      const args = [
        '-y',
        '-loglevel',
        'warning', // 'debug',
        '-f',
        'image2',
        '-framerate',
        `${options.videoFrameRate}`,
github sidorares / crconsole / index.js View on Github external
connect: function(options, cb) {
    var self = this;
    self.options = options;
    var client = chrome.createClient();
    client.on("error", function(error) {
      console.log(error);
    });
    self.client = client;
    if (options.websocket) {
      return cb(null, {
        url: '',
        webSocketDebuggerUrl: options.websocket
      });
    } else {
      client.listTabs(options.host, options.port, function(err, tabs) {
        if(err) return cb(err);
        // TODO: skip tabs without webSocketDebuggerUrl (likely already being debugged)
        cb(null, tabs[0]);
      });
    }