1 |
|
2 |
|
3 |
|
4 |
|
5 |
|
6 |
|
7 |
|
8 |
|
9 |
|
10 |
|
11 |
|
12 |
|
13 |
|
14 |
|
15 |
|
16 |
|
17 |
|
18 | if (require('./package.json').name === 'puppeteer-core')
|
19 | return;
|
20 |
|
21 | buildNode6IfNecessary();
|
22 |
|
23 | if (process.env.PUPPETEER_SKIP_CHROMIUM_DOWNLOAD) {
|
24 | logPolitely('**INFO** Skipping Chromium download. "PUPPETEER_SKIP_CHROMIUM_DOWNLOAD" environment variable was found.');
|
25 | return;
|
26 | }
|
27 | if (process.env.NPM_CONFIG_PUPPETEER_SKIP_CHROMIUM_DOWNLOAD || process.env.npm_config_puppeteer_skip_chromium_download) {
|
28 | logPolitely('**INFO** Skipping Chromium download. "PUPPETEER_SKIP_CHROMIUM_DOWNLOAD" was set in npm config.');
|
29 | return;
|
30 | }
|
31 | if (process.env.NPM_PACKAGE_CONFIG_PUPPETEER_SKIP_CHROMIUM_DOWNLOAD || process.env.npm_package_config_puppeteer_skip_chromium_download) {
|
32 | logPolitely('**INFO** Skipping Chromium download. "PUPPETEER_SKIP_CHROMIUM_DOWNLOAD" was set in project config.');
|
33 | return;
|
34 | }
|
35 |
|
36 | const downloadHost = process.env.PUPPETEER_DOWNLOAD_HOST || process.env.npm_config_puppeteer_download_host || process.env.npm_package_config_puppeteer_download_host;
|
37 |
|
38 | const puppeteer = require('./index');
|
39 | const browserFetcher = puppeteer.createBrowserFetcher({ host: downloadHost });
|
40 |
|
41 | const revision = process.env.PUPPETEER_CHROMIUM_REVISION || process.env.npm_config_puppeteer_chromium_revision || process.env.npm_package_config_puppeteer_chromium_revision
|
42 | || require('./package.json').puppeteer.chromium_revision;
|
43 |
|
44 | const revisionInfo = browserFetcher.revisionInfo(revision);
|
45 |
|
46 |
|
47 | if (revisionInfo.local) {
|
48 | generateProtocolTypesIfNecessary(false );
|
49 | return;
|
50 | }
|
51 |
|
52 |
|
53 | const NPM_HTTPS_PROXY = process.env.npm_config_https_proxy || process.env.npm_config_proxy;
|
54 | const NPM_HTTP_PROXY = process.env.npm_config_http_proxy || process.env.npm_config_proxy;
|
55 | const NPM_NO_PROXY = process.env.npm_config_no_proxy;
|
56 |
|
57 | if (NPM_HTTPS_PROXY)
|
58 | process.env.HTTPS_PROXY = NPM_HTTPS_PROXY;
|
59 | if (NPM_HTTP_PROXY)
|
60 | process.env.HTTP_PROXY = NPM_HTTP_PROXY;
|
61 | if (NPM_NO_PROXY)
|
62 | process.env.NO_PROXY = NPM_NO_PROXY;
|
63 |
|
64 | browserFetcher.download(revisionInfo.revision, onProgress)
|
65 | .then(() => browserFetcher.localRevisions())
|
66 | .then(onSuccess)
|
67 | .catch(onError);
|
68 |
|
69 |
|
70 |
|
71 |
|
72 |
|
73 | function onSuccess(localRevisions) {
|
74 | logPolitely('Chromium downloaded to ' + revisionInfo.folderPath);
|
75 | localRevisions = localRevisions.filter(revision => revision !== revisionInfo.revision);
|
76 |
|
77 | const cleanupOldVersions = localRevisions.map(revision => browserFetcher.remove(revision));
|
78 | return Promise.all([...cleanupOldVersions, generateProtocolTypesIfNecessary(true )]);
|
79 | }
|
80 |
|
81 |
|
82 |
|
83 |
|
84 | function onError(error) {
|
85 | console.error(`ERROR: Failed to download Chromium r${revision}! Set "PUPPETEER_SKIP_CHROMIUM_DOWNLOAD" env variable to skip download.`);
|
86 | console.error(error);
|
87 | process.exit(1);
|
88 | }
|
89 |
|
90 | let progressBar = null;
|
91 | let lastDownloadedBytes = 0;
|
92 | function onProgress(downloadedBytes, totalBytes) {
|
93 | if (!progressBar) {
|
94 | const ProgressBar = require('progress');
|
95 | progressBar = new ProgressBar(`Downloading Chromium r${revision} - ${toMegabytes(totalBytes)} [:bar] :percent :etas `, {
|
96 | complete: '=',
|
97 | incomplete: ' ',
|
98 | width: 20,
|
99 | total: totalBytes,
|
100 | });
|
101 | }
|
102 | const delta = downloadedBytes - lastDownloadedBytes;
|
103 | lastDownloadedBytes = downloadedBytes;
|
104 | progressBar.tick(delta);
|
105 | }
|
106 |
|
107 | function toMegabytes(bytes) {
|
108 | const mb = bytes / 1024 / 1024;
|
109 | return `${Math.round(mb * 10) / 10} Mb`;
|
110 | }
|
111 |
|
112 | function buildNode6IfNecessary() {
|
113 | const fs = require('fs');
|
114 | const path = require('path');
|
115 |
|
116 |
|
117 |
|
118 | if (!fs.existsSync(path.join('utils', 'node6-transform')))
|
119 | return;
|
120 |
|
121 | if (supportsAsyncAwait())
|
122 | return;
|
123 |
|
124 | logPolitely('Building Puppeteer for Node 6');
|
125 | require(path.join(__dirname, 'utils', 'node6-transform'));
|
126 | }
|
127 |
|
128 | function supportsAsyncAwait() {
|
129 | try {
|
130 | new Function('async function test(){await 1}');
|
131 | } catch (error) {
|
132 | return false;
|
133 | }
|
134 | return true;
|
135 | }
|
136 |
|
137 | function generateProtocolTypesIfNecessary(updated) {
|
138 | if (!supportsAsyncAwait())
|
139 | return;
|
140 | const fs = require('fs');
|
141 | const path = require('path');
|
142 | if (!fs.existsSync(path.join(__dirname, 'utils', 'protocol-types-generator')))
|
143 | return;
|
144 | if (!updated && fs.existsSync(path.join(__dirname, 'lib', 'protocol.d.ts')))
|
145 | return;
|
146 | return require('./utils/protocol-types-generator');
|
147 | }
|
148 |
|
149 | function logPolitely(toBeLogged) {
|
150 | const logLevel = process.env.npm_config_loglevel;
|
151 | const logLevelDisplay = ['silent', 'error', 'warn'].indexOf(logLevel) > -1;
|
152 |
|
153 | if (!logLevelDisplay)
|
154 | console.log(toBeLogged);
|
155 | }
|
156 |
|