@webqit/webflo 0.11.61-0 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.gitignore +7 -7
- package/LICENSE +20 -20
- package/README.md +2079 -2074
- package/docker/Dockerfile +42 -42
- package/docker/README.md +91 -91
- package/docker/package.json +2 -2
- package/package.json +80 -81
- package/src/{Context.js → AbstractContext.js} +71 -79
- package/src/config-pi/deployment/Env.js +68 -68
- package/src/config-pi/deployment/Layout.js +63 -63
- package/src/config-pi/deployment/Origins.js +139 -139
- package/src/config-pi/deployment/Proxy.js +74 -74
- package/src/config-pi/deployment/index.js +17 -17
- package/src/config-pi/index.js +15 -15
- package/src/config-pi/runtime/Client.js +116 -98
- package/src/config-pi/runtime/Server.js +125 -125
- package/src/config-pi/runtime/client/Worker.js +109 -134
- package/src/config-pi/runtime/client/index.js +11 -11
- package/src/config-pi/runtime/index.js +17 -17
- package/src/config-pi/runtime/server/Headers.js +74 -74
- package/src/config-pi/runtime/server/Redirects.js +69 -69
- package/src/config-pi/runtime/server/index.js +13 -13
- package/src/config-pi/static/Manifest.js +319 -319
- package/src/config-pi/static/Ssg.js +49 -49
- package/src/config-pi/static/index.js +13 -13
- package/src/deployment-pi/index.js +10 -10
- package/src/deployment-pi/origins/index.js +216 -216
- package/src/index.js +11 -19
- package/src/runtime-pi/HttpEvent.js +126 -106
- package/src/runtime-pi/HttpUser.js +126 -0
- package/src/runtime-pi/MessagingOverBroadcast.js +9 -0
- package/src/runtime-pi/MessagingOverChannel.js +85 -0
- package/src/runtime-pi/MessagingOverSocket.js +106 -0
- package/src/runtime-pi/MultiportMessagingAPI.js +81 -0
- package/src/runtime-pi/WebfloCookieStorage.js +27 -0
- package/src/runtime-pi/WebfloEventTarget.js +39 -0
- package/src/runtime-pi/WebfloMessageEvent.js +58 -0
- package/src/runtime-pi/WebfloMessagingAPI.js +69 -0
- package/src/runtime-pi/{Router.js → WebfloRouter.js} +99 -130
- package/src/runtime-pi/WebfloRuntime.js +52 -0
- package/src/runtime-pi/WebfloStorage.js +109 -0
- package/src/runtime-pi/client/ClientMessaging.js +5 -0
- package/src/runtime-pi/client/Context.js +3 -7
- package/src/runtime-pi/client/CookieStorage.js +17 -0
- package/src/runtime-pi/client/Router.js +38 -48
- package/src/runtime-pi/client/SessionStorage.js +33 -0
- package/src/runtime-pi/client/Url.js +156 -205
- package/src/runtime-pi/client/WebfloClient.js +544 -0
- package/src/runtime-pi/client/WebfloRootClient1.js +179 -0
- package/src/runtime-pi/client/WebfloRootClient2.js +109 -0
- package/src/runtime-pi/client/WebfloSubClient.js +165 -0
- package/src/runtime-pi/client/Workport.js +118 -178
- package/src/runtime-pi/client/generate.js +480 -471
- package/src/runtime-pi/client/index.js +16 -21
- package/src/runtime-pi/client/worker/ClientMessaging.js +5 -0
- package/src/runtime-pi/client/worker/Context.js +3 -7
- package/src/runtime-pi/client/worker/CookieStorage.js +17 -0
- package/src/runtime-pi/client/worker/SessionStorage.js +13 -0
- package/src/runtime-pi/client/worker/WebfloWorker.js +294 -0
- package/src/runtime-pi/client/worker/Workport.js +17 -85
- package/src/runtime-pi/client/worker/index.js +10 -21
- package/src/runtime-pi/index.js +6 -13
- package/src/runtime-pi/server/ClientMessaging.js +18 -0
- package/src/runtime-pi/server/ClientMessagingRegistry.js +57 -0
- package/src/runtime-pi/server/Context.js +11 -15
- package/src/runtime-pi/server/CookieStorage.js +17 -0
- package/src/runtime-pi/server/Router.js +93 -159
- package/src/runtime-pi/server/SessionStorage.js +53 -0
- package/src/runtime-pi/server/WebfloServer.js +755 -0
- package/src/runtime-pi/server/index.js +10 -21
- package/src/runtime-pi/util-http.js +322 -86
- package/src/runtime-pi/util-url.js +146 -146
- package/src/runtime-pi/xURL.js +108 -105
- package/src/runtime-pi/xfetch.js +22 -22
- package/src/services-pi/cert/http-auth-hook.js +22 -22
- package/src/services-pi/cert/http-cleanup-hook.js +22 -22
- package/src/services-pi/cert/index.js +79 -79
- package/src/services-pi/index.js +8 -8
- package/src/static-pi/index.js +10 -10
- package/src/webflo.js +30 -30
- package/test/index.test.js +26 -26
- package/test/site/package.json +9 -9
- package/test/site/public/bundle.html +5 -5
- package/test/site/public/bundle.html.json +3 -3
- package/test/site/public/bundle.js +2 -2
- package/test/site/public/bundle.webflo.js +15 -15
- package/test/site/public/index.html +29 -29
- package/test/site/public/index1.html +34 -34
- package/test/site/public/page-2/bundle.html +4 -4
- package/test/site/public/page-2/bundle.js +2 -2
- package/test/site/public/page-2/index.html +45 -45
- package/test/site/public/page-2/main.html +2 -2
- package/test/site/public/page-4/subpage/bundle.js +2 -2
- package/test/site/public/page-4/subpage/index.html +30 -30
- package/test/site/public/sparoots.json +4 -4
- package/test/site/public/worker.js +3 -3
- package/test/site/server/index.js +15 -15
- package/src/runtime-pi/Application.js +0 -29
- package/src/runtime-pi/Cookies.js +0 -82
- package/src/runtime-pi/Runtime.js +0 -21
- package/src/runtime-pi/client/Application.js +0 -100
- package/src/runtime-pi/client/Runtime.js +0 -332
- package/src/runtime-pi/client/createStorage.js +0 -57
- package/src/runtime-pi/client/oohtml/full.js +0 -7
- package/src/runtime-pi/client/oohtml/namespacing.js +0 -7
- package/src/runtime-pi/client/oohtml/scripting.js +0 -8
- package/src/runtime-pi/client/oohtml/templating.js +0 -8
- package/src/runtime-pi/client/worker/Application.js +0 -44
- package/src/runtime-pi/client/worker/Runtime.js +0 -269
- package/src/runtime-pi/server/Application.js +0 -116
- package/src/runtime-pi/server/Runtime.js +0 -557
- package/src/runtime-pi/xFormData.js +0 -24
- package/src/runtime-pi/xHeaders.js +0 -146
- package/src/runtime-pi/xRequest.js +0 -46
- package/src/runtime-pi/xRequestHeaders.js +0 -109
- package/src/runtime-pi/xResponse.js +0 -33
- package/src/runtime-pi/xResponseHeaders.js +0 -117
- package/src/runtime-pi/xxHttpMessage.js +0 -102
|
@@ -1,80 +1,80 @@
|
|
|
1
|
-
|
|
2
|
-
/**
|
|
3
|
-
* imports
|
|
4
|
-
*/
|
|
5
|
-
import Fs from 'fs';
|
|
6
|
-
import { spawn } from 'child_process';
|
|
7
|
-
import { _from as _arrFrom } from '@webqit/util/arr/index.js';
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* @description
|
|
11
|
-
*/
|
|
12
|
-
export const desc = {
|
|
13
|
-
generate: 'Generate an SSL cert for a domain or list of domains.',
|
|
14
|
-
};
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* Reads SSL from file.
|
|
18
|
-
*
|
|
19
|
-
* @param string allDomains
|
|
20
|
-
*
|
|
21
|
-
* @return object
|
|
22
|
-
*/
|
|
23
|
-
export async function generate(allDomains) {
|
|
24
|
-
const cx = this || {};
|
|
25
|
-
if (!cx.config.runtime?.Server) {
|
|
26
|
-
throw new Error(`The Server configurator "config.runtime.Server" is required in context.`);
|
|
27
|
-
}
|
|
28
|
-
const domains = _arrFrom(allDomains).reduce((all, d) => all.concat(d.split(',')), []).filter(d => d.trim());
|
|
29
|
-
const args = [
|
|
30
|
-
'certonly',
|
|
31
|
-
'--manual',
|
|
32
|
-
'--preferred-challenges', 'http',
|
|
33
|
-
].concat(domains.reduce((all, d) => all.concat('-d', d), []))
|
|
34
|
-
.concat([
|
|
35
|
-
'--manual-auth-hook', 'webflo-certbot-http-auth-hook',
|
|
36
|
-
'--manual-cleanup-hook', 'webflo-certbot-http-cleanup-hook',
|
|
37
|
-
'--debug-challenges',
|
|
38
|
-
'--force-interactive',
|
|
39
|
-
]);
|
|
40
|
-
const child = spawn('certbot', args);
|
|
41
|
-
process.stdin.pipe(child.stdin);
|
|
42
|
-
|
|
43
|
-
child.stdout.on('data', data => {
|
|
44
|
-
if (cx.logger) {
|
|
45
|
-
cx.logger.log('[' + cx.logger.style.keyword('CERTBOT') + '][' + cx.logger.style.var('OUT') + ']:', data + '');
|
|
46
|
-
}
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
child.stderr.on('data', data => {
|
|
50
|
-
if (cx.logger) {
|
|
51
|
-
cx.logger.log('[' + cx.logger.style.keyword('CERTBOT') + '][' + cx.logger.style.err('ERR') + ']:', (data + '').trim());
|
|
52
|
-
}
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
child.on('error', data => {
|
|
56
|
-
cx.logger && cx.logger.error(data);
|
|
57
|
-
process.exit();
|
|
58
|
-
});
|
|
59
|
-
|
|
60
|
-
child.on('exit', async exitCode => {
|
|
61
|
-
const serverConfig = new cx.config.runtime.Server(cx);
|
|
62
|
-
const server = await serverConfig.read();
|
|
63
|
-
const domain = domains[0], certDir = `/etc/letsencrypt/live/${domain}`;
|
|
64
|
-
if (!exitCode && cx.flags && (cx.flags['auto-config'] || cx.flags.c)) {
|
|
65
|
-
if (Fs.existsSync(certDir)) {
|
|
66
|
-
cx.logger && cx.logger.log('Automatically configuring the server with the generated cert.');
|
|
67
|
-
if (!server.https) {
|
|
68
|
-
server.https = {};
|
|
69
|
-
}
|
|
70
|
-
server.https.keyfile = `${certDir}/privkey.pem`;
|
|
71
|
-
server.https.certfile = `${certDir}/fullchain.pem`;
|
|
72
|
-
await serverConfig.write(server);
|
|
73
|
-
} else {
|
|
74
|
-
cx.logger && cx.logger.log(`Generated cert files not found in ${certDir}; be sure to configure the server with the valid cert files.`);
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
process.exit();
|
|
78
|
-
});
|
|
79
|
-
|
|
1
|
+
|
|
2
|
+
/**
|
|
3
|
+
* imports
|
|
4
|
+
*/
|
|
5
|
+
import Fs from 'fs';
|
|
6
|
+
import { spawn } from 'child_process';
|
|
7
|
+
import { _from as _arrFrom } from '@webqit/util/arr/index.js';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* @description
|
|
11
|
+
*/
|
|
12
|
+
export const desc = {
|
|
13
|
+
generate: 'Generate an SSL cert for a domain or list of domains.',
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Reads SSL from file.
|
|
18
|
+
*
|
|
19
|
+
* @param string allDomains
|
|
20
|
+
*
|
|
21
|
+
* @return object
|
|
22
|
+
*/
|
|
23
|
+
export async function generate(allDomains) {
|
|
24
|
+
const cx = this || {};
|
|
25
|
+
if (!cx.config.runtime?.Server) {
|
|
26
|
+
throw new Error(`The Server configurator "config.runtime.Server" is required in context.`);
|
|
27
|
+
}
|
|
28
|
+
const domains = _arrFrom(allDomains).reduce((all, d) => all.concat(d.split(',')), []).filter(d => d.trim());
|
|
29
|
+
const args = [
|
|
30
|
+
'certonly',
|
|
31
|
+
'--manual',
|
|
32
|
+
'--preferred-challenges', 'http',
|
|
33
|
+
].concat(domains.reduce((all, d) => all.concat('-d', d), []))
|
|
34
|
+
.concat([
|
|
35
|
+
'--manual-auth-hook', 'webflo-certbot-http-auth-hook',
|
|
36
|
+
'--manual-cleanup-hook', 'webflo-certbot-http-cleanup-hook',
|
|
37
|
+
'--debug-challenges',
|
|
38
|
+
'--force-interactive',
|
|
39
|
+
]);
|
|
40
|
+
const child = spawn('certbot', args);
|
|
41
|
+
process.stdin.pipe(child.stdin);
|
|
42
|
+
|
|
43
|
+
child.stdout.on('data', data => {
|
|
44
|
+
if (cx.logger) {
|
|
45
|
+
cx.logger.log('[' + cx.logger.style.keyword('CERTBOT') + '][' + cx.logger.style.var('OUT') + ']:', data + '');
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
child.stderr.on('data', data => {
|
|
50
|
+
if (cx.logger) {
|
|
51
|
+
cx.logger.log('[' + cx.logger.style.keyword('CERTBOT') + '][' + cx.logger.style.err('ERR') + ']:', (data + '').trim());
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
child.on('error', data => {
|
|
56
|
+
cx.logger && cx.logger.error(data);
|
|
57
|
+
process.exit();
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
child.on('exit', async exitCode => {
|
|
61
|
+
const serverConfig = new cx.config.runtime.Server(cx);
|
|
62
|
+
const server = await serverConfig.read();
|
|
63
|
+
const domain = domains[0], certDir = `/etc/letsencrypt/live/${domain}`;
|
|
64
|
+
if (!exitCode && cx.flags && (cx.flags['auto-config'] || cx.flags.c)) {
|
|
65
|
+
if (Fs.existsSync(certDir)) {
|
|
66
|
+
cx.logger && cx.logger.log('Automatically configuring the server with the generated cert.');
|
|
67
|
+
if (!server.https) {
|
|
68
|
+
server.https = {};
|
|
69
|
+
}
|
|
70
|
+
server.https.keyfile = `${certDir}/privkey.pem`;
|
|
71
|
+
server.https.certfile = `${certDir}/fullchain.pem`;
|
|
72
|
+
await serverConfig.write(server);
|
|
73
|
+
} else {
|
|
74
|
+
cx.logger && cx.logger.log(`Generated cert files not found in ${certDir}; be sure to configure the server with the valid cert files.`);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
process.exit();
|
|
78
|
+
});
|
|
79
|
+
|
|
80
80
|
}
|
package/src/services-pi/index.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
/**
|
|
3
|
-
* @imports
|
|
4
|
-
*/
|
|
5
|
-
import * as cert from './cert/index.js';
|
|
6
|
-
|
|
7
|
-
export {
|
|
8
|
-
cert,
|
|
1
|
+
|
|
2
|
+
/**
|
|
3
|
+
* @imports
|
|
4
|
+
*/
|
|
5
|
+
import * as cert from './cert/index.js';
|
|
6
|
+
|
|
7
|
+
export {
|
|
8
|
+
cert,
|
|
9
9
|
}
|
package/src/static-pi/index.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
|
|
2
|
-
/**
|
|
3
|
-
* @imports
|
|
4
|
-
import * as client from './client/index.js';
|
|
5
|
-
import * as server from './server/index.js';
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
export {
|
|
9
|
-
//client,
|
|
10
|
-
//server,
|
|
1
|
+
|
|
2
|
+
/**
|
|
3
|
+
* @imports
|
|
4
|
+
import * as client from './client/index.js';
|
|
5
|
+
import * as server from './server/index.js';
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
export {
|
|
9
|
+
//client,
|
|
10
|
+
//server,
|
|
11
11
|
}
|
package/src/webflo.js
CHANGED
|
@@ -1,31 +1,31 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* @imports
|
|
5
|
-
*/
|
|
6
|
-
import Url from 'url';
|
|
7
|
-
import Path from 'path';
|
|
8
|
-
import { jsonFile } from '@webqit/backpack/src/dotfile/index.js';
|
|
9
|
-
import { Logger, Cli } from '@webqit/backpack';
|
|
10
|
-
import * as WebfloPI from './index.js';
|
|
11
|
-
|
|
12
|
-
const dirSelf = Path.dirname(Url.fileURLToPath(import.meta.url));
|
|
13
|
-
const webfloJson = jsonFile.read(Path.join(dirSelf, '../package.json'));
|
|
14
|
-
const appJson = jsonFile.read('./package.json');
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* @cx
|
|
18
|
-
*/
|
|
19
|
-
const cx = WebfloPI.Context.create({
|
|
20
|
-
meta: { title: webfloJson.title, version: webfloJson.version },
|
|
21
|
-
app: { title: appJson.title, version: appJson.version },
|
|
22
|
-
logger: Logger,
|
|
23
|
-
config: WebfloPI.config,
|
|
24
|
-
middlewares: [ WebfloPI.deployment.origins.webhook ],
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
/**
|
|
28
|
-
* @cli
|
|
29
|
-
*/
|
|
30
|
-
const cli = new Cli(WebfloPI);
|
|
31
|
-
await cli.exec(cx);
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @imports
|
|
5
|
+
*/
|
|
6
|
+
import Url from 'url';
|
|
7
|
+
import Path from 'path';
|
|
8
|
+
import { jsonFile } from '@webqit/backpack/src/dotfile/index.js';
|
|
9
|
+
import { Logger, Cli } from '@webqit/backpack';
|
|
10
|
+
import * as WebfloPI from './index.js';
|
|
11
|
+
|
|
12
|
+
const dirSelf = Path.dirname(Url.fileURLToPath(import.meta.url));
|
|
13
|
+
const webfloJson = jsonFile.read(Path.join(dirSelf, '../package.json'));
|
|
14
|
+
const appJson = jsonFile.read('./package.json');
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* @cx
|
|
18
|
+
*/
|
|
19
|
+
const cx = WebfloPI.Context.create({
|
|
20
|
+
meta: { title: webfloJson.title, version: webfloJson.version },
|
|
21
|
+
app: { title: appJson.title, version: appJson.version },
|
|
22
|
+
logger: Logger,
|
|
23
|
+
config: WebfloPI.config,
|
|
24
|
+
middlewares: [ WebfloPI.deployment.origins.webhook ],
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* @cli
|
|
29
|
+
*/
|
|
30
|
+
const cli = new Cli(WebfloPI);
|
|
31
|
+
await cli.exec(cx);
|
package/test/index.test.js
CHANGED
|
@@ -1,26 +1,26 @@
|
|
|
1
|
-
|
|
2
|
-
/**
|
|
3
|
-
* @imports
|
|
4
|
-
*/
|
|
5
|
-
import { config, runtime, Context } from '../src/index.js';
|
|
6
|
-
|
|
7
|
-
let client = {
|
|
8
|
-
handle: function( httpEvent ) {
|
|
9
|
-
return new httpEvent.Response({ abcd: '1234' }, {
|
|
10
|
-
status: 302,
|
|
11
|
-
headers: {
|
|
12
|
-
//location: '/dddd',
|
|
13
|
-
cookies: {
|
|
14
|
-
cookie1: { value: 'value1' },
|
|
15
|
-
cookie2: { value: 'value2' },
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
});
|
|
19
|
-
},
|
|
20
|
-
};
|
|
21
|
-
|
|
22
|
-
const cx = Context.create( { config: config, } );
|
|
23
|
-
const clientCallback = ( _cx, hostName, defaultClientCallback ) => client;
|
|
24
|
-
const app = await runtime.server.start.call( cx, clientCallback );
|
|
25
|
-
|
|
26
|
-
const response = await app.go( 'http://localhost/', { headers: { range: 'bytes=0-5, 6' } } );
|
|
1
|
+
|
|
2
|
+
/**
|
|
3
|
+
* @imports
|
|
4
|
+
*/
|
|
5
|
+
import { config, runtime, Context } from '../src/index.js';
|
|
6
|
+
|
|
7
|
+
let client = {
|
|
8
|
+
handle: function( httpEvent ) {
|
|
9
|
+
return new httpEvent.Response({ abcd: '1234' }, {
|
|
10
|
+
status: 302,
|
|
11
|
+
headers: {
|
|
12
|
+
//location: '/dddd',
|
|
13
|
+
cookies: {
|
|
14
|
+
cookie1: { value: 'value1' },
|
|
15
|
+
cookie2: { value: 'value2' },
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
},
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
const cx = Context.create( { config: config, } );
|
|
23
|
+
const clientCallback = ( _cx, hostName, defaultClientCallback ) => client;
|
|
24
|
+
const app = await runtime.server.start.call( cx, clientCallback );
|
|
25
|
+
|
|
26
|
+
const response = await app.go( 'http://localhost/', { headers: { range: 'bytes=0-5, 6' } } );
|
package/test/site/package.json
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
{
|
|
2
|
-
"title": "Webflo Test",
|
|
3
|
-
"type": "module",
|
|
4
|
-
"scripts": {
|
|
5
|
-
"generate": "webflo generate::client --recursive --compression --auto-embed",
|
|
6
|
-
"bundle": "cd public && oohtml bundle --recursive --auto-embed=routes",
|
|
7
|
-
"build": "npm run generate && npm run bundle"
|
|
8
|
-
}
|
|
9
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"title": "Webflo Test",
|
|
3
|
+
"type": "module",
|
|
4
|
+
"scripts": {
|
|
5
|
+
"generate": "webflo generate::client --recursive --compression --auto-embed",
|
|
6
|
+
"bundle": "cd public && oohtml bundle --recursive --auto-embed=routes",
|
|
7
|
+
"build": "npm run generate && npm run bundle"
|
|
8
|
+
}
|
|
9
|
+
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
|
|
2
|
-
<template
|
|
3
|
-
<img src="/
|
|
4
|
-
</template>
|
|
5
|
-
<template
|
|
1
|
+
|
|
2
|
+
<template def="page-3">
|
|
3
|
+
<img src="/logo-130x130.png" def="logo-130x130.png" />
|
|
4
|
+
</template>
|
|
5
|
+
<template def="page-4">
|
|
6
6
|
</template>
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
{
|
|
2
|
-
"page-3": {},
|
|
3
|
-
"page-4": {}
|
|
1
|
+
{
|
|
2
|
+
"page-3": {},
|
|
3
|
+
"page-4": {}
|
|
4
4
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
/** @webqit/webflo */
|
|
2
|
-
var{start:e}=WebQit.Webflo,r={},o={bundle_filename:"bundle.js",public_base_url:"/",spa_routing:!0,oohtml_support:"full",service_worker_support:!0,worker_scope:"/",worker_filename:"worker.js",routing:{root:"/",subroots:["/page-2","/page-4/subpage"],targets:2}};e.call({layout:r,params:o});
|
|
1
|
+
/** @webqit/webflo */
|
|
2
|
+
var{start:e}=WebQit.Webflo,r={},o={bundle_filename:"bundle.js",public_base_url:"/",spa_routing:!0,oohtml_support:"full",service_worker_support:!0,worker_scope:"/",worker_filename:"worker.js",routing:{root:"/",subroots:["/page-2","/page-4/subpage"],targets:2}};e.call({layout:r,params:o});
|