@luzzle/web.tools 0.0.70 → 0.0.71
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/dist/src/cli.d.ts +2 -0
- package/dist/src/cli.js +19 -0
- package/dist/src/cli.js.map +1 -0
- package/dist/src/commands/assets/command.d.ts +30 -0
- package/dist/src/commands/assets/command.js +41 -0
- package/dist/src/commands/assets/command.js.map +1 -0
- package/dist/src/commands/assets/index.d.ts +4 -0
- package/dist/src/commands/assets/index.js +79 -0
- package/dist/src/commands/assets/index.js.map +1 -0
- package/dist/src/commands/assets/index.test.d.ts +1 -0
- package/dist/src/commands/assets/index.test.js +419 -0
- package/dist/src/commands/assets/index.test.js.map +1 -0
- package/dist/src/commands/assets/variants.d.ts +8 -0
- package/dist/src/commands/assets/variants.js +23 -0
- package/dist/src/commands/assets/variants.js.map +1 -0
- package/dist/src/commands/assets/variants.test.d.ts +1 -0
- package/dist/src/commands/assets/variants.test.js +48 -0
- package/dist/src/commands/assets/variants.test.js.map +1 -0
- package/dist/src/commands/config/command.d.ts +2 -0
- package/dist/src/commands/config/command.js +42 -0
- package/dist/src/commands/config/command.js.map +1 -0
- package/dist/src/commands/config/index.d.ts +3 -0
- package/dist/src/commands/config/index.js +37 -0
- package/dist/src/commands/config/index.js.map +1 -0
- package/dist/src/commands/config/index.test.d.ts +1 -0
- package/dist/src/commands/config/index.test.js +93 -0
- package/dist/src/commands/config/index.test.js.map +1 -0
- package/dist/src/commands/opengraph/browser.d.ts +3 -0
- package/dist/src/commands/opengraph/browser.js +23 -0
- package/dist/src/commands/opengraph/browser.js.map +1 -0
- package/dist/src/commands/opengraph/browser.test.d.ts +1 -0
- package/dist/src/commands/opengraph/browser.test.js +30 -0
- package/dist/src/commands/opengraph/browser.test.js.map +1 -0
- package/dist/src/commands/opengraph/command.d.ts +30 -0
- package/dist/src/commands/opengraph/command.js +41 -0
- package/dist/src/commands/opengraph/command.js.map +1 -0
- package/dist/src/commands/opengraph/command.test.d.ts +1 -0
- package/dist/src/commands/opengraph/command.test.js +68 -0
- package/dist/src/commands/opengraph/command.test.js.map +1 -0
- package/dist/src/commands/opengraph/index.d.ts +4 -0
- package/dist/src/commands/opengraph/index.js +47 -0
- package/dist/src/commands/opengraph/index.js.map +1 -0
- package/dist/src/commands/opengraph/index.test.d.ts +1 -0
- package/dist/src/commands/opengraph/index.test.js +162 -0
- package/dist/src/commands/opengraph/index.test.js.map +1 -0
- package/dist/src/commands/opengraph/png.d.ts +3 -0
- package/dist/src/commands/opengraph/png.js +26 -0
- package/dist/src/commands/opengraph/png.js.map +1 -0
- package/dist/src/commands/opengraph/png.test.d.ts +1 -0
- package/dist/src/commands/opengraph/png.test.js +50 -0
- package/dist/src/commands/opengraph/png.test.js.map +1 -0
- package/dist/src/commands/sqlite/command.d.ts +8 -0
- package/dist/src/commands/sqlite/command.js +16 -0
- package/dist/src/commands/sqlite/command.js.map +1 -0
- package/dist/src/commands/sqlite/command.test.d.ts +1 -0
- package/dist/src/commands/sqlite/command.test.js +42 -0
- package/dist/src/commands/sqlite/command.test.js.map +1 -0
- package/dist/src/commands/sqlite/database.d.ts +9 -0
- package/dist/src/commands/sqlite/database.js +174 -0
- package/dist/src/commands/sqlite/database.js.map +1 -0
- package/dist/src/commands/sqlite/database.mock.d.ts +24 -0
- package/dist/src/commands/sqlite/database.mock.js +58 -0
- package/dist/src/commands/sqlite/database.mock.js.map +1 -0
- package/dist/src/commands/sqlite/database.test.d.ts +1 -0
- package/dist/src/commands/sqlite/database.test.js +211 -0
- package/dist/src/commands/sqlite/database.test.js.map +1 -0
- package/dist/src/commands/sqlite/index.d.ts +1 -0
- package/dist/src/commands/sqlite/index.js +26 -0
- package/dist/src/commands/sqlite/index.js.map +1 -0
- package/dist/src/commands/sqlite/index.test.d.ts +1 -0
- package/dist/src/commands/sqlite/index.test.js +48 -0
- package/dist/src/commands/sqlite/index.test.js.map +1 -0
- package/dist/src/commands/theme/command.d.ts +13 -0
- package/dist/src/commands/theme/command.js +21 -0
- package/dist/src/commands/theme/command.js.map +1 -0
- package/dist/src/commands/theme/command.test.d.ts +1 -0
- package/dist/src/commands/theme/command.test.js +40 -0
- package/dist/src/commands/theme/command.test.js.map +1 -0
- package/dist/src/commands/theme/index.d.ts +1 -0
- package/dist/src/commands/theme/index.js +9 -0
- package/dist/src/commands/theme/index.js.map +1 -0
- package/dist/src/commands/theme/index.test.d.ts +1 -0
- package/dist/src/commands/theme/index.test.js +46 -0
- package/dist/src/commands/theme/index.test.js.map +1 -0
- package/dist/src/commands/theme/theme.d.ts +4 -0
- package/dist/src/commands/theme/theme.js +76 -0
- package/dist/src/commands/theme/theme.js.map +1 -0
- package/dist/src/commands/theme/theme.test.d.ts +1 -0
- package/dist/src/commands/theme/theme.test.js +54 -0
- package/dist/src/commands/theme/theme.test.js.map +1 -0
- package/dist/src/lib/lastRun.d.ts +4 -0
- package/dist/src/lib/lastRun.js +23 -0
- package/dist/src/lib/lastRun.js.map +1 -0
- package/dist/src/lib/lastRun.test.d.ts +1 -0
- package/dist/src/lib/lastRun.test.js +47 -0
- package/dist/src/lib/lastRun.test.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +3 -3
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import Sharp from 'sharp';
|
|
2
|
+
import { LuzzleSelectable, Pieces } from '@luzzle/core';
|
|
3
|
+
declare function generateVariantJobs(item: LuzzleSelectable<'pieces_items'>, asset: string, pieces: Pieces, widths: number[], formats: Array<'avif' | 'jpg'>): Promise<{
|
|
4
|
+
width: number;
|
|
5
|
+
format: (typeof formats)[number];
|
|
6
|
+
sharp: Sharp.Sharp;
|
|
7
|
+
}[]>;
|
|
8
|
+
export { generateVariantJobs };
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import Sharp from 'sharp';
|
|
2
|
+
function generateVariantSharpJob(sharp, width, format) {
|
|
3
|
+
return sharp.clone().resize({ width }).toFormat(format);
|
|
4
|
+
}
|
|
5
|
+
async function generateVariantJobs(item, asset, pieces, widths, formats) {
|
|
6
|
+
const jobs = [];
|
|
7
|
+
try {
|
|
8
|
+
const image = await pieces.getPieceAsset(asset);
|
|
9
|
+
const sharpImage = Sharp(image);
|
|
10
|
+
for (const format of formats) {
|
|
11
|
+
for (const width of widths) {
|
|
12
|
+
const sharp = generateVariantSharpJob(sharpImage, width, format);
|
|
13
|
+
jobs.push({ width, format, sharp });
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
catch (error) {
|
|
18
|
+
console.error(`error generating variant jobs for ${item.file_path} asset at ${asset}: ${error}`);
|
|
19
|
+
}
|
|
20
|
+
return jobs;
|
|
21
|
+
}
|
|
22
|
+
export { generateVariantJobs };
|
|
23
|
+
//# sourceMappingURL=variants.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"variants.js","sourceRoot":"","sources":["../../../../src/commands/assets/variants.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,SAAS,uBAAuB,CAAC,KAAkB,EAAE,KAAa,EAAE,MAAsB;IACzF,OAAO,KAAK,CAAC,KAAK,EAAE,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAA;AACxD,CAAC;AAED,KAAK,UAAU,mBAAmB,CACjC,IAAsC,EACtC,KAAa,EACb,MAAc,EACd,MAAgB,EAChB,OAA8B;IAE9B,MAAM,IAAI,GAIJ,EAAE,CAAA;IAER,IAAI,CAAC;QACJ,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;QAC/C,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,CAAC,CAAA;QAE/B,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC9B,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;gBAC5B,MAAM,KAAK,GAAG,uBAAuB,CAAC,UAAU,EAAE,KAAK,EAAE,MAAM,CAAC,CAAA;gBAChE,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAA;YACpC,CAAC;QACF,CAAC;IACF,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QAChB,OAAO,CAAC,KAAK,CAAC,qCAAqC,IAAI,CAAC,SAAS,aAAa,KAAK,KAAK,KAAK,EAAE,CAAC,CAAA;IACjG,CAAC;IAED,OAAO,IAAI,CAAA;AACZ,CAAC;AAED,OAAO,EAAE,mBAAmB,EAAE,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { describe, test, expect, vi, afterEach } from 'vitest';
|
|
2
|
+
import { generateVariantJobs } from './variants.js';
|
|
3
|
+
import Sharp from 'sharp';
|
|
4
|
+
vi.mock('sharp');
|
|
5
|
+
describe('generateVariantJobs', () => {
|
|
6
|
+
afterEach(() => {
|
|
7
|
+
vi.clearAllMocks();
|
|
8
|
+
});
|
|
9
|
+
test('should return an empty array if getPieceAsset fails', async () => {
|
|
10
|
+
const mockPieces = {
|
|
11
|
+
getPieceAsset: vi.fn().mockRejectedValue(new Error('test error')),
|
|
12
|
+
};
|
|
13
|
+
const mockItem = {
|
|
14
|
+
id: '1',
|
|
15
|
+
type: 'test',
|
|
16
|
+
file_path: 'path/to/file.jpg',
|
|
17
|
+
};
|
|
18
|
+
const consoleErrorSpy = vi.spyOn(console, 'error').mockImplementation(() => { });
|
|
19
|
+
const jobs = await generateVariantJobs(mockItem, 'image.jpg', mockPieces, [100], ['avif', 'jpg']);
|
|
20
|
+
expect(jobs).toEqual([]);
|
|
21
|
+
expect(consoleErrorSpy).toHaveBeenCalledOnce();
|
|
22
|
+
consoleErrorSpy.mockRestore();
|
|
23
|
+
});
|
|
24
|
+
test('should generate variant jobs for an image asset', async () => {
|
|
25
|
+
const mockPieces = { getPieceAsset: vi.fn(() => 'asset_content') };
|
|
26
|
+
const mockItem = {
|
|
27
|
+
id: '1',
|
|
28
|
+
type: 'test',
|
|
29
|
+
file_path: 'path/to/file.jpg',
|
|
30
|
+
};
|
|
31
|
+
const mockSharp = {
|
|
32
|
+
clone: vi.fn().mockReturnThis(),
|
|
33
|
+
resize: vi.fn().mockReturnThis(),
|
|
34
|
+
toFormat: vi.fn().mockReturnThis(),
|
|
35
|
+
};
|
|
36
|
+
vi.mocked(Sharp).mockReturnValue(mockSharp);
|
|
37
|
+
const jobs = await generateVariantJobs(mockItem, 'image.jpg', mockPieces, [100, 200], ['avif', 'jpg']);
|
|
38
|
+
expect(mockPieces.getPieceAsset).toHaveBeenCalledWith('image.jpg');
|
|
39
|
+
expect(Sharp).toHaveBeenCalledWith('asset_content');
|
|
40
|
+
expect(mockSharp.clone).toHaveBeenCalledTimes(4);
|
|
41
|
+
expect(mockSharp.resize).toHaveBeenCalledWith({ width: 100 });
|
|
42
|
+
expect(mockSharp.resize).toHaveBeenCalledWith({ width: 200 });
|
|
43
|
+
expect(mockSharp.toFormat).toHaveBeenCalledWith('avif');
|
|
44
|
+
expect(mockSharp.toFormat).toHaveBeenCalledWith('jpg');
|
|
45
|
+
expect(jobs).toHaveLength(4);
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
//# sourceMappingURL=variants.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"variants.test.js","sourceRoot":"","sources":["../../../../src/commands/assets/variants.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAA;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAA;AACnD,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;AAEhB,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;IACpC,SAAS,CAAC,GAAG,EAAE;QACd,EAAE,CAAC,aAAa,EAAE,CAAA;IACnB,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,qDAAqD,EAAE,KAAK,IAAI,EAAE;QACtE,MAAM,UAAU,GAAG;YAClB,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,IAAI,KAAK,CAAC,YAAY,CAAC,CAAC;SAC5C,CAAA;QACtB,MAAM,QAAQ,GAAG;YAChB,EAAE,EAAE,GAAG;YACP,IAAI,EAAE,MAAM;YACZ,SAAS,EAAE,kBAAkB;SACkB,CAAA;QAEhD,MAAM,eAAe,GAAG,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,kBAAkB,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAA;QAE/E,MAAM,IAAI,GAAG,MAAM,mBAAmB,CAAC,QAAQ,EAAE,WAAW,EAAE,UAAU,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAA;QAEjG,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;QACxB,MAAM,CAAC,eAAe,CAAC,CAAC,oBAAoB,EAAE,CAAA;QAE9C,eAAe,CAAC,WAAW,EAAE,CAAA;IAC9B,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAClE,MAAM,UAAU,GAAG,EAAE,aAAa,EAAE,EAAE,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC,EAAuB,CAAA;QACvF,MAAM,QAAQ,GAAG;YAChB,EAAE,EAAE,GAAG;YACP,IAAI,EAAE,MAAM;YACZ,SAAS,EAAE,kBAAkB;SACkB,CAAA;QAEhD,MAAM,SAAS,GAAG;YACjB,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,cAAc,EAAE;YAC/B,MAAM,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,cAAc,EAAE;YAChC,QAAQ,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,cAAc,EAAE;SAClC,CAAA;QACD,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,eAAe,CAAC,SAAmC,CAAC,CAAA;QAErE,MAAM,IAAI,GAAG,MAAM,mBAAmB,CACrC,QAAQ,EACR,WAAW,EACX,UAAU,EACV,CAAC,GAAG,EAAE,GAAG,CAAC,EACV,CAAC,MAAM,EAAE,KAAK,CAAC,CACf,CAAA;QAED,MAAM,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,oBAAoB,CAAC,WAAW,CAAC,CAAA;QAClE,MAAM,CAAC,KAAK,CAAC,CAAC,oBAAoB,CAAC,eAAe,CAAC,CAAA;QACnD,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAA;QAChD,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,oBAAoB,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAA;QAC7D,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,oBAAoB,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAA;QAC7D,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAA;QACvD,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAA;QACtD,MAAM,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;IAC7B,CAAC,CAAC,CAAA;AACH,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { validateHandler, getHandler, setHandler } from './index.js';
|
|
2
|
+
export default function configCommand(cli) {
|
|
3
|
+
return cli.command('config <subcommand>', 'Manage configuration', (yargs) => {
|
|
4
|
+
yargs
|
|
5
|
+
.command('validate', 'Validate the configuration file', function (yargs) {
|
|
6
|
+
return yargs.option('config', {
|
|
7
|
+
alias: 'c',
|
|
8
|
+
type: 'string',
|
|
9
|
+
description: 'Path to the configuration file',
|
|
10
|
+
demandOption: true,
|
|
11
|
+
});
|
|
12
|
+
}, function (argv) {
|
|
13
|
+
validateHandler(argv.config);
|
|
14
|
+
})
|
|
15
|
+
.command('get <path>', 'Get a value from the configuration', function (yargs) {
|
|
16
|
+
return yargs.positional('path', {
|
|
17
|
+
type: 'string',
|
|
18
|
+
description: 'Path to the value to get',
|
|
19
|
+
demandOption: true,
|
|
20
|
+
});
|
|
21
|
+
}, function (argv) {
|
|
22
|
+
getHandler(argv.config, argv.path);
|
|
23
|
+
})
|
|
24
|
+
.command('set <path> <value>', 'Set a value in the configuration', function (yargs) {
|
|
25
|
+
return yargs
|
|
26
|
+
.positional('path', {
|
|
27
|
+
type: 'string',
|
|
28
|
+
description: 'Path to the value to set',
|
|
29
|
+
demandOption: true,
|
|
30
|
+
})
|
|
31
|
+
.positional('value', {
|
|
32
|
+
type: 'string',
|
|
33
|
+
description: 'The value to set',
|
|
34
|
+
demandOption: true,
|
|
35
|
+
});
|
|
36
|
+
}, function (argv) {
|
|
37
|
+
setHandler(argv.config, argv.path, argv.value);
|
|
38
|
+
})
|
|
39
|
+
.demandCommand(1, 'You need to specify a subcommand [validate, get, set]');
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=command.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"command.js","sourceRoot":"","sources":["../../../../src/commands/config/command.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,YAAY,CAAA;AAEpE,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,GAAS;IAC9C,OAAO,GAAG,CAAC,OAAO,CAAC,qBAAqB,EAAE,sBAAsB,EAAE,CAAC,KAAK,EAAE,EAAE;QAC3E,KAAK;aACH,OAAO,CACP,UAAU,EACV,iCAAiC,EACjC,UAAS,KAAK;YACb,OAAO,KAAK,CAAC,MAAM,CAAC,QAAQ,EAAE;gBAC7B,KAAK,EAAE,GAAG;gBACV,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,gCAAgC;gBAC7C,YAAY,EAAE,IAAI;aAClB,CAAC,CAAA;QACH,CAAC,EACD,UAAS,IAAI;YACZ,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QAC7B,CAAC,CACD;aACA,OAAO,CACP,YAAY,EACZ,oCAAoC,EACpC,UAAS,KAAK;YACb,OAAO,KAAK,CAAC,UAAU,CAAC,MAAM,EAAE;gBAC/B,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,0BAA0B;gBACvC,YAAY,EAAE,IAAI;aAClB,CAAC,CAAA;QACH,CAAC,EACD,UAAS,IAAI;YACZ,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,CAAA;QACnC,CAAC,CACD;aACA,OAAO,CACP,oBAAoB,EACpB,kCAAkC,EAClC,UAAS,KAAK;YACb,OAAO,KAAK;iBACV,UAAU,CAAC,MAAM,EAAE;gBACnB,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,0BAA0B;gBACvC,YAAY,EAAE,IAAI;aAClB,CAAC;iBACD,UAAU,CAAC,OAAO,EAAE;gBACpB,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,kBAAkB;gBAC/B,YAAY,EAAE,IAAI;aAClB,CAAC,CAAA;QACJ,CAAC,EACD,UAAS,IAAI;YACZ,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAA;QAC/C,CAAC,CACD;aACA,aAAa,CAAC,CAAC,EAAE,uDAAuD,CAAC,CAAA;IAC5E,CAAC,CAAC,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { writeFileSync } from 'fs';
|
|
2
|
+
import yaml from 'yaml';
|
|
3
|
+
import { getConfigValue, setConfigValue, loadConfig } from '@luzzle/web.utils/server';
|
|
4
|
+
export function validateHandler(config) {
|
|
5
|
+
try {
|
|
6
|
+
loadConfig(config);
|
|
7
|
+
console.log('Configuration is valid.');
|
|
8
|
+
}
|
|
9
|
+
catch (error) {
|
|
10
|
+
console.error('Configuration check failed:', error);
|
|
11
|
+
process.exit(1);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
export function getHandler(userConfig, path) {
|
|
15
|
+
try {
|
|
16
|
+
const config = loadConfig(userConfig);
|
|
17
|
+
const value = getConfigValue(config, path);
|
|
18
|
+
console.log(value);
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
console.error('Could not get value:', error);
|
|
22
|
+
process.exit(1);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
export function setHandler(userConfig, path, value) {
|
|
26
|
+
try {
|
|
27
|
+
const config = loadConfig(userConfig);
|
|
28
|
+
setConfigValue(config, path, value);
|
|
29
|
+
writeFileSync(userConfig, yaml.stringify(config));
|
|
30
|
+
console.log('Configuration updated.');
|
|
31
|
+
}
|
|
32
|
+
catch (error) {
|
|
33
|
+
console.error('Could not set value:', error);
|
|
34
|
+
process.exit(1);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/commands/config/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,IAAI,CAAA;AAClC,OAAO,IAAI,MAAM,MAAM,CAAA;AACvB,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAA;AAErF,MAAM,UAAU,eAAe,CAAC,MAAc;IAC5C,IAAI,CAAC;QACH,UAAU,CAAC,MAAM,CAAC,CAAA;QAClB,OAAO,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAA;IACxC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,6BAA6B,EAAE,KAAK,CAAC,CAAA;QACnD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACjB,CAAC;AACH,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,UAAkB,EAAE,IAAY;IACzD,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,UAAU,CAAC,UAAU,CAAC,CAAA;QACrC,MAAM,KAAK,GAAG,cAAc,CAAC,MAAM,EAAE,IAAI,CAAC,CAAA;QAC1C,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;IACpB,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,sBAAsB,EAAE,KAAK,CAAC,CAAA;QAC5C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACjB,CAAC;AACH,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,UAAkB,EAAE,IAAY,EAAE,KAAc;IACzE,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,UAAU,CAAC,UAAU,CAAC,CAAA;QACrC,cAAc,CAAC,MAAM,EAAE,IAAI,EAAE,KAAK,CAAC,CAAA;QACnC,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAA;QACjD,OAAO,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAA;IACvC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,sBAAsB,EAAE,KAAK,CAAC,CAAA;QAC5C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACjB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { describe, test, vi, afterEach, expect } from 'vitest';
|
|
2
|
+
import { getHandler, setHandler, validateHandler } from './index.js';
|
|
3
|
+
import { getConfigValue, setConfigValue, loadConfig } from '@luzzle/web.utils/server';
|
|
4
|
+
import { writeFileSync } from 'fs';
|
|
5
|
+
import yaml from 'yaml';
|
|
6
|
+
vi.mock('@luzzle/web.utils/server');
|
|
7
|
+
vi.mock('fs');
|
|
8
|
+
vi.mock('yaml');
|
|
9
|
+
const mocks = {
|
|
10
|
+
getConfigValue: vi.mocked(getConfigValue),
|
|
11
|
+
setConfigValue: vi.mocked(setConfigValue),
|
|
12
|
+
loadConfig: vi.mocked(loadConfig),
|
|
13
|
+
writeFileSync: vi.mocked(writeFileSync),
|
|
14
|
+
yamlStringify: vi.spyOn(yaml, 'stringify')
|
|
15
|
+
};
|
|
16
|
+
const spies = {};
|
|
17
|
+
describe('src/commands/config', () => {
|
|
18
|
+
afterEach(() => {
|
|
19
|
+
vi.clearAllMocks();
|
|
20
|
+
});
|
|
21
|
+
describe('validateHandler', () => {
|
|
22
|
+
test('should log success when config is valid', () => {
|
|
23
|
+
mocks.loadConfig.mockReturnValue({});
|
|
24
|
+
spies.consoleLog = vi.spyOn(console, 'log').mockImplementation(() => { });
|
|
25
|
+
spies.processExit = vi.spyOn(process, 'exit').mockReturnValue(0);
|
|
26
|
+
validateHandler('test');
|
|
27
|
+
expect(mocks.loadConfig).toHaveBeenCalledOnce();
|
|
28
|
+
expect(spies.consoleLog).toHaveBeenCalledOnce();
|
|
29
|
+
expect(spies.processExit).not.toHaveBeenCalled();
|
|
30
|
+
});
|
|
31
|
+
test('should log error and exit when config is invalid', () => {
|
|
32
|
+
mocks.loadConfig.mockImplementation(() => {
|
|
33
|
+
throw new Error('Invalid config');
|
|
34
|
+
});
|
|
35
|
+
spies.consoleError = vi.spyOn(console, 'error').mockImplementation(() => { });
|
|
36
|
+
spies.processExit = vi.spyOn(process, 'exit').mockReturnValue(0);
|
|
37
|
+
validateHandler('test');
|
|
38
|
+
expect(mocks.loadConfig).toHaveBeenCalledOnce();
|
|
39
|
+
expect(spies.consoleError).toHaveBeenCalledOnce();
|
|
40
|
+
expect(spies.processExit).toHaveBeenCalledWith(1);
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
describe('getHandler', () => {
|
|
44
|
+
test('should log the value when the path is valid', () => {
|
|
45
|
+
mocks.loadConfig.mockReturnValue({});
|
|
46
|
+
mocks.getConfigValue.mockReturnValue('test-value');
|
|
47
|
+
spies.consoleLog = vi.spyOn(console, 'log').mockImplementation(() => { });
|
|
48
|
+
getHandler('test', 'test.path');
|
|
49
|
+
expect(mocks.loadConfig).toHaveBeenCalledOnce();
|
|
50
|
+
expect(mocks.getConfigValue).toHaveBeenCalledOnce();
|
|
51
|
+
expect(spies.consoleLog).toHaveBeenCalledOnce();
|
|
52
|
+
});
|
|
53
|
+
test('should log error and exit when the path is invalid', () => {
|
|
54
|
+
mocks.loadConfig.mockReturnValue({});
|
|
55
|
+
mocks.getConfigValue.mockImplementation(() => {
|
|
56
|
+
throw new Error('Invalid path');
|
|
57
|
+
});
|
|
58
|
+
spies.consoleError = vi.spyOn(console, 'error').mockImplementation(() => { });
|
|
59
|
+
spies.processExit = vi.spyOn(process, 'exit').mockReturnValue(0);
|
|
60
|
+
getHandler('test', 'test.path');
|
|
61
|
+
expect(mocks.loadConfig).toHaveBeenCalledOnce();
|
|
62
|
+
expect(mocks.getConfigValue).toHaveBeenCalledOnce();
|
|
63
|
+
expect(spies.consoleError).toHaveBeenCalledOnce();
|
|
64
|
+
expect(spies.processExit).toHaveBeenCalledWith(1);
|
|
65
|
+
});
|
|
66
|
+
});
|
|
67
|
+
describe('setHandler', () => {
|
|
68
|
+
test('should write the updated config to the file', () => {
|
|
69
|
+
mocks.loadConfig.mockReturnValue({});
|
|
70
|
+
mocks.yamlStringify.mockReturnValue('test-config');
|
|
71
|
+
spies.consoleLog = vi.spyOn(console, 'log').mockImplementation(() => { });
|
|
72
|
+
setHandler('test', 'test.path', 'test-value');
|
|
73
|
+
expect(mocks.loadConfig).toHaveBeenCalledOnce();
|
|
74
|
+
expect(mocks.setConfigValue).toHaveBeenCalledOnce();
|
|
75
|
+
expect(mocks.writeFileSync).toHaveBeenCalledOnce();
|
|
76
|
+
expect(spies.consoleLog).toHaveBeenCalledOnce();
|
|
77
|
+
});
|
|
78
|
+
test('should log error and exit when the value cannot be set', () => {
|
|
79
|
+
mocks.loadConfig.mockReturnValue({});
|
|
80
|
+
mocks.setConfigValue.mockImplementation(() => {
|
|
81
|
+
throw new Error('Invalid value');
|
|
82
|
+
});
|
|
83
|
+
spies.consoleError = vi.spyOn(console, 'error').mockImplementation(() => { });
|
|
84
|
+
spies.processExit = vi.spyOn(process, 'exit').mockReturnValue(0);
|
|
85
|
+
setHandler('test', 'test.path', 'test-value');
|
|
86
|
+
expect(mocks.loadConfig).toHaveBeenCalledOnce();
|
|
87
|
+
expect(mocks.setConfigValue).toHaveBeenCalledOnce();
|
|
88
|
+
expect(spies.consoleError).toHaveBeenCalledOnce();
|
|
89
|
+
expect(spies.processExit).toHaveBeenCalledWith(1);
|
|
90
|
+
});
|
|
91
|
+
});
|
|
92
|
+
});
|
|
93
|
+
//# sourceMappingURL=index.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../../../src/commands/config/index.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import puppeteer from 'puppeteer';
|
|
2
|
+
let browserSingleton;
|
|
3
|
+
async function initializeBrowser() {
|
|
4
|
+
const launchArgs = [
|
|
5
|
+
'--no-sandbox',
|
|
6
|
+
'--disable-setuid-sandbox',
|
|
7
|
+
'--disable-dev-shm-usage',
|
|
8
|
+
'--disable-accelerated-2d-canvas',
|
|
9
|
+
'--disable-gpu',
|
|
10
|
+
];
|
|
11
|
+
return await puppeteer.launch({
|
|
12
|
+
headless: true,
|
|
13
|
+
args: launchArgs,
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
async function getBrowser() {
|
|
17
|
+
if (!browserSingleton || !browserSingleton.connected) {
|
|
18
|
+
browserSingleton = await initializeBrowser();
|
|
19
|
+
}
|
|
20
|
+
return browserSingleton;
|
|
21
|
+
}
|
|
22
|
+
export { getBrowser };
|
|
23
|
+
//# sourceMappingURL=browser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"browser.js","sourceRoot":"","sources":["../../../../src/commands/opengraph/browser.ts"],"names":[],"mappings":"AAAA,OAAO,SAAsB,MAAM,WAAW,CAAA;AAE9C,IAAI,gBAAgC,CAAA;AAEpC,KAAK,UAAU,iBAAiB;IAC/B,MAAM,UAAU,GAAG;QAClB,cAAc;QACd,0BAA0B;QAC1B,yBAAyB;QACzB,iCAAiC;QACjC,eAAe;KACf,CAAA;IAED,OAAO,MAAM,SAAS,CAAC,MAAM,CAAC;QAC7B,QAAQ,EAAE,IAAI;QACd,IAAI,EAAE,UAAU;KAChB,CAAC,CAAA;AACH,CAAC;AAED,KAAK,UAAU,UAAU;IACxB,IAAI,CAAC,gBAAgB,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC;QACtD,gBAAgB,GAAG,MAAM,iBAAiB,EAAE,CAAA;IAC7C,CAAC;IACD,OAAO,gBAAgB,CAAA;AACxB,CAAC;AAED,OAAO,EAAE,UAAU,EAAE,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { describe, test, vi, afterEach, expect } from 'vitest';
|
|
2
|
+
import puppeteer from 'puppeteer';
|
|
3
|
+
vi.mock('puppeteer');
|
|
4
|
+
describe('generate-open-graph/browser', () => {
|
|
5
|
+
const mocks = {
|
|
6
|
+
launch: vi.mocked(puppeteer.launch),
|
|
7
|
+
};
|
|
8
|
+
afterEach(() => {
|
|
9
|
+
vi.resetModules();
|
|
10
|
+
Object.values(mocks).forEach((mock) => {
|
|
11
|
+
mock.mockReset();
|
|
12
|
+
});
|
|
13
|
+
});
|
|
14
|
+
test('should initialize and return a browser instance', async () => {
|
|
15
|
+
const { getBrowser } = await import('./browser.js');
|
|
16
|
+
mocks.launch.mockResolvedValue({ connected: true });
|
|
17
|
+
const browser = await getBrowser();
|
|
18
|
+
expect(mocks.launch).toHaveBeenCalledOnce();
|
|
19
|
+
expect(browser).toBeDefined();
|
|
20
|
+
});
|
|
21
|
+
test('should return the existing browser instance', async () => {
|
|
22
|
+
const { getBrowser } = await import('./browser.js');
|
|
23
|
+
mocks.launch.mockResolvedValue({ connected: true });
|
|
24
|
+
const browser1 = await getBrowser();
|
|
25
|
+
const browser2 = await getBrowser();
|
|
26
|
+
expect(mocks.launch).toHaveBeenCalledOnce();
|
|
27
|
+
expect(browser1).toBe(browser2);
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
//# sourceMappingURL=browser.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"browser.test.js","sourceRoot":"","sources":["../../../../src/commands/opengraph/browser.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC/D,OAAO,SAAsB,MAAM,WAAW,CAAC;AAE/C,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;AAErB,QAAQ,CAAC,6BAA6B,EAAE,GAAG,EAAE;IAC5C,MAAM,KAAK,GAAG;QACb,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC;KACnC,CAAC;IAEF,SAAS,CAAC,GAAG,EAAE;QACd,EAAE,CAAC,YAAY,EAAE,CAAC;QAClB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACrC,IAAI,CAAC,SAAS,EAAE,CAAC;QAClB,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAClE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,MAAM,CAAC,cAAc,CAAC,CAAC;QACpD,KAAK,CAAC,MAAM,CAAC,iBAAiB,CAAC,EAAE,SAAS,EAAE,IAAI,EAAwB,CAAC,CAAC;QAE1E,MAAM,OAAO,GAAG,MAAM,UAAU,EAAE,CAAC;QAEnC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,oBAAoB,EAAE,CAAC;QAC5C,MAAM,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,6CAA6C,EAAE,KAAK,IAAI,EAAE;QAC9D,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,MAAM,CAAC,cAAc,CAAC,CAAC;QACpD,KAAK,CAAC,MAAM,CAAC,iBAAiB,CAAC,EAAE,SAAS,EAAE,IAAI,EAAwB,CAAC,CAAC;QAE1E,MAAM,QAAQ,GAAG,MAAM,UAAU,EAAE,CAAC;QACpC,MAAM,QAAQ,GAAG,MAAM,UAAU,EAAE,CAAC;QAEpC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,oBAAoB,EAAE,CAAC;QAC5C,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { Argv } from 'yargs';
|
|
2
|
+
export default function command(cli: Argv): Argv<import("yargs").Omit<{}, "id" | "config" | "luzzle" | "out" | "force"> & import("yargs").InferredOptionTypes<{
|
|
3
|
+
config: {
|
|
4
|
+
type: "string";
|
|
5
|
+
description: string;
|
|
6
|
+
demandOption: true;
|
|
7
|
+
};
|
|
8
|
+
luzzle: {
|
|
9
|
+
type: "string";
|
|
10
|
+
description: string;
|
|
11
|
+
alias: string;
|
|
12
|
+
demandOption: true;
|
|
13
|
+
};
|
|
14
|
+
out: {
|
|
15
|
+
type: "string";
|
|
16
|
+
description: string;
|
|
17
|
+
alias: string;
|
|
18
|
+
demandOption: true;
|
|
19
|
+
};
|
|
20
|
+
id: {
|
|
21
|
+
type: "string";
|
|
22
|
+
description: string;
|
|
23
|
+
};
|
|
24
|
+
force: {
|
|
25
|
+
type: "boolean";
|
|
26
|
+
description: string;
|
|
27
|
+
default: boolean;
|
|
28
|
+
alias: string;
|
|
29
|
+
};
|
|
30
|
+
}>>;
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import generateOpenGraphs from './index.js';
|
|
2
|
+
export default function command(cli) {
|
|
3
|
+
return cli.command('opengraph', 'generate open graph images', function (yargs) {
|
|
4
|
+
const options = yargs.options({
|
|
5
|
+
config: {
|
|
6
|
+
type: 'string',
|
|
7
|
+
description: 'path to config.yaml',
|
|
8
|
+
demandOption: true,
|
|
9
|
+
},
|
|
10
|
+
luzzle: {
|
|
11
|
+
type: 'string',
|
|
12
|
+
description: 'path to luzzle directory',
|
|
13
|
+
alias: 'in',
|
|
14
|
+
demandOption: true,
|
|
15
|
+
},
|
|
16
|
+
out: {
|
|
17
|
+
type: 'string',
|
|
18
|
+
description: 'path to direct asset output',
|
|
19
|
+
alias: 'o',
|
|
20
|
+
demandOption: true,
|
|
21
|
+
},
|
|
22
|
+
id: {
|
|
23
|
+
type: 'string',
|
|
24
|
+
description: 'id of just one item to process',
|
|
25
|
+
},
|
|
26
|
+
force: {
|
|
27
|
+
type: 'boolean',
|
|
28
|
+
description: 'force processing of all items, irrespective of last modified times',
|
|
29
|
+
default: false,
|
|
30
|
+
alias: 'f',
|
|
31
|
+
},
|
|
32
|
+
});
|
|
33
|
+
return options;
|
|
34
|
+
}, async function (argv) {
|
|
35
|
+
await generateOpenGraphs(argv.config, argv.luzzle, argv.out, {
|
|
36
|
+
id: argv.id,
|
|
37
|
+
force: argv.force,
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=command.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"command.js","sourceRoot":"","sources":["../../../../src/commands/opengraph/command.ts"],"names":[],"mappings":"AACA,OAAO,kBAAkB,MAAM,YAAY,CAAA;AAE3C,MAAM,CAAC,OAAO,UAAU,OAAO,CAAC,GAAS;IACxC,OAAO,GAAG,CAAC,OAAO,CACjB,WAAW,EACX,4BAA4B,EAC5B,UAAS,KAAK;QACb,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;YAC7B,MAAM,EAAE;gBACP,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,qBAAqB;gBAClC,YAAY,EAAE,IAAI;aAClB;YACD,MAAM,EAAE;gBACP,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,0BAA0B;gBACvC,KAAK,EAAE,IAAI;gBACX,YAAY,EAAE,IAAI;aAClB;YACD,GAAG,EAAE;gBACJ,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,6BAA6B;gBAC1C,KAAK,EAAE,GAAG;gBACV,YAAY,EAAE,IAAI;aAClB;YACD,EAAE,EAAE;gBACH,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,gCAAgC;aAC7C;YACD,KAAK,EAAE;gBACN,IAAI,EAAE,SAAS;gBACf,WAAW,EAAE,oEAAoE;gBACjF,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,GAAG;aACV;SACD,CAAC,CAAA;QACF,OAAO,OAAO,CAAA;IACf,CAAC,EACD,KAAK,WAAU,IAAI;QAClB,MAAM,kBAAkB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,GAAG,EAAE;YAC5D,EAAE,EAAE,IAAI,CAAC,EAAE;YACX,KAAK,EAAE,IAAI,CAAC,KAAK;SACjB,CAAC,CAAA;IACH,CAAC,CACD,CAAA;AACF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { describe, test, expect, vi, afterEach } from 'vitest';
|
|
2
|
+
import command from './command.js';
|
|
3
|
+
import generateOpenGraphs from './index.js';
|
|
4
|
+
vi.mock('./index.js');
|
|
5
|
+
const mocks = {
|
|
6
|
+
generateOpenGraphs: vi.mocked(generateOpenGraphs),
|
|
7
|
+
};
|
|
8
|
+
describe('opengraph command', () => {
|
|
9
|
+
afterEach(() => {
|
|
10
|
+
vi.clearAllMocks();
|
|
11
|
+
});
|
|
12
|
+
test('should configure the command and call generateOpenGraphs', async () => {
|
|
13
|
+
const handler = vi.fn();
|
|
14
|
+
const builder = vi.fn();
|
|
15
|
+
const cli = {
|
|
16
|
+
command: vi.fn((_cmd, _desc, b, h) => {
|
|
17
|
+
builder.mockImplementation(b);
|
|
18
|
+
handler.mockImplementation(h);
|
|
19
|
+
return cli;
|
|
20
|
+
}),
|
|
21
|
+
};
|
|
22
|
+
command(cli);
|
|
23
|
+
expect(cli.command).toHaveBeenCalledWith('opengraph', 'generate open graph images', expect.any(Function), expect.any(Function));
|
|
24
|
+
const yargsMock = { options: vi.fn() };
|
|
25
|
+
builder(yargsMock);
|
|
26
|
+
expect(yargsMock.options).toHaveBeenCalledWith({
|
|
27
|
+
config: {
|
|
28
|
+
type: 'string',
|
|
29
|
+
description: 'path to config.yaml',
|
|
30
|
+
demandOption: true,
|
|
31
|
+
},
|
|
32
|
+
luzzle: {
|
|
33
|
+
type: 'string',
|
|
34
|
+
description: 'path to luzzle directory',
|
|
35
|
+
alias: 'in',
|
|
36
|
+
demandOption: true,
|
|
37
|
+
},
|
|
38
|
+
out: {
|
|
39
|
+
type: 'string',
|
|
40
|
+
description: 'path to direct asset output',
|
|
41
|
+
alias: 'o',
|
|
42
|
+
demandOption: true,
|
|
43
|
+
},
|
|
44
|
+
id: {
|
|
45
|
+
type: 'string',
|
|
46
|
+
description: 'id of just one item to process',
|
|
47
|
+
},
|
|
48
|
+
force: {
|
|
49
|
+
type: 'boolean',
|
|
50
|
+
description: 'force processing of all items, irrespective of last modified times',
|
|
51
|
+
default: false,
|
|
52
|
+
alias: 'f',
|
|
53
|
+
},
|
|
54
|
+
});
|
|
55
|
+
await handler({
|
|
56
|
+
config: 'test',
|
|
57
|
+
luzzle: 'test',
|
|
58
|
+
out: 'test',
|
|
59
|
+
id: 'test-id',
|
|
60
|
+
force: true,
|
|
61
|
+
});
|
|
62
|
+
expect(mocks.generateOpenGraphs).toHaveBeenCalledWith('test', 'test', 'test', {
|
|
63
|
+
id: 'test-id',
|
|
64
|
+
force: true,
|
|
65
|
+
});
|
|
66
|
+
});
|
|
67
|
+
});
|
|
68
|
+
//# sourceMappingURL=command.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"command.test.js","sourceRoot":"","sources":["../../../../src/commands/opengraph/command.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAA;AAC9D,OAAO,OAAO,MAAM,cAAc,CAAA;AAClC,OAAO,kBAAkB,MAAM,YAAY,CAAA;AAG3C,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;AAErB,MAAM,KAAK,GAAG;IACb,kBAAkB,EAAE,EAAE,CAAC,MAAM,CAAC,kBAAkB,CAAC;CACjD,CAAA;AAED,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IAClC,SAAS,CAAC,GAAG,EAAE;QACd,EAAE,CAAC,aAAa,EAAE,CAAA;IACnB,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,0DAA0D,EAAE,KAAK,IAAI,EAAE;QAC3E,MAAM,OAAO,GAAG,EAAE,CAAC,EAAE,EAAE,CAAA;QACvB,MAAM,OAAO,GAAG,EAAE,CAAC,EAAE,EAAE,CAAA;QACvB,MAAM,GAAG,GAAG;YACX,OAAO,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE;gBACpC,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAA;gBAC7B,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAA;gBAC7B,OAAO,GAAG,CAAA;YACX,CAAC,CAAC;SACF,CAAA;QAED,OAAO,CAAC,GAAsB,CAAC,CAAA;QAE/B,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,oBAAoB,CACvC,WAAW,EACX,4BAA4B,EAC5B,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,EACpB,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CACpB,CAAA;QAED,MAAM,SAAS,GAAG,EAAE,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAA;QACtC,OAAO,CAAC,SAAS,CAAC,CAAA;QAClB,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,oBAAoB,CAAC;YAC9C,MAAM,EAAE;gBACP,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,qBAAqB;gBAClC,YAAY,EAAE,IAAI;aAClB;YACD,MAAM,EAAE;gBACP,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,0BAA0B;gBACvC,KAAK,EAAE,IAAI;gBACX,YAAY,EAAE,IAAI;aAClB;YACD,GAAG,EAAE;gBACJ,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,6BAA6B;gBAC1C,KAAK,EAAE,GAAG;gBACV,YAAY,EAAE,IAAI;aAClB;YACD,EAAE,EAAE;gBACH,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,gCAAgC;aAC7C;YACD,KAAK,EAAE;gBACN,IAAI,EAAE,SAAS;gBACf,WAAW,EAAE,oEAAoE;gBACjF,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,GAAG;aACV;SACD,CAAC,CAAA;QAEF,MAAM,OAAO,CAAC;YACb,MAAM,EAAE,MAAM;YACd,MAAM,EAAE,MAAM;YACd,GAAG,EAAE,MAAM;YACX,EAAE,EAAE,SAAS;YACb,KAAK,EAAE,IAAI;SACX,CAAC,CAAA;QAEF,MAAM,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC,oBAAoB,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE;YAC7E,EAAE,EAAE,SAAS;YACb,KAAK,EAAE,IAAI;SACX,CAAC,CAAA;IACH,CAAC,CAAC,CAAA;AACH,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { getLastRunFor, setLastRunFor } from '../../lib/lastRun.js';
|
|
2
|
+
import { generatePngFromUrl } from './png.js';
|
|
3
|
+
import { getBrowser } from './browser.js';
|
|
4
|
+
import path from 'path';
|
|
5
|
+
import { getDatabaseClient } from '@luzzle/core';
|
|
6
|
+
import { loadConfig } from '@luzzle/web.utils/server';
|
|
7
|
+
import { getOpenGraphPath } from '@luzzle/web.utils';
|
|
8
|
+
export default async function generateOpenGraphs(configPath, luzzle, outputDir, options) {
|
|
9
|
+
const config = loadConfig(configPath);
|
|
10
|
+
const configDir = path.dirname(configPath);
|
|
11
|
+
const dbPath = path.join(configDir, config.paths.database);
|
|
12
|
+
const db = getDatabaseClient(dbPath);
|
|
13
|
+
const items = await db
|
|
14
|
+
.withTables()
|
|
15
|
+
.selectFrom('web_pieces')
|
|
16
|
+
.selectAll()
|
|
17
|
+
.orderBy('date_updated', 'desc')
|
|
18
|
+
.orderBy('type', 'asc')
|
|
19
|
+
.execute();
|
|
20
|
+
const force = options.force || false;
|
|
21
|
+
const id = options.id || null;
|
|
22
|
+
const operation = 'generate-open-graph';
|
|
23
|
+
const lastRun = force ? new Date(0) : await getLastRunFor(outputDir, operation);
|
|
24
|
+
const browser = await getBrowser();
|
|
25
|
+
const piecesToProcess = id ? items.filter((item) => item.id === id) : items;
|
|
26
|
+
for (const item of piecesToProcess) {
|
|
27
|
+
const pieceModifiedTime = new Date(item.date_updated || item.date_added);
|
|
28
|
+
if (pieceModifiedTime > lastRun || force || id) {
|
|
29
|
+
try {
|
|
30
|
+
const ogPath = getOpenGraphPath(item.type, item.id);
|
|
31
|
+
const outputPath = path.join(outputDir, ogPath);
|
|
32
|
+
const url = `${config.url.app}/api/pieces/${item.type}/${item.slug}/opengraph`;
|
|
33
|
+
await generatePngFromUrl(url, browser, outputPath);
|
|
34
|
+
console.log(`generated opengraph for ${item.file_path} (${item.id})`);
|
|
35
|
+
}
|
|
36
|
+
catch (e) {
|
|
37
|
+
console.log(luzzle);
|
|
38
|
+
console.error(`error making opengraph for ${item.file_path} (${item.id}): ${e}`);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
if (!id) {
|
|
43
|
+
await setLastRunFor(outputDir, operation, new Date());
|
|
44
|
+
}
|
|
45
|
+
await browser.close();
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/commands/opengraph/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|