@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 +2 -2
- package/bootstrap.js +6 -4
- package/lib/prefixHandler.d.ts +1 -1
- package/package.json +9 -2
- package/CHANGELOG.md +0 -21
- package/bootstrap.ts +0 -47
- package/env.ts +0 -4
- package/index.ts +0 -111
- package/lib/fileStream.ts +0 -71
- package/lib/log.ts +0 -3
- package/lib/ns.ts +0 -29
- package/lib/prefixHandler.ts +0 -12
- package/test/__snapshots__/index.test.ts.snap +0 -12
- package/test/index.test.d.ts +0 -1
- package/test/index.test.js +0 -61
- package/test/index.test.ts +0 -81
- package/test/lib/prefixHandler.test.d.ts +0 -1
- package/test/lib/prefixHandler.test.js +0 -36
- package/test/lib/prefixHandler.test.ts +0 -43
- package/tsconfig.json +0 -3
package/bootstrap.d.ts
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { NamedNode, DatasetCore } from '
|
|
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
|
|
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
|
-
|
|
15
|
-
|
|
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,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9vdHN0cmFwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYm9vdHN0cmFwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQTtBQUM5QyxPQUFPLE1BQU0sTUFBTSwyQkFBMkIsQ0FBQTtBQUM5QyxPQUFPLElBQUksTUFBTSxVQUFVLENBQUE7QUFDM0IsT0FBTyxHQUFHLE1BQU0sY0FBYyxDQUFBO0FBUTlCLE1BQU0sQ0FBQyxLQUFLLFVBQVUsU0FBUyxDQUFDLEVBQUUsT0FBTyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQWE7SUFDbkUsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQTtJQUN6RSxNQUFNLFNBQVMsR0FBRyxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFBO0lBQ2pELEtBQUssTUFBTSxRQUFRLElBQUksU0FBUyxDQUFDLE9BQU8sRUFBRSxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsRUFBRTtRQUM5RCxNQUFNLFlBQVksR0FBRyxDQUFDLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7YUFDckUsR0FBRyxDQUFDLENBQUMsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQTtRQUNqRixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO1lBQzdCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQztZQUNuQyxJQUFJLEVBQUUsUUFBUSxDQUFDLElBQUk7U0FDcEIsQ0FBQyxDQUFBO1FBRUYsSUFBSSxNQUFNLEVBQUU7WUFDVixPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLGdCQUFnQixFQUFFLE1BQU0sQ0FBQyxDQUFBO1NBQ3ZEO1FBRUQsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxJQUFJLENBQUE7UUFDdEQsTUFBTSxNQUFNLEdBQUcsTUFBTSxLQUFLLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQTtRQUMvQyxJQUFJLE1BQU0sSUFBSSxJQUFJLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQy9DLEdBQUcsQ0FBQyxxQkFBcUIsUUFBUSxFQUFFLENBQUMsQ0FBQTtZQUNwQyxTQUFRO1NBQ1Q7UUFFRCxJQUFJLE1BQU0sRUFBRTtZQUNWLElBQUksSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRTtnQkFDdEMsR0FBRyxDQUFDLDZCQUE2QixRQUFRLEVBQUUsQ0FBQyxDQUFBO2dCQUM1QyxNQUFNLE9BQU8sR0FBRyxNQUFNLEtBQUssQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFBO2dCQUM5QyxNQUFNLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUE7YUFDekM7aUJBQU07Z0JBQ0wsR0FBRyxDQUFDLHNCQUFzQixRQUFRLEVBQUUsQ0FBQyxDQUFBO2FBQ3RDO1NBQ0Y7YUFBTTtZQUNMLEdBQUcsQ0FBQyxxQkFBcUIsUUFBUSxFQUFFLENBQUMsQ0FBQTtTQUNyQztRQUVELE1BQU0sS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQTtLQUMxQjtBQUNILENBQUMifQ==
|
package/lib/prefixHandler.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { NamedNode } from '
|
|
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.
|
|
3
|
+
"version": "0.1.4",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"scripts": {
|
|
7
|
-
"
|
|
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
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
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
|
-
}
|
package/lib/prefixHandler.ts
DELETED
|
@@ -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
|
-
|
package/test/index.test.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/test/index.test.js
DELETED
|
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXgudGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImluZGV4LnRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxJQUFJLE1BQU0sTUFBTSxDQUFBO0FBQ3ZCLE9BQU8sR0FBRyxNQUFNLEtBQUssQ0FBQTtBQUNyQixPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sTUFBTSxDQUFBO0FBQzdCLE9BQU8sT0FBTyxNQUFNLGdDQUFnQyxDQUFBO0FBRXBELE9BQU8sSUFBSSxNQUFNLFdBQVcsQ0FBQTtBQUM1QixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sYUFBYSxDQUFBO0FBRTdDLE1BQU0sT0FBTyxHQUFHLEdBQUcsQ0FBQyxhQUFhLENBQUMsSUFBSSxHQUFHLENBQUMseUJBQXlCLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFBO0FBQ3RGLE1BQU0sRUFBRSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMscUJBQXFCLENBQUMsQ0FBQTtBQUVoRCxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQztJQUNsQixXQUFXLEVBQUUsT0FBTyxDQUFDLFdBQVc7Q0FDakMsQ0FBQyxDQUFBO0FBRUYsUUFBUSxDQUFDLHVCQUF1QixFQUFFLEdBQUcsRUFBRTtJQUNyQyxRQUFRLENBQUMsaUJBQWlCLEVBQUUsR0FBRyxFQUFFO1FBQy9CLElBQUksT0FBZ0IsQ0FBQTtRQUVwQixVQUFVLENBQUMsS0FBSyxJQUFJLEVBQUU7WUFDcEIsTUFBTSxJQUFJLEdBQUc7Z0JBQ1gsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsYUFBYSxDQUFDO2dCQUNwQyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxpQkFBaUIsQ0FBQztnQkFDeEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsaUJBQWlCLENBQUM7YUFDekMsQ0FBQTtZQUNELE9BQU8sR0FBRyxNQUFNLGVBQWUsQ0FBQyxJQUFJLEVB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
|
package/test/index.test.ts
DELETED
|
@@ -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