@hydrofoil/talos-core 0.1.2 → 0.1.4

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/bootstrap.d.ts CHANGED
@@ -1,9 +1,9 @@
1
- import { NamedNode, DatasetCore } from 'rdf-js';
1
+ import type { NamedNode, DatasetCore } from '@rdfjs/types';
2
2
  import type { ResourceStore } from '@hydrofoil/resource-store';
3
3
  type Bootstrap = {
4
4
  store: ResourceStore;
5
5
  dataset: DatasetCore;
6
- apiUri: NamedNode;
6
+ apiUri?: NamedNode;
7
7
  };
8
8
  export declare function bootstrap({ dataset, apiUri, store }: Bootstrap): Promise<void>;
9
9
  export {};
package/bootstrap.js CHANGED
@@ -10,9 +10,11 @@ export async function bootstrap({ dataset, apiUri, store }) {
10
10
  .map(({ subject, predicate, object }) => $rdf.quad(subject, predicate, object));
11
11
  const pointer = $rdf.clownface({
12
12
  dataset: $rdf.dataset(resourceData),
13
- })
14
- .namedNode(resource.term)
15
- .addOut($rdf.ns.hydra.apiDocumentation, apiUri);
13
+ term: resource.term,
14
+ });
15
+ if (apiUri) {
16
+ pointer.addOut($rdf.ns.hydra.apiDocumentation, apiUri);
17
+ }
16
18
  const action = resource.out($rdf.ns.talos.action).term;
17
19
  const exists = await store.exists(pointer.term);
18
20
  if (exists && $rdf.ns.talos.skip.equals(action)) {
@@ -35,4 +37,4 @@ export async function bootstrap({ dataset, apiUri, store }) {
35
37
  await store.save(pointer);
36
38
  }
37
39
  }
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9vdHN0cmFwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYm9vdHN0cmFwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQTtBQUM5QyxPQUFPLE1BQU0sTUFBTSwyQkFBMkIsQ0FBQTtBQUM5QyxPQUFPLElBQUksTUFBTSxVQUFVLENBQUE7QUFDM0IsT0FBTyxHQUFHLE1BQU0sY0FBYyxDQUFBO0FBUTlCLE1BQU0sQ0FBQyxLQUFLLFVBQVUsU0FBUyxDQUFDLEVBQUUsT0FBTyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQWE7SUFDbkUsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQTtJQUN6RSxNQUFNLFNBQVMsR0FBRyxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFBO0lBQ2pELEtBQUssTUFBTSxRQUFRLElBQUksU0FBUyxDQUFDLE9BQU8sRUFBRSxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsRUFBRTtRQUM5RCxNQUFNLFlBQVksR0FBRyxDQUFDLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7YUFDckUsR0FBRyxDQUFDLENBQUMsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQTtRQUNqRixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO1lBQzdCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQztTQUNwQyxDQUFDO2FBQ0MsU0FBUyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUM7YUFDeEIsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLGdCQUFnQixFQUFFLE1BQU0sQ0FBQyxDQUFBO1FBRWpELE1BQU0sTUFBTSxHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUFBO1FBQ3RELE1BQU0sTUFBTSxHQUFHLE1BQU0sS0FBSyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDL0MsSUFBSSxNQUFNLElBQUksSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUMvQyxHQUFHLENBQUMscUJBQXFCLFFBQVEsRUFBRSxDQUFDLENBQUE7WUFDcEMsU0FBUTtTQUNUO1FBRUQsSUFBSSxNQUFNLEVBQUU7WUFDVixJQUFJLElBQUksQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUU7Z0JBQ3RDLEdBQUcsQ0FBQyw2QkFBNkIsUUFBUSxFQUFFLENBQUMsQ0FBQTtnQkFDNUMsTUFBTSxPQUFPLEdBQUcsTUFBTSxLQUFLLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQTtnQkFDOUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFBO2FBQ3pDO2lCQUFNO2dCQUNMLEdBQUcsQ0FBQyxzQkFBc0IsUUFBUSxFQUFFLENBQUMsQ0FBQTthQUN0QztTQUNGO2FBQU07WUFDTCxHQUFHLENBQUMscUJBQXFCLFFBQVEsRUFBRSxDQUFDLENBQUE7U0FDckM7UUFFRCxNQUFNLEtBQUssQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUE7S0FDMUI7QUFDSCxDQUFDIn0=
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9vdHN0cmFwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYm9vdHN0cmFwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQTtBQUM5QyxPQUFPLE1BQU0sTUFBTSwyQkFBMkIsQ0FBQTtBQUM5QyxPQUFPLElBQUksTUFBTSxVQUFVLENBQUE7QUFDM0IsT0FBTyxHQUFHLE1BQU0sY0FBYyxDQUFBO0FBUTlCLE1BQU0sQ0FBQyxLQUFLLFVBQVUsU0FBUyxDQUFDLEVBQUUsT0FBTyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQWE7SUFDbkUsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQTtJQUN6RSxNQUFNLFNBQVMsR0FBRyxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFBO0lBQ2pELEtBQUssTUFBTSxRQUFRLElBQUksU0FBUyxDQUFDLE9BQU8sRUFBRSxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsRUFBRTtRQUM5RCxNQUFNLFlBQVksR0FBRyxDQUFDLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7YUFDckUsR0FBRyxDQUFDLENBQUMsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQTtRQUNqRixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO1lBQzdCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQztZQUNuQyxJQUFJLEVBQUUsUUFBUSxDQUFDLElBQUk7U0FDcEIsQ0FBQyxDQUFBO1FBRUYsSUFBSSxNQUFNLEVBQUU7WUFDVixPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLGdCQUFnQixFQUFFLE1BQU0sQ0FBQyxDQUFBO1NBQ3ZEO1FBRUQsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxJQUFJLENBQUE7UUFDdEQsTUFBTSxNQUFNLEdBQUcsTUFBTSxLQUFLLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQTtRQUMvQyxJQUFJLE1BQU0sSUFBSSxJQUFJLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQy9DLEdBQUcsQ0FBQyxxQkFBcUIsUUFBUSxFQUFFLENBQUMsQ0FBQTtZQUNwQyxTQUFRO1NBQ1Q7UUFFRCxJQUFJLE1BQU0sRUFBRTtZQUNWLElBQUksSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRTtnQkFDdEMsR0FBRyxDQUFDLDZCQUE2QixRQUFRLEVBQUUsQ0FBQyxDQUFBO2dCQUM1QyxNQUFNLE9BQU8sR0FBRyxNQUFNLEtBQUssQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFBO2dCQUM5QyxNQUFNLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUE7YUFDekM7aUJBQU07Z0JBQ0wsR0FBRyxDQUFDLHNCQUFzQixRQUFRLEVBQUUsQ0FBQyxDQUFBO2FBQ3RDO1NBQ0Y7YUFBTTtZQUNMLEdBQUcsQ0FBQyxxQkFBcUIsUUFBUSxFQUFFLENBQUMsQ0FBQTtTQUNyQztRQUVELE1BQU0sS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQTtLQUMxQjtBQUNILENBQUMifQ==
@@ -1,2 +1,2 @@
1
- import { NamedNode } from 'rdf-js';
1
+ import type { NamedNode } from '@rdfjs/types';
2
2
  export declare function optionsFromPrefixes(options: Record<string, unknown>): (prefix: string, namespace: NamedNode) => void;
package/package.json CHANGED
@@ -1,14 +1,21 @@
1
1
  {
2
2
  "name": "@hydrofoil/talos-core",
3
- "version": "0.1.2",
3
+ "version": "0.1.4",
4
4
  "type": "module",
5
5
  "main": "index.js",
6
6
  "scripts": {
7
- "prepublishOnly": "tsc",
7
+ "prepack": "tsc",
8
8
  "test": "mocha --package ../../package.json test"
9
9
  },
10
+ "files": [
11
+ "lib/**/*.js",
12
+ "lib/**/*.d.ts",
13
+ "*.js",
14
+ "*.d.ts"
15
+ ],
10
16
  "dependencies": {
11
17
  "@fcostarodrigo/walk": "^5.0.1",
18
+ "@types/rdf-dataset-ext": "^1.0.8",
12
19
  "@zazuko/env-node": "^2.1.3",
13
20
  "anylogger": "^1.1.0-beta.5",
14
21
  "is-absolute-url": "^4.0.1",
package/CHANGELOG.md DELETED
@@ -1,21 +0,0 @@
1
- # @hydrofoil/talos-core
2
-
3
- ## 0.1.2
4
-
5
- ### Patch Changes
6
-
7
- - 33d941d: Moved `bootstrap.js` to core package
8
- - 3d2bf6e: Update `get-stream`
9
-
10
- ## 0.1.1
11
-
12
- ### Patch Changes
13
-
14
- - 0cbf9cf: Updated `@zazuko/env-node` to v2
15
- - 59639c1: Update `@zazuko/env`
16
-
17
- ## 0.1.0
18
-
19
- ### Minor Changes
20
-
21
- - 085a4a6: Extracted core functionality of loading resource from file system to a new library `@hydrofoil/talos-core`
package/bootstrap.ts DELETED
@@ -1,47 +0,0 @@
1
- import { NamedNode, DatasetCore } from 'rdf-js'
2
- import type { ResourceStore } from '@hydrofoil/resource-store'
3
- import { isNamedNode } from 'is-graph-pointer'
4
- import addAll from 'rdf-dataset-ext/addAll.js'
5
- import $rdf from './env.js'
6
- import log from './lib/log.js'
7
-
8
- type Bootstrap = {
9
- store: ResourceStore
10
- dataset: DatasetCore
11
- apiUri: NamedNode
12
- }
13
-
14
- export async function bootstrap({ dataset, apiUri, store }: Bootstrap): Promise<void> {
15
- const graph = $rdf.clownface({ dataset, graph: $rdf.ns.talos.resources })
16
- const resources = graph.has($rdf.ns.talos.action)
17
- for (const resource of resources.toArray().filter(isNamedNode)) {
18
- const resourceData = [...dataset.match(null, null, null, resource.term)]
19
- .map(({ subject, predicate, object }) => $rdf.quad(subject, predicate, object))
20
- const pointer = $rdf.clownface({
21
- dataset: $rdf.dataset(resourceData),
22
- })
23
- .namedNode(resource.term)
24
- .addOut($rdf.ns.hydra.apiDocumentation, apiUri)
25
-
26
- const action = resource.out($rdf.ns.talos.action).term
27
- const exists = await store.exists(pointer.term)
28
- if (exists && $rdf.ns.talos.skip.equals(action)) {
29
- log(`Skipping resource ${resource}`)
30
- continue
31
- }
32
-
33
- if (exists) {
34
- if ($rdf.ns.talos.merge.equals(action)) {
35
- log(`Merging existing resource ${resource}`)
36
- const current = await store.load(pointer.term)
37
- addAll(pointer.dataset, current.dataset)
38
- } else {
39
- log(`Replacing resource ${resource}`)
40
- }
41
- } else {
42
- log(`Creating resource ${resource}`)
43
- }
44
-
45
- await store.save(pointer)
46
- }
47
- }
package/env.ts DELETED
@@ -1,4 +0,0 @@
1
- import parent, { Environment } from '@zazuko/env-node'
2
- import { TalosNsFactory } from './lib/ns.js'
3
-
4
- export default new Environment([TalosNsFactory], { parent })
package/index.ts DELETED
@@ -1,111 +0,0 @@
1
- import path from 'path'
2
- import fs from 'fs'
3
- import { NamedNode, DatasetCore } from 'rdf-js'
4
- import walk from '@fcostarodrigo/walk'
5
- import type { Dataset } from '@zazuko/env/lib/DatasetExt.js'
6
- import $rdf from './env.js'
7
- import log from './lib/log.js'
8
- import { getPatchedStream } from './lib/fileStream.js'
9
- import { optionsFromPrefixes } from './lib/prefixHandler.js'
10
-
11
- const { talos: ns } = $rdf.ns
12
- export { ns }
13
-
14
- interface ResourceOptions {
15
- existingResource: 'merge' | 'overwrite' | 'skip'
16
- environmentRepresentation: 'default' | 'replace'
17
- }
18
-
19
- export async function fromDirectories(directories: string[], api: string): Promise<Dataset> {
20
- const validDirs = directories.filter(isValidDir)
21
- const dataset = await validDirs.reduce(toGraphs(api), Promise.resolve($rdf.dataset()))
22
-
23
- setDefaultAction(dataset)
24
-
25
- return dataset
26
- }
27
-
28
- function setDefaultAction(dataset: DatasetCore) {
29
- $rdf.clownface({ dataset, graph: $rdf.ns.talos.resources })
30
- .has($rdf.ns.talos.action, $rdf.ns.talos.default)
31
- .deleteOut($rdf.ns.talos.action, $rdf.ns.talos.default)
32
- .addOut($rdf.ns.talos.action, $rdf.ns.talos.overwrite)
33
- }
34
-
35
- function toGraphs(api: string) {
36
- return async function (previousPromise: Promise<Dataset>, dir: string): Promise<Dataset> {
37
- let previous = await previousPromise
38
- const dataset = $rdf.dataset()
39
-
40
- log.debug('Processing dir %s', dir)
41
-
42
- for await (const file of walk(dir)) {
43
- const relative = path.relative(dir, file)
44
- const resourcePath = path.relative(dir, file)
45
- .replace(/\.[^.]+$/, '')
46
- .replace(/\/?index$/, '')
47
-
48
- const url = resourcePath === ''
49
- ? encodeURI(api)
50
- : encodeURI(`${api}/${resourcePath}`)
51
-
52
- const parserStream = getPatchedStream(file, dir, api, url)
53
- if (!parserStream) {
54
- continue
55
- }
56
-
57
- log.debug('Parsing %s', relative)
58
- const parsedResourceOptions: Partial<ResourceOptions> = { }
59
- parserStream.on('prefix', optionsFromPrefixes(parsedResourceOptions))
60
-
61
- const resources = $rdf.termSet<NamedNode>()
62
- const resourceOptions = $rdf.clownface({ dataset: previous, graph: $rdf.ns.talos.resources })
63
- try {
64
- for await (const { subject, predicate, object, ...quad } of parserStream) {
65
- const graph: NamedNode = quad.graph.equals($rdf.defaultGraph()) ? $rdf.namedNode(url) : quad.graph
66
-
67
- if (!resources.has(graph)) {
68
- log.debug('Parsed resource %s', graph.value)
69
- }
70
- resources.add(graph)
71
- dataset.add($rdf.quad(subject, predicate, object, graph))
72
- }
73
- } catch (e: unknown) {
74
- if (e instanceof Error) {
75
- log('Failed to parse %s: %s', relative, e.message)
76
- }
77
- }
78
-
79
- resources.forEach(id => {
80
- const action = parsedResourceOptions.existingResource || 'default'
81
- const environmentRepresentation = parsedResourceOptions.environmentRepresentation || 'default'
82
- const options = resourceOptions.node(id)
83
- options
84
- .deleteOut($rdf.ns.talos.action, $rdf.ns.talos.default)
85
- .addOut($rdf.ns.talos.action, $rdf.ns.talos(action))
86
- .deleteOut($rdf.ns.talos.environmentRepresentation, $rdf.ns.talos.default)
87
- .addOut($rdf.ns.talos.environmentRepresentation, $rdf.ns.talos(environmentRepresentation))
88
-
89
- if (options.has($rdf.ns.talos.environmentRepresentation, $rdf.ns.talos.replace).terms.length) {
90
- previous = previous.deleteMatches(undefined, undefined, undefined, id)
91
- }
92
- })
93
- }
94
-
95
- previous.addAll(dataset)
96
- return previous
97
- }
98
- }
99
-
100
- function isValidDir(dir: string) {
101
- if (!fs.existsSync(dir)) {
102
- log('Skipping path %s which does not exist', dir)
103
- return false
104
- }
105
- if (!fs.statSync(dir).isDirectory()) {
106
- log('Skipping path %s which is not a directory', dir)
107
- return false
108
- }
109
-
110
- return true
111
- }
package/lib/fileStream.ts DELETED
@@ -1,71 +0,0 @@
1
- import fs from 'fs'
2
- import { Readable } from 'stream'
3
- import path from 'path'
4
- import * as mime from 'mime-types'
5
- import replaceStream from 'replacestream'
6
- import isAbsoluteUrl from 'is-absolute-url'
7
- import rdf from '../env.js'
8
- import log from './log.js'
9
-
10
- function replacer(basePath: string, resourceUrl: string, s: string, e = s) {
11
- return (_: unknown, match: string) => {
12
- let absolute: string
13
- if (isAbsoluteUrl(match)) {
14
- return `${s}${match}${e}`
15
- }
16
-
17
- if (match.startsWith('/') && basePath !== '/') {
18
- absolute = basePath + match
19
- } else {
20
- absolute = new URL(match, resourceUrl).toString()
21
- if (!match.endsWith('/')) {
22
- absolute = absolute.replace(/\/?$/, '')
23
- }
24
- }
25
-
26
- const absoluteUrl = new URL(absolute, resourceUrl)
27
- if (absoluteUrl.pathname === '/' && basePath !== '/') {
28
- absoluteUrl.pathname = basePath
29
- absolute = absoluteUrl.toString()
30
- }
31
-
32
- return `${s}${absolute}${e}`
33
- }
34
- }
35
-
36
- const angleBracketTransform = (basePath: string, resourceUrl: string) => replaceStream(/<([^>]+)>(?=([^"\\]*(\\.|"([^"\\]*\\.)*[^"\\]*"))*[^"]*$)/g, replacer(basePath, resourceUrl, '<', '>'))
37
- const jsonTransform = (basePath: string, resourceUrl: string) => replaceStream(/"([./][^"]+)"/g, replacer(basePath, resourceUrl, '"'))
38
-
39
- const filePatchTransforms = new Map([
40
- ['text/turtle', angleBracketTransform],
41
- ['application/n-triples', angleBracketTransform],
42
- ['application/n-quads', angleBracketTransform],
43
- ['application/trig', angleBracketTransform],
44
- ['application/ld+json', jsonTransform],
45
- ])
46
-
47
- export function getPatchedStream(file: string, cwd: string, api: string, resourceUrl: string): Readable | null {
48
- const relative = path.relative(cwd, file)
49
- const basePath = new URL(api).pathname
50
- const mediaType = mime.lookup(file)
51
- if (!mediaType) {
52
- log('Could not determine media type for file %s', relative)
53
- return null
54
- }
55
-
56
- let fileStream = fs.createReadStream(file)
57
- if (filePatchTransforms.has(mediaType)) {
58
- fileStream = fileStream.pipe(filePatchTransforms.get(mediaType)!(basePath, resourceUrl))
59
- }
60
-
61
- const parserStream = rdf.formats.parsers.import(mediaType, fileStream, {
62
- baseIRI: resourceUrl,
63
- blankNodePrefix: '',
64
- })
65
-
66
- if (!parserStream) {
67
- log('Unsupported media type %s from %s', mediaType, relative)
68
- }
69
-
70
- return parserStream as unknown as Readable | null
71
- }
package/lib/log.ts DELETED
@@ -1,3 +0,0 @@
1
- import Debugger from 'anylogger'
2
-
3
- export default Debugger('talos')
package/lib/ns.ts DELETED
@@ -1,29 +0,0 @@
1
- import type NsBuildersFactory from '@tpluscode/rdf-ns-builders'
2
- import type { NamespaceFactory } from '@rdfjs/namespace/Factory.js'
3
- import type { Environment } from '@rdfjs/environment/Environment.js'
4
- import type { NamespaceBuilder } from '@rdfjs/namespace'
5
-
6
- type TalosTerms =
7
- 'resources' |
8
- 'action' |
9
- 'default' |
10
- 'overwrite' |
11
- 'skip' |
12
- 'merge'|
13
- 'environmentRepresentation' |
14
- 'replace'
15
-
16
- declare module '@tpluscode/rdf-ns-builders' {
17
- interface CustomNamespaces {
18
- talos: NamespaceBuilder<TalosTerms>
19
- }
20
- }
21
-
22
- export class TalosNsFactory {
23
- init(this: Environment<NsBuildersFactory | NamespaceFactory>) {
24
- this.ns = {
25
- ...this.ns,
26
- talos: this.namespace<TalosTerms>('urn:talos:'),
27
- }
28
- }
29
- }
@@ -1,12 +0,0 @@
1
- import { NamedNode } from 'rdf-js'
2
-
3
- export function optionsFromPrefixes(options: Record<string, unknown>) {
4
- return (prefix: string, namespace: NamedNode) => {
5
- if (prefix === 'talos') {
6
- const [key, value] = namespace.value.split(':')
7
- if (key && value) {
8
- options[key] = decodeURIComponent(value)
9
- }
10
- }
11
- }
12
- }
@@ -1,12 +0,0 @@
1
- exports["@hydrofoil/talos-core fromDirectories merges resources from multiple graph documents"] = "\n<https://example.com> {\n\t<https://example.com> a <http://schema.org/Thing> ;\n\t\t<http://schema.org/hasPart> <https://example.com/#part>, _:b1, _:namedPart, _:b6 ;\n\t\t<http://schema.org/name> \"Bar environment\" .\n\n\t<https://example.com/#part> <http://schema.org/minValue> \"10\"^^<http://www.w3.org/2001/XMLSchema#integer> ;\n\t\t<http://schema.org/maxValue> \"100\"^^<http://www.w3.org/2001/XMLSchema#integer> .\n\n\t_:b1 <http://schema.org/name> \"totally anonymous\" .\n\n\t_:namedPart <http://schema.org/name> \"Foo part\", \"Bar part\" .\n\n\t_:b6 <http://schema.org/name> \"totally anonymous\" .\n}\n\n";
2
-
3
- exports["@hydrofoil/talos-core fromDirectories merges resources from dataset and graph documents"] = "\n<https://example.com/trig/users/john-doe> {\n\t<https://example.com/trig/users/john-doe> a <http://xmlns.com/foaf/0.1/Person> ;\n\t\t<http://www.w3.org/ns/earl#test> \"trig\" ;\n\t\t<http://xmlns.com/foaf/0.1/name> \"John Doe\" .\n}\n\n";
4
-
5
- exports["@hydrofoil/talos-core fromDirectories merges resources from multiple dataset documents"] = "\n<https://example.com/trig/users/jane-doe> {\n\t<https://example.com/trig/users/jane-doe> a <http://xmlns.com/foaf/0.1/Person> ;\n\t\t<http://www.w3.org/ns/earl#test> \"trig\" ;\n\t\t<http://xmlns.com/foaf/0.1/name> \"Jane Doe\" .\n}\n\n";
6
-
7
- exports["@hydrofoil/talos-core fromDirectories uses the last representation when is marked to replace other envs"] = "\n<https://example.com/only/one> {\n\t<https://example.com/only/one> <http://schema.org/name> \"bar\" .\n}\n\n";
8
-
9
- exports["@hydrofoil/talos-core fromDirectories uses the last representation when is marked in another env"] = "\n<https://example.com/only/two> {\n\t<https://example.com/only/two> <http://schema.org/name> \"bar\" .\n}\n\n";
10
-
11
- exports["@hydrofoil/talos-core fromDirectories uses the last representation when is marked in a dataset document"] = "\n<https://example.com/only/three> {\n\t<https://example.com/only/three> <http://schema.org/name> \"bar\" .\n}\n\n";
12
-
@@ -1 +0,0 @@
1
- export {};
@@ -1,61 +0,0 @@
1
- import path from 'path';
2
- import url from 'url';
3
- import { expect } from 'chai';
4
- import formats from '@rdfjs-elements/formats-pretty';
5
- import $rdf from '../env.js';
6
- import { fromDirectories } from '../index.js';
7
- const testDir = url.fileURLToPath(new URL('../../../test-resources', import.meta.url));
8
- const ns = $rdf.namespace('https://example.com');
9
- $rdf.formats.import({
10
- serializers: formats.serializers,
11
- });
12
- describe('@hydrofoil/talos-core', () => {
13
- describe('fromDirectories', () => {
14
- let dataset;
15
- beforeEach(async () => {
16
- const dirs = [
17
- path.resolve(testDir, './resources'),
18
- path.resolve(testDir, './resources.foo'),
19
- path.resolve(testDir, './resources.bar'),
20
- ];
21
- dataset = await fromDirectories(dirs, ns().value);
22
- });
23
- it('merges resources from multiple graph documents', async function () {
24
- const resource = dataset.match(null, null, null, ns());
25
- expect(await resource.serialize({ format: 'application/trig' })).to.matchSnapshot(this);
26
- });
27
- it('merges resources from dataset and graph documents', async function () {
28
- const resource = dataset.match(null, null, null, ns('/trig/users/john-doe'));
29
- expect(await resource.serialize({ format: 'application/trig' })).to.matchSnapshot(this);
30
- });
31
- it('merges resources from multiple dataset documents', async function () {
32
- const resource = dataset.match(null, null, null, ns('/trig/users/jane-doe'));
33
- expect(await resource.serialize({ format: 'application/trig' })).to.matchSnapshot(this);
34
- });
35
- it('marks a resource for "overwrite" by default', () => {
36
- const match = dataset.match(ns(), $rdf.ns.talos.action, null, $rdf.ns.talos.resources);
37
- const [{ object: action }, ...more] = match;
38
- expect(action).to.deep.eq($rdf.ns.talos.overwrite);
39
- expect(more).to.be.empty;
40
- });
41
- it('marks a resource for "merge" when prefix is used', () => {
42
- const datasetCore = dataset.match(ns('/project/creta/user.group/admins'), $rdf.ns.talos.action, null, $rdf.ns.talos.resources);
43
- const [{ object: action }, ...more] = datasetCore;
44
- expect(action).to.deep.eq($rdf.ns.talos.merge);
45
- expect(more).to.be.empty;
46
- });
47
- it('uses the last representation when is marked to replace other envs', async function () {
48
- const resource = dataset.match(null, null, null, ns('/only/one'));
49
- expect(await resource.serialize({ format: 'application/trig' })).to.matchSnapshot(this);
50
- });
51
- it('uses the last representation when is marked in another env', async function () {
52
- const resource = dataset.match(null, null, null, ns('/only/two'));
53
- expect(await resource.serialize({ format: 'application/trig' })).to.matchSnapshot(this);
54
- });
55
- it('uses the last representation when is marked in a dataset document', async function () {
56
- const resource = dataset.match(null, null, null, ns('/only/three'));
57
- expect(await resource.serialize({ format: 'application/trig' })).to.matchSnapshot(this);
58
- });
59
- });
60
- });
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXgudGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImluZGV4LnRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxJQUFJLE1BQU0sTUFBTSxDQUFBO0FBQ3ZCLE9BQU8sR0FBRyxNQUFNLEtBQUssQ0FBQTtBQUNyQixPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sTUFBTSxDQUFBO0FBQzdCLE9BQU8sT0FBTyxNQUFNLGdDQUFnQyxDQUFBO0FBRXBELE9BQU8sSUFBSSxNQUFNLFdBQVcsQ0FBQTtBQUM1QixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sYUFBYSxDQUFBO0FBRTdDLE1BQU0sT0FBTyxHQUFHLEdBQUcsQ0FBQyxhQUFhLENBQUMsSUFBSSxHQUFHLENBQUMseUJBQXlCLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFBO0FBQ3RGLE1BQU0sRUFBRSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMscUJBQXFCLENBQUMsQ0FBQTtBQUVoRCxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQztJQUNsQixXQUFXLEVBQUUsT0FBTyxDQUFDLFdBQVc7Q0FDakMsQ0FBQyxDQUFBO0FBRUYsUUFBUSxDQUFDLHVCQUF1QixFQUFFLEdBQUcsRUFBRTtJQUNyQyxRQUFRLENBQUMsaUJBQWlCLEVBQUUsR0FBRyxFQUFFO1FBQy9CLElBQUksT0FBZ0IsQ0FBQTtRQUVwQixVQUFVLENBQUMsS0FBSyxJQUFJLEVBQUU7WUFDcEIsTUFBTSxJQUFJLEdBQUc7Z0JBQ1gsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsYUFBYSxDQUFDO2dCQUNwQyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxpQkFBaUIsQ0FBQztnQkFDeEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsaUJBQWlCLENBQUM7YUFDekMsQ0FBQTtZQUNELE9BQU8sR0FBRyxNQUFNLGVBQWUsQ0FBQyxJQUFJLEVBQUUsRUFBRSxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDbkQsQ0FBQyxDQUFDLENBQUE7UUFFRixFQUFFLENBQUMsZ0RBQWdELEVBQUUsS0FBSztZQUN4RCxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUE7WUFFdEQsTUFBTSxDQUFDLE1BQU0sUUFBUSxDQUFDLFNBQVMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxrQkFBa0IsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFBO1FBQ3pGLENBQUMsQ0FBQyxDQUFBO1FBRUYsRUFBRSxDQUFDLG1EQUFtRCxFQUFFLEtBQUs7WUFDM0QsTUFBTSxRQUFRLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsc0JBQXNCLENBQUMsQ0FBQyxDQUFBO1lBRTVFLE1BQU0sQ0FBQyxNQUFNLFFBQVEsQ0FBQyxTQUFTLENBQUMsRUFBRSxNQUFNLEVBQUUsa0JBQWtCLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQTtRQUN6RixDQUFDLENBQUMsQ0FBQTtRQUVGLEVBQUUsQ0FBQyxrREFBa0QsRUFBRSxLQUFLO1lBQzFELE1BQU0sUUFBUSxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLHNCQUFzQixDQUFDLENBQUMsQ0FBQTtZQUU1RSxNQUFNLENBQUMsTUFBTSxRQUFRLENBQUMsU0FBUyxDQUFDLEVBQUUsTUFBTSxFQUFFLGtCQUFrQixFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDekYsQ0FBQyxDQUFDLENBQUE7UUFFRixFQUFFLENBQUMsNkNBQTZDLEVBQUUsR0FBRyxFQUFFO1lBQ3JELE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxFQUFFLEVBQUUsSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQTtZQUN0RixNQUFNLENBQUMsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLEVBQUUsR0FBRyxJQUFJLENBQUMsR0FBRyxLQUFLLENBQUE7WUFFM0MsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFBO1lBQ2xELE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQTtRQUMxQixDQUFDLENBQUMsQ0FBQTtRQUVGLEVBQUUsQ0FBQyxrREFBa0QsRUFBRSxHQUFHLEVBQUU7WUFDMUQsTUFBTSxXQUFXLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsa0NBQWtDLENBQUMsRUFBRSxJQUFJLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFBO1lBQzlILE1BQU0sQ0FBQyxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsRUFBRSxHQUFHLElBQUksQ0FBQyxHQUFHLFdBQVcsQ0FBQTtZQUVqRCxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUE7WUFDOUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFBO1FBQzFCLENBQUMsQ0FBQyxDQUFBO1FBRUYsRUFBRSxDQUFDLG1FQUFtRSxFQUFFLEtBQUs7WUFDM0UsTUFBTSxRQUFRLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQTtZQUVqRSxNQUFNLENBQUMsTUFBTSxRQUFRLENBQUMsU0FBUyxDQUFDLEVBQUUsTUFBTSxFQUFFLGtCQUFrQixFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDekYsQ0FBQyxDQUFDLENBQUE7UUFFRixFQUFFLENBQUMsNERBQTRELEVBQUUsS0FBSztZQUNwRSxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFBO1lBRWpFLE1BQU0sQ0FBQyxNQUFNLFFBQVEsQ0FBQyxTQUFTLENBQUMsRUFBRSxNQUFNLEVBQUUsa0JBQWtCLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQTtRQUN6RixDQUFDLENBQUMsQ0FBQTtRQUVGLEVBQUUsQ0FBQyxtRUFBbUUsRUFBRSxLQUFLO1lBQzNFLE1BQU0sUUFBUSxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUE7WUFFbkUsTUFBTSxDQUFDLE1BQU0sUUFBUSxDQUFDLFNBQVMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxrQkFBa0IsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFBO1FBQ3pGLENBQUMsQ0FBQyxDQUFBO0lBQ0osQ0FBQyxDQUFDLENBQUE7QUFDSixDQUFDLENBQUMsQ0FBQSJ9
@@ -1,81 +0,0 @@
1
- import path from 'path'
2
- import url from 'url'
3
- import { expect } from 'chai'
4
- import formats from '@rdfjs-elements/formats-pretty'
5
- import type { Dataset } from '@zazuko/env/lib/DatasetExt.js'
6
- import $rdf from '../env.js'
7
- import { fromDirectories } from '../index.js'
8
-
9
- const testDir = url.fileURLToPath(new URL('../../../test-resources', import.meta.url))
10
- const ns = $rdf.namespace('https://example.com')
11
-
12
- $rdf.formats.import({
13
- serializers: formats.serializers,
14
- })
15
-
16
- describe('@hydrofoil/talos-core', () => {
17
- describe('fromDirectories', () => {
18
- let dataset: Dataset
19
-
20
- beforeEach(async () => {
21
- const dirs = [
22
- path.resolve(testDir, './resources'),
23
- path.resolve(testDir, './resources.foo'),
24
- path.resolve(testDir, './resources.bar'),
25
- ]
26
- dataset = await fromDirectories(dirs, ns().value)
27
- })
28
-
29
- it('merges resources from multiple graph documents', async function () {
30
- const resource = dataset.match(null, null, null, ns())
31
-
32
- expect(await resource.serialize({ format: 'application/trig' })).to.matchSnapshot(this)
33
- })
34
-
35
- it('merges resources from dataset and graph documents', async function () {
36
- const resource = dataset.match(null, null, null, ns('/trig/users/john-doe'))
37
-
38
- expect(await resource.serialize({ format: 'application/trig' })).to.matchSnapshot(this)
39
- })
40
-
41
- it('merges resources from multiple dataset documents', async function () {
42
- const resource = dataset.match(null, null, null, ns('/trig/users/jane-doe'))
43
-
44
- expect(await resource.serialize({ format: 'application/trig' })).to.matchSnapshot(this)
45
- })
46
-
47
- it('marks a resource for "overwrite" by default', () => {
48
- const match = dataset.match(ns(), $rdf.ns.talos.action, null, $rdf.ns.talos.resources)
49
- const [{ object: action }, ...more] = match
50
-
51
- expect(action).to.deep.eq($rdf.ns.talos.overwrite)
52
- expect(more).to.be.empty
53
- })
54
-
55
- it('marks a resource for "merge" when prefix is used', () => {
56
- const datasetCore = dataset.match(ns('/project/creta/user.group/admins'), $rdf.ns.talos.action, null, $rdf.ns.talos.resources)
57
- const [{ object: action }, ...more] = datasetCore
58
-
59
- expect(action).to.deep.eq($rdf.ns.talos.merge)
60
- expect(more).to.be.empty
61
- })
62
-
63
- it('uses the last representation when is marked to replace other envs', async function () {
64
- const resource = dataset.match(null, null, null, ns('/only/one'))
65
-
66
- expect(await resource.serialize({ format: 'application/trig' })).to.matchSnapshot(this)
67
- })
68
-
69
- it('uses the last representation when is marked in another env', async function () {
70
- const resource = dataset.match(null, null, null, ns('/only/two'))
71
-
72
- expect(await resource.serialize({ format: 'application/trig' })).to.matchSnapshot(this)
73
- })
74
-
75
- it('uses the last representation when is marked in a dataset document', async function () {
76
- const resource = dataset.match(null, null, null, ns('/only/three'))
77
-
78
- expect(await resource.serialize({ format: 'application/trig' })).to.matchSnapshot(this)
79
- })
80
- })
81
- })
@@ -1 +0,0 @@
1
- export {};
@@ -1,36 +0,0 @@
1
- import { expect } from 'chai';
2
- import rdf from '@zazuko/env-node';
3
- import toStream from 'into-stream';
4
- import getStream from 'get-stream';
5
- import { optionsFromPrefixes } from '../../lib/prefixHandler.js';
6
- describe('@hydrofoil/talos/lib/prefixHandler', () => {
7
- function parse(str) {
8
- return rdf.formats.parsers.import('text/turtle', toStream(str));
9
- }
10
- describe('optionsFromPrefixes', () => {
11
- it('sets options from parsed prefixes', async () => {
12
- // given
13
- const options = {};
14
- // when
15
- const stream = parse(`prefix talos: <foo:bar>
16
- prefix talos: <foo:baz>
17
- prefix talos: <another:also%20baz>`);
18
- stream.on('prefix', optionsFromPrefixes(options));
19
- await getStream(stream);
20
- // then
21
- expect(options).to.have.property('foo', 'baz');
22
- expect(options).to.have.property('another', 'also baz');
23
- });
24
- it('ignores other prefixes', async () => {
25
- // given
26
- const options = {};
27
- // when
28
- const stream = parse('prefix schema: <http://schema.org/>');
29
- stream.on('prefix', optionsFromPrefixes(options));
30
- await getStream(stream);
31
- // then
32
- expect(options).to.deep.eq({});
33
- });
34
- });
35
- });
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJlZml4SGFuZGxlci50ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsicHJlZml4SGFuZGxlci50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxNQUFNLENBQUE7QUFDN0IsT0FBTyxHQUFHLE1BQU0sa0JBQWtCLENBQUE7QUFDbEMsT0FBTyxRQUFRLE1BQU0sYUFBYSxDQUFBO0FBQ2xDLE9BQU8sU0FBUyxNQUFNLFlBQVksQ0FBQTtBQUNsQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQTtBQUVoRSxRQUFRLENBQUMsb0NBQW9DLEVBQUUsR0FBRyxFQUFFO0lBQ2xELFNBQVMsS0FBSyxDQUFDLEdBQVc7UUFDeEIsT0FBTyxHQUFHLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsYUFBYSxFQUFFLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBaUMsQ0FBQTtJQUNqRyxDQUFDO0lBRUQsUUFBUSxDQUFDLHFCQUFxQixFQUFFLEdBQUcsRUFBRTtRQUNuQyxFQUFFLENBQUMsbUNBQW1DLEVBQUUsS0FBSyxJQUFJLEVBQUU7WUFDakQsUUFBUTtZQUNSLE1BQU0sT0FBTyxHQUFHLEVBQUUsQ0FBQTtZQUVsQixPQUFPO1lBQ1AsTUFBTSxNQUFNLEdBQUcsS0FBSyxDQUFDOzttQ0FFUSxDQUFDLENBQUE7WUFDOUIsTUFBTSxDQUFDLEVBQUUsQ0FBQyxRQUFRLEVBQUUsbUJBQW1CLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQTtZQUNqRCxNQUFNLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQTtZQUV2QixPQUFPO1lBQ1AsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQTtZQUM5QyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUyxFQUFFLFVBQVUsQ0FBQyxDQUFBO1FBQ3pELENBQUMsQ0FBQyxDQUFBO1FBRUYsRUFBRSxDQUFDLHdCQUF3QixFQUFFLEtBQUssSUFBSSxFQUFFO1lBQ3RDLFFBQVE7WUFDUixNQUFNLE9BQU8sR0FBRyxFQUFFLENBQUE7WUFFbEIsT0FBTztZQUNQLE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxxQ0FBcUMsQ0FBQyxDQUFBO1lBQzNELE1BQU0sQ0FBQyxFQUFFLENBQUMsUUFBUSxFQUFFLG1CQUFtQixDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUE7WUFDakQsTUFBTSxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUE7WUFFdkIsT0FBTztZQUNQLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQTtRQUNoQyxDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUMsQ0FBQyxDQUFBO0FBQ0osQ0FBQyxDQUFDLENBQUEifQ==
@@ -1,43 +0,0 @@
1
- import { Readable, Stream } from 'stream'
2
- import { expect } from 'chai'
3
- import rdf from '@zazuko/env-node'
4
- import toStream from 'into-stream'
5
- import getStream from 'get-stream'
6
- import { optionsFromPrefixes } from '../../lib/prefixHandler.js'
7
-
8
- describe('@hydrofoil/talos/lib/prefixHandler', () => {
9
- function parse(str: string) {
10
- return rdf.formats.parsers.import('text/turtle', toStream(str)) as unknown as Stream & Readable
11
- }
12
-
13
- describe('optionsFromPrefixes', () => {
14
- it('sets options from parsed prefixes', async () => {
15
- // given
16
- const options = {}
17
-
18
- // when
19
- const stream = parse(`prefix talos: <foo:bar>
20
- prefix talos: <foo:baz>
21
- prefix talos: <another:also%20baz>`)
22
- stream.on('prefix', optionsFromPrefixes(options))
23
- await getStream(stream)
24
-
25
- // then
26
- expect(options).to.have.property('foo', 'baz')
27
- expect(options).to.have.property('another', 'also baz')
28
- })
29
-
30
- it('ignores other prefixes', async () => {
31
- // given
32
- const options = {}
33
-
34
- // when
35
- const stream = parse('prefix schema: <http://schema.org/>')
36
- stream.on('prefix', optionsFromPrefixes(options))
37
- await getStream(stream)
38
-
39
- // then
40
- expect(options).to.deep.eq({})
41
- })
42
- })
43
- })
package/tsconfig.json DELETED
@@ -1,3 +0,0 @@
1
- {
2
- "extends": "../../tsconfig.json"
3
- }