-
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathserver.js
More file actions
111 lines (100 loc) · 3.33 KB
/
server.js
File metadata and controls
111 lines (100 loc) · 3.33 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
import {red, green, cyan, bold} from 'colorette';
const loadConfigFile = require('rollup/dist/loadConfigFile');
const path = require('path');
const fs = require('fs');
const http = require('http');
const handler = require('serve-handler');
const rollup = require('rollup');
const metablock = require('rollup-plugin-userscript-metablock');
const pkg = require('./package.json');
const meta = require('./meta.js');
console.log('👀 watch & serve 🤲\n###################\n');
const port = pkg.config.port;
const destDir = 'dist/';
const devScriptInFile = 'dev.user.js';
const hyperlink = (url, title) => `\u001B]8;;${url}\u0007${title || url}\u001B]8;;\u0007`;
fs.mkdir('dist/', {recursive: true}, () => null);
// Start web server
const server = http.createServer((request, response) => {
return handler(request, response, {
public: destDir,
});
});
server.listen(port, () => {
console.log(`Running webserver at ${hyperlink(`http://localhost:${port}`)}`);
});
// Create the userscript for development 'dist/dev.user.js'
const devScriptOutFile = path.join(destDir, devScriptInFile);
console.log(
cyan(
`generate development userscript ${bold('package.json')}, ${bold('meta.js')}, ${bold(devScriptInFile)} → ${bold(
devScriptOutFile,
)}...`,
),
);
const devScriptContent = fs.readFileSync(devScriptInFile, 'utf8').replace(/%PORT%/gm, port.toString());
const grants = 'grant' in meta ? meta.grant : [];
if (grants.indexOf('GM.xmlHttpRequest') === -1) {
grants.push('GM.xmlHttpRequest');
}
if (grants.indexOf('GM.setValue') === -1) {
grants.push('GM.setValue');
}
if (grants.indexOf('GM.getValue') === -1) {
grants.push('GM.getValue');
}
const override = {
name: pkg.name + ' [dev]',
version: pkg.version,
description: pkg.description,
homepage: pkg.homepage,
author: pkg.author,
license: pkg.license,
grant: grants,
};
if ('connect' in meta) {
override.connect = meta.connect;
override.connect.push('localhost');
}
const devMetablock = metablock({
file: './meta.js',
override: override,
});
const result = devMetablock.renderChunk(devScriptContent, null, {sourcemap: false});
const outContent = typeof result === 'string' ? result : result.code;
fs.writeFileSync(devScriptOutFile, outContent);
console.log(
green(`created ${bold(devScriptOutFile)}. Please install in Tampermonkey: `) +
hyperlink(`http://localhost:${port}/${devScriptInFile}`),
);
loadConfigFile(path.resolve(__dirname, 'rollup.config.js')).then(async ({options, warnings}) => {
// Start rollup watch
const watcher = rollup.watch(options);
watcher.on('event', (event) => {
if (event.code === 'BUNDLE_START') {
console.log(
cyan(
`bundles ${bold(event.input)} → ${bold(
event.output.map((fullPath) => path.relative(path.resolve(__dirname), fullPath)).join(', '),
)}...`,
),
);
} else if (event.code === 'BUNDLE_END') {
console.log(
green(
`created ${bold(
event.output.map((fullPath) => path.relative(path.resolve(__dirname), fullPath)).join(', '),
)} in ${event.duration}ms`,
),
);
} else if (event.code === 'ERROR') {
console.log(bold(red('⚠ Error')));
console.log(event.error);
}
if ('result' in event && event.result) {
event.result.close();
}
});
// stop watching
watcher.close();
});