@openhi/types 0.0.30 → 0.0.32
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.
|
@@ -6,3 +6,27 @@ export declare const CONTROL_PLANE_ROLE_CODE: {
|
|
|
6
6
|
};
|
|
7
7
|
export type ControlPlaneRoleCode = (typeof CONTROL_PLANE_ROLE_CODE)[keyof typeof CONTROL_PLANE_ROLE_CODE];
|
|
8
8
|
export declare const controlPlaneRoleCodeSchema: z.ZodEnum<["system-admin", "tenant-admin", "tenant-user"]>;
|
|
9
|
+
export declare const CONTROL_PLANE_ROLE_CONCEPTS: {
|
|
10
|
+
readonly SYSTEM_ADMIN: {
|
|
11
|
+
readonly code: "system-admin";
|
|
12
|
+
readonly display: "System Admin";
|
|
13
|
+
readonly definition: "Administrative functions within control plane only; can change tenant/workspace records, assign memberships and role assignments; CANNOT view tenant-isolated data.";
|
|
14
|
+
};
|
|
15
|
+
readonly TENANT_ADMIN: {
|
|
16
|
+
readonly code: "tenant-admin";
|
|
17
|
+
readonly display: "Tenant Admin";
|
|
18
|
+
readonly definition: "Admin within a given tenant and optionally workspace; 100% tenant-isolated access.";
|
|
19
|
+
};
|
|
20
|
+
readonly TENANT_USER: {
|
|
21
|
+
readonly code: "tenant-user";
|
|
22
|
+
readonly display: "Tenant User";
|
|
23
|
+
readonly definition: "User within a given tenant and optionally workspace; 100% tenant-isolated access.";
|
|
24
|
+
};
|
|
25
|
+
};
|
|
26
|
+
export type ControlPlaneRoleConcept = (typeof CONTROL_PLANE_ROLE_CONCEPTS)[keyof typeof CONTROL_PLANE_ROLE_CONCEPTS];
|
|
27
|
+
export declare const CONTROL_PLANE_ROLE_IDS: {
|
|
28
|
+
readonly SYSTEM_ADMIN: "role-system-admin";
|
|
29
|
+
readonly TENANT_ADMIN: "role-tenant-admin";
|
|
30
|
+
readonly TENANT_USER: "role-tenant-user";
|
|
31
|
+
};
|
|
32
|
+
export type ControlPlaneRoleId = (typeof CONTROL_PLANE_ROLE_IDS)[keyof typeof CONTROL_PLANE_ROLE_IDS];
|
package/lib/control/constants.js
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
// THIS FILE IS GENERATED by @openhi/types-generator.
|
|
3
3
|
// Do not edit. Edit sds/ or generator-config.yaml and regenerate.
|
|
4
4
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
-
exports.controlPlaneRoleCodeSchema = exports.CONTROL_PLANE_ROLE_CODE = void 0;
|
|
5
|
+
exports.CONTROL_PLANE_ROLE_IDS = exports.CONTROL_PLANE_ROLE_CONCEPTS = exports.controlPlaneRoleCodeSchema = exports.CONTROL_PLANE_ROLE_CODE = void 0;
|
|
6
6
|
const zod_1 = require("zod");
|
|
7
7
|
exports.CONTROL_PLANE_ROLE_CODE = {
|
|
8
8
|
SYSTEM_ADMIN: "system-admin",
|
|
@@ -14,4 +14,26 @@ exports.controlPlaneRoleCodeSchema = zod_1.z.enum([
|
|
|
14
14
|
"tenant-admin",
|
|
15
15
|
"tenant-user",
|
|
16
16
|
]);
|
|
17
|
-
|
|
17
|
+
exports.CONTROL_PLANE_ROLE_CONCEPTS = {
|
|
18
|
+
SYSTEM_ADMIN: {
|
|
19
|
+
code: "system-admin",
|
|
20
|
+
display: "System Admin",
|
|
21
|
+
definition: "Administrative functions within control plane only; can change tenant/workspace records, assign memberships and role assignments; CANNOT view tenant-isolated data.",
|
|
22
|
+
},
|
|
23
|
+
TENANT_ADMIN: {
|
|
24
|
+
code: "tenant-admin",
|
|
25
|
+
display: "Tenant Admin",
|
|
26
|
+
definition: "Admin within a given tenant and optionally workspace; 100% tenant-isolated access.",
|
|
27
|
+
},
|
|
28
|
+
TENANT_USER: {
|
|
29
|
+
code: "tenant-user",
|
|
30
|
+
display: "Tenant User",
|
|
31
|
+
definition: "User within a given tenant and optionally workspace; 100% tenant-isolated access.",
|
|
32
|
+
},
|
|
33
|
+
};
|
|
34
|
+
exports.CONTROL_PLANE_ROLE_IDS = {
|
|
35
|
+
SYSTEM_ADMIN: "role-system-admin",
|
|
36
|
+
TENANT_ADMIN: "role-tenant-admin",
|
|
37
|
+
TENANT_USER: "role-tenant-user",
|
|
38
|
+
};
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnRyb2wvY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxxREFBcUQ7QUFDckQsa0VBQWtFOzs7QUFFbEUsNkJBQXdCO0FBRVgsUUFBQSx1QkFBdUIsR0FBRztJQUNyQyxZQUFZLEVBQUUsY0FBYztJQUM1QixZQUFZLEVBQUUsY0FBYztJQUM1QixXQUFXLEVBQUUsYUFBYTtDQUNsQixDQUFDO0FBR0UsUUFBQSwwQkFBMEIsR0FBRyxPQUFDLENBQUMsSUFBSSxDQUFDO0lBQy9DLGNBQWM7SUFDZCxjQUFjO0lBQ2QsYUFBYTtDQUNkLENBQUMsQ0FBQztBQUVVLFFBQUEsMkJBQTJCLEdBQUc7SUFDekMsWUFBWSxFQUFFO1FBQ1osSUFBSSxFQUFFLGNBQWM7UUFDcEIsT0FBTyxFQUFFLGNBQWM7UUFDdkIsVUFBVSxFQUNSLHFLQUFxSztLQUN4SztJQUNELFlBQVksRUFBRTtRQUNaLElBQUksRUFBRSxjQUFjO1FBQ3BCLE9BQU8sRUFBRSxjQUFjO1FBQ3ZCLFVBQVUsRUFDUixvRkFBb0Y7S0FDdkY7SUFDRCxXQUFXLEVBQUU7UUFDWCxJQUFJLEVBQUUsYUFBYTtRQUNuQixPQUFPLEVBQUUsYUFBYTtRQUN0QixVQUFVLEVBQ1IsbUZBQW1GO0tBQ3RGO0NBQ08sQ0FBQztBQUlFLFFBQUEsc0JBQXNCLEdBQUc7SUFDcEMsWUFBWSxFQUFFLG1CQUFtQjtJQUNqQyxZQUFZLEVBQUUsbUJBQW1CO0lBQ2pDLFdBQVcsRUFBRSxrQkFBa0I7Q0FDdkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIFRISVMgRklMRSBJUyBHRU5FUkFURUQgYnkgQG9wZW5oaS90eXBlcy1nZW5lcmF0b3IuXG4vLyBEbyBub3QgZWRpdC4gRWRpdCBzZHMvIG9yIGdlbmVyYXRvci1jb25maWcueWFtbCBhbmQgcmVnZW5lcmF0ZS5cblxuaW1wb3J0IHsgeiB9IGZyb20gXCJ6b2RcIjtcblxuZXhwb3J0IGNvbnN0IENPTlRST0xfUExBTkVfUk9MRV9DT0RFID0ge1xuICBTWVNURU1fQURNSU46IFwic3lzdGVtLWFkbWluXCIsXG4gIFRFTkFOVF9BRE1JTjogXCJ0ZW5hbnQtYWRtaW5cIixcbiAgVEVOQU5UX1VTRVI6IFwidGVuYW50LXVzZXJcIixcbn0gYXMgY29uc3Q7XG5leHBvcnQgdHlwZSBDb250cm9sUGxhbmVSb2xlQ29kZSA9XG4gICh0eXBlb2YgQ09OVFJPTF9QTEFORV9ST0xFX0NPREUpW2tleW9mIHR5cGVvZiBDT05UUk9MX1BMQU5FX1JPTEVfQ09ERV07XG5leHBvcnQgY29uc3QgY29udHJvbFBsYW5lUm9sZUNvZGVTY2hlbWEgPSB6LmVudW0oW1xuICBcInN5c3RlbS1hZG1pblwiLFxuICBcInRlbmFudC1hZG1pblwiLFxuICBcInRlbmFudC11c2VyXCIsXG5dKTtcblxuZXhwb3J0IGNvbnN0IENPTlRST0xfUExBTkVfUk9MRV9DT05DRVBUUyA9IHtcbiAgU1lTVEVNX0FETUlOOiB7XG4gICAgY29kZTogXCJzeXN0ZW0tYWRtaW5cIixcbiAgICBkaXNwbGF5OiBcIlN5c3RlbSBBZG1pblwiLFxuICAgIGRlZmluaXRpb246XG4gICAgICBcIkFkbWluaXN0cmF0aXZlIGZ1bmN0aW9ucyB3aXRoaW4gY29udHJvbCBwbGFuZSBvbmx5OyBjYW4gY2hhbmdlIHRlbmFudC93b3Jrc3BhY2UgcmVjb3JkcywgYXNzaWduIG1lbWJlcnNoaXBzIGFuZCByb2xlIGFzc2lnbm1lbnRzOyBDQU5OT1QgdmlldyB0ZW5hbnQtaXNvbGF0ZWQgZGF0YS5cIixcbiAgfSxcbiAgVEVOQU5UX0FETUlOOiB7XG4gICAgY29kZTogXCJ0ZW5hbnQtYWRtaW5cIixcbiAgICBkaXNwbGF5OiBcIlRlbmFudCBBZG1pblwiLFxuICAgIGRlZmluaXRpb246XG4gICAgICBcIkFkbWluIHdpdGhpbiBhIGdpdmVuIHRlbmFudCBhbmQgb3B0aW9uYWxseSB3b3Jrc3BhY2U7IDEwMCUgdGVuYW50LWlzb2xhdGVkIGFjY2Vzcy5cIixcbiAgfSxcbiAgVEVOQU5UX1VTRVI6IHtcbiAgICBjb2RlOiBcInRlbmFudC11c2VyXCIsXG4gICAgZGlzcGxheTogXCJUZW5hbnQgVXNlclwiLFxuICAgIGRlZmluaXRpb246XG4gICAgICBcIlVzZXIgd2l0aGluIGEgZ2l2ZW4gdGVuYW50IGFuZCBvcHRpb25hbGx5IHdvcmtzcGFjZTsgMTAwJSB0ZW5hbnQtaXNvbGF0ZWQgYWNjZXNzLlwiLFxuICB9LFxufSBhcyBjb25zdDtcbmV4cG9ydCB0eXBlIENvbnRyb2xQbGFuZVJvbGVDb25jZXB0ID1cbiAgKHR5cGVvZiBDT05UUk9MX1BMQU5FX1JPTEVfQ09OQ0VQVFMpW2tleW9mIHR5cGVvZiBDT05UUk9MX1BMQU5FX1JPTEVfQ09OQ0VQVFNdO1xuXG5leHBvcnQgY29uc3QgQ09OVFJPTF9QTEFORV9ST0xFX0lEUyA9IHtcbiAgU1lTVEVNX0FETUlOOiBcInJvbGUtc3lzdGVtLWFkbWluXCIsXG4gIFRFTkFOVF9BRE1JTjogXCJyb2xlLXRlbmFudC1hZG1pblwiLFxuICBURU5BTlRfVVNFUjogXCJyb2xlLXRlbmFudC11c2VyXCIsXG59IGFzIGNvbnN0O1xuZXhwb3J0IHR5cGUgQ29udHJvbFBsYW5lUm9sZUlkID1cbiAgKHR5cGVvZiBDT05UUk9MX1BMQU5FX1JPTEVfSURTKVtrZXlvZiB0eXBlb2YgQ09OVFJPTF9QTEFORV9ST0xFX0lEU107XG4iXX0=
|
|
@@ -29,6 +29,18 @@ import type { FhirResourceLike } from "../summary/extract-summary";
|
|
|
29
29
|
* 3. Unlabeled fallback — `<ISO-8601 lastUpdated>#<id>`.
|
|
30
30
|
*/
|
|
31
31
|
export declare function extractSortKey(resource: FhirResourceLike): string;
|
|
32
|
+
/**
|
|
33
|
+
* Returns the normalized natural label for `resource`, or `undefined` when
|
|
34
|
+
* no label can be extracted. Used directly by control-plane writers that
|
|
35
|
+
* compose their own `<label>#<id>` vs `<entity.lastUpdated>#<id>` fallback,
|
|
36
|
+
* and indirectly by `extractSortKey` for the data plane.
|
|
37
|
+
*
|
|
38
|
+
* Resolution order matches `extractSortKey`:
|
|
39
|
+
* 1. `LABEL_PATHS[resourceType]` — curated, type-aware extraction.
|
|
40
|
+
* 2. Introspection fallback — `resource.name` (string), then `resource.title`.
|
|
41
|
+
* 3. Returns `undefined` so the caller can decide on its own fallback.
|
|
42
|
+
*/
|
|
43
|
+
export declare function extractLabel(resource: FhirResourceLike): string | undefined;
|
|
32
44
|
/**
|
|
33
45
|
* Normalize a natural-language label per DR-004:
|
|
34
46
|
* 1. ASCII-fold common Latin diacritics (ñ→n, é→e, ø→o, …).
|
|
@@ -14,6 +14,7 @@
|
|
|
14
14
|
*/
|
|
15
15
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
16
|
exports.extractSortKey = extractSortKey;
|
|
17
|
+
exports.extractLabel = extractLabel;
|
|
17
18
|
exports.normalizeLabel = normalizeLabel;
|
|
18
19
|
const label_paths_1 = require("./label-paths");
|
|
19
20
|
/**
|
|
@@ -34,23 +35,39 @@ const label_paths_1 = require("./label-paths");
|
|
|
34
35
|
*/
|
|
35
36
|
function extractSortKey(resource) {
|
|
36
37
|
const id = typeof resource.id === "string" ? resource.id : "";
|
|
37
|
-
const
|
|
38
|
-
if (
|
|
39
|
-
|
|
40
|
-
if (label.length > 0) {
|
|
41
|
-
return `${normalizeLabel(label)}#${id}`;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
const introspected = introspectStringField(resource, "name") ??
|
|
45
|
-
introspectStringField(resource, "title");
|
|
46
|
-
if (introspected !== undefined) {
|
|
47
|
-
return `${normalizeLabel(introspected)}#${id}`;
|
|
38
|
+
const label = extractLabel(resource);
|
|
39
|
+
if (label !== undefined) {
|
|
40
|
+
return `${label}#${id}`;
|
|
48
41
|
}
|
|
49
42
|
const lastUpdated = typeof resource.meta?.lastUpdated === "string"
|
|
50
43
|
? resource.meta.lastUpdated
|
|
51
44
|
: "";
|
|
52
45
|
return `${lastUpdated}#${id}`;
|
|
53
46
|
}
|
|
47
|
+
/**
|
|
48
|
+
* Returns the normalized natural label for `resource`, or `undefined` when
|
|
49
|
+
* no label can be extracted. Used directly by control-plane writers that
|
|
50
|
+
* compose their own `<label>#<id>` vs `<entity.lastUpdated>#<id>` fallback,
|
|
51
|
+
* and indirectly by `extractSortKey` for the data plane.
|
|
52
|
+
*
|
|
53
|
+
* Resolution order matches `extractSortKey`:
|
|
54
|
+
* 1. `LABEL_PATHS[resourceType]` — curated, type-aware extraction.
|
|
55
|
+
* 2. Introspection fallback — `resource.name` (string), then `resource.title`.
|
|
56
|
+
* 3. Returns `undefined` so the caller can decide on its own fallback.
|
|
57
|
+
*/
|
|
58
|
+
function extractLabel(resource) {
|
|
59
|
+
const source = label_paths_1.LABEL_PATHS[resource.resourceType];
|
|
60
|
+
if (source) {
|
|
61
|
+
const raw = extractLabelBySource(resource, source);
|
|
62
|
+
if (raw.length > 0)
|
|
63
|
+
return normalizeLabel(raw);
|
|
64
|
+
}
|
|
65
|
+
const introspected = introspectStringField(resource, "name") ??
|
|
66
|
+
introspectStringField(resource, "title");
|
|
67
|
+
if (introspected !== undefined)
|
|
68
|
+
return normalizeLabel(introspected);
|
|
69
|
+
return undefined;
|
|
70
|
+
}
|
|
54
71
|
/**
|
|
55
72
|
* Returns the value of `field` on `resource` only if it's a non-empty string.
|
|
56
73
|
* Guards against HumanName arrays (Patient.name) and other non-string shapes
|
|
@@ -63,7 +80,7 @@ function introspectStringField(resource, field) {
|
|
|
63
80
|
return value;
|
|
64
81
|
return undefined;
|
|
65
82
|
}
|
|
66
|
-
function
|
|
83
|
+
function extractLabelBySource(resource, source) {
|
|
67
84
|
if (source.kind === "humanName") {
|
|
68
85
|
const names = resource[source.path];
|
|
69
86
|
if (!Array.isArray(names))
|
|
@@ -99,6 +116,29 @@ function extractLabel(resource, source) {
|
|
|
99
116
|
}
|
|
100
117
|
return typeof cc.text === "string" ? cc.text : "";
|
|
101
118
|
}
|
|
119
|
+
if (source.kind === "identifier") {
|
|
120
|
+
return extractIdentifierValue(resource[source.path]);
|
|
121
|
+
}
|
|
122
|
+
return "";
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Reads `Identifier.value` from a FHIR `Identifier` or `Identifier[]` field.
|
|
126
|
+
* Most FHIR R4 resources expose `identifier` as an array; a few (Bundle,
|
|
127
|
+
* QuestionnaireResponse) use a singular `Identifier`. Returns empty when no
|
|
128
|
+
* usable value is present so the caller's empty-label fallthrough kicks in.
|
|
129
|
+
*/
|
|
130
|
+
function extractIdentifierValue(field) {
|
|
131
|
+
if (Array.isArray(field)) {
|
|
132
|
+
const first = field[0];
|
|
133
|
+
if (!first || typeof first !== "object")
|
|
134
|
+
return "";
|
|
135
|
+
const value = first.value;
|
|
136
|
+
return typeof value === "string" ? value : "";
|
|
137
|
+
}
|
|
138
|
+
if (field && typeof field === "object") {
|
|
139
|
+
const value = field.value;
|
|
140
|
+
return typeof value === "string" ? value : "";
|
|
141
|
+
}
|
|
102
142
|
return "";
|
|
103
143
|
}
|
|
104
144
|
/**
|
|
@@ -127,4 +167,4 @@ function asciiFold(input) {
|
|
|
127
167
|
// diacritics (é, ñ, ü, …). Non-Latin scripts are unaffected.
|
|
128
168
|
return input.normalize("NFKD").replace(/\p{M}+/gu, "");
|
|
129
169
|
}
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"extract-sort-key.js","sourceRoot":"","sources":["../../src/sort-key/extract-sort-key.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Pure projection of a FHIR R4 resource into its GSI1 sort key per DR-004.\n *\n * - Labeled types (entries in `LABEL_PATHS`): `<normalizedLabel>#<id>`\n *   so list endpoints sort alphabetically and `BEGINS_WITH` serves\n *   prefix queries like `?name=Sm`.\n * - Unlabeled types: `<ISO-8601 lastUpdated>#<id>` so list endpoints\n *   serve reverse-chronological with `ScanIndexForward=false`.\n *\n * Pure: no I/O, no DynamoDB access, deterministic over the resource and\n * the committed `LABEL_PATHS` table. Consumed by the data-plane writer\n * before each `PutItem` / `UpdateItem`.\n */\n\nimport { LABEL_PATHS, type LabelSource } from \"./label-paths\";\nimport type { FhirResourceLike } from \"../summary/extract-summary\";\n\n/**\n * Returns the GSI1 sort-key value for `resource`. The id is the\n * tie-breaker suffix; callers must pass a resource that carries an `id`\n * for an `<id>` segment to be present, but `extractSortKey` returns\n * `<label>#` (or `<lastUpdated>#`) with an empty trailing segment when id\n * is missing rather than throwing — the caller validates id at the\n * write-path entry.\n *\n * Resolution order:\n * 1. `LABEL_PATHS[resourceType]` — the curated, type-aware extraction.\n * 2. Introspection fallback per ADR-011 / DR-004: try `resource.name`\n *    (when it's a non-empty string), then `resource.title` (same), so\n *    spec types with a string `name`/`title` participate in alphabetical\n *    sort and `BEGINS_WITH` even if they aren't in `LABEL_PATHS` yet.\n * 3. Unlabeled fallback — `<ISO-8601 lastUpdated>#<id>`.\n */\nexport function extractSortKey(resource: FhirResourceLike): string {\n  const id = typeof resource.id === \"string\" ? resource.id : \"\";\n\n  const source = LABEL_PATHS[resource.resourceType];\n  if (source) {\n    const label = extractLabel(resource, source);\n    if (label.length > 0) {\n      return `${normalizeLabel(label)}#${id}`;\n    }\n  }\n\n  const introspected =\n    introspectStringField(resource, \"name\") ??\n    introspectStringField(resource, \"title\");\n  if (introspected !== undefined) {\n    return `${normalizeLabel(introspected)}#${id}`;\n  }\n\n  const lastUpdated =\n    typeof resource.meta?.lastUpdated === \"string\"\n      ? resource.meta.lastUpdated\n      : \"\";\n  return `${lastUpdated}#${id}`;\n}\n\n/**\n * Returns the value of `field` on `resource` only if it's a non-empty string.\n * Guards against HumanName arrays (Patient.name) and other non-string shapes\n * so the introspection fallback never produces a key from a typed field it\n * doesn't understand — that case stays on the lastUpdated fallback.\n */\nfunction introspectStringField(\n  resource: FhirResourceLike,\n  field: string,\n): string | undefined {\n  const value = resource[field];\n  if (typeof value === \"string\" && value.length > 0) return value;\n  return undefined;\n}\n\nfunction extractLabel(resource: FhirResourceLike, source: LabelSource): string {\n  if (source.kind === \"humanName\") {\n    const names = resource[source.path];\n    if (!Array.isArray(names)) return \"\";\n    const first = names[0];\n    if (!first || typeof first !== \"object\") return \"\";\n    const name = first as { family?: unknown; given?: unknown };\n    const family = typeof name.family === \"string\" ? name.family : \"\";\n    const given =\n      Array.isArray(name.given) && typeof name.given[0] === \"string\"\n        ? name.given[0]\n        : \"\";\n    if (family.length === 0 && given.length === 0) return \"\";\n    return `${family},${given}`;\n  }\n\n  if (source.kind === \"string\") {\n    const value = resource[source.path];\n    return typeof value === \"string\" ? value : \"\";\n  }\n\n  if (source.kind === \"codeDisplay\") {\n    const code = resource[source.path];\n    if (!code || typeof code !== \"object\") return \"\";\n    const cc = code as {\n      coding?: unknown;\n      text?: unknown;\n    };\n    if (Array.isArray(cc.coding)) {\n      const first = cc.coding[0];\n      if (first && typeof first === \"object\") {\n        const display = (first as { display?: unknown }).display;\n        if (typeof display === \"string\" && display.length > 0) return display;\n      }\n    }\n    return typeof cc.text === \"string\" ? cc.text : \"\";\n  }\n\n  return \"\";\n}\n\n/**\n * Normalize a natural-language label per DR-004:\n * 1. ASCII-fold common Latin diacritics (ñ→n, é→e, ø→o, …).\n * 2. Lowercase (DynamoDB byte-order sort).\n * 3. Strip apostrophes and periods (so `O'Connor` → `oconnor`).\n * 4. Replace hyphens with spaces (so `García-López` → `garcia lopez`).\n * 5. Strip other punctuation, collapse runs of whitespace, trim.\n *\n * Non-Latin scripts pass through unchanged after ASCII-fold so same-script\n * items sort together. Locale-aware collation is a downstream client\n * concern.\n */\nexport function normalizeLabel(input: string): string {\n  return asciiFold(input)\n    .toLowerCase()\n    .replace(/['’.]/g, \"\")\n    .replace(/-/g, \" \")\n    .replace(/[^\\p{L}\\p{N},\\s]/gu, \" \")\n    .replace(/\\s+/g, \" \")\n    .trim();\n}\n\nfunction asciiFold(input: string): string {\n  // Decompose accents and strip combining marks; covers the common Latin\n  // diacritics (é, ñ, ü, …). Non-Latin scripts are unaffected.\n  return input.normalize(\"NFKD\").replace(/\\p{M}+/gu, \"\");\n}\n"]}
|
|
170
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"extract-sort-key.js","sourceRoot":"","sources":["../../src/sort-key/extract-sort-key.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Pure projection of a FHIR R4 resource into its GSI1 sort key per DR-004.\n *\n * - Labeled types (entries in `LABEL_PATHS`): `<normalizedLabel>#<id>`\n *   so list endpoints sort alphabetically and `BEGINS_WITH` serves\n *   prefix queries like `?name=Sm`.\n * - Unlabeled types: `<ISO-8601 lastUpdated>#<id>` so list endpoints\n *   serve reverse-chronological with `ScanIndexForward=false`.\n *\n * Pure: no I/O, no DynamoDB access, deterministic over the resource and\n * the committed `LABEL_PATHS` table. Consumed by the data-plane writer\n * before each `PutItem` / `UpdateItem`.\n */\n\nimport { LABEL_PATHS, type LabelSource } from \"./label-paths\";\nimport type { FhirResourceLike } from \"../summary/extract-summary\";\n\n/**\n * Returns the GSI1 sort-key value for `resource`. The id is the\n * tie-breaker suffix; callers must pass a resource that carries an `id`\n * for an `<id>` segment to be present, but `extractSortKey` returns\n * `<label>#` (or `<lastUpdated>#`) with an empty trailing segment when id\n * is missing rather than throwing — the caller validates id at the\n * write-path entry.\n *\n * Resolution order:\n * 1. `LABEL_PATHS[resourceType]` — the curated, type-aware extraction.\n * 2. Introspection fallback per ADR-011 / DR-004: try `resource.name`\n *    (when it's a non-empty string), then `resource.title` (same), so\n *    spec types with a string `name`/`title` participate in alphabetical\n *    sort and `BEGINS_WITH` even if they aren't in `LABEL_PATHS` yet.\n * 3. Unlabeled fallback — `<ISO-8601 lastUpdated>#<id>`.\n */\nexport function extractSortKey(resource: FhirResourceLike): string {\n  const id = typeof resource.id === \"string\" ? resource.id : \"\";\n\n  const label = extractLabel(resource);\n  if (label !== undefined) {\n    return `${label}#${id}`;\n  }\n\n  const lastUpdated =\n    typeof resource.meta?.lastUpdated === \"string\"\n      ? resource.meta.lastUpdated\n      : \"\";\n  return `${lastUpdated}#${id}`;\n}\n\n/**\n * Returns the normalized natural label for `resource`, or `undefined` when\n * no label can be extracted. Used directly by control-plane writers that\n * compose their own `<label>#<id>` vs `<entity.lastUpdated>#<id>` fallback,\n * and indirectly by `extractSortKey` for the data plane.\n *\n * Resolution order matches `extractSortKey`:\n * 1. `LABEL_PATHS[resourceType]` — curated, type-aware extraction.\n * 2. Introspection fallback — `resource.name` (string), then `resource.title`.\n * 3. Returns `undefined` so the caller can decide on its own fallback.\n */\nexport function extractLabel(resource: FhirResourceLike): string | undefined {\n  const source = LABEL_PATHS[resource.resourceType];\n  if (source) {\n    const raw = extractLabelBySource(resource, source);\n    if (raw.length > 0) return normalizeLabel(raw);\n  }\n\n  const introspected =\n    introspectStringField(resource, \"name\") ??\n    introspectStringField(resource, \"title\");\n  if (introspected !== undefined) return normalizeLabel(introspected);\n\n  return undefined;\n}\n\n/**\n * Returns the value of `field` on `resource` only if it's a non-empty string.\n * Guards against HumanName arrays (Patient.name) and other non-string shapes\n * so the introspection fallback never produces a key from a typed field it\n * doesn't understand — that case stays on the lastUpdated fallback.\n */\nfunction introspectStringField(\n  resource: FhirResourceLike,\n  field: string,\n): string | undefined {\n  const value = resource[field];\n  if (typeof value === \"string\" && value.length > 0) return value;\n  return undefined;\n}\n\nfunction extractLabelBySource(\n  resource: FhirResourceLike,\n  source: LabelSource,\n): string {\n  if (source.kind === \"humanName\") {\n    const names = resource[source.path];\n    if (!Array.isArray(names)) return \"\";\n    const first = names[0];\n    if (!first || typeof first !== \"object\") return \"\";\n    const name = first as { family?: unknown; given?: unknown };\n    const family = typeof name.family === \"string\" ? name.family : \"\";\n    const given =\n      Array.isArray(name.given) && typeof name.given[0] === \"string\"\n        ? name.given[0]\n        : \"\";\n    if (family.length === 0 && given.length === 0) return \"\";\n    return `${family},${given}`;\n  }\n\n  if (source.kind === \"string\") {\n    const value = resource[source.path];\n    return typeof value === \"string\" ? value : \"\";\n  }\n\n  if (source.kind === \"codeDisplay\") {\n    const code = resource[source.path];\n    if (!code || typeof code !== \"object\") return \"\";\n    const cc = code as {\n      coding?: unknown;\n      text?: unknown;\n    };\n    if (Array.isArray(cc.coding)) {\n      const first = cc.coding[0];\n      if (first && typeof first === \"object\") {\n        const display = (first as { display?: unknown }).display;\n        if (typeof display === \"string\" && display.length > 0) return display;\n      }\n    }\n    return typeof cc.text === \"string\" ? cc.text : \"\";\n  }\n\n  if (source.kind === \"identifier\") {\n    return extractIdentifierValue(resource[source.path]);\n  }\n\n  return \"\";\n}\n\n/**\n * Reads `Identifier.value` from a FHIR `Identifier` or `Identifier[]` field.\n * Most FHIR R4 resources expose `identifier` as an array; a few (Bundle,\n * QuestionnaireResponse) use a singular `Identifier`. Returns empty when no\n * usable value is present so the caller's empty-label fallthrough kicks in.\n */\nfunction extractIdentifierValue(field: unknown): string {\n  if (Array.isArray(field)) {\n    const first = field[0];\n    if (!first || typeof first !== \"object\") return \"\";\n    const value = (first as { value?: unknown }).value;\n    return typeof value === \"string\" ? value : \"\";\n  }\n  if (field && typeof field === \"object\") {\n    const value = (field as { value?: unknown }).value;\n    return typeof value === \"string\" ? value : \"\";\n  }\n  return \"\";\n}\n\n/**\n * Normalize a natural-language label per DR-004:\n * 1. ASCII-fold common Latin diacritics (ñ→n, é→e, ø→o, …).\n * 2. Lowercase (DynamoDB byte-order sort).\n * 3. Strip apostrophes and periods (so `O'Connor` → `oconnor`).\n * 4. Replace hyphens with spaces (so `García-López` → `garcia lopez`).\n * 5. Strip other punctuation, collapse runs of whitespace, trim.\n *\n * Non-Latin scripts pass through unchanged after ASCII-fold so same-script\n * items sort together. Locale-aware collation is a downstream client\n * concern.\n */\nexport function normalizeLabel(input: string): string {\n  return asciiFold(input)\n    .toLowerCase()\n    .replace(/['’.]/g, \"\")\n    .replace(/-/g, \" \")\n    .replace(/[^\\p{L}\\p{N},\\s]/gu, \" \")\n    .replace(/\\s+/g, \" \")\n    .trim();\n}\n\nfunction asciiFold(input: string): string {\n  // Decompose accents and strip combining marks; covers the common Latin\n  // diacritics (é, ñ, ü, …). Non-Latin scripts are unaffected.\n  return input.normalize(\"NFKD\").replace(/\\p{M}+/gu, \"\");\n}\n"]}
|
|
@@ -1,29 +1,52 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* `LABEL_PATHS` — per-resource-type label-extraction rule for `extractSortKey`.
|
|
3
|
-
* Hand-curated
|
|
3
|
+
* Hand-curated table per DR-004.
|
|
4
4
|
*
|
|
5
5
|
* Resource types listed here emit GSI1 sort keys of the form
|
|
6
6
|
* `<normalizedLabel>#<id>` so list endpoints return alphabetically sorted by
|
|
7
7
|
* natural label and `BEGINS_WITH` queries serve prefix searches like
|
|
8
|
-
* `?name=Sm`. Resource types absent from this map
|
|
9
|
-
* `<ISO-8601 lastUpdated>#<id>`.
|
|
8
|
+
* `?name=Sm` or `?identifier=INV-2024`. Resource types absent from this map
|
|
9
|
+
* fall back to `<ISO-8601 lastUpdated>#<id>`.
|
|
10
10
|
*
|
|
11
|
-
*
|
|
12
|
-
*
|
|
13
|
-
*
|
|
11
|
+
* Five buckets cover the FHIR R4 surface:
|
|
12
|
+
*
|
|
13
|
+
* - **humanName** — `name: HumanName[]` (Patient, Practitioner, Person,
|
|
14
|
+
* RelatedPerson). Label is `family,given`.
|
|
15
|
+
* - **string** with `path: "name"` — plain string `name` fields on
|
|
16
|
+
* directory-style resources (Organization, Location, Account, …) and
|
|
17
|
+
* on conformance resources (StructureDefinition, ValueSet, …).
|
|
18
|
+
* - **string** with `path: "title"` — title-keyed resources where the
|
|
19
|
+
* business label is `title` rather than `name` (CarePlan, Composition,
|
|
20
|
+
* Contract, List, ResearchStudy, …).
|
|
21
|
+
* - **codeDisplay** — primary CodeableConcept on the resource
|
|
22
|
+
* (Condition.code, Observation.code, Immunization.vaccineCode,
|
|
23
|
+
* BodyStructure.morphology, …). Label is `coding[0].display` with
|
|
24
|
+
* `text` fallback.
|
|
25
|
+
* - **identifier** — business identifier on transactional / financial /
|
|
26
|
+
* scheduling resources (Claim.identifier, Invoice.identifier,
|
|
27
|
+
* Encounter.identifier, …). Label is `identifier[0].value`.
|
|
28
|
+
*
|
|
29
|
+
* Resource types not in this table fall through to `<lastUpdated>#<id>` —
|
|
30
|
+
* intentional for event-log and metadata resources (AuditEvent, Bundle,
|
|
31
|
+
* Provenance, Linkage, MessageHeader, VerificationResult) and for the
|
|
32
|
+
* substance / medicinal-product detail families (SubstanceNucleicAcid,
|
|
33
|
+
* MedicinalProductIngredient, …) that are not list-by-name resources.
|
|
14
34
|
*
|
|
15
35
|
* @see openhi-planning DR-004 — FHIR Summary-Attribute and Sort-Key Projection Strategy
|
|
16
36
|
*/
|
|
17
37
|
/** Source of the natural label for a labeled resource type. */
|
|
18
38
|
export type LabelSource = {
|
|
19
39
|
kind: "humanName";
|
|
20
|
-
path:
|
|
40
|
+
path: string;
|
|
21
41
|
} | {
|
|
22
42
|
kind: "string";
|
|
23
|
-
path:
|
|
43
|
+
path: string;
|
|
24
44
|
} | {
|
|
25
45
|
kind: "codeDisplay";
|
|
26
|
-
path:
|
|
46
|
+
path: string;
|
|
47
|
+
} | {
|
|
48
|
+
kind: "identifier";
|
|
49
|
+
path: string;
|
|
27
50
|
};
|
|
28
|
-
/** Resource types with curated natural labels
|
|
51
|
+
/** Resource types with curated natural labels. */
|
|
29
52
|
export declare const LABEL_PATHS: Record<string, LabelSource>;
|
|
@@ -1,28 +1,169 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
/**
|
|
3
3
|
* `LABEL_PATHS` — per-resource-type label-extraction rule for `extractSortKey`.
|
|
4
|
-
* Hand-curated
|
|
4
|
+
* Hand-curated table per DR-004.
|
|
5
5
|
*
|
|
6
6
|
* Resource types listed here emit GSI1 sort keys of the form
|
|
7
7
|
* `<normalizedLabel>#<id>` so list endpoints return alphabetically sorted by
|
|
8
8
|
* natural label and `BEGINS_WITH` queries serve prefix searches like
|
|
9
|
-
* `?name=Sm`. Resource types absent from this map
|
|
10
|
-
* `<ISO-8601 lastUpdated>#<id>`.
|
|
9
|
+
* `?name=Sm` or `?identifier=INV-2024`. Resource types absent from this map
|
|
10
|
+
* fall back to `<ISO-8601 lastUpdated>#<id>`.
|
|
11
11
|
*
|
|
12
|
-
*
|
|
13
|
-
*
|
|
14
|
-
*
|
|
12
|
+
* Five buckets cover the FHIR R4 surface:
|
|
13
|
+
*
|
|
14
|
+
* - **humanName** — `name: HumanName[]` (Patient, Practitioner, Person,
|
|
15
|
+
* RelatedPerson). Label is `family,given`.
|
|
16
|
+
* - **string** with `path: "name"` — plain string `name` fields on
|
|
17
|
+
* directory-style resources (Organization, Location, Account, …) and
|
|
18
|
+
* on conformance resources (StructureDefinition, ValueSet, …).
|
|
19
|
+
* - **string** with `path: "title"` — title-keyed resources where the
|
|
20
|
+
* business label is `title` rather than `name` (CarePlan, Composition,
|
|
21
|
+
* Contract, List, ResearchStudy, …).
|
|
22
|
+
* - **codeDisplay** — primary CodeableConcept on the resource
|
|
23
|
+
* (Condition.code, Observation.code, Immunization.vaccineCode,
|
|
24
|
+
* BodyStructure.morphology, …). Label is `coding[0].display` with
|
|
25
|
+
* `text` fallback.
|
|
26
|
+
* - **identifier** — business identifier on transactional / financial /
|
|
27
|
+
* scheduling resources (Claim.identifier, Invoice.identifier,
|
|
28
|
+
* Encounter.identifier, …). Label is `identifier[0].value`.
|
|
29
|
+
*
|
|
30
|
+
* Resource types not in this table fall through to `<lastUpdated>#<id>` —
|
|
31
|
+
* intentional for event-log and metadata resources (AuditEvent, Bundle,
|
|
32
|
+
* Provenance, Linkage, MessageHeader, VerificationResult) and for the
|
|
33
|
+
* substance / medicinal-product detail families (SubstanceNucleicAcid,
|
|
34
|
+
* MedicinalProductIngredient, …) that are not list-by-name resources.
|
|
15
35
|
*
|
|
16
36
|
* @see openhi-planning DR-004 — FHIR Summary-Attribute and Sort-Key Projection Strategy
|
|
17
37
|
*/
|
|
18
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
39
|
exports.LABEL_PATHS = void 0;
|
|
20
|
-
/** Resource types with curated natural labels
|
|
40
|
+
/** Resource types with curated natural labels. */
|
|
21
41
|
exports.LABEL_PATHS = {
|
|
42
|
+
// HumanName arrays
|
|
22
43
|
Patient: { kind: "humanName", path: "name" },
|
|
44
|
+
Person: { kind: "humanName", path: "name" },
|
|
23
45
|
Practitioner: { kind: "humanName", path: "name" },
|
|
24
|
-
|
|
46
|
+
RelatedPerson: { kind: "humanName", path: "name" },
|
|
47
|
+
// Plain string `name` (directory-style resources)
|
|
48
|
+
Account: { kind: "string", path: "name" },
|
|
49
|
+
CareTeam: { kind: "string", path: "name" },
|
|
50
|
+
Endpoint: { kind: "string", path: "name" },
|
|
51
|
+
Group: { kind: "string", path: "name" },
|
|
52
|
+
HealthcareService: { kind: "string", path: "name" },
|
|
53
|
+
InsurancePlan: { kind: "string", path: "name" },
|
|
25
54
|
Location: { kind: "string", path: "name" },
|
|
55
|
+
Organization: { kind: "string", path: "name" },
|
|
56
|
+
// Control-plane FHIR types (ADR-2026-03-13-01 — Tenant/Workspace as FHIR types)
|
|
57
|
+
Tenant: { kind: "string", path: "name" },
|
|
58
|
+
Workspace: { kind: "string", path: "name" },
|
|
59
|
+
// `title`-keyed (title is the only or primary human label)
|
|
60
|
+
CarePlan: { kind: "string", path: "title" },
|
|
61
|
+
ChargeItemDefinition: { kind: "string", path: "title" },
|
|
62
|
+
Composition: { kind: "string", path: "title" },
|
|
63
|
+
Contract: { kind: "string", path: "title" },
|
|
64
|
+
List: { kind: "string", path: "title" },
|
|
65
|
+
ResearchStudy: { kind: "string", path: "title" },
|
|
66
|
+
// Conformance resources (string `name` is required; `title` is optional)
|
|
67
|
+
ActivityDefinition: { kind: "string", path: "name" },
|
|
68
|
+
CapabilityStatement: { kind: "string", path: "name" },
|
|
69
|
+
CodeSystem: { kind: "string", path: "name" },
|
|
70
|
+
CompartmentDefinition: { kind: "string", path: "name" },
|
|
71
|
+
ConceptMap: { kind: "string", path: "name" },
|
|
72
|
+
EffectEvidenceSynthesis: { kind: "string", path: "name" },
|
|
73
|
+
EventDefinition: { kind: "string", path: "name" },
|
|
74
|
+
Evidence: { kind: "string", path: "name" },
|
|
75
|
+
EvidenceVariable: { kind: "string", path: "name" },
|
|
76
|
+
ExampleScenario: { kind: "string", path: "name" },
|
|
77
|
+
GraphDefinition: { kind: "string", path: "name" },
|
|
78
|
+
ImplementationGuide: { kind: "string", path: "name" },
|
|
79
|
+
Library: { kind: "string", path: "name" },
|
|
80
|
+
Measure: { kind: "string", path: "name" },
|
|
81
|
+
MessageDefinition: { kind: "string", path: "name" },
|
|
82
|
+
NamingSystem: { kind: "string", path: "name" },
|
|
83
|
+
OperationDefinition: { kind: "string", path: "name" },
|
|
84
|
+
PlanDefinition: { kind: "string", path: "name" },
|
|
85
|
+
Questionnaire: { kind: "string", path: "name" },
|
|
86
|
+
ResearchDefinition: { kind: "string", path: "name" },
|
|
87
|
+
ResearchElementDefinition: { kind: "string", path: "name" },
|
|
88
|
+
RiskEvidenceSynthesis: { kind: "string", path: "name" },
|
|
89
|
+
SearchParameter: { kind: "string", path: "name" },
|
|
90
|
+
StructureDefinition: { kind: "string", path: "name" },
|
|
91
|
+
StructureMap: { kind: "string", path: "name" },
|
|
92
|
+
TerminologyCapabilities: { kind: "string", path: "name" },
|
|
93
|
+
TestReport: { kind: "string", path: "name" },
|
|
94
|
+
TestScript: { kind: "string", path: "name" },
|
|
95
|
+
ValueSet: { kind: "string", path: "name" },
|
|
96
|
+
// Primary CodeableConcept (codeDisplay reads `coding[0].display` with `text` fallback)
|
|
97
|
+
AdverseEvent: { kind: "codeDisplay", path: "event" },
|
|
98
|
+
AllergyIntolerance: { kind: "codeDisplay", path: "code" },
|
|
99
|
+
Basic: { kind: "codeDisplay", path: "code" },
|
|
100
|
+
BodyStructure: { kind: "codeDisplay", path: "morphology" },
|
|
101
|
+
ChargeItem: { kind: "codeDisplay", path: "code" },
|
|
102
|
+
Communication: { kind: "codeDisplay", path: "topic" },
|
|
103
|
+
Condition: { kind: "codeDisplay", path: "code" },
|
|
104
|
+
DetectedIssue: { kind: "codeDisplay", path: "code" },
|
|
105
|
+
DeviceMetric: { kind: "codeDisplay", path: "type" },
|
|
106
|
+
DiagnosticReport: { kind: "codeDisplay", path: "code" },
|
|
107
|
+
DocumentManifest: { kind: "codeDisplay", path: "type" },
|
|
108
|
+
DocumentReference: { kind: "codeDisplay", path: "type" },
|
|
109
|
+
FamilyMemberHistory: { kind: "codeDisplay", path: "relationship" },
|
|
110
|
+
Flag: { kind: "codeDisplay", path: "code" },
|
|
111
|
+
Goal: { kind: "codeDisplay", path: "description" },
|
|
112
|
+
Immunization: { kind: "codeDisplay", path: "vaccineCode" },
|
|
113
|
+
ImmunizationEvaluation: { kind: "codeDisplay", path: "vaccineCode" },
|
|
26
114
|
Medication: { kind: "codeDisplay", path: "code" },
|
|
115
|
+
MedicationKnowledge: { kind: "codeDisplay", path: "code" },
|
|
116
|
+
Observation: { kind: "codeDisplay", path: "code" },
|
|
117
|
+
ObservationDefinition: { kind: "codeDisplay", path: "code" },
|
|
118
|
+
Procedure: { kind: "codeDisplay", path: "code" },
|
|
119
|
+
ServiceRequest: { kind: "codeDisplay", path: "code" },
|
|
120
|
+
Specimen: { kind: "codeDisplay", path: "type" },
|
|
121
|
+
SpecimenDefinition: { kind: "codeDisplay", path: "typeCollected" },
|
|
122
|
+
Substance: { kind: "codeDisplay", path: "code" },
|
|
123
|
+
Task: { kind: "codeDisplay", path: "code" },
|
|
124
|
+
// Business identifier — `identifier[0].value` (singular `Identifier` also supported)
|
|
125
|
+
Appointment: { kind: "identifier", path: "identifier" },
|
|
126
|
+
AppointmentResponse: { kind: "identifier", path: "identifier" },
|
|
127
|
+
CatalogEntry: { kind: "identifier", path: "identifier" },
|
|
128
|
+
Claim: { kind: "identifier", path: "identifier" },
|
|
129
|
+
ClaimResponse: { kind: "identifier", path: "identifier" },
|
|
130
|
+
ClinicalImpression: { kind: "identifier", path: "identifier" },
|
|
131
|
+
CommunicationRequest: { kind: "identifier", path: "identifier" },
|
|
132
|
+
Consent: { kind: "identifier", path: "identifier" },
|
|
133
|
+
Coverage: { kind: "identifier", path: "identifier" },
|
|
134
|
+
CoverageEligibilityRequest: { kind: "identifier", path: "identifier" },
|
|
135
|
+
CoverageEligibilityResponse: { kind: "identifier", path: "identifier" },
|
|
136
|
+
DeviceRequest: { kind: "identifier", path: "identifier" },
|
|
137
|
+
DeviceUseStatement: { kind: "identifier", path: "identifier" },
|
|
138
|
+
Encounter: { kind: "identifier", path: "identifier" },
|
|
139
|
+
EnrollmentRequest: { kind: "identifier", path: "identifier" },
|
|
140
|
+
EnrollmentResponse: { kind: "identifier", path: "identifier" },
|
|
141
|
+
EpisodeOfCare: { kind: "identifier", path: "identifier" },
|
|
142
|
+
ExplanationOfBenefit: { kind: "identifier", path: "identifier" },
|
|
143
|
+
GuidanceResponse: { kind: "identifier", path: "identifier" },
|
|
144
|
+
ImagingStudy: { kind: "identifier", path: "identifier" },
|
|
145
|
+
ImmunizationRecommendation: { kind: "identifier", path: "identifier" },
|
|
146
|
+
Invoice: { kind: "identifier", path: "identifier" },
|
|
147
|
+
MeasureReport: { kind: "identifier", path: "identifier" },
|
|
148
|
+
Media: { kind: "identifier", path: "identifier" },
|
|
149
|
+
MedicationAdministration: { kind: "identifier", path: "identifier" },
|
|
150
|
+
MedicationDispense: { kind: "identifier", path: "identifier" },
|
|
151
|
+
MedicationRequest: { kind: "identifier", path: "identifier" },
|
|
152
|
+
MedicationStatement: { kind: "identifier", path: "identifier" },
|
|
153
|
+
MolecularSequence: { kind: "identifier", path: "identifier" },
|
|
154
|
+
NutritionOrder: { kind: "identifier", path: "identifier" },
|
|
155
|
+
OrganizationAffiliation: { kind: "identifier", path: "identifier" },
|
|
156
|
+
PaymentNotice: { kind: "identifier", path: "identifier" },
|
|
157
|
+
PaymentReconciliation: { kind: "identifier", path: "identifier" },
|
|
158
|
+
PractitionerRole: { kind: "identifier", path: "identifier" },
|
|
159
|
+
QuestionnaireResponse: { kind: "identifier", path: "identifier" },
|
|
160
|
+
RequestGroup: { kind: "identifier", path: "identifier" },
|
|
161
|
+
ResearchSubject: { kind: "identifier", path: "identifier" },
|
|
162
|
+
RiskAssessment: { kind: "identifier", path: "identifier" },
|
|
163
|
+
Schedule: { kind: "identifier", path: "identifier" },
|
|
164
|
+
Slot: { kind: "identifier", path: "identifier" },
|
|
165
|
+
SupplyDelivery: { kind: "identifier", path: "identifier" },
|
|
166
|
+
SupplyRequest: { kind: "identifier", path: "identifier" },
|
|
167
|
+
VisionPrescription: { kind: "identifier", path: "identifier" },
|
|
27
168
|
};
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFiZWwtcGF0aHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc29ydC1rZXkvbGFiZWwtcGF0aHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7Ozs7R0FlRzs7O0FBUUgsa0VBQWtFO0FBQ3JELFFBQUEsV0FBVyxHQUFnQztJQUN0RCxPQUFPLEVBQUUsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUU7SUFDNUMsWUFBWSxFQUFFLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFO0lBQ2pELFlBQVksRUFBRSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRTtJQUM5QyxRQUFRLEVBQUUsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUU7SUFDMUMsVUFBVSxFQUFFLEVBQUUsSUFBSSxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFO0NBQ2xELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIGBMQUJFTF9QQVRIU2Ag4oCUIHBlci1yZXNvdXJjZS10eXBlIGxhYmVsLWV4dHJhY3Rpb24gcnVsZSBmb3IgYGV4dHJhY3RTb3J0S2V5YC5cbiAqIEhhbmQtY3VyYXRlZCBwbGF0Zm9ybS10aWVyIHRhYmxlIHBlciBEUi0wMDQuXG4gKlxuICogUmVzb3VyY2UgdHlwZXMgbGlzdGVkIGhlcmUgZW1pdCBHU0kxIHNvcnQga2V5cyBvZiB0aGUgZm9ybVxuICogYDxub3JtYWxpemVkTGFiZWw+IzxpZD5gIHNvIGxpc3QgZW5kcG9pbnRzIHJldHVybiBhbHBoYWJldGljYWxseSBzb3J0ZWQgYnlcbiAqIG5hdHVyYWwgbGFiZWwgYW5kIGBCRUdJTlNfV0lUSGAgcXVlcmllcyBzZXJ2ZSBwcmVmaXggc2VhcmNoZXMgbGlrZVxuICogYD9uYW1lPVNtYC4gUmVzb3VyY2UgdHlwZXMgYWJzZW50IGZyb20gdGhpcyBtYXAgZmFsbCBiYWNrIHRvXG4gKiBgPElTTy04NjAxIGxhc3RVcGRhdGVkPiM8aWQ+YC5cbiAqXG4gKiBUaGUgbWluaW11bSBwbGF0Zm9ybS1jdXJhdGVkIHNldCBwZXIgRFItMDA0IGlzIFBhdGllbnQsIFByYWN0aXRpb25lcixcbiAqIE9yZ2FuaXphdGlvbiwgTG9jYXRpb24sIE1lZGljYXRpb24uIE5ldyBlbnRyaWVzIGhlcmUgYXJlIG9uZS1saW5lIGFkZGl0aW9uc1xuICogcmV2aWV3ZWQgYXQgUFIgdGltZSDigJQgbm8gZW5naW5lIGNoYW5nZSByZXF1aXJlZC5cbiAqXG4gKiBAc2VlIG9wZW5oaS1wbGFubmluZyBEUi0wMDQg4oCUIEZISVIgU3VtbWFyeS1BdHRyaWJ1dGUgYW5kIFNvcnQtS2V5IFByb2plY3Rpb24gU3RyYXRlZ3lcbiAqL1xuXG4vKiogU291cmNlIG9mIHRoZSBuYXR1cmFsIGxhYmVsIGZvciBhIGxhYmVsZWQgcmVzb3VyY2UgdHlwZS4gKi9cbmV4cG9ydCB0eXBlIExhYmVsU291cmNlID1cbiAgfCB7IGtpbmQ6IFwiaHVtYW5OYW1lXCI7IHBhdGg6IFwibmFtZVwiIH1cbiAgfCB7IGtpbmQ6IFwic3RyaW5nXCI7IHBhdGg6IFwibmFtZVwiIH1cbiAgfCB7IGtpbmQ6IFwiY29kZURpc3BsYXlcIjsgcGF0aDogXCJjb2RlXCIgfTtcblxuLyoqIFJlc291cmNlIHR5cGVzIHdpdGggY3VyYXRlZCBuYXR1cmFsIGxhYmVscyAoRFItMDA0IFRpZXIgMSkuICovXG5leHBvcnQgY29uc3QgTEFCRUxfUEFUSFM6IFJlY29yZDxzdHJpbmcsIExhYmVsU291cmNlPiA9IHtcbiAgUGF0aWVudDogeyBraW5kOiBcImh1bWFuTmFtZVwiLCBwYXRoOiBcIm5hbWVcIiB9LFxuICBQcmFjdGl0aW9uZXI6IHsga2luZDogXCJodW1hbk5hbWVcIiwgcGF0aDogXCJuYW1lXCIgfSxcbiAgT3JnYW5pemF0aW9uOiB7IGtpbmQ6IFwic3RyaW5nXCIsIHBhdGg6IFwibmFtZVwiIH0sXG4gIExvY2F0aW9uOiB7IGtpbmQ6IFwic3RyaW5nXCIsIHBhdGg6IFwibmFtZVwiIH0sXG4gIE1lZGljYXRpb246IHsga2luZDogXCJjb2RlRGlzcGxheVwiLCBwYXRoOiBcImNvZGVcIiB9LFxufTtcbiJdfQ==
|
|
169
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"label-paths.js","sourceRoot":"","sources":["../../src/sort-key/label-paths.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * `LABEL_PATHS` — per-resource-type label-extraction rule for `extractSortKey`.\n * Hand-curated table per DR-004.\n *\n * Resource types listed here emit GSI1 sort keys of the form\n * `<normalizedLabel>#<id>` so list endpoints return alphabetically sorted by\n * natural label and `BEGINS_WITH` queries serve prefix searches like\n * `?name=Sm` or `?identifier=INV-2024`. Resource types absent from this map\n * fall back to `<ISO-8601 lastUpdated>#<id>`.\n *\n * Five buckets cover the FHIR R4 surface:\n *\n * - **humanName** — `name: HumanName[]` (Patient, Practitioner, Person,\n *   RelatedPerson). Label is `family,given`.\n * - **string** with `path: \"name\"` — plain string `name` fields on\n *   directory-style resources (Organization, Location, Account, …) and\n *   on conformance resources (StructureDefinition, ValueSet, …).\n * - **string** with `path: \"title\"` — title-keyed resources where the\n *   business label is `title` rather than `name` (CarePlan, Composition,\n *   Contract, List, ResearchStudy, …).\n * - **codeDisplay** — primary CodeableConcept on the resource\n *   (Condition.code, Observation.code, Immunization.vaccineCode,\n *   BodyStructure.morphology, …). Label is `coding[0].display` with\n *   `text` fallback.\n * - **identifier** — business identifier on transactional / financial /\n *   scheduling resources (Claim.identifier, Invoice.identifier,\n *   Encounter.identifier, …). Label is `identifier[0].value`.\n *\n * Resource types not in this table fall through to `<lastUpdated>#<id>` —\n * intentional for event-log and metadata resources (AuditEvent, Bundle,\n * Provenance, Linkage, MessageHeader, VerificationResult) and for the\n * substance / medicinal-product detail families (SubstanceNucleicAcid,\n * MedicinalProductIngredient, …) that are not list-by-name resources.\n *\n * @see openhi-planning DR-004 — FHIR Summary-Attribute and Sort-Key Projection Strategy\n */\n\n/** Source of the natural label for a labeled resource type. */\nexport type LabelSource =\n  | { kind: \"humanName\"; path: string }\n  | { kind: \"string\"; path: string }\n  | { kind: \"codeDisplay\"; path: string }\n  | { kind: \"identifier\"; path: string };\n\n/** Resource types with curated natural labels. */\nexport const LABEL_PATHS: Record<string, LabelSource> = {\n  // HumanName arrays\n  Patient: { kind: \"humanName\", path: \"name\" },\n  Person: { kind: \"humanName\", path: \"name\" },\n  Practitioner: { kind: \"humanName\", path: \"name\" },\n  RelatedPerson: { kind: \"humanName\", path: \"name\" },\n\n  // Plain string `name` (directory-style resources)\n  Account: { kind: \"string\", path: \"name\" },\n  CareTeam: { kind: \"string\", path: \"name\" },\n  Endpoint: { kind: \"string\", path: \"name\" },\n  Group: { kind: \"string\", path: \"name\" },\n  HealthcareService: { kind: \"string\", path: \"name\" },\n  InsurancePlan: { kind: \"string\", path: \"name\" },\n  Location: { kind: \"string\", path: \"name\" },\n  Organization: { kind: \"string\", path: \"name\" },\n\n  // Control-plane FHIR types (ADR-2026-03-13-01 — Tenant/Workspace as FHIR types)\n  Tenant: { kind: \"string\", path: \"name\" },\n  Workspace: { kind: \"string\", path: \"name\" },\n\n  // `title`-keyed (title is the only or primary human label)\n  CarePlan: { kind: \"string\", path: \"title\" },\n  ChargeItemDefinition: { kind: \"string\", path: \"title\" },\n  Composition: { kind: \"string\", path: \"title\" },\n  Contract: { kind: \"string\", path: \"title\" },\n  List: { kind: \"string\", path: \"title\" },\n  ResearchStudy: { kind: \"string\", path: \"title\" },\n\n  // Conformance resources (string `name` is required; `title` is optional)\n  ActivityDefinition: { kind: \"string\", path: \"name\" },\n  CapabilityStatement: { kind: \"string\", path: \"name\" },\n  CodeSystem: { kind: \"string\", path: \"name\" },\n  CompartmentDefinition: { kind: \"string\", path: \"name\" },\n  ConceptMap: { kind: \"string\", path: \"name\" },\n  EffectEvidenceSynthesis: { kind: \"string\", path: \"name\" },\n  EventDefinition: { kind: \"string\", path: \"name\" },\n  Evidence: { kind: \"string\", path: \"name\" },\n  EvidenceVariable: { kind: \"string\", path: \"name\" },\n  ExampleScenario: { kind: \"string\", path: \"name\" },\n  GraphDefinition: { kind: \"string\", path: \"name\" },\n  ImplementationGuide: { kind: \"string\", path: \"name\" },\n  Library: { kind: \"string\", path: \"name\" },\n  Measure: { kind: \"string\", path: \"name\" },\n  MessageDefinition: { kind: \"string\", path: \"name\" },\n  NamingSystem: { kind: \"string\", path: \"name\" },\n  OperationDefinition: { kind: \"string\", path: \"name\" },\n  PlanDefinition: { kind: \"string\", path: \"name\" },\n  Questionnaire: { kind: \"string\", path: \"name\" },\n  ResearchDefinition: { kind: \"string\", path: \"name\" },\n  ResearchElementDefinition: { kind: \"string\", path: \"name\" },\n  RiskEvidenceSynthesis: { kind: \"string\", path: \"name\" },\n  SearchParameter: { kind: \"string\", path: \"name\" },\n  StructureDefinition: { kind: \"string\", path: \"name\" },\n  StructureMap: { kind: \"string\", path: \"name\" },\n  TerminologyCapabilities: { kind: \"string\", path: \"name\" },\n  TestReport: { kind: \"string\", path: \"name\" },\n  TestScript: { kind: \"string\", path: \"name\" },\n  ValueSet: { kind: \"string\", path: \"name\" },\n\n  // Primary CodeableConcept (codeDisplay reads `coding[0].display` with `text` fallback)\n  AdverseEvent: { kind: \"codeDisplay\", path: \"event\" },\n  AllergyIntolerance: { kind: \"codeDisplay\", path: \"code\" },\n  Basic: { kind: \"codeDisplay\", path: \"code\" },\n  BodyStructure: { kind: \"codeDisplay\", path: \"morphology\" },\n  ChargeItem: { kind: \"codeDisplay\", path: \"code\" },\n  Communication: { kind: \"codeDisplay\", path: \"topic\" },\n  Condition: { kind: \"codeDisplay\", path: \"code\" },\n  DetectedIssue: { kind: \"codeDisplay\", path: \"code\" },\n  DeviceMetric: { kind: \"codeDisplay\", path: \"type\" },\n  DiagnosticReport: { kind: \"codeDisplay\", path: \"code\" },\n  DocumentManifest: { kind: \"codeDisplay\", path: \"type\" },\n  DocumentReference: { kind: \"codeDisplay\", path: \"type\" },\n  FamilyMemberHistory: { kind: \"codeDisplay\", path: \"relationship\" },\n  Flag: { kind: \"codeDisplay\", path: \"code\" },\n  Goal: { kind: \"codeDisplay\", path: \"description\" },\n  Immunization: { kind: \"codeDisplay\", path: \"vaccineCode\" },\n  ImmunizationEvaluation: { kind: \"codeDisplay\", path: \"vaccineCode\" },\n  Medication: { kind: \"codeDisplay\", path: \"code\" },\n  MedicationKnowledge: { kind: \"codeDisplay\", path: \"code\" },\n  Observation: { kind: \"codeDisplay\", path: \"code\" },\n  ObservationDefinition: { kind: \"codeDisplay\", path: \"code\" },\n  Procedure: { kind: \"codeDisplay\", path: \"code\" },\n  ServiceRequest: { kind: \"codeDisplay\", path: \"code\" },\n  Specimen: { kind: \"codeDisplay\", path: \"type\" },\n  SpecimenDefinition: { kind: \"codeDisplay\", path: \"typeCollected\" },\n  Substance: { kind: \"codeDisplay\", path: \"code\" },\n  Task: { kind: \"codeDisplay\", path: \"code\" },\n\n  // Business identifier — `identifier[0].value` (singular `Identifier` also supported)\n  Appointment: { kind: \"identifier\", path: \"identifier\" },\n  AppointmentResponse: { kind: \"identifier\", path: \"identifier\" },\n  CatalogEntry: { kind: \"identifier\", path: \"identifier\" },\n  Claim: { kind: \"identifier\", path: \"identifier\" },\n  ClaimResponse: { kind: \"identifier\", path: \"identifier\" },\n  ClinicalImpression: { kind: \"identifier\", path: \"identifier\" },\n  CommunicationRequest: { kind: \"identifier\", path: \"identifier\" },\n  Consent: { kind: \"identifier\", path: \"identifier\" },\n  Coverage: { kind: \"identifier\", path: \"identifier\" },\n  CoverageEligibilityRequest: { kind: \"identifier\", path: \"identifier\" },\n  CoverageEligibilityResponse: { kind: \"identifier\", path: \"identifier\" },\n  DeviceRequest: { kind: \"identifier\", path: \"identifier\" },\n  DeviceUseStatement: { kind: \"identifier\", path: \"identifier\" },\n  Encounter: { kind: \"identifier\", path: \"identifier\" },\n  EnrollmentRequest: { kind: \"identifier\", path: \"identifier\" },\n  EnrollmentResponse: { kind: \"identifier\", path: \"identifier\" },\n  EpisodeOfCare: { kind: \"identifier\", path: \"identifier\" },\n  ExplanationOfBenefit: { kind: \"identifier\", path: \"identifier\" },\n  GuidanceResponse: { kind: \"identifier\", path: \"identifier\" },\n  ImagingStudy: { kind: \"identifier\", path: \"identifier\" },\n  ImmunizationRecommendation: { kind: \"identifier\", path: \"identifier\" },\n  Invoice: { kind: \"identifier\", path: \"identifier\" },\n  MeasureReport: { kind: \"identifier\", path: \"identifier\" },\n  Media: { kind: \"identifier\", path: \"identifier\" },\n  MedicationAdministration: { kind: \"identifier\", path: \"identifier\" },\n  MedicationDispense: { kind: \"identifier\", path: \"identifier\" },\n  MedicationRequest: { kind: \"identifier\", path: \"identifier\" },\n  MedicationStatement: { kind: \"identifier\", path: \"identifier\" },\n  MolecularSequence: { kind: \"identifier\", path: \"identifier\" },\n  NutritionOrder: { kind: \"identifier\", path: \"identifier\" },\n  OrganizationAffiliation: { kind: \"identifier\", path: \"identifier\" },\n  PaymentNotice: { kind: \"identifier\", path: \"identifier\" },\n  PaymentReconciliation: { kind: \"identifier\", path: \"identifier\" },\n  PractitionerRole: { kind: \"identifier\", path: \"identifier\" },\n  QuestionnaireResponse: { kind: \"identifier\", path: \"identifier\" },\n  RequestGroup: { kind: \"identifier\", path: \"identifier\" },\n  ResearchSubject: { kind: \"identifier\", path: \"identifier\" },\n  RiskAssessment: { kind: \"identifier\", path: \"identifier\" },\n  Schedule: { kind: \"identifier\", path: \"identifier\" },\n  Slot: { kind: \"identifier\", path: \"identifier\" },\n  SupplyDelivery: { kind: \"identifier\", path: \"identifier\" },\n  SupplyRequest: { kind: \"identifier\", path: \"identifier\" },\n  VisionPrescription: { kind: \"identifier\", path: \"identifier\" },\n};\n"]}
|
package/package.json
CHANGED