@kanonak-protocol/sdk 3.4.0 → 3.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser.d.ts +2 -0
- package/dist/browser.js +26 -26
- package/dist/derivation/findDerivation.d.ts +85 -0
- package/dist/derivation/index.d.ts +2 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +37 -37
- package/dist/parsing/KanonakObjectParser.d.ts +22 -0
- package/dist/parsing/index.js +1 -1
- package/dist/reasoning/index.js +1 -1
- package/package.json +2 -2
package/dist/browser.js
CHANGED
|
@@ -1,48 +1,48 @@
|
|
|
1
|
-
var Jt=Object.defineProperty;var Zt=(l,e)=>()=>(l&&(e=l(l=0)),e);var Qt=(l,e)=>{for(var t in e)Jt(l,t,{get:e[t],enumerable:!0})};var It={};Qt(It,{KanonakUri:()=>K});function er(l,e,t){return{major:l,minor:e,patch:t,toString:()=>`${l}.${e}.${t}`,equals:r=>!r||typeof r!="object"?!1:r.major===l&&r.minor===e&&r.patch===t,getHashCode:()=>l<<20|e<<10|t,compareTo:r=>l!==r.major?l-r.major:e!==r.minor?e-r.minor:t-r.patch}}var K,ee=Zt(()=>{"use strict";K=class l{constructor(e,t,r,n){this.publisher=e;this.package_=t;this.name=r;this.version=n}publisher;package_;name;version;static parse(e){if(!e||e.trim().length===0)throw new Error("Kanonak URI string cannot be null or empty");let t=e.split("/");if(t.length!==3)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let[r,n,o]=t;if(!r||!n||!o)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let s=n.indexOf("@");if(s===-1)return new l(r,n,o,void 0);let a=n.substring(0,s),c=n.substring(s+1);if(!a||!c)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let i=c.split(".").map(Number),p=er(i[0]||0,i[1]||0,i[2]||0);return new l(r,a,o,p)}toString(){return this.version?`${this.publisher}/${this.package_}@${this.version.major}.${this.version.minor}.${this.version.patch}/${this.name}`:`${this.publisher}/${this.package_}/${this.name}`}}});import*as Ue from"js-yaml";var E=class{parse(e){let t=this.parseWithErrors(e);if(!t.isValid){let r=t.errors[0];throw new Error(`YAML parse error at line ${r.line}, column ${r.column}: ${r.message}`)}return t.document}parseWithErrors(e){let t=[],r;try{e=e.replace(/^\uFEFF/,"");let n=Ue.load(e);if(!n||typeof n!="object")return r={metadata:this.createEmptyMetadata(),body:{},toString:()=>"KanonakDocument(empty)"},{document:r,errors:t,isValid:!0};let o=this.extractMetadata(n),s=this.extractBody(n,o);return r={metadata:o,body:s,toString:function(){return this.metadata.namespace_?`KanonakDocument(${this.metadata.namespace_.publisher}/${this.metadata.namespace_.package_})`:"KanonakDocument(no namespace)"}},{document:r,errors:t,isValid:!0}}catch(n){let o=n,s={message:o.message||"Unknown parse error",line:o.mark?.line??0,column:o.mark?.column??0,errorType:o.name==="YAMLException"?"SyntaxError":"Unknown",toString:()=>`${o.name==="YAMLException"?"SyntaxError":"Unknown"} at line ${o.mark?.line??0}: ${o.message||"Unknown parse error"}`};return t.push(s),{document:void 0,errors:t,isValid:!1}}}save(e){let t={};if(e.metadata.namespace_){let r=e.metadata.namespace_,n={type:"Package",publisher:r.publisher};r.version&&(n.version=`${r.version.major}.${r.version.minor}.${r.version.patch}`),e.metadata.imports&&(n.imports=this.serializeImports(e.metadata.imports)),t[r.package_]=n}return Object.assign(t,e.body),Ue.dump(t,{indent:2,noRefs:!0,sortKeys:!1})}createEmptyMetadata(){return{get allImports(){return[]}}}addAllImportsGetter(e){let t=e.imports;return Object.defineProperty(e,"allImports",{get:function(){if(!t)return[];let r=[];for(let n of Object.values(t))r.push(...n);return r},enumerable:!0,configurable:!0}),e}createVersion(e,t,r){return{major:e,minor:t,patch:r,toString:()=>`${e}.${t}.${r}`,equals:o=>!o||typeof o!="object"?!1:o.major===e&&o.minor===t&&o.patch===r,getHashCode:()=>e<<20|t<<10|r,compareTo:o=>e!==o.major?e-o.major:t!==o.minor?t-o.minor:r-o.patch}}extractMetadata(e){let t=this.createEmptyMetadata();for(let[r,n]of Object.entries(e))if(n&&typeof n=="object"&&n.type==="Package"){t.type_="Package";let o=r,s=n.publisher,a=n.version?this.parseVersion(n.version):void 0;return s&&o&&(t.namespace_={publisher:s,package_:o,version:a,toString:function(){return`${this.publisher}/${this.package_}@${this.version?.major??1}.${this.version?.minor??0}.${this.version?.patch??0}`},equals:c=>!c||typeof c!="object"?!1:c.publisher===s&&c.package_===o&&(!a||!c.version||a.equals(c.version)),getHashCode:()=>{let c=0;for(let i=0;i<s.length;i++)c=(c<<5)-c+s.charCodeAt(i);for(let i=0;i<o.length;i++)c=(c<<5)-c+o.charCodeAt(i);return c|0}}),n.imports&&Array.isArray(n.imports)&&(t.imports=this.parseImportsV3(n.imports)),this.addAllImportsGetter(t)}if(e.kanonak&&typeof e.kanonak=="object"){let r=e.kanonak;return(r.publisher||r.package||r.version)&&(t.namespace_=this.parseNamespace(r)),r.imports&&typeof r.imports=="object"&&(t.imports=this.parseImportsLegacy(r.imports)),this.addAllImportsGetter(t)}return t}extractBody(e,t){let r={},n;for(let[o,s]of Object.entries(e))if(s&&typeof s=="object"&&s.type==="Package"){n=o;break}for(let[o,s]of Object.entries(e))o!==n&&o!=="kanonak"&&o!=="namespace"&&o!=="imports"&&(r[o]=s);return r}parseNamespace(e){if(typeof e=="string"){let o=e.match(/^([^/]+)\/([^@]+)(?:@(.+))?$/);if(o){let s=o[3]?this.parseVersion(o[3]):this.createVersion(1,0,0);return{publisher:o[1],package_:o[2],version:s,toString:()=>e,equals:a=>!a||typeof a!="object"?!1:a.publisher===o[1]&&a.package_===o[2]&&(!s||!a.version||s.equals(a.version)),getHashCode:()=>{let a=0;for(let c=0;c<o[1].length;c++)a=(a<<5)-a+o[1].charCodeAt(c);for(let c=0;c<o[2].length;c++)a=(a<<5)-a+o[2].charCodeAt(c);return a|0}}}}let t=e.publisher||"",r=e.package||"",n=e.version?this.parseVersion(e.version):this.createVersion(1,0,0);return{publisher:t,package_:r,version:n,toString:function(){return`${this.publisher}/${this.package_}@${this.version?.major??1}.${this.version?.minor??0}.${this.version?.patch??0}`},equals:o=>!o||typeof o!="object"?!1:o.publisher===t&&o.package_===r&&(!n||!o.version||n.equals(o.version)),getHashCode:()=>{let o=0;for(let s=0;s<t.length;s++)o=(o<<5)-o+t.charCodeAt(s);for(let s=0;s<r.length;s++)o=(o<<5)-o+r.charCodeAt(s);return o|0}}}parseVersion(e){if(typeof e=="string"){let t=e.split(".").map(Number);return this.createVersion(t[0]||0,t[1]||0,t[2]||0)}return this.createVersion(e.major||0,e.minor||0,e.patch||0)}parseImportsV3(e){let t={};for(let r of e)if(!(!r||typeof r!="object"))if(r.packages&&Array.isArray(r.packages)){let n=r.publisher;if(!n)throw new Error("PublisherImport requires 'publisher' property");t[n]||(t[n]=[]);for(let o of r.packages){if(!o||typeof o!="object")continue;let s=this.parseImportFromEmbeddedObject(o,n);t[n].push(s)}}else{let n=this.parseImportFromEmbeddedObject(r,r.publisher),o=n.publisher||"";t[o]||(t[o]=[]),t[o].push(n)}return t}parseImportsLegacy(e){let t={};for(let[r,n]of Object.entries(e))Array.isArray(n)&&(t[r]=n.map(o=>this.parseImport(o,r)));return t}parseImportFromEmbeddedObject(e,t){let r=e.package;if(!r)throw new Error("Import requires 'package' property");let n=e.match;if(!n)throw new Error("Import requires 'match' property");let o=e.version;if(!o)throw new Error("Import requires 'version' property");let s=this.parseVersion(o),a=this.parseVersionOperator(n),c=this.calculateMaxVersion(n,s),i=e.alias;return{package_:`${r} ${n} ${s.toString()}`,publisher:t,packageName:r,versionOperator:a,version:s,alias:i,minVersion:s,maxVersion:c,toEmbeddedObject:()=>{let p={package:r,match:n,version:s.toString()};return i&&(p.alias=i),p},toString:()=>i?`${r} ${n} ${s.toString()} as ${i}`:`${r} ${n} ${s.toString()}`}}parseImport(e,t){if(typeof e=="string"){let c=e.match(/^(.+?)\s*([~^=*])\s*(\S+)\s+as\s+(\S+)$/);if(c){let p=c[1].trim(),u=c[2],y=this.parseVersion(c[3].trim()),m=c[4].trim(),f=this.parseVersionOperator(u),d=this.calculateMaxVersion(u,y);return{package_:e,publisher:t,packageName:p,versionOperator:f,version:y,alias:m,minVersion:y,maxVersion:d,toEmbeddedObject:()=>{let g={package:p,match:u,version:y.toString()};return m&&(g.alias=m),g},toString:()=>`${p} ${u} ${y.toString()} as ${m}`}}let i=e.match(/^(.+?)\s*([~^=*])\s*(.+)$/);if(i){let p=i[1].trim(),u=i[2],y=this.parseVersion(i[3].trim()),m=this.parseVersionOperator(u),f=this.calculateMaxVersion(u,y);return{package_:e,publisher:t,packageName:p,versionOperator:m,version:y,alias:void 0,minVersion:y,maxVersion:f,toEmbeddedObject:()=>({package:p,match:u,version:y.toString()}),toString:()=>`${p} ${u} ${y.toString()}`}}}let r=this.parseVersionOperator(e.operator||"~"),n=this.parseVersion(e.version||"1.0.0"),o=e.packageName||e.package||"",s=["=","~","^","*"][r],a=this.calculateMaxVersion(e.operator||"~",n);return{package_:e.package||"",publisher:t,packageName:o,versionOperator:r,version:n,alias:e.alias,minVersion:n,maxVersion:a,toEmbeddedObject:()=>{let c={package:o,match:s,version:n.toString()};return e.alias&&(c.alias=e.alias),c},toString:()=>`${o} ${s} ${n.toString()}`}}parseVersionOperator(e){switch(e){case"=":return 0;case"~":return 1;case"^":return 2;case"*":return 3;default:return 1}}calculateMaxVersion(e,t){switch(e){case"~":return this.createVersion(t.major,t.minor+1,0);case"^":return t.major===0?this.createVersion(0,t.minor+1,0):this.createVersion(t.major+1,0,0);default:return this.createVersion(999,999,999)}}serializeImports(e){let t=[];for(let[r,n]of Object.entries(e)){let o={publisher:r,packages:n.map(s=>{let a=["=","~","^","*"][s.versionOperator],c={package:s.packageName,match:a,version:`${s.version.major}.${s.version.minor}.${s.version.patch}`};return s.alias&&(c.alias=s.alias),c})};t.push(o)}return t}};var T=class{};var H=class extends T{statement=[]};var q=class extends H{namespace;name;icon};var L=class extends H{name};ee();var I=class l extends T{subject;static parse(e){let t=new l;return t.subject=K.parse(e),t}};var je=class extends T{value};var x=class{predicate;object};var N=class extends x{};var G=class l extends N{static parse(e,t){let r=new l;return r.predicate=I.parse(e),r.object=t,r}};var te=class l extends N{static parse(e,t){let r=new l;return r.predicate=I.parse(e),r.object=t,r}};var re=class extends N{};var ne=class l extends x{static parse(e,t){let r=new l;return r.predicate=I.parse(e),r.object=I.parse(t),r}};var z=class extends x{};var X=class extends x{};ee();function S(l){if(Array.isArray(l))return l.map(t=>t?.toString()??"").filter(t=>t.length>0);let e=l?.toString();return e?[e]:[]}var A=class{cache=new Map;repository;logger;constructor(e,t){this.repository=e,this.logger=t}async resolveEntityAsync(e,t){let r=t.metadata?.namespace_?.toString()??"unknown",n=this.cache.get(r);if(n){let s=n.get(e);if(s)return s}let o=await this.buildEntityIndexAsyncInternal(t,new Set,"");return this.cache.set(r,o),o.get(e)??null}async resolveAllEntitiesAsync(e,t){let r=await this.buildAllEntitiesIndexAsync(t,new Set,"");if(e.includes(".")){let n=e.split("."),o=n[0],s=n[1],a=await this.findDocumentForAlias(t,o);return a?await this.resolveAllEntitiesAsync(s,a):[]}return r.filter(n=>n.entityName===e)}async buildAllEntitiesIndexAsync(e,t,r){let n=[],o=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building ALL entities index for namespace: ${o}`),t.has(o))return this.logger?.debug?.(`Skipping ${o} - already visited (circular import prevention)`),n;t.add(o);let s=r.length===0?o:`${r} \u2192 ${o}`;for(let[a,c]of Object.entries(e.body))if(c&&typeof c=="object"&&!Array.isArray(c)){let i=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};n.push({entityName:a,uri:new K(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,a,i),entity:c,definedInNamespace:o,isImported:r.length>0,importPath:s})}if(this.logger?.debug?.(`Collected ${n.length} entities from ${o}`),e.metadata?.imports){let a=Object.values(e.metadata.imports).reduce((c,i)=>c+i.length,0);this.logger?.debug?.(`Processing ${a} import(s) for ${o}`);for(let[c,i]of Object.entries(e.metadata.imports))for(let p of i)try{this.logger?.debug?.(`Resolving import: ${c}/${p.packageName}`);let u=await this.repository.getHighestCompatibleVersionAsync(c,p);if(u){this.logger?.debug?.(`Successfully loaded import: ${u.metadata?.namespace_?.toString()}`);let y=await this.buildAllEntitiesIndexAsync(u,t,s);n.push(...y),this.logger?.debug?.(`Added ${y.length} entities from import ${u.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${c}/${p.packageName}`)}catch(u){let y=u;throw this.logger?.error?.(`Failed to process import ${c}/${p.packageName} for namespace ${o}. Error: ${y.message}`,y),new Error(`Failed to process import ${c}/${p.packageName} for namespace ${o}. See inner exception for details.`,{cause:u})}}return n}async buildEntityIndexAsync(e){return await this.buildEntityIndexAsyncInternal(e,new Set,"")}async buildEntityIndexAsyncInternal(e,t,r){let n=new Map,o=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building entity index for namespace: ${o}`),t.has(o))return this.logger?.debug?.(`Skipping ${o} - already visited (circular import prevention)`),n;t.add(o);let s=r.length===0?o:`${r} \u2192 ${o}`,a=0;for(let[c,i]of Object.entries(e.body))if(i&&typeof i=="object"&&!Array.isArray(i)&&!n.has(c)){let p=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};n.set(c,{entityName:c,uri:new K(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,c,p),entity:i,definedInNamespace:o,isImported:r.length>0,importPath:s}),a++}if(this.logger?.debug?.(`Indexed ${a} entities from ${o}`),e.metadata?.imports){let c=Object.values(e.metadata.imports).reduce((i,p)=>i+p.length,0);this.logger?.debug?.(`Processing ${c} import(s) for ${o}`);for(let[i,p]of Object.entries(e.metadata.imports))for(let u of p)try{this.logger?.debug?.(`Resolving import: ${i}/${u.packageName}`);let y=await this.repository.getHighestCompatibleVersionAsync(i,u);if(y){this.logger?.debug?.(`Successfully loaded import: ${y.metadata?.namespace_?.toString()}`);let m=await this.buildEntityIndexAsyncInternal(y,t,s),f=0;for(let[d,g]of m.entries())if(n.has(d)||(n.set(d,g),f++),u.alias&&!d.includes(".")){let h=`${u.alias}.${d}`;n.has(h)||(n.set(h,g),f++)}this.logger?.debug?.(`Merged ${f} entities from import ${y.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${i}/${u.packageName}`)}catch(y){let m=y;throw this.logger?.error?.(`Failed to process import ${i}/${u.packageName} for namespace ${o}. Error: ${m.message}`,m),new Error(`Failed to process import ${i}/${u.packageName} for namespace ${o}. See inner exception for details.`,{cause:y})}}return n}async findDocumentForAlias(e,t){if(!e.metadata?.imports)return null;for(let[r,n]of Object.entries(e.metadata.imports))for(let o of n){if(o.alias===t)return await this.repository.getHighestCompatibleVersionAsync(r,o);if(!o.alias&&o.packageName===t)return await this.repository.getHighestCompatibleVersionAsync(r,o)}return null}clearCache(){this.cache.clear()}clearCacheForDocument(e){this.cache.delete(e)}async isSubclassOfAsync(e,t,r){if(e===t)return!0;let n=new Set;return await this.isSubclassOfRecursiveAsync(e,t,r,n)}async isSubclassOfRecursiveAsync(e,t,r,n){if(n.has(e))return!1;n.add(e);let o=await this.resolveEntityAsync(e,r);if(!o?.entity)return!1;let s=o.entity.subClassOf;if(s){let a=S(s);for(let c of a)if(c===t||await this.isSubclassOfRecursiveAsync(c,t,r,n))return!0}return!1}async isSubpropertyOfAsync(e,t,r){if(e===t)return!0;let n=new Set;return await this.isSubpropertyOfRecursiveAsync(e,t,r,n)}async isSubpropertyOfRecursiveAsync(e,t,r,n){if(n.has(e))return!1;n.add(e);let o=await this.resolveEntityAsync(e,r);if(!o?.entity)return!1;let s=o.entity.subPropertyOf;if(s){let a=S(s);for(let c of a)if(c===t||await this.isSubpropertyOfRecursiveAsync(c,t,r,n))return!0}return!1}};var Y=class l{static KNOWN_XSD_DATATYPES=new Set(["string","integer","int","boolean","bool","decimal","float","double","date","datetime","time","duration","anyuri","base64binary","hexbinary","long","short","byte","nonnegativeinteger","positiveinteger","negativeinteger","nonpositiveinteger","unsignedint","unsignedlong","unsignedshort","unsignedbyte"]);resourceResolver;constructor(e){this.resourceResolver=e}isXsdDatatype(e){return e?e.publisher==="kanonak.org"&&e.package_==="core.xsd"&&l.KNOWN_XSD_DATATYPES.has(e.name.toLowerCase()):!1}isLiteralType(e){return e?e.publisher==="kanonak.org"&&e.package_==="core.rdf"&&e.name==="Literal":!1}isKnownXsdDatatypeName(e){let t=e.includes(".")?e.split(".")[1]:e;return l.KNOWN_XSD_DATATYPES.has(t.toLowerCase())}async isClassTypeAsync(e,t){if(this.isKnownXsdDatatypeName(e))return!1;let r=await this.resourceResolver.resolveEntityAsync(e,t);if(r){let n=r.entity.type;if(n){let o=String(n);return o==="Class"||o==="rdfs.Class"||o.endsWith(".Class")}}return!0}getPropertyTypeClassification(e){if(!e||e.trim().length===0)return"Property";switch(e.includes(".")?e.split(".")[1]:e){case"DatatypeProperty":return"DatatypeProperty";case"ObjectProperty":return"ObjectProperty";case"AnnotationProperty":return"AnnotationProperty";case"Property":return"Property";default:return"Property"}}isEffectiveDatatypeProperty(e,t){return!!(e==="DatatypeProperty"||e==="Property"&&this.isXsdDatatype(t)||e==="Property"&&this.isLiteralType(t))}isEffectiveObjectProperty(e,t){return!!(e==="ObjectProperty"||e==="Property"&&t&&!this.isXsdDatatype(t)&&!this.isLiteralType(t))}};var Ee=class{constructor(e){}async parseKanonaks(e){let t=[],r=await e.getAllDocumentsAsync(),n=new A(e),o=new Y(n);for(let s of r)for(let[a,c]of Object.entries(s.body)){let i=new q;i.namespace=s.metadata.namespace_?.toString()??"",i.name=a,i.statement=[];let p=await this.parseStatements(c,s,n,o,e);i.statement.push(...p),t.push(i)}return t}async parseStatements(e,t,r,n,o){let s=[];if(typeof e!="object"||e===null||Array.isArray(e))return s;for(let[a,c]of Object.entries(e))try{let i=await this.getPropertyMetadata(a,t,r,o,n);if(!i)continue;let p=await this.parsePropertyValue(a,c,i,t,r,n);p&&s.push(p)}catch(i){console.error(`Error parsing property ${a}:`,i)}return s}async getPropertyMetadata(e,t,r,n,o){let s=await r.resolveEntityAsync(e,t);if(!s)return;let a=s.entity,c=a.type?.toString()??"",i=c.includes(".")?c.substring(c.lastIndexOf(".")+1):c;if(!new Set(["Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]).has(i))return;let u=o.getPropertyTypeClassification(c),y=a.range?.toString(),m;if(u==="ObjectProperty")m="ObjectProperty";else if(u==="DatatypeProperty")m="DatatypeProperty";else{let d=y&&y.includes(".")?y.substring(y.lastIndexOf(".")+1):y??"";(y?o.isKnownXsdDatatypeName(y):!1)||d==="Literal"?m="DatatypeProperty":m="ObjectProperty"}return{propertyUri:s.uri.toString(),propertyType:m,range:y,isImported:s.isImported,definedInNamespace:s.definedInNamespace}}async parsePropertyValue(e,t,r,n,o,s){let a=r.propertyUri;if(t!=null){if(Array.isArray(t))return this.parseListValue(a,t,r,n,o,s);if(r.propertyType==="DatatypeProperty")return this.parseDatatypeValue(a,t,r);if(r.propertyType==="ObjectProperty")return this.parseObjectValue(a,t,r,n,o,s)}}parseDatatypeValue(e,t,r){if(t instanceof Date)return G.parse(e,t.toISOString());if(typeof t=="string")return G.parse(e,t);if(typeof t=="number")return te.parse(e,t);if(typeof t=="boolean"){let n=new re;return n.predicate=I.parse(e),n.object=t,n}}async parseObjectValue(e,t,r,n,o,s){if(typeof t=="string"){let a=await this.resolveReference(t,n,o);if(!a)return;let c=new ne;return c.predicate=I.parse(e),c.object=a,c}if(typeof t=="object"&&!Array.isArray(t)){let a=new L;if(a.statement=await this.parseStatements(t,n,o,s,{}),a.statement.length>0){let p=new z;return p.predicate=I.parse(e),p.object=a,p}let c=[];for(let[p,u]of Object.entries(t))if(typeof u=="object"&&u!==null&&!Array.isArray(u)){let y=new L;y.name=p,y.statement=await this.parseStatements(u,n,o,s,{}),c.push(y)}else if(typeof u=="string"){let y=await this.resolveReference(u,n,o);y&&c.push(y)}if(c.length>0){let p=new X;return p.predicate=I.parse(e),p.object=c,p}let i=new z;return i.predicate=I.parse(e),i.object=a,i}}async parseListValue(e,t,r,n,o,s){let a=[],c=r.propertyType==="DatatypeProperty";for(let p of t){if(c&&(typeof p=="string"||typeof p=="number"||typeof p=="boolean")){let u=new je;u.value=p,a.push(u);continue}if(c&&p instanceof Date){let u=new je;u.value=p.toISOString(),a.push(u);continue}if(typeof p=="string"){let u=await this.resolveReference(p,n,o);u&&a.push(u)}else if(typeof p=="object"&&p!==null&&!Array.isArray(p)){let u=new L;u.statement=await this.parseStatements(p,n,o,s,{}),a.push(u)}}let i=new X;return i.predicate=I.parse(e),i.object=a,i}async resolveReference(e,t,r){let n=await r.resolveEntityAsync(e,t);if(n){let s=new I;return s.subject=n.uri,s}let o=t.metadata?.namespace_;if(o){let{KanonakUri:s}=await Promise.resolve().then(()=>(ee(),It)),a=o.version??{major:0,minor:0,patch:0,toString:()=>"0.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};if(e.includes(".")){let i=e.indexOf("."),p=e.substring(0,i),u=e.substring(i+1);if(t.metadata?.imports){for(let[y,m]of Object.entries(t.metadata.imports))for(let f of m)if((f.alias??f.packageName)===p){let g=new I;return g.subject=new s(y,f.packageName,u,f.version),g}}}let c=new I;return c.subject=new s(o.publisher,o.package_,e,a),c}return null}async saveKanonaks(e,t){let r=new Map;for(let n of e)n instanceof q&&n.namespace&&(r.has(n.namespace)||r.set(n.namespace,[]),r.get(n.namespace).push(n));for(let[n,o]of r){let s=await this.convertKanonaksToDocument(n,o),a=`${n.split("@")[0]}.yml`;await t.saveDocumentAsync(s,a)}}async serializeToYaml(e,t){let r=e.filter(s=>s instanceof q&&s.namespace===t);if(r.length===0)throw new Error(`No kanonaks found with namespace '${t}'`);let n=await this.convertKanonaksToDocument(t,r);return new E().save(n)}async convertKanonaksToDocument(e,t){let n={metadata:{namespace_:e,get allImports(){if(!this.imports)return[];let s=[];for(let a of Object.values(this.imports))s.push(...a);return s}},body:{}},o=new Map;for(let s of t){let a={};for(let c of s.statement){let[i,p]=this.convertStatementToProperty(c);i&&p!==null&&p!==void 0&&(a[i]=p),this.collectImportsFromStatement(c,e,o)}n.body[s.name]=a}return n}convertStatementToProperty(e){if(e instanceof G)return[e.predicate.subject.name,e.object];if(e instanceof te)return[e.predicate.subject.name,e.object];if(e instanceof re)return[e.predicate.subject.name,e.object];if(e instanceof ne)return[e.predicate.subject.name,e.object.subject.name];if(e instanceof X){let t=this.convertKanonakListToValue(e.object);return[e.predicate.subject.name,t]}else if(e instanceof z){let t=this.convertEmbeddedKanonakToValue(e.object);return[e.predicate.subject.name,t]}return[null,null]}convertKanonakListToValue(e){let t=[];for(let r of e)r instanceof I?t.push(r.subject.name):r instanceof L&&t.push(this.convertEmbeddedKanonakToValue(r));return t}convertEmbeddedKanonakToValue(e){let t={};for(let r of e.statement){let[n,o]=this.convertStatementToProperty(r);n&&o!==null&&o!==void 0&&(t[n]=o)}return t}collectImportsFromStatement(e,t,r){}};var Le=class{propertyUri;propertyType;range;isImported;definedInNamespace};import{parseDocument as tr,LineCounter as rr,isMap as xe,isPair as V,isScalar as j,isSeq as Fe}from"yaml";var Oe=class l{entities=new Map;entityBlocks=new Map;properties=new Map;propertyValues=new Map;valueListItems=new Map;importPackages=new Map;nestedKeys=new Map;nestedValues=new Map;static fromContent(e){let t=new l,r=new rr,n=tr(e,{lineCounter:r});if(n.errors.length>0||!xe(n.contents))return t;lt(n.contents,[],r,t);for(let o of n.contents.items){if(!V(o)||!j(o.key))continue;let s=String(o.key.value),a=o.key.range;if(!a)continue;t.entities.set(s,C(a,r));let c=o.value,i=c&&typeof c=="object"&&"range"in c?c.range:void 0;if(i?t.entityBlocks.set(s,C([a[0],a[1],i[2]],r)):t.entityBlocks.set(s,C(a,r)),xe(o.value)){let p=new Map,u=new Map,y=new Map;for(let f of o.value.items){if(!V(f)||!j(f.key))continue;let d=String(f.key.value),g=f.key.range;g&&p.set(d,C(g,r));let h=f.value;if(h&&typeof h=="object"&&"range"in h&&Array.isArray(h.range)){let b=h.range;u.set(d,C(b,r))}if(Fe(h)){let b=[];for(let R of h.items)R&&typeof R=="object"&&"range"in R&&Array.isArray(R.range)&&b.push(C(R.range,r));b.length>0&&y.set(d,b)}}p.size>0&&t.properties.set(s,p),u.size>0&&t.propertyValues.set(s,u),y.size>0&&t.valueListItems.set(s,y);let m=nr(o.value,r);m.length>0&&t.importPackages.set(s,m)}}return t}getEntityPosition(e){return this.entities.get(e)}getEntityBlockPosition(e){return this.entityBlocks.get(e)}findEntityAtPosition(e,t){for(let[r,n]of this.entityBlocks)if(pt(n,e,t))return r}findPropertyAtPosition(e,t){let r=this.findEntityAtPosition(e,t);if(!r)return;let n=this.properties.get(r),o=this.propertyValues.get(r);if(!n&&!o)return{entityName:r};let s,a;if(o)for(let[c,i]of o)pt(i,e,t)&&(!a||At(i,a))&&(s=c,a=i);if(n)for(let[c,i]of n)pt(i,e,t)&&(!a||At(i,a))&&(s=c,a=i);return s?{entityName:r,propertyName:s}:{entityName:r}}getPropertyPosition(e,t){return this.properties.get(e)?.get(t)}getPropertyValuePosition(e,t){return this.propertyValues.get(e)?.get(t)}getImportPackages(e){return this.importPackages.get(e)??[]}getAllImportPackages(){let e=[];for(let[t,r]of this.importPackages)for(let n of r)e.push({entityName:t,entry:n});return e}findPropertySourceName(e,t){let r=this.properties.get(e);if(r){if(r.has(t))return t;for(let n of r.keys()){let o=n.lastIndexOf(".");if((o===-1?n:n.substring(o+1))===t)return n}}}getListItemPosition(e,t,r){let n=this.valueListItems.get(e)?.get(t);if(!(!n||r<0||r>=n.length))return n[r]}getNodeKeyPosition(e){return this.nestedKeys.get(JSON.stringify(e))}getNodeValuePosition(e){return this.nestedValues.get(JSON.stringify(e))}setNestedKeyPosition(e,t){this.nestedKeys.set(e,t)}setNestedValuePosition(e,t){this.nestedValues.set(e,t)}getMostSpecificPosition(e,t,r){if(e){if(t!==void 0){if(r!==void 0){let s=this.getListItemPosition(e,t,r);if(s)return s}let n=this.getPropertyValuePosition(e,t);if(n)return n;let o=this.getPropertyPosition(e,t);if(o)return o}return this.getEntityPosition(e)}}};function nr(l,e){let t=[];if(!xe(l))return t;let r=l.items.find(n=>V(n)&&j(n.key)&&String(n.key.value)==="imports");if(!r||!V(r)||!Fe(r.value))return t;for(let n of r.value.items){if(!xe(n))continue;let o=n.items.find(c=>V(c)&&j(c.key)&&String(c.key.value)==="publisher");if(!o||!V(o)||!j(o.value))continue;let s=String(o.value.value),a=n.items.find(c=>V(c)&&j(c.key)&&String(c.key.value)==="packages");if(!(!a||!V(a)||!Fe(a.value)))for(let c of a.value.items){if(!xe(c))continue;let i=c.items.find(g=>V(g)&&j(g.key)&&String(g.key.value)==="package");if(!i||!V(i)||!j(i.value)||!i.value.range)continue;let p=String(i.value.value),u=c.items.find(g=>V(g)&&j(g.key)&&String(g.key.value)==="version"),y=u&&V(u)&&j(u.value)?String(u.value.value):"",m=c.items.find(g=>V(g)&&j(g.key)&&String(g.key.value)==="alias"),f=m&&V(m)&&j(m.value)?String(m.value.value):void 0,d=f!==void 0?{publisher:s,package_:p,version:y,alias:f,position:C(i.value.range,e)}:{publisher:s,package_:p,version:y,position:C(i.value.range,e)};t.push(d)}}return t}function pt(l,e,t){return!(e<l.line||e>l.endLine||e===l.line&&t<l.column||e===l.endLine&&t>l.endColumn)}function At(l,e){let t=l.endLine-l.line,r=e.endLine-e.line;if(t!==r)return t<r;let n=l.endLine===l.line?l.endColumn-l.column:Number.MAX_SAFE_INTEGER,o=e.endLine===e.line?e.endColumn-e.column:Number.MAX_SAFE_INTEGER;return n<o}function lt(l,e,t,r){if(xe(l)){for(let n of l.items){if(!V(n)||!j(n.key))continue;let o=String(n.key.value),s=[...e,o],a=JSON.stringify(s);n.key.range&&r.setNestedKeyPosition(a,C(n.key.range,t));let c=n.value,i=Dt(c);i&&r.setNestedValuePosition(a,C(i,t)),lt(c,s,t,r)}return}if(Fe(l)){for(let n=0;n<l.items.length;n++){let o=l.items[n],s=[...e,n],a=JSON.stringify(s),c=Dt(o);c&&r.setNestedValuePosition(a,C(c,t)),lt(o,s,t,r)}return}}function Dt(l){if(!l||typeof l!="object"||!("range"in l))return;let e=l.range;return Array.isArray(e)&&e.length>=3?e:void 0}function C(l,e){let t=e.linePos(l[0]),r=e.linePos(l[2]);return{line:t.line-1,column:t.col-1,endLine:r.line-1,endColumn:r.col-1}}function St(l,e){let r=(e??new E).parse(l),n=Oe.fromContent(l);return{document:r,positions:n}}var or=new Set(["kanonak.org/core-rdf","kanonak.org/core-rdfs","kanonak.org/core-owl","kanonak.org/core-xsd","kanonak.org/core-kanonak"]),Vt={Class:{publisher:"kanonak.org",package_:"core-owl"},ObjectProperty:{publisher:"kanonak.org",package_:"core-owl"},DatatypeProperty:{publisher:"kanonak.org",package_:"core-owl"},AnnotationProperty:{publisher:"kanonak.org",package_:"core-owl"},Property:{publisher:"kanonak.org",package_:"core-rdf"},Datatype:{publisher:"kanonak.org",package_:"core-rdfs"},Resource:{publisher:"kanonak.org",package_:"core-rdfs"},Literal:{publisher:"kanonak.org",package_:"core-rdfs"},Thing:{publisher:"kanonak.org",package_:"core-owl"},Nothing:{publisher:"kanonak.org",package_:"core-owl"}};function _(l){let e=l;if(e.entity&&typeof e.entity=="object"){let t=e.entity.type;if(typeof t=="string"){let r=Vt[t];return r?{publisher:r.publisher,package_:r.package_,name:t}:{publisher:"",package_:"",name:t}}}if(e.statement&&Array.isArray(e.statement)){for(let t of e.statement)if(t.predicate?.subject?.name==="type"&&t.object?.subject){let r=t.object.subject;if(!r.publisher&&!r.package_||r.publisher===""&&r.package_===""){let n=Vt[r.name];if(n)return{publisher:n.publisher,package_:n.package_,name:r.name}}return r}}return null}function F(l,e){return or.has(`${l}/${e}`)}var w=class l{static getTypeUri(e){return _(e)}static isCoreOntologyType(e){return F(e.publisher,e.package_)}static isClassType(e){let t=_(e);return t?F(t.publisher,t.package_)&&t.name==="Class":!1}static isDatatypeType(e){let t=_(e);return t?F(t.publisher,t.package_)&&t.name==="Datatype":!1}static isDatatypePropertyType(e){let t=_(e);return t?F(t.publisher,t.package_)&&t.name==="DatatypeProperty":!1}static isObjectPropertyType(e){let t=_(e);return t?F(t.publisher,t.package_)&&t.name==="ObjectProperty":!1}static isAnnotationPropertyType(e){let t=_(e);return t?F(t.publisher,t.package_)&&t.name==="AnnotationProperty":!1}static isGenericPropertyType(e){let t=_(e);return t?F(t.publisher,t.package_)&&t.name==="Property":!1}static isAnyPropertyType(e){let t=_(e);return!t||!F(t.publisher,t.package_)?!1:t.name==="Property"||t.name==="DatatypeProperty"||t.name==="ObjectProperty"||t.name==="AnnotationProperty"}static isSchemaDefinitionType(e){let t=_(e);return!t||!F(t.publisher,t.package_)?!1:t.name==="Class"||t.name==="Property"||t.name==="DatatypeProperty"||t.name==="ObjectProperty"||t.name==="AnnotationProperty"||t.name==="Datatype"}static isInstanceOfKnownClass(e,t){if(l.isSchemaDefinitionType(e))return!1;let r=_(e);return r?t.has(r.name):!1}};var yt=(a=>(a.Class="Class",a.DatatypeProperty="DatatypeProperty",a.ObjectProperty="ObjectProperty",a.AnnotationProperty="AnnotationProperty",a.Instance="Instance",a.Datatype="Datatype",a.Unknown="Unknown",a))(yt||{}),mt=(a=>(a.InstanceOf="instanceOf",a.SubClassOf="subClassOf",a.Domain="domain",a.Range="range",a.ObjectRelationship="objectRelationship",a.SubPropertyOf="subPropertyOf",a.PropertyValue="propertyValue",a))(mt||{}),Be=class{static async buildFromRepository(e){let r=await new Ee().parseKanonaks(e),n=await e.getAllDocumentsAsync(),o=[],s=[],a=new Set,c=new Set,i=new Map;for(let u of r){let y=u;y.name&&(w.isClassType(y)&&a.add(y.name),(w.isObjectPropertyType(y)||w.isGenericPropertyType(y))&&c.add(y.name))}for(let u of n)for(let[y,m]of Object.entries(u.body))c.has(y)&&m?.range&&typeof m.range=="string"&&i.set(y,m.range);let p=new Map;for(let u of r){let y=u;y.name&&p.set(y.name,y)}for(let u of n){let y=u.metadata.namespace_,m=y?`${y.publisher}/${y.package_}`:"",f=y?.version?`${y.version.major}.${y.version.minor}.${y.version.patch}`:"",d=$t(u);for(let[g,h]of Object.entries(u.body)){if(!h||typeof h!="object")continue;let b=p.get(g),R="Unknown";if(b){let $=b;w.isClassType($)?R="Class":w.isObjectPropertyType($)?R="ObjectProperty":w.isDatatypePropertyType($)?R="DatatypeProperty":w.isAnnotationPropertyType($)?R="AnnotationProperty":w.isDatatypeType($)?R="Datatype":w.isGenericPropertyType($)?R="ObjectProperty":w.isInstanceOfKnownClass($,a)&&(R="Instance")}let v=m&&f?`${m}/${g}@${f}`:g,D={};for(let[$,ct]of Object.entries(h))$!=="type"&&(typeof ct!="object"||ct===null)&&(D[$]=ct);o.push({id:v,label:h.label??g,type:R,namespace:m,properties:D}),Kt(v,h,R,a,c,s,m,f,d),ut(v,h,c,i,o,s,m,f,d)}}return{nodes:o,edges:s}}static buildFromDocument(e){let t=[],r=[],n=e.metadata.namespace_,o=n?.version?`${n.version.major}.${n.version.minor}.${n.version.patch}`:"",s=n?`${n.publisher}/${n.package_}`:"",a=new Set,c=new Set,i=new Map,p=$t(e);for(let[m,f]of Object.entries(e.body)){let d=f?.type;d&&(ar(d,p)&&a.add(m),ir(d,p)&&(c.add(m),f.range&&typeof f.range=="string"&&i.set(m,f.range)))}for(let[m,f]of Object.entries(e.body)){if(!f||typeof f!="object")continue;let d=f.type,g=cr(d,m,a,p),h=s&&o?`${s}/${m}@${o}`:m,b={};for(let[R,v]of Object.entries(f))R!=="type"&&(typeof v!="object"||v===null)&&(b[R]=v);t.push({id:h,label:f.label??m,type:g,namespace:s,properties:b}),Kt(h,f,g,a,c,r,s,o,p),ut(h,f,c,i,t,r,s,o,p)}let u=new Set(t.map(m=>m.id)),y=r.filter(m=>u.has(m.source)&&u.has(m.target));return{nodes:t,edges:y}}};function $t(l,e){let t=new Map;if(l.metadata?.imports)for(let[r,n]of Object.entries(l.metadata.imports))for(let o of n){let s=o.alias??o.packageName,a=o.version,c=`${a.major}.${a.minor}.${a.patch}`;t.set(s,{publisher:r,package_:o.packageName,version:c})}return t}var jt={"kanonak.org/core-rdf/Class":"Class","kanonak.org/core-owl/Class":"Class","kanonak.org/core-rdfs/Class":"Class","kanonak.org/core-owl/ObjectProperty":"ObjectProperty","kanonak.org/core-owl/DatatypeProperty":"DatatypeProperty","kanonak.org/core-owl/AnnotationProperty":"AnnotationProperty","kanonak.org/core-rdf/Property":"ObjectProperty","kanonak.org/core-rdfs/Datatype":"Datatype"},sr=new Set(["kanonak.org/core-owl/ObjectProperty","kanonak.org/core-owl/DatatypeProperty","kanonak.org/core-owl/AnnotationProperty","kanonak.org/core-rdf/Property"]);function ft(l,e){if(l.includes(".")){let t=l.indexOf("."),r=l.substring(0,t),n=l.substring(t+1),o=e.get(r);if(o)return`${o.publisher}/${o.package_}/${n}`}return null}function ar(l,e){let t=ft(l,e);return t?jt[t]==="Class":!1}function ir(l,e){let t=ft(l,e);return t?sr.has(t):!1}function cr(l,e,t,r){if(!l||l==="Package")return"Unknown";let n=ft(l,r);if(n){let s=jt[n];if(s)return s;let a=n.split("/").pop()?.split("@")[0]??"";return t.has(a)?"Instance":"Unknown"}let o=l.split(".").pop()??l;return t.has(o)?"Instance":"Unknown"}var Et=new Set(["type","label","comment","version","publisher","imports","license","match","alias","package"]);function Kt(l,e,t,r,n,o,s,a,c){let i=e.type,p=e.subClassOf;if(p){let f=Array.isArray(p)?p:[p];for(let d of f)typeof d=="string"&&o.push({source:l,target:J(d,s,a,c),type:"subClassOf",label:"subClassOf"})}let u=e.subPropertyOf;if(u){let f=Array.isArray(u)?u:[u];for(let d of f)typeof d=="string"&&o.push({source:l,target:J(d,s,a,c),type:"subPropertyOf",label:"subPropertyOf"})}if(t==="Instance"&&i){let f=i.split(".").pop()??i;o.push({source:l,target:J(f,s,a,c),type:"instanceOf",label:"type"})}if(t==="Instance")for(let[f,d]of Object.entries(e)){if(Et.has(f)||!n.has(f))continue;let g=Array.isArray(d)?d:[d];for(let h of g)typeof h=="string"&&pr(h)&&o.push({source:l,target:J(h,s,a,c),type:"propertyValue",label:f,propertyId:J(f,s,a,c)})}let y=t==="ObjectProperty"||t==="DatatypeProperty",m=e.domain&&e.range;if((y||m)&&e.domain&&e.range){let f=typeof e.domain=="string"?e.domain:null,d=typeof e.range=="string"?e.range:null;f&&d&&o.push({source:J(f,s,a,c),target:J(d,s,a,c),type:"objectRelationship",label:e.label??l.split("/").pop()??"",propertyId:l})}}function ut(l,e,t,r,n,o,s,a,c){for(let[i,p]of Object.entries(e)){if(Et.has(i)||typeof p!="object"||p===null||Array.isArray(p))continue;let u=p,y=`${l}/${i}`,m=r.get(i),f=m?m.split(".").pop()??m:"Unknown",d={};for(let[h,b]of Object.entries(u))(typeof b!="object"||b===null)&&(d[h]=b);n.push({id:y,label:`${f} (embedded)`,type:"Instance",namespace:s,properties:d});let g=s&&a?`${s}/${i}@${a}`:i;o.push({source:l,target:y,type:"propertyValue",label:i,propertyId:t.has(i)?g:void 0}),m&&o.push({source:y,target:J(f,s,a,c),type:"instanceOf",label:"type (inferred)"}),ut(y,u,t,r,n,o,s,a,c)}}function pr(l){return!(!l||l.includes(" ")||l.includes(`
|
|
2
|
-
`)||
|
|
1
|
+
var rr=Object.defineProperty;var nr=(p,e)=>()=>(p&&(e=p(p=0)),e);var or=(p,e)=>{for(var t in e)rr(p,t,{get:e[t],enumerable:!0})};var Dt={};or(Dt,{KanonakUri:()=>$});function sr(p,e,t){return{major:p,minor:e,patch:t,toString:()=>`${p}.${e}.${t}`,equals:r=>!r||typeof r!="object"?!1:r.major===p&&r.minor===e&&r.patch===t,getHashCode:()=>p<<20|e<<10|t,compareTo:r=>p!==r.major?p-r.major:e!==r.minor?e-r.minor:t-r.patch}}var $,te=nr(()=>{"use strict";$=class p{constructor(e,t,r,n){this.publisher=e;this.package_=t;this.name=r;this.version=n}publisher;package_;name;version;static parse(e){if(!e||e.trim().length===0)throw new Error("Kanonak URI string cannot be null or empty");let t=e.split("/");if(t.length!==3)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let[r,n,o]=t;if(!r||!n||!o)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let s=n.indexOf("@");if(s===-1)return new p(r,n,o,void 0);let a=n.substring(0,s),i=n.substring(s+1);if(!a||!i)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let c=i.split(".").map(Number),l=sr(c[0]||0,c[1]||0,c[2]||0);return new p(r,a,o,l)}toString(){return this.version?`${this.publisher}/${this.package_}@${this.version.major}.${this.version.minor}.${this.version.patch}/${this.name}`:`${this.publisher}/${this.package_}/${this.name}`}}});import*as Ue from"js-yaml";var E=class{parse(e){let t=this.parseWithErrors(e);if(!t.isValid){let r=t.errors[0];throw new Error(`YAML parse error at line ${r.line}, column ${r.column}: ${r.message}`)}return t.document}parseWithErrors(e){let t=[],r;try{e=e.replace(/^\uFEFF/,"");let n=Ue.load(e);if(!n||typeof n!="object")return r={metadata:this.createEmptyMetadata(),body:{},toString:()=>"KanonakDocument(empty)"},{document:r,errors:t,isValid:!0};let o=this.extractMetadata(n),s=this.extractBody(n,o);return r={metadata:o,body:s,toString:function(){return this.metadata.namespace_?`KanonakDocument(${this.metadata.namespace_.publisher}/${this.metadata.namespace_.package_})`:"KanonakDocument(no namespace)"}},{document:r,errors:t,isValid:!0}}catch(n){let o=n,s={message:o.message||"Unknown parse error",line:o.mark?.line??0,column:o.mark?.column??0,errorType:o.name==="YAMLException"?"SyntaxError":"Unknown",toString:()=>`${o.name==="YAMLException"?"SyntaxError":"Unknown"} at line ${o.mark?.line??0}: ${o.message||"Unknown parse error"}`};return t.push(s),{document:void 0,errors:t,isValid:!1}}}save(e){let t={};if(e.metadata.namespace_){let r=e.metadata.namespace_,n={type:"Package",publisher:r.publisher};r.version&&(n.version=`${r.version.major}.${r.version.minor}.${r.version.patch}`),e.metadata.imports&&(n.imports=this.serializeImports(e.metadata.imports)),t[r.package_]=n}return Object.assign(t,e.body),Ue.dump(t,{indent:2,noRefs:!0,sortKeys:!1})}createEmptyMetadata(){return{get allImports(){return[]}}}addAllImportsGetter(e){let t=e.imports;return Object.defineProperty(e,"allImports",{get:function(){if(!t)return[];let r=[];for(let n of Object.values(t))r.push(...n);return r},enumerable:!0,configurable:!0}),e}createVersion(e,t,r){return{major:e,minor:t,patch:r,toString:()=>`${e}.${t}.${r}`,equals:o=>!o||typeof o!="object"?!1:o.major===e&&o.minor===t&&o.patch===r,getHashCode:()=>e<<20|t<<10|r,compareTo:o=>e!==o.major?e-o.major:t!==o.minor?t-o.minor:r-o.patch}}extractMetadata(e){let t=this.createEmptyMetadata();for(let[r,n]of Object.entries(e))if(n&&typeof n=="object"&&n.type==="Package"){t.type_="Package";let o=r,s=n.publisher,a=n.version?this.parseVersion(n.version):void 0;return s&&o&&(t.namespace_={publisher:s,package_:o,version:a,toString:function(){return`${this.publisher}/${this.package_}@${this.version?.major??1}.${this.version?.minor??0}.${this.version?.patch??0}`},equals:i=>!i||typeof i!="object"?!1:i.publisher===s&&i.package_===o&&(!a||!i.version||a.equals(i.version)),getHashCode:()=>{let i=0;for(let c=0;c<s.length;c++)i=(i<<5)-i+s.charCodeAt(c);for(let c=0;c<o.length;c++)i=(i<<5)-i+o.charCodeAt(c);return i|0}}),n.imports&&Array.isArray(n.imports)&&(t.imports=this.parseImportsV3(n.imports)),this.addAllImportsGetter(t)}if(e.kanonak&&typeof e.kanonak=="object"){let r=e.kanonak;return(r.publisher||r.package||r.version)&&(t.namespace_=this.parseNamespace(r)),r.imports&&typeof r.imports=="object"&&(t.imports=this.parseImportsLegacy(r.imports)),this.addAllImportsGetter(t)}return t}extractBody(e,t){let r={},n;for(let[o,s]of Object.entries(e))if(s&&typeof s=="object"&&s.type==="Package"){n=o;break}for(let[o,s]of Object.entries(e))o!==n&&o!=="kanonak"&&o!=="namespace"&&o!=="imports"&&(r[o]=s);return r}parseNamespace(e){if(typeof e=="string"){let o=e.match(/^([^/]+)\/([^@]+)(?:@(.+))?$/);if(o){let s=o[3]?this.parseVersion(o[3]):this.createVersion(1,0,0);return{publisher:o[1],package_:o[2],version:s,toString:()=>e,equals:a=>!a||typeof a!="object"?!1:a.publisher===o[1]&&a.package_===o[2]&&(!s||!a.version||s.equals(a.version)),getHashCode:()=>{let a=0;for(let i=0;i<o[1].length;i++)a=(a<<5)-a+o[1].charCodeAt(i);for(let i=0;i<o[2].length;i++)a=(a<<5)-a+o[2].charCodeAt(i);return a|0}}}}let t=e.publisher||"",r=e.package||"",n=e.version?this.parseVersion(e.version):this.createVersion(1,0,0);return{publisher:t,package_:r,version:n,toString:function(){return`${this.publisher}/${this.package_}@${this.version?.major??1}.${this.version?.minor??0}.${this.version?.patch??0}`},equals:o=>!o||typeof o!="object"?!1:o.publisher===t&&o.package_===r&&(!n||!o.version||n.equals(o.version)),getHashCode:()=>{let o=0;for(let s=0;s<t.length;s++)o=(o<<5)-o+t.charCodeAt(s);for(let s=0;s<r.length;s++)o=(o<<5)-o+r.charCodeAt(s);return o|0}}}parseVersion(e){if(typeof e=="string"){let t=e.split(".").map(Number);return this.createVersion(t[0]||0,t[1]||0,t[2]||0)}return this.createVersion(e.major||0,e.minor||0,e.patch||0)}parseImportsV3(e){let t={};for(let r of e)if(!(!r||typeof r!="object"))if(r.packages&&Array.isArray(r.packages)){let n=r.publisher;if(!n)throw new Error("PublisherImport requires 'publisher' property");t[n]||(t[n]=[]);for(let o of r.packages){if(!o||typeof o!="object")continue;let s=this.parseImportFromEmbeddedObject(o,n);t[n].push(s)}}else{let n=this.parseImportFromEmbeddedObject(r,r.publisher),o=n.publisher||"";t[o]||(t[o]=[]),t[o].push(n)}return t}parseImportsLegacy(e){let t={};for(let[r,n]of Object.entries(e))Array.isArray(n)&&(t[r]=n.map(o=>this.parseImport(o,r)));return t}parseImportFromEmbeddedObject(e,t){let r=e.package;if(!r)throw new Error("Import requires 'package' property");let n=e.match;if(!n)throw new Error("Import requires 'match' property");let o=e.version;if(!o)throw new Error("Import requires 'version' property");let s=this.parseVersion(o),a=this.parseVersionOperator(n),i=this.calculateMaxVersion(n,s),c=e.alias;return{package_:`${r} ${n} ${s.toString()}`,publisher:t,packageName:r,versionOperator:a,version:s,alias:c,minVersion:s,maxVersion:i,toEmbeddedObject:()=>{let l={package:r,match:n,version:s.toString()};return c&&(l.alias=c),l},toString:()=>c?`${r} ${n} ${s.toString()} as ${c}`:`${r} ${n} ${s.toString()}`}}parseImport(e,t){if(typeof e=="string"){let i=e.match(/^(.+?)\s*([~^=*])\s*(\S+)\s+as\s+(\S+)$/);if(i){let l=i[1].trim(),u=i[2],m=this.parseVersion(i[3].trim()),y=i[4].trim(),f=this.parseVersionOperator(u),d=this.calculateMaxVersion(u,m);return{package_:e,publisher:t,packageName:l,versionOperator:f,version:m,alias:y,minVersion:m,maxVersion:d,toEmbeddedObject:()=>{let g={package:l,match:u,version:m.toString()};return y&&(g.alias=y),g},toString:()=>`${l} ${u} ${m.toString()} as ${y}`}}let c=e.match(/^(.+?)\s*([~^=*])\s*(.+)$/);if(c){let l=c[1].trim(),u=c[2],m=this.parseVersion(c[3].trim()),y=this.parseVersionOperator(u),f=this.calculateMaxVersion(u,m);return{package_:e,publisher:t,packageName:l,versionOperator:y,version:m,alias:void 0,minVersion:m,maxVersion:f,toEmbeddedObject:()=>({package:l,match:u,version:m.toString()}),toString:()=>`${l} ${u} ${m.toString()}`}}}let r=this.parseVersionOperator(e.operator||"~"),n=this.parseVersion(e.version||"1.0.0"),o=e.packageName||e.package||"",s=["=","~","^","*"][r],a=this.calculateMaxVersion(e.operator||"~",n);return{package_:e.package||"",publisher:t,packageName:o,versionOperator:r,version:n,alias:e.alias,minVersion:n,maxVersion:a,toEmbeddedObject:()=>{let i={package:o,match:s,version:n.toString()};return e.alias&&(i.alias=e.alias),i},toString:()=>`${o} ${s} ${n.toString()}`}}parseVersionOperator(e){switch(e){case"=":return 0;case"~":return 1;case"^":return 2;case"*":return 3;default:return 1}}calculateMaxVersion(e,t){switch(e){case"~":return this.createVersion(t.major,t.minor+1,0);case"^":return t.major===0?this.createVersion(0,t.minor+1,0):this.createVersion(t.major+1,0,0);default:return this.createVersion(999,999,999)}}serializeImports(e){let t=[];for(let[r,n]of Object.entries(e)){let o={publisher:r,packages:n.map(s=>{let a=["=","~","^","*"][s.versionOperator],i={package:s.packageName,match:a,version:`${s.version.major}.${s.version.minor}.${s.version.patch}`};return s.alias&&(i.alias=s.alias),i})};t.push(o)}return t}};var U=class{};var Y=class extends U{statement=[]};var C=class extends Y{namespace;name;icon};var T=class extends Y{name};te();var w=class p extends U{subject;static parse(e){let t=new p;return t.subject=$.parse(e),t}};var je=class extends U{value};var x=class{predicate;object};var L=class extends x{};var F=class p extends L{static parse(e,t){let r=new p;return r.predicate=w.parse(e),r.object=t,r}};var re=class p extends L{static parse(e,t){let r=new p;return r.predicate=w.parse(e),r.object=t,r}};var ne=class extends L{};var N=class p extends x{static parse(e,t){let r=new p;return r.predicate=w.parse(e),r.object=w.parse(t),r}};var B=class extends x{};var _=class extends x{};te();function S(p){if(Array.isArray(p))return p.map(t=>t?.toString()??"").filter(t=>t.length>0);let e=p?.toString();return e?[e]:[]}var A=class{cache=new Map;repository;logger;constructor(e,t){this.repository=e,this.logger=t}async resolveEntityAsync(e,t){let r=t.metadata?.namespace_?.toString()??"unknown",n=this.cache.get(r);if(n){let s=n.get(e);if(s)return s}let o=await this.buildEntityIndexAsyncInternal(t,new Set,"");return this.cache.set(r,o),o.get(e)??null}async resolveAllEntitiesAsync(e,t){let r=await this.buildAllEntitiesIndexAsync(t,new Set,"");if(e.includes(".")){let n=e.split("."),o=n[0],s=n[1],a=await this.findDocumentForAlias(t,o);return a?await this.resolveAllEntitiesAsync(s,a):[]}return r.filter(n=>n.entityName===e)}async buildAllEntitiesIndexAsync(e,t,r){let n=[],o=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building ALL entities index for namespace: ${o}`),t.has(o))return this.logger?.debug?.(`Skipping ${o} - already visited (circular import prevention)`),n;t.add(o);let s=r.length===0?o:`${r} \u2192 ${o}`;for(let[a,i]of Object.entries(e.body))if(i&&typeof i=="object"&&!Array.isArray(i)){let c=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};n.push({entityName:a,uri:new $(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,a,c),entity:i,definedInNamespace:o,isImported:r.length>0,importPath:s})}if(this.logger?.debug?.(`Collected ${n.length} entities from ${o}`),e.metadata?.imports){let a=Object.values(e.metadata.imports).reduce((i,c)=>i+c.length,0);this.logger?.debug?.(`Processing ${a} import(s) for ${o}`);for(let[i,c]of Object.entries(e.metadata.imports))for(let l of c)try{this.logger?.debug?.(`Resolving import: ${i}/${l.packageName}`);let u=await this.repository.getHighestCompatibleVersionAsync(i,l);if(u){this.logger?.debug?.(`Successfully loaded import: ${u.metadata?.namespace_?.toString()}`);let m=await this.buildAllEntitiesIndexAsync(u,t,s);n.push(...m),this.logger?.debug?.(`Added ${m.length} entities from import ${u.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${i}/${l.packageName}`)}catch(u){let m=u;throw this.logger?.error?.(`Failed to process import ${i}/${l.packageName} for namespace ${o}. Error: ${m.message}`,m),new Error(`Failed to process import ${i}/${l.packageName} for namespace ${o}. See inner exception for details.`,{cause:u})}}return n}async buildEntityIndexAsync(e){return await this.buildEntityIndexAsyncInternal(e,new Set,"")}async buildEntityIndexAsyncInternal(e,t,r){let n=new Map,o=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building entity index for namespace: ${o}`),t.has(o))return this.logger?.debug?.(`Skipping ${o} - already visited (circular import prevention)`),n;t.add(o);let s=r.length===0?o:`${r} \u2192 ${o}`,a=0;for(let[i,c]of Object.entries(e.body))if(c&&typeof c=="object"&&!Array.isArray(c)&&!n.has(i)){let l=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};n.set(i,{entityName:i,uri:new $(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,i,l),entity:c,definedInNamespace:o,isImported:r.length>0,importPath:s}),a++}if(this.logger?.debug?.(`Indexed ${a} entities from ${o}`),e.metadata?.imports){let i=Object.values(e.metadata.imports).reduce((c,l)=>c+l.length,0);this.logger?.debug?.(`Processing ${i} import(s) for ${o}`);for(let[c,l]of Object.entries(e.metadata.imports))for(let u of l)try{this.logger?.debug?.(`Resolving import: ${c}/${u.packageName}`);let m=await this.repository.getHighestCompatibleVersionAsync(c,u);if(m){this.logger?.debug?.(`Successfully loaded import: ${m.metadata?.namespace_?.toString()}`);let y=await this.buildEntityIndexAsyncInternal(m,t,s),f=0;for(let[d,g]of y.entries())if(n.has(d)||(n.set(d,g),f++),u.alias&&!d.includes(".")){let h=`${u.alias}.${d}`;n.has(h)||(n.set(h,g),f++)}this.logger?.debug?.(`Merged ${f} entities from import ${m.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${c}/${u.packageName}`)}catch(m){let y=m;throw this.logger?.error?.(`Failed to process import ${c}/${u.packageName} for namespace ${o}. Error: ${y.message}`,y),new Error(`Failed to process import ${c}/${u.packageName} for namespace ${o}. See inner exception for details.`,{cause:m})}}return n}async findDocumentForAlias(e,t){if(!e.metadata?.imports)return null;for(let[r,n]of Object.entries(e.metadata.imports))for(let o of n){if(o.alias===t)return await this.repository.getHighestCompatibleVersionAsync(r,o);if(!o.alias&&o.packageName===t)return await this.repository.getHighestCompatibleVersionAsync(r,o)}return null}clearCache(){this.cache.clear()}clearCacheForDocument(e){this.cache.delete(e)}async isSubclassOfAsync(e,t,r){if(e===t)return!0;let n=new Set;return await this.isSubclassOfRecursiveAsync(e,t,r,n)}async isSubclassOfRecursiveAsync(e,t,r,n){if(n.has(e))return!1;n.add(e);let o=await this.resolveEntityAsync(e,r);if(!o?.entity)return!1;let s=o.entity.subClassOf;if(s){let a=S(s);for(let i of a)if(i===t||await this.isSubclassOfRecursiveAsync(i,t,r,n))return!0}return!1}async isSubpropertyOfAsync(e,t,r){if(e===t)return!0;let n=new Set;return await this.isSubpropertyOfRecursiveAsync(e,t,r,n)}async isSubpropertyOfRecursiveAsync(e,t,r,n){if(n.has(e))return!1;n.add(e);let o=await this.resolveEntityAsync(e,r);if(!o?.entity)return!1;let s=o.entity.subPropertyOf;if(s){let a=S(s);for(let i of a)if(i===t||await this.isSubpropertyOfRecursiveAsync(i,t,r,n))return!0}return!1}};var J=class p{static KNOWN_XSD_DATATYPES=new Set(["string","integer","int","boolean","bool","decimal","float","double","date","datetime","time","duration","anyuri","base64binary","hexbinary","long","short","byte","nonnegativeinteger","positiveinteger","negativeinteger","nonpositiveinteger","unsignedint","unsignedlong","unsignedshort","unsignedbyte"]);resourceResolver;constructor(e){this.resourceResolver=e}isXsdDatatype(e){return e?e.publisher==="kanonak.org"&&e.package_==="core.xsd"&&p.KNOWN_XSD_DATATYPES.has(e.name.toLowerCase()):!1}isLiteralType(e){return e?e.publisher==="kanonak.org"&&e.package_==="core.rdf"&&e.name==="Literal":!1}isKnownXsdDatatypeName(e){let t=e.includes(".")?e.split(".")[1]:e;return p.KNOWN_XSD_DATATYPES.has(t.toLowerCase())}async isClassTypeAsync(e,t){if(this.isKnownXsdDatatypeName(e))return!1;let r=await this.resourceResolver.resolveEntityAsync(e,t);if(r){let n=r.entity.type;if(n){let o=String(n);return o==="Class"||o==="rdfs.Class"||o.endsWith(".Class")}}return!0}getPropertyTypeClassification(e){if(!e||e.trim().length===0)return"Property";switch(e.includes(".")?e.split(".")[1]:e){case"DatatypeProperty":return"DatatypeProperty";case"ObjectProperty":return"ObjectProperty";case"AnnotationProperty":return"AnnotationProperty";case"Property":return"Property";default:return"Property"}}isEffectiveDatatypeProperty(e,t){return!!(e==="DatatypeProperty"||e==="Property"&&this.isXsdDatatype(t)||e==="Property"&&this.isLiteralType(t))}isEffectiveObjectProperty(e,t){return!!(e==="ObjectProperty"||e==="Property"&&t&&!this.isXsdDatatype(t)&&!this.isLiteralType(t))}};var Ee=class{constructor(e){}async parseKanonaks(e){let t=[],r=await e.getAllDocumentsAsync(),n=new A(e),o=new J(n);for(let i of r){let c=i.metadata.namespace_?.toString()??"";for(let[l,u]of Object.entries(i.body)){let m=new C,y=this.resolveCanonicalEntity(l,i,c);m.namespace=y.namespace,m.name=y.name,m.statement=[];let f=await this.parseStatements(u,i,n,o,e);m.statement.push(...f),t.push(m)}}let s=new Map,a=[];for(let i of t)if(i instanceof C){let c=`${i.namespace}/${i.name}`,l=s.get(c);l?l.statement.push(...i.statement):(s.set(c,i),a.push(i))}else a.push(i);return a}resolveCanonicalEntity(e,t,r){if(!e.includes(".")||!t.metadata?.imports)return{namespace:r,name:e};let n=e.indexOf("."),o=e.substring(0,n),s=e.substring(n+1);for(let[a,i]of Object.entries(t.metadata.imports))for(let c of i)if((c.alias??c.packageName)===o){let u=c.version;return{namespace:`${a}/${c.packageName}@${u.major}.${u.minor}.${u.patch}`,name:s}}return{namespace:r,name:e}}async parseStatements(e,t,r,n,o){let s=[];if(typeof e!="object"||e===null||Array.isArray(e))return s;for(let[a,i]of Object.entries(e))try{let c=await this.getPropertyMetadata(a,t,r,o,n);if(!c)continue;let l=await this.parsePropertyValue(a,i,c,t,r,n);l&&s.push(l)}catch(c){console.error(`Error parsing property ${a}:`,c)}return s}async getPropertyMetadata(e,t,r,n,o){let s=await r.resolveEntityAsync(e,t);if(!s)return;let a=s.entity,i=a.type?.toString()??"",c=i.includes(".")?i.substring(i.lastIndexOf(".")+1):i;if(!new Set(["Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]).has(c))return;let u=o.getPropertyTypeClassification(i),m=a.range?.toString(),y;if(u==="ObjectProperty")y="ObjectProperty";else if(u==="DatatypeProperty")y="DatatypeProperty";else{let d=m&&m.includes(".")?m.substring(m.lastIndexOf(".")+1):m??"";(m?o.isKnownXsdDatatypeName(m):!1)||d==="Literal"?y="DatatypeProperty":y="ObjectProperty"}return{propertyUri:s.uri.toString(),propertyType:y,range:m,isImported:s.isImported,definedInNamespace:s.definedInNamespace}}async parsePropertyValue(e,t,r,n,o,s){let a=r.propertyUri;if(t!=null){if(Array.isArray(t))return this.parseListValue(a,t,r,n,o,s);if(r.propertyType==="DatatypeProperty")return this.parseDatatypeValue(a,t,r);if(r.propertyType==="ObjectProperty")return this.parseObjectValue(a,t,r,n,o,s)}}parseDatatypeValue(e,t,r){if(t instanceof Date)return F.parse(e,t.toISOString());if(typeof t=="string")return F.parse(e,t);if(typeof t=="number")return re.parse(e,t);if(typeof t=="boolean"){let n=new ne;return n.predicate=w.parse(e),n.object=t,n}}async parseObjectValue(e,t,r,n,o,s){if(typeof t=="string"){let a=await this.resolveReference(t,n,o);if(!a)return;let i=new N;return i.predicate=w.parse(e),i.object=a,i}if(typeof t=="object"&&!Array.isArray(t)){let a=new T;if(a.statement=await this.parseStatements(t,n,o,s,{}),a.statement.length>0){let l=new B;return l.predicate=w.parse(e),l.object=a,l}let i=[];for(let[l,u]of Object.entries(t))if(typeof u=="object"&&u!==null&&!Array.isArray(u)){let m=new T;m.name=l,m.statement=await this.parseStatements(u,n,o,s,{}),i.push(m)}else if(typeof u=="string"){let m=await this.resolveReference(u,n,o);m&&i.push(m)}if(i.length>0){let l=new _;return l.predicate=w.parse(e),l.object=i,l}let c=new B;return c.predicate=w.parse(e),c.object=a,c}}async parseListValue(e,t,r,n,o,s){let a=[],i=r.propertyType==="DatatypeProperty";for(let l of t){if(i&&(typeof l=="string"||typeof l=="number"||typeof l=="boolean")){let u=new je;u.value=l,a.push(u);continue}if(i&&l instanceof Date){let u=new je;u.value=l.toISOString(),a.push(u);continue}if(typeof l=="string"){let u=await this.resolveReference(l,n,o);u&&a.push(u)}else if(typeof l=="object"&&l!==null&&!Array.isArray(l)){let u=new T;u.statement=await this.parseStatements(l,n,o,s,{}),a.push(u)}}let c=new _;return c.predicate=w.parse(e),c.object=a,c}async resolveReference(e,t,r){let n=await r.resolveEntityAsync(e,t);if(n){let s=new w;return s.subject=n.uri,s}let o=t.metadata?.namespace_;if(o){let{KanonakUri:s}=await Promise.resolve().then(()=>(te(),Dt)),a=o.version??{major:0,minor:0,patch:0,toString:()=>"0.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};if(e.includes(".")){let c=e.indexOf("."),l=e.substring(0,c),u=e.substring(c+1);if(t.metadata?.imports){for(let[m,y]of Object.entries(t.metadata.imports))for(let f of y)if((f.alias??f.packageName)===l){let g=new w;return g.subject=new s(m,f.packageName,u,f.version),g}}}let i=new w;return i.subject=new s(o.publisher,o.package_,e,a),i}return null}async saveKanonaks(e,t){let r=new Map;for(let n of e)n instanceof C&&n.namespace&&(r.has(n.namespace)||r.set(n.namespace,[]),r.get(n.namespace).push(n));for(let[n,o]of r){let s=await this.convertKanonaksToDocument(n,o),a=`${n.split("@")[0]}.yml`;await t.saveDocumentAsync(s,a)}}async serializeToYaml(e,t){let r=e.filter(s=>s instanceof C&&s.namespace===t);if(r.length===0)throw new Error(`No kanonaks found with namespace '${t}'`);let n=await this.convertKanonaksToDocument(t,r);return new E().save(n)}async convertKanonaksToDocument(e,t){let n={metadata:{namespace_:e,get allImports(){if(!this.imports)return[];let s=[];for(let a of Object.values(this.imports))s.push(...a);return s}},body:{}},o=new Map;for(let s of t){let a={};for(let i of s.statement){let[c,l]=this.convertStatementToProperty(i);c&&l!==null&&l!==void 0&&(a[c]=l),this.collectImportsFromStatement(i,e,o)}n.body[s.name]=a}return n}convertStatementToProperty(e){if(e instanceof F)return[e.predicate.subject.name,e.object];if(e instanceof re)return[e.predicate.subject.name,e.object];if(e instanceof ne)return[e.predicate.subject.name,e.object];if(e instanceof N)return[e.predicate.subject.name,e.object.subject.name];if(e instanceof _){let t=this.convertKanonakListToValue(e.object);return[e.predicate.subject.name,t]}else if(e instanceof B){let t=this.convertEmbeddedKanonakToValue(e.object);return[e.predicate.subject.name,t]}return[null,null]}convertKanonakListToValue(e){let t=[];for(let r of e)r instanceof w?t.push(r.subject.name):r instanceof T&&t.push(this.convertEmbeddedKanonakToValue(r));return t}convertEmbeddedKanonakToValue(e){let t={};for(let r of e.statement){let[n,o]=this.convertStatementToProperty(r);n&&o!==null&&o!==void 0&&(t[n]=o)}return t}collectImportsFromStatement(e,t,r){}};var Le=class{propertyUri;propertyType;range;isImported;definedInNamespace};import{parseDocument as ar,LineCounter as ir,isMap as xe,isPair as V,isScalar as j,isSeq as Fe}from"yaml";var Oe=class p{entities=new Map;entityBlocks=new Map;properties=new Map;propertyValues=new Map;valueListItems=new Map;importPackages=new Map;nestedKeys=new Map;nestedValues=new Map;static fromContent(e){let t=new p,r=new ir,n=ar(e,{lineCounter:r});if(n.errors.length>0||!xe(n.contents))return t;mt(n.contents,[],r,t);for(let o of n.contents.items){if(!V(o)||!j(o.key))continue;let s=String(o.key.value),a=o.key.range;if(!a)continue;t.entities.set(s,M(a,r));let i=o.value,c=i&&typeof i=="object"&&"range"in i?i.range:void 0;if(c?t.entityBlocks.set(s,M([a[0],a[1],c[2]],r)):t.entityBlocks.set(s,M(a,r)),xe(o.value)){let l=new Map,u=new Map,m=new Map;for(let f of o.value.items){if(!V(f)||!j(f.key))continue;let d=String(f.key.value),g=f.key.range;g&&l.set(d,M(g,r));let h=f.value;if(h&&typeof h=="object"&&"range"in h&&Array.isArray(h.range)){let b=h.range;u.set(d,M(b,r))}if(Fe(h)){let b=[];for(let R of h.items)R&&typeof R=="object"&&"range"in R&&Array.isArray(R.range)&&b.push(M(R.range,r));b.length>0&&m.set(d,b)}}l.size>0&&t.properties.set(s,l),u.size>0&&t.propertyValues.set(s,u),m.size>0&&t.valueListItems.set(s,m);let y=cr(o.value,r);y.length>0&&t.importPackages.set(s,y)}}return t}getEntityPosition(e){return this.entities.get(e)}getEntityBlockPosition(e){return this.entityBlocks.get(e)}findEntityAtPosition(e,t){for(let[r,n]of this.entityBlocks)if(ut(n,e,t))return r}findPropertyAtPosition(e,t){let r=this.findEntityAtPosition(e,t);if(!r)return;let n=this.properties.get(r),o=this.propertyValues.get(r);if(!n&&!o)return{entityName:r};let s,a;if(o)for(let[i,c]of o)ut(c,e,t)&&(!a||St(c,a))&&(s=i,a=c);if(n)for(let[i,c]of n)ut(c,e,t)&&(!a||St(c,a))&&(s=i,a=c);return s?{entityName:r,propertyName:s}:{entityName:r}}getPropertyPosition(e,t){return this.properties.get(e)?.get(t)}getPropertyValuePosition(e,t){return this.propertyValues.get(e)?.get(t)}getImportPackages(e){return this.importPackages.get(e)??[]}getAllImportPackages(){let e=[];for(let[t,r]of this.importPackages)for(let n of r)e.push({entityName:t,entry:n});return e}findPropertySourceName(e,t){let r=this.properties.get(e);if(r){if(r.has(t))return t;for(let n of r.keys()){let o=n.lastIndexOf(".");if((o===-1?n:n.substring(o+1))===t)return n}}}getListItemPosition(e,t,r){let n=this.valueListItems.get(e)?.get(t);if(!(!n||r<0||r>=n.length))return n[r]}getNodeKeyPosition(e){return this.nestedKeys.get(JSON.stringify(e))}getNodeValuePosition(e){return this.nestedValues.get(JSON.stringify(e))}setNestedKeyPosition(e,t){this.nestedKeys.set(e,t)}setNestedValuePosition(e,t){this.nestedValues.set(e,t)}getMostSpecificPosition(e,t,r){if(e){if(t!==void 0){if(r!==void 0){let s=this.getListItemPosition(e,t,r);if(s)return s}let n=this.getPropertyValuePosition(e,t);if(n)return n;let o=this.getPropertyPosition(e,t);if(o)return o}return this.getEntityPosition(e)}}};function cr(p,e){let t=[];if(!xe(p))return t;let r=p.items.find(n=>V(n)&&j(n.key)&&String(n.key.value)==="imports");if(!r||!V(r)||!Fe(r.value))return t;for(let n of r.value.items){if(!xe(n))continue;let o=n.items.find(i=>V(i)&&j(i.key)&&String(i.key.value)==="publisher");if(!o||!V(o)||!j(o.value))continue;let s=String(o.value.value),a=n.items.find(i=>V(i)&&j(i.key)&&String(i.key.value)==="packages");if(!(!a||!V(a)||!Fe(a.value)))for(let i of a.value.items){if(!xe(i))continue;let c=i.items.find(g=>V(g)&&j(g.key)&&String(g.key.value)==="package");if(!c||!V(c)||!j(c.value)||!c.value.range)continue;let l=String(c.value.value),u=i.items.find(g=>V(g)&&j(g.key)&&String(g.key.value)==="version"),m=u&&V(u)&&j(u.value)?String(u.value.value):"",y=i.items.find(g=>V(g)&&j(g.key)&&String(g.key.value)==="alias"),f=y&&V(y)&&j(y.value)?String(y.value.value):void 0,d=f!==void 0?{publisher:s,package_:l,version:m,alias:f,position:M(c.value.range,e)}:{publisher:s,package_:l,version:m,position:M(c.value.range,e)};t.push(d)}}return t}function ut(p,e,t){return!(e<p.line||e>p.endLine||e===p.line&&t<p.column||e===p.endLine&&t>p.endColumn)}function St(p,e){let t=p.endLine-p.line,r=e.endLine-e.line;if(t!==r)return t<r;let n=p.endLine===p.line?p.endColumn-p.column:Number.MAX_SAFE_INTEGER,o=e.endLine===e.line?e.endColumn-e.column:Number.MAX_SAFE_INTEGER;return n<o}function mt(p,e,t,r){if(xe(p)){for(let n of p.items){if(!V(n)||!j(n.key))continue;let o=String(n.key.value),s=[...e,o],a=JSON.stringify(s);n.key.range&&r.setNestedKeyPosition(a,M(n.key.range,t));let i=n.value,c=Vt(i);c&&r.setNestedValuePosition(a,M(c,t)),mt(i,s,t,r)}return}if(Fe(p)){for(let n=0;n<p.items.length;n++){let o=p.items[n],s=[...e,n],a=JSON.stringify(s),i=Vt(o);i&&r.setNestedValuePosition(a,M(i,t)),mt(o,s,t,r)}return}}function Vt(p){if(!p||typeof p!="object"||!("range"in p))return;let e=p.range;return Array.isArray(e)&&e.length>=3?e:void 0}function M(p,e){let t=e.linePos(p[0]),r=e.linePos(p[2]);return{line:t.line-1,column:t.col-1,endLine:r.line-1,endColumn:r.col-1}}function Kt(p,e){let r=(e??new E).parse(p),n=Oe.fromContent(p);return{document:r,positions:n}}var pr=new Set(["kanonak.org/core-rdf","kanonak.org/core-rdfs","kanonak.org/core-owl","kanonak.org/core-xsd","kanonak.org/core-kanonak"]),$t={Class:{publisher:"kanonak.org",package_:"core-owl"},ObjectProperty:{publisher:"kanonak.org",package_:"core-owl"},DatatypeProperty:{publisher:"kanonak.org",package_:"core-owl"},AnnotationProperty:{publisher:"kanonak.org",package_:"core-owl"},Property:{publisher:"kanonak.org",package_:"core-rdf"},Datatype:{publisher:"kanonak.org",package_:"core-rdfs"},Resource:{publisher:"kanonak.org",package_:"core-rdfs"},Literal:{publisher:"kanonak.org",package_:"core-rdfs"},Thing:{publisher:"kanonak.org",package_:"core-owl"},Nothing:{publisher:"kanonak.org",package_:"core-owl"}};function W(p){let e=p;if(e.entity&&typeof e.entity=="object"){let t=e.entity.type;if(typeof t=="string"){let r=$t[t];return r?{publisher:r.publisher,package_:r.package_,name:t}:{publisher:"",package_:"",name:t}}}if(e.statement&&Array.isArray(e.statement)){for(let t of e.statement)if(t.predicate?.subject?.name==="type"&&t.object?.subject){let r=t.object.subject;if(!r.publisher&&!r.package_||r.publisher===""&&r.package_===""){let n=$t[r.name];if(n)return{publisher:n.publisher,package_:n.package_,name:r.name}}return r}}return null}function G(p,e){return pr.has(`${p}/${e}`)}var I=class p{static getTypeUri(e){return W(e)}static isCoreOntologyType(e){return G(e.publisher,e.package_)}static isClassType(e){let t=W(e);return t?G(t.publisher,t.package_)&&t.name==="Class":!1}static isDatatypeType(e){let t=W(e);return t?G(t.publisher,t.package_)&&t.name==="Datatype":!1}static isDatatypePropertyType(e){let t=W(e);return t?G(t.publisher,t.package_)&&t.name==="DatatypeProperty":!1}static isObjectPropertyType(e){let t=W(e);return t?G(t.publisher,t.package_)&&t.name==="ObjectProperty":!1}static isAnnotationPropertyType(e){let t=W(e);return t?G(t.publisher,t.package_)&&t.name==="AnnotationProperty":!1}static isGenericPropertyType(e){let t=W(e);return t?G(t.publisher,t.package_)&&t.name==="Property":!1}static isAnyPropertyType(e){let t=W(e);return!t||!G(t.publisher,t.package_)?!1:t.name==="Property"||t.name==="DatatypeProperty"||t.name==="ObjectProperty"||t.name==="AnnotationProperty"}static isSchemaDefinitionType(e){let t=W(e);return!t||!G(t.publisher,t.package_)?!1:t.name==="Class"||t.name==="Property"||t.name==="DatatypeProperty"||t.name==="ObjectProperty"||t.name==="AnnotationProperty"||t.name==="Datatype"}static isInstanceOfKnownClass(e,t){if(p.isSchemaDefinitionType(e))return!1;let r=W(e);return r?t.has(r.name):!1}};var ft=(a=>(a.Class="Class",a.DatatypeProperty="DatatypeProperty",a.ObjectProperty="ObjectProperty",a.AnnotationProperty="AnnotationProperty",a.Instance="Instance",a.Datatype="Datatype",a.Unknown="Unknown",a))(ft||{}),dt=(a=>(a.InstanceOf="instanceOf",a.SubClassOf="subClassOf",a.Domain="domain",a.Range="range",a.ObjectRelationship="objectRelationship",a.SubPropertyOf="subPropertyOf",a.PropertyValue="propertyValue",a))(dt||{}),Be=class{static async buildFromRepository(e){let r=await new Ee().parseKanonaks(e),n=await e.getAllDocumentsAsync(),o=[],s=[],a=new Set,i=new Set,c=new Map;for(let u of r){let m=u;m.name&&(I.isClassType(m)&&a.add(m.name),(I.isObjectPropertyType(m)||I.isGenericPropertyType(m))&&i.add(m.name))}for(let u of n)for(let[m,y]of Object.entries(u.body))i.has(m)&&y?.range&&typeof y.range=="string"&&c.set(m,y.range);let l=new Map;for(let u of r){let m=u;m.name&&l.set(m.name,m)}for(let u of n){let m=u.metadata.namespace_,y=m?`${m.publisher}/${m.package_}`:"",f=m?.version?`${m.version.major}.${m.version.minor}.${m.version.patch}`:"",d=jt(u);for(let[g,h]of Object.entries(u.body)){if(!h||typeof h!="object")continue;let b=l.get(g),R="Unknown";if(b){let K=b;I.isClassType(K)?R="Class":I.isObjectPropertyType(K)?R="ObjectProperty":I.isDatatypePropertyType(K)?R="DatatypeProperty":I.isAnnotationPropertyType(K)?R="AnnotationProperty":I.isDatatypeType(K)?R="Datatype":I.isGenericPropertyType(K)?R="ObjectProperty":I.isInstanceOfKnownClass(K,a)&&(R="Instance")}let v=y&&f?`${y}/${g}@${f}`:g,D={};for(let[K,lt]of Object.entries(h))K!=="type"&&(typeof lt!="object"||lt===null)&&(D[K]=lt);o.push({id:v,label:h.label??g,type:R,namespace:y,properties:D}),Et(v,h,R,a,i,s,y,f,d),yt(v,h,i,c,o,s,y,f,d)}}return{nodes:o,edges:s}}static buildFromDocument(e){let t=[],r=[],n=e.metadata.namespace_,o=n?.version?`${n.version.major}.${n.version.minor}.${n.version.patch}`:"",s=n?`${n.publisher}/${n.package_}`:"",a=new Set,i=new Set,c=new Map,l=jt(e);for(let[y,f]of Object.entries(e.body)){let d=f?.type;d&&(ur(d,l)&&a.add(y),mr(d,l)&&(i.add(y),f.range&&typeof f.range=="string"&&c.set(y,f.range)))}for(let[y,f]of Object.entries(e.body)){if(!f||typeof f!="object")continue;let d=f.type,g=yr(d,y,a,l),h=s&&o?`${s}/${y}@${o}`:y,b={};for(let[R,v]of Object.entries(f))R!=="type"&&(typeof v!="object"||v===null)&&(b[R]=v);t.push({id:h,label:f.label??y,type:g,namespace:s,properties:b}),Et(h,f,g,a,i,r,s,o,l),yt(h,f,i,c,t,r,s,o,l)}let u=new Set(t.map(y=>y.id)),m=r.filter(y=>u.has(y.source)&&u.has(y.target));return{nodes:t,edges:m}}};function jt(p,e){let t=new Map;if(p.metadata?.imports)for(let[r,n]of Object.entries(p.metadata.imports))for(let o of n){let s=o.alias??o.packageName,a=o.version,i=`${a.major}.${a.minor}.${a.patch}`;t.set(s,{publisher:r,package_:o.packageName,version:i})}return t}var xt={"kanonak.org/core-rdf/Class":"Class","kanonak.org/core-owl/Class":"Class","kanonak.org/core-rdfs/Class":"Class","kanonak.org/core-owl/ObjectProperty":"ObjectProperty","kanonak.org/core-owl/DatatypeProperty":"DatatypeProperty","kanonak.org/core-owl/AnnotationProperty":"AnnotationProperty","kanonak.org/core-rdf/Property":"ObjectProperty","kanonak.org/core-rdfs/Datatype":"Datatype"},lr=new Set(["kanonak.org/core-owl/ObjectProperty","kanonak.org/core-owl/DatatypeProperty","kanonak.org/core-owl/AnnotationProperty","kanonak.org/core-rdf/Property"]);function gt(p,e){if(p.includes(".")){let t=p.indexOf("."),r=p.substring(0,t),n=p.substring(t+1),o=e.get(r);if(o)return`${o.publisher}/${o.package_}/${n}`}return null}function ur(p,e){let t=gt(p,e);return t?xt[t]==="Class":!1}function mr(p,e){let t=gt(p,e);return t?lr.has(t):!1}function yr(p,e,t,r){if(!p||p==="Package")return"Unknown";let n=gt(p,r);if(n){let s=xt[n];if(s)return s;let a=n.split("/").pop()?.split("@")[0]??"";return t.has(a)?"Instance":"Unknown"}let o=p.split(".").pop()??p;return t.has(o)?"Instance":"Unknown"}var Ot=new Set(["type","label","comment","version","publisher","imports","license","match","alias","package"]);function Et(p,e,t,r,n,o,s,a,i){let c=e.type,l=e.subClassOf;if(l){let f=Array.isArray(l)?l:[l];for(let d of f)typeof d=="string"&&o.push({source:p,target:Z(d,s,a,i),type:"subClassOf",label:"subClassOf"})}let u=e.subPropertyOf;if(u){let f=Array.isArray(u)?u:[u];for(let d of f)typeof d=="string"&&o.push({source:p,target:Z(d,s,a,i),type:"subPropertyOf",label:"subPropertyOf"})}if(t==="Instance"&&c){let f=c.split(".").pop()??c;o.push({source:p,target:Z(f,s,a,i),type:"instanceOf",label:"type"})}if(t==="Instance")for(let[f,d]of Object.entries(e)){if(Ot.has(f)||!n.has(f))continue;let g=Array.isArray(d)?d:[d];for(let h of g)typeof h=="string"&&fr(h)&&o.push({source:p,target:Z(h,s,a,i),type:"propertyValue",label:f,propertyId:Z(f,s,a,i)})}let m=t==="ObjectProperty"||t==="DatatypeProperty",y=e.domain&&e.range;if((m||y)&&e.domain&&e.range){let f=typeof e.domain=="string"?e.domain:null,d=typeof e.range=="string"?e.range:null;f&&d&&o.push({source:Z(f,s,a,i),target:Z(d,s,a,i),type:"objectRelationship",label:e.label??p.split("/").pop()??"",propertyId:p})}}function yt(p,e,t,r,n,o,s,a,i){for(let[c,l]of Object.entries(e)){if(Ot.has(c)||typeof l!="object"||l===null||Array.isArray(l))continue;let u=l,m=`${p}/${c}`,y=r.get(c),f=y?y.split(".").pop()??y:"Unknown",d={};for(let[h,b]of Object.entries(u))(typeof b!="object"||b===null)&&(d[h]=b);n.push({id:m,label:`${f} (embedded)`,type:"Instance",namespace:s,properties:d});let g=s&&a?`${s}/${c}@${a}`:c;o.push({source:p,target:m,type:"propertyValue",label:c,propertyId:t.has(c)?g:void 0}),y&&o.push({source:m,target:Z(f,s,a,i),type:"instanceOf",label:"type (inferred)"}),yt(m,u,t,r,n,o,s,a,i)}}function fr(p){return!(!p||p.includes(" ")||p.includes(`
|
|
2
|
+
`)||p.startsWith("http://")||p.startsWith("https://")||/^\d{4}-\d{2}/.test(p)||/^\d+(\.\d+)?$/.test(p))}function Z(p,e,t,r){if(p.includes("@")&&p.includes("/"))return p;if(p.includes(".")){let n=p.indexOf("."),o=p.substring(0,n),s=p.substring(n+1);if(r){let a=r.get(o);if(a)return`${a.publisher}/${a.package_}/${s}@${a.version}`}return e&&t?`${e}/${s}@${t}`:s}return e&&t?`${e}/${p}@${t}`:p}var oe=class{isValid=!1;errors=[];warnings=[];get totalIssues(){return this.errors.length+this.warnings.length}};var P=(t=>(t.Warning="Warning",t.Error="Error",t))(P||{});var k=class{ruleType="";severity="Error";lineNumber;column;entityName;propertyName;propertyPath;message="";suggestion;actualValue;expectedValue;toString(){let e="";return this.lineNumber!==void 0&&(e+=`Line ${this.lineNumber}: `),this.entityName&&(e+=`[${this.entityName}] `),e+=this.message,e}};var We=class p{resolvedDocuments=[];currentEntityPath;withPath(e){let t=new p;return t.resolvedDocuments=this.resolvedDocuments,t.currentEntityPath=e,t}};var se=class p{static NAMESPACE_PREFIX_PATTERN=/^(rdfs|xsd|owl|rdf|dc|foaf|skos|dct|dcterms|geo|time|prov|schema|og|dbo):/i;ruleName="NamespacePrefix";validate(e){let t=[];for(let[r,n]of Object.entries(e.body))n&&typeof n=="object"&&!Array.isArray(n)&&this.validateEntity(r,n,t);return t}validateEntity(e,t,r){for(let[n,o]of Object.entries(t)){let s=o?.toString()??"";if(s&&p.NAMESPACE_PREFIX_PATTERN.test(s)){let a=this.getSuggestionForPrefixedValue(s),i=e.split(".")[0],c=new k;c.ruleType=this.ruleName,c.severity="Error",c.entityName=i,c.propertyName=e,c.actualValue=n,c.expectedValue=a,c.message=`Invalid namespace prefix '${s}'. Use '${a}' without prefix.`,c.suggestion="Kanonak YAML uses simple type names. Namespace resolution is handled through imports.",r.push(c)}o&&typeof o=="object"&&!Array.isArray(o)&&this.validateEntity(`${e}.${n}`,o,r)}}getSuggestionForPrefixedValue(e){let t=e.toLowerCase();if(t==="rdfs:class"||t==="owl:class")return"Class";if(t==="rdfs:property"||t==="rdf:property")return"DatatypeProperty or ObjectProperty";if(t.startsWith("xsd:"))return e.substring(4);let r=e.indexOf(":");return r>=0?e.substring(r+1):e}};var ae=class p{static RESERVED_WORDS=new Set(["kanonak","imports","namespace","type","label","comment","subclassof","domain","range","required","functional"]);static VALID_PROPERTIES=new Set(["type","label","comment","subClassOf","subPropertyOf","domain","range","required","functional","inverseOf","transitive","symmetric","inverseFunctional"]);static VALID_NAME_PATTERN=/^[a-zA-Z][a-zA-Z0-9_-]*$/;static VALID_PROPERTY_NAME_PATTERN=/^[a-zA-Z][a-zA-Z0-9_.]*$/;ruleName="ResourceNaming";validate(e){let t=[],r=e.metadata?.namespace_?.publisher==="kanonak.org"&&e.metadata?.namespace_?.package_?.startsWith("core-");for(let[n,o]of Object.entries(e.body)){if(!r&&p.RESERVED_WORDS.has(n.toLowerCase())){let s=new k;s.ruleType=this.ruleName,s.severity="Error",s.entityName=n,s.message=`Entity name '${n}' is a reserved word and cannot be used.`,s.suggestion="Choose a different name that doesn't conflict with Kanonak reserved words.",t.push(s);continue}if(!p.VALID_NAME_PATTERN.test(n)){let s;/^\d/.test(n)?s="Entity names must start with a letter, not a number.":n.includes(" ")?s="Entity names cannot contain spaces. Use camelCase or underscores instead.":s="Entity names must start with a letter and contain only letters, numbers, and underscores.";let a=new k;a.ruleType=this.ruleName,a.severity="Error",a.entityName=n,a.message=`Invalid entity name '${n}'. ${s}`,a.suggestion=s,t.push(a)}o&&typeof o=="object"&&!Array.isArray(o)&&this.validatePropertyNames(n,o,t)}return t}validatePropertyNames(e,t,r){for(let n of Object.keys(t))if(!p.VALID_PROPERTIES.has(n)&&!p.VALID_PROPERTY_NAME_PATTERN.test(n)){let o=new k;o.ruleType=this.ruleName,o.severity="Warning",o.entityName=e,o.propertyName=n,o.message=`Property name '${n}' in entity '${e}' doesn't follow naming conventions.`,o.suggestion="Property names should start with a letter and contain only letters, numbers, and underscores.",r.push(o)}}};var ie=class p{static XSD_TYPES=new Set(["string","integer","int","long","short","byte","decimal","float","double","boolean","bool","datetime","date","time","duration","anyuri","anysimpletype","nonnegativeinteger","positiveinteger","negativeinteger","nonpositiveinteger","unsignedint","unsignedlong","unsignedshort","unsignedbyte","base64binary","hexbinary"]);ruleName="PropertyTypeSpecificity";validate(e){let t=[];if(e.metadata?.namespace_?.publisher==="kanonak.org"&&e.metadata?.namespace_?.package_?.startsWith("core-"))return t;let r=this.isPropertyDefinedAsClass(e);for(let[n,o]of Object.entries(e.body))if(o&&typeof o=="object"&&!Array.isArray(o)){let s=o,a=s.type;if(a){let i=[];if(Array.isArray(a))for(let c of a){let l=c?.toString();l&&l==="Property"&&!r&&i.push(l)}else{let c=a?.toString();c&&c==="Property"&&!r&&i.push(c)}for(let c of i){let l=this.getPropertyValue(s,"range"),u=this.determinePropertyType(l),m=new k;m.ruleType=this.ruleName,m.severity="Error",m.entityName=n,m.propertyName="type",m.actualValue=c,m.expectedValue=u,m.message=`Invalid property type '${c}'. Use '${u}' instead.`,m.suggestion="Properties should specify their type: DatatypeProperty for data values, ObjectProperty for relationships.",t.push(m)}}}return t}determinePropertyType(e){return!e||e.trim().length===0?"DatatypeProperty or ObjectProperty":p.XSD_TYPES.has(e.toLowerCase())?"DatatypeProperty":/^[A-Z]/.test(e)?"ObjectProperty":"DatatypeProperty or ObjectProperty"}getPropertyValue(e,t){let r=e[t];return r?r.toString():null}isPropertyDefinedAsClass(e){let t=e.body.Property;if(t&&typeof t=="object"&&!Array.isArray(t)){let n=t.type;if(n){let o=n.toString();return o==="Class"||o.endsWith(".Class")}}return!1}};var ce=class{get ruleName(){return"SubjectKanonakTypeRequired"}validate(e){let t=[];for(let[r,n]of Object.entries(e.body)){if(typeof n!="object"||n===null||Array.isArray(n))continue;let o=n,s="type"in o,a=o.type?.toString().trim();if(!s||!a){let i=new k;i.ruleType=this.ruleName,i.severity="Error",i.entityName=r,i.propertyName="type",i.message=`Subject Kanonak '${r}' must have a 'type' property.`,i.suggestion=`Add a type statement like:
|
|
3
3
|
type: Scene
|
|
4
4
|
|
|
5
|
-
Only embedded objects can infer type from their parent property's range. Subject Kanonaks (top-level entities) must explicitly declare their type.`,
|
|
5
|
+
Only embedded objects can infer type from their parent property's range. Subject Kanonaks (top-level entities) must explicitly declare their type.`,i.expectedValue="A valid class name (Scene, Character, Story, etc.)",t.push(i)}}return t}};var pe=class{get ruleName(){return"EmbeddedKanonakType"}async validateAsync(e,t){let r=[],n=new A(t),o=await this.buildPropertyRangeMap(e,n);for(let[s,a]of Object.entries(e.body))typeof a=="object"&&a!==null&&!Array.isArray(a)&&await this.checkEmbeddedTypes(s,a,void 0,o,n,e,r,0);return r}async checkEmbeddedTypes(e,t,r,n,o,s,a,i){if(i>0){let c=t.type;if(c!=null){let l=await this.validateEmbeddedType(e,String(c),r,o,s);l&&a.push(l)}}for(let[c,l]of Object.entries(t)){let u=this.localName(c),m=n.has(u)?n.get(u):r;if(typeof l=="object"&&l!==null)if(Array.isArray(l))for(let y=0;y<l.length;y++){let f=l[y];typeof f=="object"&&f!==null&&!Array.isArray(f)&&await this.checkEmbeddedTypes(`${e}.${c}[${y}]`,f,m,n,o,s,a,i+1)}else await this.checkEmbeddedTypes(`${e}.${c}`,l,m,n,o,s,a,i+1)}}async validateEmbeddedType(e,t,r,n,o){if(t.length===0||!r)return null;let s=this.localName(t),a=this.localName(r);if(a==="Resource"||a==="Class")return null;let i=e.split(".")[0];if(s===a){let l=new k;return l.ruleType=this.ruleName,l.severity="Warning",l.entityName=i,l.propertyName=e,l.actualValue=t,l.expectedValue=r,l.message=`Embedded object at '${e}' declares 'type: ${t}', which equals the parent property's range '${r}'. The declaration is redundant \u2014 the type is already inferred from the property's range.`,l.suggestion=`Remove the 'type: ${t}' line, or keep it if explicitness is preferred over concision.`,l}if(await n.isSubclassOfAsync(t,r,o)||(s!==t||a!==r)&&await n.isSubclassOfAsync(s,a,o))return null;let c=new k;return c.ruleType=this.ruleName,c.severity="Error",c.entityName=i,c.propertyName=e,c.actualValue=t,c.expectedValue=r,c.message=`Embedded object at '${e}' has 'type: ${t}', which is not a subclass of the parent property's range '${r}'.`,c.suggestion=`Either remove the 'type: ${t}' line (so the type is inferred from the property's range '${r}'), or add 'subClassOf: ${r}' to the '${t}' class definition so the relationship holds.`,c}localName(e){let t=e.lastIndexOf(".");return t<0||t===e.length-1?e:e.substring(t+1)}async buildPropertyRangeMap(e,t){let r=new Map,n=await t.buildEntityIndexAsync(e);for(let[o,s]of n){let a=s.entity.type;if(a==null)continue;let i=String(a),c=this.localName(i);if(!(c==="Property"||c==="DatatypeProperty"||c==="ObjectProperty"||c==="AnnotationProperty"))continue;let u=s.entity.range;if(u==null)continue;let m=String(u);m.length!==0&&r.set(this.localName(o),m)}return r}};var le=class{ruleName="ImportExistence";async validateAsync(e,t){let r=[];if(!e.metadata?.imports)return r;let n=await t.getAllDocumentsAsync();for(let[o,s]of Object.entries(e.metadata.imports))for(let a of s)if(!await t.getHighestCompatibleVersionAsync(o,a)){let c=await this.determineImportErrorAsync(t,o,a,n),l=new k;l.ruleType=this.ruleName,l.severity="Error",l.message=c.message,l.suggestion=c.suggestion,l.entityName=`Import: ${o}/${a.packageName}`,l.actualValue=a.toString(),l.expectedValue=c.expectedValue,r.push(l)}return r}async determineImportErrorAsync(e,t,r,n){let o=await e.getDocumentsByNamespaceAsync(t,r.packageName);if(o.length===0){let c=n.filter(y=>y.metadata.namespace_?.publisher===t).map(y=>y.metadata.namespace_.package_).filter((y,f,d)=>d.indexOf(y)===f),l=this.findSimilarPackages(r.packageName,c),u=`Import '${t}/${r.package_}' not found - package does not exist`,m=l.length>0?`Did you mean: ${l.slice(0,3).join(", ")}?`:c.length>0?`Available packages in ${t}: ${c.slice(0,5).join(", ")}`:`No packages found for publisher '${t}'. Verify the publisher name is correct.`;return{message:u,suggestion:m,expectedValue:"Existing package"}}let a=o.filter(c=>c.metadata.namespace_?.version).map(c=>c.metadata.namespace_.version.toString()).sort().join(", "),i=this.getAcceptableVersionRange(r);return{message:`Import '${t}/${r.toString()}' version mismatch - no compatible version found`,suggestion:`Available versions: ${a}. Required: ${i}`,expectedValue:i}}getAcceptableVersionRange(e){switch(e.versionOperator){case 0:return`exactly ${e.version.major}.${e.version.minor}.${e.version.patch}`;case 1:return`${e.version.major}.${e.version.minor}.${e.version.patch} to ${e.version.major}.${e.version.minor}.x`;case 2:return e.version.major===0?`0.${e.version.minor}.x`:`${e.version.major}.x.x`;case 3:return`any version >= ${e.version.major}.${e.version.minor}.${e.version.patch}`;default:return e.toString()}}findSimilarPackages(e,t){if(t.length===0)return[];let r=t.filter(s=>s.toLowerCase().includes(e.toLowerCase())||e.toLowerCase().includes(s.toLowerCase()));if(r.length>0)return r.sort((s,a)=>s.length-a.length);let n=t.map(s=>({package:s,distance:this.levenshteinDistance(e.toLowerCase(),s.toLowerCase())})).sort((s,a)=>s.distance-a.distance),o=Math.max(3,Math.floor(e.length*.4));return n.filter(s=>s.distance<=o).map(s=>s.package)}levenshteinDistance(e,t){if(!e||e.length===0)return t?.length??0;if(!t||t.length===0)return e.length;let r=e.length,n=t.length,o=Array(r+1).fill(null).map(()=>Array(n+1).fill(0));for(let s=0;s<=r;s++)o[s][0]=s;for(let s=0;s<=n;s++)o[0][s]=s;for(let s=1;s<=r;s++)for(let a=1;a<=n;a++){let i=e[s-1]===t[a-1]?0:1;o[s][a]=Math.min(Math.min(o[s-1][a]+1,o[s][a-1]+1),o[s-1][a-1]+i)}return o[r][n]}};var ue=class{ruleName="UnresolvedReference";async validateAsync(e,t){let r=[],n=new A(t),o=await n.buildEntityIndexAsync(e),s=new Set;for(let[a,i]of o.entries()){let c=i.entity.type;if(c){let l=c.toString();(l==="ObjectProperty"||l.endsWith(".ObjectProperty"))&&s.add(a)}}for(let[a,i]of Object.entries(e.body)){if(!i||typeof i!="object"||Array.isArray(i))continue;let c=i,l=this.getPropertyValue(c,"type");if(!(!l||l==="Class"||l.endsWith("Property")||l==="AnnotationProperty"))for(let[u,m]of Object.entries(c))u==="type"||u==="label"||u==="comment"||!(s.has(u)||Array.from(s).some(f=>f.endsWith(`.${u}`)))||await this.validateReferenceValue(a,u,m,e,n,r)}return r}async validateReferenceValue(e,t,r,n,o,s){if(r!=null){if(typeof r=="string")await o.resolveEntityAsync(r,n)||s.push(this.createUnresolvedReferenceError(e,t,r));else if(Array.isArray(r))for(let a=0;a<r.length;a++){let i=r[a];typeof i=="string"&&(await o.resolveEntityAsync(i,n)||s.push(this.createUnresolvedReferenceError(e,`${t}[${a}]`,i)))}}}createUnresolvedReferenceError(e,t,r){let n=`The entity '${r}' cannot be found in the current document or any imported namespaces.
|
|
6
6
|
|
|
7
7
|
Possible solutions:
|
|
8
8
|
\u2022 Add import if the entity is defined in another namespace:
|
|
9
9
|
kanonak namespace add-import <publisher>/<package>@<version>
|
|
10
10
|
\u2022 Check for typos in the reference name '${r}'
|
|
11
11
|
\u2022 Define '${r}' in the current namespace or an appropriate namespace
|
|
12
|
-
\u2022 Use 'kanonak search type ${r} --include-imports' to locate the entity`,o=new k;return o.ruleType=this.ruleName,o.severity="Warning",o.entityName=e,o.propertyName=t,o.actualValue=r,o.message=`Reference to '${r}' could not be resolved`,o.suggestion=n,o.expectedValue="A valid entity reference that exists in the current document or imported namespaces",o}getPropertyValue(e,t){let r=e[t];return r?r.toString():null}};var ye=class{ruleName="TypeAmbiguity";async validateAsync(e,t){let r=[],n=new Map,o=[];if(e.metadata?.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let c of a){let i=await t.getHighestCompatibleVersionAsync(s,c);if(i){o.push({doc:i,import:c,publisher:s});let p=await this.getTransitiveImportsAsync(t,i,new Set);o.push(...p.map(u=>({doc:u,import:null,publisher:s})))}}for(let{doc:s,import:a}of o){let c=s.metadata?.namespace_?.toString()??"unknown";for(let i of Object.keys(s.body))n.has(i)||n.set(i,[]),n.get(i).push({namespace:c,import:a})}for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let c=a;this.checkAmbiguousReference(c,"type",n,s,r),this.checkAmbiguousReference(c,"subClassOf",n,s,r),this.checkAmbiguousReference(c,"subPropertyOf",n,s,r),this.checkAmbiguousReference(c,"domain",n,s,r),this.checkAmbiguousReference(c,"range",n,s,r)}return r}checkAmbiguousReference(e,t,r,n,o){let s=e[t];if(!s)return;let a=S(s);for(let c of a){if(c.includes("."))continue;let i=r.get(c);if(i&&i.length>1){let p=i.map(f=>f.namespace).join(", "),u=[];for(let{namespace:f,import:d}of i)if(d?.alias)u.push(`${d.alias}.${c}`);else{let g=f.split("/"),b=g[g.length-1]?.split("@")[0]??"alias";u.push(`${b}.${c}`)}let y=u.length>0?`Use one of: ${u.join(", ")}`:"Consider adding namespace aliases to your imports",m=new k;m.ruleType=this.ruleName,m.severity="Warning",m.entityName=n,m.propertyName=t,m.actualValue=c,m.message=`Type '${c}' is ambiguous. It's defined in: ${p}`,m.suggestion=y,o.push(m)}}}async getTransitiveImportsAsync(e,t,r){let n=[],o=t.metadata?.namespace_?.toString()??"";if(r.has(o))return n;if(r.add(o),t.metadata?.imports)for(let[s,a]of Object.entries(t.metadata.imports))for(let c of a){let i=await e.getHighestCompatibleVersionAsync(s,c);if(i){n.push(i);let p=await this.getTransitiveImportsAsync(e,i,r);n.push(...p)}}return n}};var me=class{ruleName="ClassHierarchyCycle";async validateAsync(e,t){let r=[],n=new Map,o=new Set;await this.buildClassHierarchy(e,t,n,o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let c=a,i=c.type,p=c.subClassOf;if(i?.toString()==="Class"&&p){let u=s,y=this.detectCycle(u,n);if(y){let m=y.join(" \u2192 "),f=new k;f.ruleType=this.ruleName,f.severity="Error",f.message=`Circular class hierarchy detected: ${m}`,f.suggestion="Remove the circular dependency by breaking one of the subClassOf relationships",f.entityName=u,f.propertyName="subClassOf",f.actualValue=m,r.push(f);break}}}return r}async buildClassHierarchy(e,t,r,n){let o=e.metadata?.namespace_?.toString()??"";if(!(o&&n.has(o))){o&&n.add(o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let c=a,i=c.type,p=c.subClassOf;if(i?.toString()==="Class"&&p){let u=S(p);u.length>0&&r.set(s,u)}}if(e.metadata?.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let c of a){let i=await t.getHighestCompatibleVersionAsync(s,c);i&&await this.buildClassHierarchy(i,t,r,n)}}}detectCycle(e,t){let r=[],n=new Set;return this.detectCycleRecursive(e,t,r,n)}detectCycleRecursive(e,t,r,n){if(r.includes(e)){let s=r.indexOf(e),a=r.slice(s);return a.push(e),a}if(n.has(e))return null;r.push(e),n.add(e);let o=t.get(e);if(o)for(let s of o){let a=this.detectCycleRecursive(s,t,r,n);if(a)return a}return r.pop(),null}};var fe=class{ruleName="PropertyHierarchyCycle";async validateAsync(e,t){let r=[],n=new Map,o=new Set;await this.buildPropertyHierarchy(e,t,n,o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)&&a.subPropertyOf){let p=s,u=this.detectCycle(p,n);if(u){let y=u.join(" \u2192 "),m=new k;m.ruleType=this.ruleName,m.severity="Error",m.message=`Circular property hierarchy detected: ${y}`,m.suggestion="Remove the circular dependency by breaking one of the subPropertyOf relationships",m.entityName=p,m.propertyName="subPropertyOf",m.actualValue=y,r.push(m);break}}return r}async buildPropertyHierarchy(e,t,r,n){let o=e.metadata?.namespace_?.toString()??"";if(!(o&&n.has(o))){o&&n.add(o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let c=a,i=c.type;if(i){let p=i.toString();if(p==="DatatypeProperty"||p==="ObjectProperty"||p==="AnnotationProperty"){let u=c.subPropertyOf;if(u){let y=S(u);y.length>0&&r.set(s,y)}}}}if(e.metadata?.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let c of a){let i=await t.getHighestCompatibleVersionAsync(s,c);i&&await this.buildPropertyHierarchy(i,t,r,n)}}}detectCycle(e,t){let r=[],n=new Set;return this.detectCycleRecursive(e,t,r,n)}detectCycleRecursive(e,t,r,n){if(r.includes(e)){let s=r.indexOf(e),a=r.slice(s);return a.push(e),a}if(n.has(e))return null;r.push(e),n.add(e);let o=t.get(e);if(o)for(let s of o){let a=this.detectCycleRecursive(s,t,r,n);if(a)return a}return r.pop(),null}};var de=class{get ruleName(){return"PropertyRangeRequired"}async validateAsync(e,t){let r=[];for(let[n,o]of Object.entries(e.body)){if(typeof o!="object"||o===null||Array.isArray(o))continue;let s=o,a=s.type?.toString();if(a==="DatatypeProperty"||a==="ObjectProperty"||a?.endsWith(".DatatypeProperty")||a?.endsWith(".ObjectProperty")){let c="range"in s,i=s.range?.toString().trim();if(!c||!i){let p=new k;p.ruleType=this.ruleName,p.severity="Error",p.entityName=n,p.propertyName="range",p.message=`Property '${n}' must have a 'range' defined.`,p.suggestion=a==="DatatypeProperty"?"Add a range like: range: string (or integer, boolean, etc.)":"Add a range like: range: ClassName (the class this property expects)",p.expectedValue=a==="DatatypeProperty"?"A datatype (string, integer, boolean, decimal, etc.)":"A class name (Character, Scene, Story, etc.)",r.push(p)}}}return r}};var ge=class{builtInClasses=new Set(["Resource","Class","Literal","Thing","Nothing","Property","DatatypeProperty","ObjectProperty","AnnotationProperty","FunctionalProperty","InverseFunctionalProperty","TransitiveProperty","SymmetricProperty"]);get ruleName(){return"SubClassOfReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let c=s.type?.toString();(c==="Class"||c&&c.endsWith(".Class"))&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let c=S(s.subClassOf);for(let i=0;i<c.length;i++){let p=c[i];if(this.builtInClasses.has(p)||n.has(p))continue;if(!await this.isClassAvailableInImports(e,t,p)){let y=c.length>1?`[${i}]`:"",m=new k;m.ruleType=this.ruleName,m.severity="Error",m.message=`Class '${p}' referenced in subClassOf${y} is not defined or imported`,m.suggestion=`Define '${p}' as a Class, or import a namespace that contains it`,m.entityName=o,m.propertyName="subClassOf",m.actualValue=p,m.expectedValue="Defined or imported class",r.push(m)}}}return r}async isClassAvailableInImports(e,t,r){if(!e.metadata.imports)return!1;let n=null,o=r;if(r.includes(".")){let s=r.split(".",2);n=s[0],o=s[1]}for(let[s,a]of Object.entries(e.metadata.imports))for(let c of a){if(n!==null&&c.alias!==n)continue;let i=await t.getHighestCompatibleVersionAsync(s,c);if(i){let p=n!==null?o:r,u=i.body[p];if(u&&typeof u=="object"&&!Array.isArray(u)){let f=u.type?.toString();if(f==="Class"||f&&f.endsWith(".Class"))return!0}let y=new Set;if(await this.isClassAvailableInImportsRecursive(i,t,p,y))return!0}}return!1}async isClassAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let c of a){let i=await t.getHighestCompatibleVersionAsync(s,c);if(i){let p=i.body[r];if(p&&typeof p=="object"&&!Array.isArray(p)){let y=p.type?.toString();if(y==="Class"||y&&y.endsWith(".Class"))return!0}if(await this.isClassAvailableInImportsRecursive(i,t,r,n))return!0}}return!1}};var he=class{builtInProperties=new Set(["type","label","comment","domain","range","subPropertyOf","subClassOf","inverseOf","sameAs","seeAlso","isDefinedBy","functional","required"]);get ruleName(){return"SubPropertyOfReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let c=s.type?.toString();(c==="DatatypeProperty"||c==="ObjectProperty"||c==="AnnotationProperty")&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let c=S(s.subPropertyOf);for(let i=0;i<c.length;i++){let p=c[i];if(this.builtInProperties.has(p)||n.has(p))continue;if(!await this.isPropertyAvailableInImports(e,t,p)){let y=c.length>1?`[${i}]`:"",m=new k;m.ruleType=this.ruleName,m.severity="Error",m.message=`Property '${p}' referenced in subPropertyOf${y} is not defined or imported`,m.suggestion=`Define '${p}' as a DatatypeProperty or ObjectProperty, or import a namespace that contains it`,m.entityName=o,m.propertyName="subPropertyOf",m.actualValue=p,m.expectedValue="Defined or imported property",r.push(m)}}}return r}async isPropertyAvailableInImports(e,t,r){if(!e.metadata.imports)return!1;let n=null,o=r;if(r.includes(".")){let s=r.split(".",2);n=s[0],o=s[1]}for(let[s,a]of Object.entries(e.metadata.imports))for(let c of a){if(n!==null&&c.alias!==n)continue;let i=await t.getHighestCompatibleVersionAsync(s,c);if(i){let p=n!==null?o:r,u=i.body[p];if(u&&typeof u=="object"&&!Array.isArray(u)){let f=u.type?.toString();if(f==="DatatypeProperty"||f==="ObjectProperty"||f==="AnnotationProperty")return!0}let y=new Set;if(await this.isPropertyAvailableInImportsRecursive(i,t,p,y))return!0}}return!1}async isPropertyAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let c of a){let i=await t.getHighestCompatibleVersionAsync(s,c);if(i){let p=i.body[r];if(p&&typeof p=="object"&&!Array.isArray(p)){let y=p.type?.toString();if(y==="DatatypeProperty"||y==="ObjectProperty"||y==="AnnotationProperty")return!0}if(await this.isPropertyAvailableInImportsRecursive(i,t,r,n))return!0}}return!1}};var ke=class{get ruleName(){return"NamespaceImportCycle"}async validateAsync(e,t){let r=[],n=e.metadata.namespace_?.toString();if(!n)return r;let o=new Map,s=new Set;await this.buildImportGraph(e,t,o,s);let a=this.detectCycle(n,o);if(a){let c=a.join(" \u2192 "),i=new k;i.ruleType=this.ruleName,i.severity="Error",i.message=`Circular namespace import detected: ${c}`,i.suggestion="Remove one of the imports to break the circular dependency. Circular dependencies prevent proper package resolution.",i.entityName="imports",i.propertyName="imports",i.actualValue=c,r.push(i)}return r}async buildImportGraph(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(!(!o||n.has(o))&&(n.add(o),e.metadata.imports)){let s=[];for(let[a,c]of Object.entries(e.metadata.imports))for(let i of c){let p=`${a}/${i.packageName}@${i.version}`;s.push(p);let u=await t.getHighestCompatibleVersionAsync(a,i);u&&await this.buildImportGraph(u,t,r,n)}s.length>0&&r.set(o,s)}}detectCycle(e,t){let r=[],n=new Set;return this.detectCycleRecursive(e,t,r,n)}detectCycleRecursive(e,t,r,n){let o=r.indexOf(e);if(o>=0){let a=r.slice(o);return a.push(e),a}if(n.has(e))return null;r.push(e),n.add(e);let s=t.get(e);if(s)for(let a of s){let c=this.detectCycleRecursive(a,t,r,n);if(c)return c}return r.pop(),null}};var be=class{metadataKeys=new Set(["type","label","comment","subClassOf","subPropertyOf","domain","range","inverseOf","transitive","symmetric","functional","inverseFunctional"]);get ruleName(){return"InstancePropertyReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let c=s.type?.toString();this.isPropertyType(c)&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let a=s,c=a.type?.toString();if(this.isPropertyType(c)||this.isClassType(c))continue;for(let[i,p]of Object.entries(a)){if(!i||this.metadataKeys.has(i))continue;let u=i,y=null;if(i.includes(".")){let f=i.lastIndexOf(".");y=i.substring(0,f),u=i.substring(f+1)}if(n.has(u))continue;if(!await this.isPropertyAvailableInImports(e,t,u,y)){let f=new k;f.ruleType=this.ruleName,f.severity="Error",f.message=`Property '${i}' is not defined or imported`,f.suggestion=y?`The property '${u}' is not found in the imported namespace with alias '${y}'.
|
|
12
|
+
\u2022 Use 'kanonak search type ${r} --include-imports' to locate the entity`,o=new k;return o.ruleType=this.ruleName,o.severity="Warning",o.entityName=e,o.propertyName=t,o.actualValue=r,o.message=`Reference to '${r}' could not be resolved`,o.suggestion=n,o.expectedValue="A valid entity reference that exists in the current document or imported namespaces",o}getPropertyValue(e,t){let r=e[t];return r?r.toString():null}};var me=class{ruleName="TypeAmbiguity";async validateAsync(e,t){let r=[],n=new Map,o=[];if(e.metadata?.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){o.push({doc:c,import:i,publisher:s});let l=await this.getTransitiveImportsAsync(t,c,new Set);o.push(...l.map(u=>({doc:u,import:null,publisher:s})))}}for(let{doc:s,import:a}of o){let i=s.metadata?.namespace_?.toString()??"unknown";for(let c of Object.keys(s.body))n.has(c)||n.set(c,[]),n.get(c).push({namespace:i,import:a})}for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let i=a;this.checkAmbiguousReference(i,"type",n,s,r),this.checkAmbiguousReference(i,"subClassOf",n,s,r),this.checkAmbiguousReference(i,"subPropertyOf",n,s,r),this.checkAmbiguousReference(i,"domain",n,s,r),this.checkAmbiguousReference(i,"range",n,s,r)}return r}checkAmbiguousReference(e,t,r,n,o){let s=e[t];if(!s)return;let a=S(s);for(let i of a){if(i.includes("."))continue;let c=r.get(i);if(c&&c.length>1){let l=c.map(f=>f.namespace).join(", "),u=[];for(let{namespace:f,import:d}of c)if(d?.alias)u.push(`${d.alias}.${i}`);else{let g=f.split("/"),b=g[g.length-1]?.split("@")[0]??"alias";u.push(`${b}.${i}`)}let m=u.length>0?`Use one of: ${u.join(", ")}`:"Consider adding namespace aliases to your imports",y=new k;y.ruleType=this.ruleName,y.severity="Warning",y.entityName=n,y.propertyName=t,y.actualValue=i,y.message=`Type '${i}' is ambiguous. It's defined in: ${l}`,y.suggestion=m,o.push(y)}}}async getTransitiveImportsAsync(e,t,r){let n=[],o=t.metadata?.namespace_?.toString()??"";if(r.has(o))return n;if(r.add(o),t.metadata?.imports)for(let[s,a]of Object.entries(t.metadata.imports))for(let i of a){let c=await e.getHighestCompatibleVersionAsync(s,i);if(c){n.push(c);let l=await this.getTransitiveImportsAsync(e,c,r);n.push(...l)}}return n}};var ye=class{ruleName="ClassHierarchyCycle";async validateAsync(e,t){let r=[],n=new Map,o=new Set;await this.buildClassHierarchy(e,t,n,o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let i=a,c=i.type,l=i.subClassOf;if(c?.toString()==="Class"&&l){let u=s,m=this.detectCycle(u,n);if(m){let y=m.join(" \u2192 "),f=new k;f.ruleType=this.ruleName,f.severity="Error",f.message=`Circular class hierarchy detected: ${y}`,f.suggestion="Remove the circular dependency by breaking one of the subClassOf relationships",f.entityName=u,f.propertyName="subClassOf",f.actualValue=y,r.push(f);break}}}return r}async buildClassHierarchy(e,t,r,n){let o=e.metadata?.namespace_?.toString()??"";if(!(o&&n.has(o))){o&&n.add(o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let i=a,c=i.type,l=i.subClassOf;if(c?.toString()==="Class"&&l){let u=S(l);u.length>0&&r.set(s,u)}}if(e.metadata?.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);c&&await this.buildClassHierarchy(c,t,r,n)}}}detectCycle(e,t){let r=[],n=new Set;return this.detectCycleRecursive(e,t,r,n)}detectCycleRecursive(e,t,r,n){if(r.includes(e)){let s=r.indexOf(e),a=r.slice(s);return a.push(e),a}if(n.has(e))return null;r.push(e),n.add(e);let o=t.get(e);if(o)for(let s of o){let a=this.detectCycleRecursive(s,t,r,n);if(a)return a}return r.pop(),null}};var fe=class{ruleName="PropertyHierarchyCycle";async validateAsync(e,t){let r=[],n=new Map,o=new Set;await this.buildPropertyHierarchy(e,t,n,o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)&&a.subPropertyOf){let l=s,u=this.detectCycle(l,n);if(u){let m=u.join(" \u2192 "),y=new k;y.ruleType=this.ruleName,y.severity="Error",y.message=`Circular property hierarchy detected: ${m}`,y.suggestion="Remove the circular dependency by breaking one of the subPropertyOf relationships",y.entityName=l,y.propertyName="subPropertyOf",y.actualValue=m,r.push(y);break}}return r}async buildPropertyHierarchy(e,t,r,n){let o=e.metadata?.namespace_?.toString()??"";if(!(o&&n.has(o))){o&&n.add(o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let i=a,c=i.type;if(c){let l=c.toString();if(l==="DatatypeProperty"||l==="ObjectProperty"||l==="AnnotationProperty"){let u=i.subPropertyOf;if(u){let m=S(u);m.length>0&&r.set(s,m)}}}}if(e.metadata?.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);c&&await this.buildPropertyHierarchy(c,t,r,n)}}}detectCycle(e,t){let r=[],n=new Set;return this.detectCycleRecursive(e,t,r,n)}detectCycleRecursive(e,t,r,n){if(r.includes(e)){let s=r.indexOf(e),a=r.slice(s);return a.push(e),a}if(n.has(e))return null;r.push(e),n.add(e);let o=t.get(e);if(o)for(let s of o){let a=this.detectCycleRecursive(s,t,r,n);if(a)return a}return r.pop(),null}};var de=class{get ruleName(){return"PropertyRangeRequired"}async validateAsync(e,t){let r=[];for(let[n,o]of Object.entries(e.body)){if(typeof o!="object"||o===null||Array.isArray(o))continue;let s=o,a=s.type?.toString();if(a==="DatatypeProperty"||a==="ObjectProperty"||a?.endsWith(".DatatypeProperty")||a?.endsWith(".ObjectProperty")){let i="range"in s,c=s.range?.toString().trim();if(!i||!c){let l=new k;l.ruleType=this.ruleName,l.severity="Error",l.entityName=n,l.propertyName="range",l.message=`Property '${n}' must have a 'range' defined.`,l.suggestion=a==="DatatypeProperty"?"Add a range like: range: string (or integer, boolean, etc.)":"Add a range like: range: ClassName (the class this property expects)",l.expectedValue=a==="DatatypeProperty"?"A datatype (string, integer, boolean, decimal, etc.)":"A class name (Character, Scene, Story, etc.)",r.push(l)}}}return r}};var ge=class{builtInClasses=new Set(["Resource","Class","Literal","Thing","Nothing","Property","DatatypeProperty","ObjectProperty","AnnotationProperty","FunctionalProperty","InverseFunctionalProperty","TransitiveProperty","SymmetricProperty"]);get ruleName(){return"SubClassOfReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();(i==="Class"||i&&i.endsWith(".Class"))&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=S(s.subClassOf);for(let c=0;c<i.length;c++){let l=i[c];if(this.builtInClasses.has(l)||n.has(l))continue;if(!await this.isClassAvailableInImports(e,t,l)){let m=i.length>1?`[${c}]`:"",y=new k;y.ruleType=this.ruleName,y.severity="Error",y.message=`Class '${l}' referenced in subClassOf${m} is not defined or imported`,y.suggestion=`Define '${l}' as a Class, or import a namespace that contains it`,y.entityName=o,y.propertyName="subClassOf",y.actualValue=l,y.expectedValue="Defined or imported class",r.push(y)}}}return r}async isClassAvailableInImports(e,t,r){if(!e.metadata.imports)return!1;let n=null,o=r;if(r.includes(".")){let s=r.split(".",2);n=s[0],o=s[1]}for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){if(n!==null&&i.alias!==n)continue;let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=n!==null?o:r,u=c.body[l];if(u&&typeof u=="object"&&!Array.isArray(u)){let f=u.type?.toString();if(f==="Class"||f&&f.endsWith(".Class"))return!0}let m=new Set;if(await this.isClassAvailableInImportsRecursive(c,t,l,m))return!0}}return!1}async isClassAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=c.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(m==="Class"||m&&m.endsWith(".Class"))return!0}if(await this.isClassAvailableInImportsRecursive(c,t,r,n))return!0}}return!1}};var he=class{builtInProperties=new Set(["type","label","comment","domain","range","subPropertyOf","subClassOf","inverseOf","sameAs","seeAlso","isDefinedBy","functional","required"]);get ruleName(){return"SubPropertyOfReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();(i==="DatatypeProperty"||i==="ObjectProperty"||i==="AnnotationProperty")&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=S(s.subPropertyOf);for(let c=0;c<i.length;c++){let l=i[c];if(this.builtInProperties.has(l)||n.has(l))continue;if(!await this.isPropertyAvailableInImports(e,t,l)){let m=i.length>1?`[${c}]`:"",y=new k;y.ruleType=this.ruleName,y.severity="Error",y.message=`Property '${l}' referenced in subPropertyOf${m} is not defined or imported`,y.suggestion=`Define '${l}' as a DatatypeProperty or ObjectProperty, or import a namespace that contains it`,y.entityName=o,y.propertyName="subPropertyOf",y.actualValue=l,y.expectedValue="Defined or imported property",r.push(y)}}}return r}async isPropertyAvailableInImports(e,t,r){if(!e.metadata.imports)return!1;let n=null,o=r;if(r.includes(".")){let s=r.split(".",2);n=s[0],o=s[1]}for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){if(n!==null&&i.alias!==n)continue;let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=n!==null?o:r,u=c.body[l];if(u&&typeof u=="object"&&!Array.isArray(u)){let f=u.type?.toString();if(f==="DatatypeProperty"||f==="ObjectProperty"||f==="AnnotationProperty")return!0}let m=new Set;if(await this.isPropertyAvailableInImportsRecursive(c,t,l,m))return!0}}return!1}async isPropertyAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=c.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(m==="DatatypeProperty"||m==="ObjectProperty"||m==="AnnotationProperty")return!0}if(await this.isPropertyAvailableInImportsRecursive(c,t,r,n))return!0}}return!1}};var ke=class{get ruleName(){return"NamespaceImportCycle"}async validateAsync(e,t){let r=[],n=e.metadata.namespace_?.toString();if(!n)return r;let o=new Map,s=new Set;await this.buildImportGraph(e,t,o,s);let a=this.detectCycle(n,o);if(a){let i=a.join(" \u2192 "),c=new k;c.ruleType=this.ruleName,c.severity="Error",c.message=`Circular namespace import detected: ${i}`,c.suggestion="Remove one of the imports to break the circular dependency. Circular dependencies prevent proper package resolution.",c.entityName="imports",c.propertyName="imports",c.actualValue=i,r.push(c)}return r}async buildImportGraph(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(!(!o||n.has(o))&&(n.add(o),e.metadata.imports)){let s=[];for(let[a,i]of Object.entries(e.metadata.imports))for(let c of i){let l=`${a}/${c.packageName}@${c.version}`;s.push(l);let u=await t.getHighestCompatibleVersionAsync(a,c);u&&await this.buildImportGraph(u,t,r,n)}s.length>0&&r.set(o,s)}}detectCycle(e,t){let r=[],n=new Set;return this.detectCycleRecursive(e,t,r,n)}detectCycleRecursive(e,t,r,n){let o=r.indexOf(e);if(o>=0){let a=r.slice(o);return a.push(e),a}if(n.has(e))return null;r.push(e),n.add(e);let s=t.get(e);if(s)for(let a of s){let i=this.detectCycleRecursive(a,t,r,n);if(i)return i}return r.pop(),null}};var be=class{metadataKeys=new Set(["type","label","comment","subClassOf","subPropertyOf","domain","range","inverseOf","transitive","symmetric","functional","inverseFunctional"]);get ruleName(){return"InstancePropertyReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();this.isPropertyType(i)&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let a=s,i=a.type?.toString();if(this.isPropertyType(i)||this.isClassType(i))continue;for(let[c,l]of Object.entries(a)){if(!c||this.metadataKeys.has(c))continue;let u=c,m=null;if(c.includes(".")){let f=c.lastIndexOf(".");m=c.substring(0,f),u=c.substring(f+1)}if(n.has(u))continue;if(!await this.isPropertyAvailableInImports(e,t,u,m)){let f=new k;f.ruleType=this.ruleName,f.severity="Error",f.message=`Property '${c}' is not defined or imported`,f.suggestion=m?`The property '${u}' is not found in the imported namespace with alias '${m}'.
|
|
13
13
|
1. Verify the namespace is imported with the correct alias
|
|
14
14
|
2. Check if the property name is spelled correctly
|
|
15
|
-
3. Ensure the imported namespace version contains this property`:`The property '${
|
|
16
|
-
1. Define '${
|
|
17
|
-
2. Import the namespace that contains '${
|
|
18
|
-
3. Use a qualified reference like 'alias.${
|
|
15
|
+
3. Ensure the imported namespace version contains this property`:`The property '${c}' is not defined in this namespace or any imported namespace.
|
|
16
|
+
1. Define '${c}' as an ObjectProperty or DatatypeProperty in this namespace, OR
|
|
17
|
+
2. Import the namespace that contains '${c}', OR
|
|
18
|
+
3. Use a qualified reference like 'alias.${c}' if already imported with an alias`,f.entityName=o,f.propertyName=c,f.actualValue=l?.toString(),f.expectedValue="A defined or imported property",r.push(f)}}}return r}isPropertyType(e){return e?e==="ObjectProperty"||e==="DatatypeProperty"||e==="AnnotationProperty"||e==="Property"||e.endsWith(".ObjectProperty")||e.endsWith(".DatatypeProperty")||e.endsWith(".AnnotationProperty")||e.endsWith(".Property"):!1}isClassType(e){return e?e==="Class"||e.endsWith(".Class"):!1}async isPropertyAvailableInImports(e,t,r,n){if(!e.metadata.imports)return!1;for(let[o,s]of Object.entries(e.metadata.imports))for(let a of s){if(n!==null&&a.alias!==n)continue;let i=await t.getHighestCompatibleVersionAsync(o,a);if(i){let c=i.body[r];if(c&&typeof c=="object"&&!Array.isArray(c)){let m=c.type?.toString();if(this.isPropertyType(m))return!0}let l=new Set;if(await this.isPropertyAvailableInImportsRecursive(i,t,r,l))return!0}}return!1}async isPropertyAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=c.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(this.isPropertyType(m))return!0}if(await this.isPropertyAvailableInImportsRecursive(c,t,r,n))return!0}}return!1}};var Re=class{metadataKeys=new Set(["type","label","comment","subClassOf","subPropertyOf","domain","range","inverseOf","transitive","symmetric","functional","inverseFunctional"]);get ruleName(){return"DefinitionPropertyReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();this.isPropertyType(i)&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let a=s,i=a.type?.toString();if(!this.isPropertyType(i)&&!this.isClassType(i))continue;for(let[c,l]of Object.entries(a)){if(!c||this.metadataKeys.has(c))continue;let u=c,m=null;if(c.includes(".")){let f=c.lastIndexOf(".");m=c.substring(0,f),u=c.substring(f+1)}if(n.has(u))continue;if(!await this.isPropertyAvailableInImports(e,t,u,m)){let f=this.isClassType(i)?"class":"property",d=new k;d.ruleType=this.ruleName,d.severity="Error",d.message=`Property '${c}' used on ${f} '${o}' is not defined or imported`,d.suggestion=m?`The property '${u}' is not found in the imported namespace with alias '${m}'.
|
|
19
19
|
1. Verify the namespace is imported with the correct alias
|
|
20
20
|
2. Check if the property name is spelled correctly
|
|
21
|
-
3. Ensure the imported namespace version contains this property`:`The property '${
|
|
22
|
-
1. Define '${
|
|
23
|
-
2. Import the namespace that contains '${
|
|
24
|
-
3. Use a qualified reference like 'alias.${
|
|
25
|
-
`),u=e.split(".")[0],
|
|
21
|
+
3. Ensure the imported namespace version contains this property`:`The property '${c}' is not defined in this namespace or any imported namespace.
|
|
22
|
+
1. Define '${c}' as an ObjectProperty or DatatypeProperty in this namespace, OR
|
|
23
|
+
2. Import the namespace that contains '${c}', OR
|
|
24
|
+
3. Use a qualified reference like 'alias.${c}' if already imported with an alias`,d.entityName=o,d.propertyName=c,d.actualValue=l?.toString(),d.expectedValue="A defined or imported property",r.push(d)}}}return r}isPropertyType(e){return e?e==="ObjectProperty"||e==="DatatypeProperty"||e==="AnnotationProperty"||e==="Property"||e.endsWith(".ObjectProperty")||e.endsWith(".DatatypeProperty")||e.endsWith(".AnnotationProperty")||e.endsWith(".Property"):!1}isClassType(e){return e?e==="Class"||e.endsWith(".Class"):!1}async isPropertyAvailableInImports(e,t,r,n){if(!e.metadata.imports)return!1;for(let[o,s]of Object.entries(e.metadata.imports))for(let a of s){if(n!==null&&a.alias!==n)continue;let i=await t.getHighestCompatibleVersionAsync(o,a);if(i){let c=i.body[r];if(c&&typeof c=="object"&&!Array.isArray(c)){let m=c.type?.toString();if(this.isPropertyType(m))return!0}let l=new Set;if(await this.isPropertyAvailableInImportsRecursive(i,t,r,l))return!0}}return!1}async isPropertyAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=c.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(this.isPropertyType(m))return!0}if(await this.isPropertyAvailableInImportsRecursive(c,t,r,n))return!0}}return!1}};var ve=class{xsdTypes=new Set(["string","integer","boolean","decimal","float","double","date","dateTime","time","duration","anyURI","base64Binary","hexBinary","long","int","short","byte","unsignedLong","unsignedInt","unsignedShort","unsignedByte","positiveInteger","nonPositiveInteger","negativeInteger","nonNegativeInteger","normalizedString","token","language","Name","NCName","ENTITY","ENTITIES","IDREF","IDREFS","NMTOKEN","NMTOKENS"]);get ruleName(){return"XsdImport"}async validateAsync(e,t){let r=[],n=new Set,o=[];for(let[s,a]of Object.entries(e.body))if(typeof a=="object"&&a!==null&&!Array.isArray(a)){let i=a,c=!1,l=i.type;if(Array.isArray(l)){for(let u of l)if(u?.toString()==="DatatypeProperty"){c=!0;break}}else l?.toString()==="DatatypeProperty"&&(c=!0);if(c){o.push(s);let u=this.getPropertyValue(i,"range");u&&this.xsdTypes.has(u)&&n.add(u)}}if(n.size>0&&!await this.checkXsdImportAsync(e.metadata,t)){let a=Array.from(n).sort().join(", "),i=o.sort().join(", "),c=new k;c.ruleType=this.ruleName,c.severity="Error",c.message=`XSD namespace not imported but XSD types are used: ${a}`,c.suggestion=`Add an XSD import to the imports section. The core XSD types package is 'core-xsd' from publisher 'kanonak.org'. Used by properties: ${i}`,c.entityName="imports",r.push(c)}return r}async checkXsdImportAsync(e,t,r=new Set){if(!e?.imports)return!1;let n=e.namespace_?.toString()??"";if(n&&r.has(n))return!1;n&&r.add(n);for(let[,o]of Object.entries(e.imports))for(let s of o)if(s.packageName==="xsd"||s.packageName.toLowerCase().endsWith("-xsd"))return!0;for(let[o,s]of Object.entries(e.imports))for(let a of s){let i=await t.getHighestCompatibleVersionAsync(o,a);if(i?.metadata&&await this.checkXsdImportAsync(i.metadata,t,r))return!0}return!1}getPropertyValue(e,t){return e[t]?.toString()}};var Pe=class{get ruleName(){return"AmbiguousReference"}async validateAsync(e,t){let r=[],n=await this.buildEntitySourceMapAsync(e,t),o=await this.buildDatatypePropertyNamesAsync(e,t);for(let[s,a]of Object.entries(e.body))typeof a=="object"&&a!==null&&!Array.isArray(a)&&this.validateEntityReferences(s,a,n,o,e,r);return r}async buildEntitySourceMapAsync(e,t){let r=new Map,n=new Set;for(let o of Object.keys(e.body)){let s=e.metadata.namespace_?.toString()??"";r.has(o)||r.set(o,[]),r.get(o).push(`(local:${s})`)}if(e.metadata.imports)for(let[o,s]of Object.entries(e.metadata.imports))for(let a of s){let i=await t.getHighestCompatibleVersionAsync(o,a);i&&await this.collectEntitiesRecursivelyAsync(i,r,n,t)}return r}async collectEntitiesRecursivelyAsync(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(!r.has(o)){r.add(o);for(let s of Object.keys(e.body)){t.has(s)||t.set(s,[]);let a=t.get(s);a.includes(o)||a.push(o)}if(e.metadata.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await n.getHighestCompatibleVersionAsync(s,i);c&&await this.collectEntitiesRecursivelyAsync(c,t,r,n)}}}async buildDatatypePropertyNamesAsync(e,t){let r=new Set,n=new Set;if(await this.collectDatatypePropertiesAsync(e,r,n,t),e.metadata.imports)for(let[o,s]of Object.entries(e.metadata.imports))for(let a of s){let i=await t.getHighestCompatibleVersionAsync(o,a);i&&await this.collectDatatypePropertiesAsync(i,r,n,t)}return r}async collectDatatypePropertiesAsync(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(!r.has(o)){r.add(o);for(let[s,a]of Object.entries(e.body)){if(typeof a!="object"||a===null||Array.isArray(a))continue;let i=a.type;if(typeof i!="string")continue;(i.includes(".")?i.substring(i.lastIndexOf(".")+1):i)==="DatatypeProperty"&&t.add(s)}if(e.metadata.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await n.getHighestCompatibleVersionAsync(s,i);c&&await this.collectDatatypePropertiesAsync(c,t,r,n)}}}validateEntityReferences(e,t,r,n,o,s){for(let[a,i]of Object.entries(t)){let c=a;if(c&&!c.includes(".")){let l=r.get(c);if(l&&l.length>1&&!l.some(m=>m.startsWith("(local:"))){let m=l.filter(y=>!y.startsWith("(local:"));m.length>1&&s.push(this.createAmbiguityError(e,c,`Property '${c}'`,m,o,!0,c))}}this.validatePropertyValue(e,c,i,r,n,o,s)}}validatePropertyValue(e,t,r,n,o,s,a){if(r==null)return;let i=t&&t.includes(".")?t.substring(t.lastIndexOf(".")+1):t,c=!!i&&o.has(i);if(typeof r=="string"&&!r.includes(".")&&!c){let l=n.get(r);if(l&&l.length>1&&!l.some(m=>m.startsWith("(local:"))){let m=l.filter(y=>!y.startsWith("(local:"));m.length>1&&a.push(this.createAmbiguityError(e,t,`Reference '${r}'`,m,s,!1,r))}}else if(Array.isArray(r))for(let l=0;l<r.length;l++){let u=`${e}.${t}[${l}]`;this.validatePropertyValue(u,t,r[l],n,o,s,a)}else if(typeof r=="object"&&!Array.isArray(r)){let l=t?`${e}.${t}`:e;this.validateEntityReferences(l,r,n,o,s,a)}}createAmbiguityError(e,t,r,n,o,s,a){let i=[];for(let d of n){let g=this.findAliasForNamespace(o,d);if(g){let h=t?.split(".").pop()??t;i.push(`${g}.${h}`)}}let c=i.length>0?`Use one of: ${i.map(d=>`'${d}'`).join(", ")}`:`Add aliases to imports and use qualified names (e.g., 'alias.${t}')`,l=n.map(d=>` \u2022 ${d}`).join(`
|
|
25
|
+
`),u=e.split(".")[0],m=e.includes(".")?e:t,y=new k;y.ruleType=this.ruleName,y.severity="Error",y.entityName=u,m&&(y.propertyName=m);let f=a??t;return f&&(y.actualValue=f),y.message=`${r} is ambiguous - defined in multiple imported namespaces`,y.suggestion=`${c}
|
|
26
26
|
|
|
27
27
|
Defined in:
|
|
28
|
-
${
|
|
28
|
+
${l}`,y.expectedValue="Unambiguous reference (use namespace alias to disambiguate)",y}findAliasForNamespace(e,t){if(!e.metadata.imports)return null;for(let[r,n]of Object.entries(e.metadata.imports))for(let o of n)if(`${r}/${o.packageName}@${o.version}`===t&&o.alias)return o.alias;return null}};var we=class{builtInClasses=new Set(["Resource","Class","Literal","Thing","Nothing","Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]);primitiveTypes=new Set(["string","integer","int","long","short","byte","decimal","float","double","boolean","bool","dateTime","date","time","duration","anyURI","anySimpleType","nonNegativeInteger","positiveInteger","negativeInteger","nonPositiveInteger","unsignedInt","unsignedLong","unsignedShort","unsignedByte","base64Binary","hexBinary","Literal","Resource"]);get ruleName(){return"PropertyRangeReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();this.isValidRangeTargetType(i)&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let a=s,i=a.type?.toString();if(i!=="DatatypeProperty"&&i!=="ObjectProperty"&&!i?.endsWith(".DatatypeProperty")&&!i?.endsWith(".ObjectProperty"))continue;let c=a.range;if(!c)continue;let l=[];if(Array.isArray(c))for(let u of c){let m=u?.toString();m&&l.push(m)}else{let u=c?.toString();u&&l.push(u)}if(l.length===0)continue;for(let u of l){if(this.primitiveTypes.has(u)||this.builtInClasses.has(u)||n.has(u))continue;if(!await this.isTypeAvailableInImports(e,t,u)){let y=i?.includes("ObjectProperty")?"ObjectProperty":"DatatypeProperty",f=new k;f.ruleType=this.ruleName,f.severity="Error",f.message=`Property '${o}' has range '${u}' which is not defined or imported`,f.suggestion=y==="ObjectProperty"?`For ObjectProperty:
|
|
29
29
|
1. Define '${u}' as a Class in this namespace, OR
|
|
30
30
|
2. Import the namespace that contains '${u}', OR
|
|
31
31
|
3. Use a qualified reference like 'alias.${u}' if already imported with an alias`:`For DatatypeProperty:
|
|
32
32
|
1. Use a primitive type (string, integer, boolean, dateTime, etc.), OR
|
|
33
|
-
2. If '${u}' should be a class, change property type to ObjectProperty`,f.entityName=o,f.propertyName="range",f.actualValue=u,f.expectedValue=
|
|
34
|
-
${
|
|
33
|
+
2. If '${u}' should be a class, change property type to ObjectProperty`,f.entityName=o,f.propertyName="range",f.actualValue=u,f.expectedValue=y==="ObjectProperty"?"A defined or imported class name":"A primitive type or defined class",r.push(f)}}}return r}async isTypeAvailableInImports(e,t,r){if(!e.metadata.imports)return!1;let n=null,o=r;if(r.includes(".")){let s=r.split(".",2);n=s[0],o=s[1]}for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){if(n!==null&&i.alias!==n)continue;let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=n!==null?o:r,u=c.body[l];if(u&&typeof u=="object"&&!Array.isArray(u)){let f=u.type?.toString();if(this.isValidRangeTargetType(f))return!0}let m=new Set;if(await this.isTypeAvailableInImportsRecursive(c,t,l,m))return!0}}return!1}async isTypeAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=c.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(this.isValidRangeTargetType(m))return!0}if(await this.isTypeAvailableInImportsRecursive(c,t,r,n))return!0}}return!1}isValidRangeTargetType(e){return e?e==="Class"||e.endsWith(".Class")||e==="Datatype"||e.endsWith(".Datatype"):!1}};var Ie=class{xsdTypes=new Set(["string","integer","boolean","decimal","float","double","date","dateTime","time","duration","anyURI","base64Binary","hexBinary","long","int","short","byte","unsignedLong","unsignedInt","unsignedShort","unsignedByte","positiveInteger","nonPositiveInteger","negativeInteger","nonNegativeInteger","normalizedString","token","language","Name","NCName","ENTITY","ENTITIES","IDREF","IDREFS","NMTOKEN","NMTOKENS"]);get ruleName(){return"ObjectPropertyImport"}async validateAsync(e,t){let r=[],n=new Map,o=new A(t);await o.buildEntityIndexAsync(e);for(let[s,a]of Object.entries(e.body))if(typeof a=="object"&&a!==null&&!Array.isArray(a)){let i=a,c=!1,l=i.type;if(Array.isArray(l)){for(let u of l)if(u?.toString()==="ObjectProperty"){c=!0;break}}else l?.toString()==="ObjectProperty"&&(c=!0);if(c){let u=i.range,m=[];if(Array.isArray(u))for(let y of u){let f=y?.toString();f&&m.push(f)}else{let y=u?.toString();y&&m.push(y)}for(let y of m)this.xsdTypes.has(y)||(n.has(y)||n.set(y,[]),n.get(y).push(s))}}for(let[s,a]of n)if(!await o.resolveEntityAsync(s,e))for(let c of a){let l=new k;l.ruleType=this.ruleName,l.severity="Warning",l.message=`ObjectProperty references class '${s}' which may not be imported`,l.suggestion=`Ensure the namespace containing '${s}' is imported, or define '${s}' in this document`,l.entityName=c,l.propertyName="range",l.actualValue=s,r.push(l)}return r}};var Ae=class{standardProperties=new Set(["type","label","comment","subClassOf","domain","range","subPropertyOf","inverseOf","sameAs","seeAlso","isDefinedBy"]);get ruleName(){return"ObjectPropertyValue"}async validateAsync(e,t){let r=[],n=new A(t),o=new J(n),s=await n.buildEntityIndexAsync(e),a=await this.buildPropertyMetadataAsync(e,t,n,s);for(let[i,c]of Object.entries(e.body))typeof c=="object"&&c!==null&&!Array.isArray(c)&&await this.scanEntityForObjectProperties(c,i,"",a,n,o,e,r);return r}async scanEntityForObjectProperties(e,t,r,n,o,s,a,i){for(let[c,l]of Object.entries(e)){if(this.standardProperties.has(c))continue;let u=c,m=c.lastIndexOf(".");m>0&&m<c.length-1&&(u=c.substring(m+1));let y=n.get(u);if(y&&s.isEffectiveObjectProperty(y.propertyType,y.rangeUri)){let d=r?`${r}.${c}`:c;if(typeof l=="string"&&l.trim().length>0){let g=l.trim();if(g.includes(",")){let b=g.split(",").map(R=>R.trim()).filter(R=>R.length>0);i.push({ruleType:this.ruleName,severity:"Error",message:`Property '${c}' has a comma-separated string value, but ObjectProperty expects a list of references`,suggestion:`Use YAML list format:
|
|
34
|
+
${c}:
|
|
35
35
|
- ${b[0]}
|
|
36
36
|
${b.slice(1).map(R=>` - ${R}`).join(`
|
|
37
|
-
`)}`,entityName:t,propertyName:
|
|
38
|
-
1. Use this property only on '${
|
|
37
|
+
`)}`,entityName:t,propertyName:c,propertyPath:d,actualValue:g,expectedValue:`A single reference to ${y.range??"an entity"} OR a YAML list`});continue}let h=await o.resolveEntityAsync(g,a);if(h)y.range&&(await this.validateRangeType(h,y.range,o,a)||i.push({ruleType:this.ruleName,severity:"Warning",message:`Property '${c}' expects a ${y.range}, but '${g}' may not be a ${y.range}`,suggestion:`Ensure '${g}' is defined with appropriate type`,entityName:t,propertyName:c,propertyPath:d,actualValue:g,expectedValue:y.range}));else{let b=y.range??"entity";i.push({ruleType:this.ruleName,severity:"Error",message:`Property '${c}' references '${g}' which is not defined or imported`,suggestion:`Define '${g}' or import a namespace that contains it. Expected range: ${b}`,entityName:t,propertyName:c,propertyPath:d,actualValue:g,expectedValue:"Defined or imported entity"})}}else if(typeof l=="object"&&l!==null&&!Array.isArray(l)){let g=r?`${r}.${c}`:c;await this.scanEntityForObjectProperties(l,t,g,n,o,s,a,i)}else if(Array.isArray(l))for(let g=0;g<l.length;g++){let h=l[g];if(typeof h=="string"&&h.trim().length>0){let b=h.trim(),R=await o.resolveEntityAsync(b,a);if(R){if(y.range&&!await this.validateRangeType(R,y.range,o,a)){let D=r?`${r}.${c}[${g}]`:`${c}[${g}]`;i.push({ruleType:this.ruleName,severity:"Warning",message:`Property '${c}' expects a ${y.range}, but '${b}' may not be a ${y.range}`,suggestion:`Ensure '${b}' is defined with appropriate type`,entityName:t,propertyName:`${c}[${g}]`,propertyPath:D,actualValue:b,expectedValue:y.range})}}else{let v=y.range??"entity",D=r?`${r}.${c}[${g}]`:`${c}[${g}]`;i.push({ruleType:this.ruleName,severity:"Error",message:`Property '${c}' references '${b}' which is not defined or imported`,suggestion:`Define '${b}' or import a namespace that contains it. Expected range: ${v}`,entityName:t,propertyName:`${c}[${g}]`,propertyPath:D,actualValue:b,expectedValue:"Defined or imported entity"})}}else if(typeof h=="object"&&h!==null&&!Array.isArray(h)){let b=r?`${r}.${c}[${g}]`:`${c}[${g}]`;await this.scanEntityForObjectProperties(h,t,b,n,o,s,a,i)}}}if(typeof l=="object"&&l!==null&&!Array.isArray(l)&&!n.has(c)){let f=r?`${r}.${c}`:c;await this.scanEntityForObjectProperties(l,t,f,n,o,s,a,i)}else if(Array.isArray(l))for(let f=0;f<l.length;f++){let d=l[f];if(typeof d=="object"&&d!==null&&!Array.isArray(d)){let g=r?`${r}.${c}[${f}]`:`${c}[${f}]`;await this.scanEntityForObjectProperties(d,t,g,n,o,s,a,i)}}}}async validateRangeType(e,t,r,n){if(!new Set(["Property","DatatypeProperty","ObjectProperty","AnnotationProperty","Class","Resource"]).has(t))return!0;let s=e.entity.type;if(s){let a=[];if(Array.isArray(s))for(let i of s){let c=i?.toString();c&&c.trim().length>0&&a.push(c)}else{let i=s?.toString();i&&i.trim().length>0&&a.push(i)}for(let i of a){let c=i.includes(".")?i.split(".")[1]:i;if(c===t||t==="Property"&&(c==="DatatypeProperty"||c==="ObjectProperty"||c==="AnnotationProperty")||t==="Class"&&c==="Class"||await r.isSubclassOfAsync(i,t,n))return!0}}return!1}async buildPropertyMetadataAsync(e,t,r,n){let o=new Map;for(let[s,a]of n){let i=a.entity.type;if(i){let c=[];if(Array.isArray(i))for(let m of i){let y=m?.toString();y&&y.trim().length>0&&c.push(y)}else{let m=i?.toString();m&&m.trim().length>0&&c.push(m)}let l=!1,u="Property";for(let m of c){let y=m.includes(".")?m.split(".")[1]:m;if(y==="Property"||y==="DatatypeProperty"||y==="ObjectProperty"||y==="AnnotationProperty"){l=!0,u=m;break}}if(l){let m={propertyType:u},y=a.entity.range;if(y){let f=y?.toString();if(f&&f.trim().length>0){m.range=f;let d=await r.resolveEntityAsync(f,e);d&&(m.rangeUri=d.uri)}}o.set(s,m)}}}return o}};var De=class{standardProperties=new Set(["type","label","comment","subClassOf","domain","range","subPropertyOf","inverseOf","sameAs","seeAlso","isDefinedBy"]);get ruleName(){return"PropertyDomain"}async validateAsync(e,t){let r=[],n=new Map;for(let[s,a]of Object.entries(e.body))if(typeof a=="object"&&a!==null&&!Array.isArray(a)){let i=a,c=this.getPropertyValue(i,"type");(c==="DatatypeProperty"||c?.endsWith(".DatatypeProperty")||c==="ObjectProperty"||c?.endsWith(".ObjectProperty")||c==="AnnotationProperty"||c?.endsWith(".AnnotationProperty"))&&n.set(s,i)}let o=await this.buildCompleteClassHierarchyAsync(e,t);for(let[s,a]of Object.entries(e.body))if(typeof a=="object"&&a!==null&&!Array.isArray(a)){let i=a,c=this.getPropertyValue(i,"type");if(!c||c==="Class"||c.endsWith(".Class")||c.endsWith("Property")||c==="AnnotationProperty")continue;this.validateEntityProperties(i,s,c,n,o,r)}return r}async buildCompleteClassHierarchyAsync(e,t){let r=new Map,n=new Set,o=async(a,i)=>{if(!n.has(i)){n.add(i);for(let[c,l]of Object.entries(a.body))if(typeof l=="object"&&l!==null&&!Array.isArray(l)){let u=l,m=this.getPropertyValue(u,"type");if(m==="Class"||m?.endsWith(".Class")){let y=u.subClassOf;if(y===void 0){for(let d of Object.keys(u))if(d.endsWith(".subClassOf")){y=u[d];break}}let f=S(y);f.length>0&&r.set(c,f)}}if(a.metadata.imports)for(let[c,l]of Object.entries(a.metadata.imports))for(let u of l)try{let m=await t.getHighestCompatibleVersionAsync(c,u);if(m){let y=`${c}/${u.packageName}@${u.version}`;await o(m,y)}}catch{}}},s=e.metadata.namespace_?.toString()??"unknown";return await o(e,s),r}validateEntityProperties(e,t,r,n,o,s){for(let[a,i]of Object.entries(e)){if(this.standardProperties.has(a))continue;let c=a,l=a.lastIndexOf(".");l>0&&l<a.length-1&&(c=a.substring(l+1));let u=n.get(c);if(!u)continue;let m=this.getPropertyValue(u,"domain");if(m){if(!this.isTypeCompatibleWithDomain(r,m,o)){let y=t.split(".")[0];s.push({ruleType:this.ruleName,severity:"Error",entityName:y,propertyName:t,actualValue:a,message:`Property '${a}' has domain '${m}' but is used on '${r}' at '${t}'`,suggestion:`Either:
|
|
38
|
+
1. Use this property only on '${m}' instances
|
|
39
39
|
2. Change the property domain to include '${r}'
|
|
40
|
-
3. Create a different property for '${r}'`,expectedValue:`Property used on ${
|
|
41
|
-
1. Create a class for this data and change '${
|
|
40
|
+
3. Create a different property for '${r}'`,expectedValue:`Property used on ${m} or its subclasses`})}if(typeof i=="object"&&i!==null&&!Array.isArray(i)){let y=i,f=this.getPropertyValue(y,"type");if(f){let d=`${t}.${a}`;this.validateEntityProperties(y,d,f,n,o,s)}else{let d=this.getPropertyValue(u,"range");if(d){let g=`${t}.${a}`;this.validateEntityProperties(y,g,d,n,o,s)}}}else if(Array.isArray(i))for(let y=0;y<i.length;y++){let f=i[y];if(typeof f=="object"&&f!==null&&!Array.isArray(f)){let d=f,g=this.getPropertyValue(d,"type");if(g){let h=`${t}.${a}[${y}]`;this.validateEntityProperties(d,h,g,n,o,s)}else{let h=this.getPropertyValue(u,"range");if(h){let b=`${t}.${a}[${y}]`;this.validateEntityProperties(d,b,h,n,o,s)}}}}}}}isTypeCompatibleWithDomain(e,t,r){if(e===t)return!0;let n=new Set,o=[e];for(;o.length>0;){let s=o.shift();if(n.has(s))continue;n.add(s);let a=r.get(s);if(a)for(let i of a){if(i===t)return!0;o.push(i)}}return!1}getPropertyValue(e,t){if(t in e){let r=e[t];return this.extractFirstValue(r)}for(let r of Object.keys(e))if(r.endsWith(`.${t}`)){let n=e[r];return this.extractFirstValue(n)}}extractFirstValue(e){if(Array.isArray(e)){let t=[];for(let r of e)t.push(r?.toString()??"");return t.length>0?t[0]:void 0}return e?.toString()}};var Se=class{get ruleName(){return"PropertyValueType"}async validateAsync(e,t){let r=[],n=new Map;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let a=s,i=this.getPropertyValue(a,"type");(i==="DatatypeProperty"||i==="ObjectProperty")&&n.set(o,a)}for(let[o,s]of Object.entries(e.body)){if(typeof s!="object"||s===null||Array.isArray(s))continue;let a=s,i=this.getPropertyValue(a,"type");if(!(!i||i==="Class"||i.endsWith("Property")||i==="AnnotationProperty"))for(let[c,l]of Object.entries(a)){if(c==="type"||c==="label"||c==="comment")continue;let u=c,m=c.lastIndexOf(".");m>0&&m<c.length-1&&(u=c.substring(m+1));let y=n.get(u);if(!y)continue;let f=this.getPropertyValue(y,"type"),d=this.getPropertyValue(y,"range");if(f==="DatatypeProperty"){if(typeof l=="object"&&l!==null&&!Array.isArray(l)||Array.isArray(l))r.push({ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:c,message:`Property '${c}' is a DatatypeProperty with range '${d}' but instance '${o}' has a complex object value`,suggestion:`Either:
|
|
41
|
+
1. Create a class for this data and change '${c}' to an ObjectProperty
|
|
42
42
|
2. Store as a JSON string to keep it as DatatypeProperty
|
|
43
|
-
3. Use separate properties instead of nesting`,expectedValue:`A simple value of type '${d}'`});else if(!this.validateDatatypeValue(d,p)){let g={ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:i,message:`Property '${i}' expects type '${d}' but instance '${o}' has value of type '${this.getValueTypeName(p)}'`,suggestion:`Provide a value of type '${d}'`,toString:()=>""};d&&(g.expectedValue=d),r.push(g)}}else if(f==="ObjectProperty")if(Array.isArray(p))for(let g=0;g<p.length;g++){let h=p[g];typeof h!="string"&&(typeof h!="object"||h===null||Array.isArray(h))&&r.push({ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:`${i}[${g}]`,message:`ObjectProperty '${i}' array item ${g} in instance '${o}' has invalid type '${this.getValueTypeName(h)}'`,suggestion:"Array items must be references (strings) or embedded objects (dictionaries)",expectedValue:"string or object"})}else typeof p!="string"&&(typeof p!="object"||p===null||Array.isArray(p))&&r.push({ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:i,message:`ObjectProperty '${i}' in instance '${o}' has invalid value type '${this.getValueTypeName(p)}'`,suggestion:"Value must be a reference (string), embedded object (dictionary), or array of these",expectedValue:`Reference to ${d} or embedded ${d} object`})}}return r}validateDatatypeValue(e,t){switch(e?.toLowerCase()){case"string":return typeof t=="string";case"integer":case"int":return typeof t=="number"&&Number.isInteger(t);case"decimal":return typeof t=="number";case"boolean":return typeof t=="boolean";case"float":case"double":return typeof t=="number";default:return!0}}getValueTypeName(e){return typeof e=="string"?"string":typeof e=="number"?Number.isInteger(e)?"integer":"decimal":typeof e=="boolean"?"boolean":Array.isArray(e)?"array":typeof e=="object"&&e!==null?"object":e===null?"null":e===void 0?"undefined":typeof e}getPropertyValue(e,t){if(t in e){let r=e[t];if(Array.isArray(r)){let n=[];for(let o of r)n.push(o?.toString()??"");return n.length>0?n[0]:void 0}return r?.toString()}}};var Ve=class{builtInClasses=new Set(["Resource","Class","Literal","Thing","Nothing","Property","DatatypeProperty","ObjectProperty","AnnotationProperty","FunctionalProperty","InverseFunctionalProperty","TransitiveProperty","SymmetricProperty"]);get ruleName(){return"ClassDefinition"}async validateAsync(e,t){let r=[],n=new Map,o=new Set;for(let[a,c]of Object.entries(e.body))if(typeof c=="object"&&c!==null&&!Array.isArray(c)){let p=c.type;if(p)if(Array.isArray(p))for(let u of p){let y=u?.toString();if(y==="Class"||y&&y.endsWith(".Class")){o.add(a);break}}else{let u=p?.toString();(u==="Class"||u&&u.endsWith(".Class"))&&o.add(a)}}for(let[a,c]of Object.entries(e.body))if(typeof c=="object"&&c!==null&&!Array.isArray(c)){let i=c,p=i.type;if(p)if(Array.isArray(p)){let u=!1;for(let y of p){let m=y?.toString();if(m&&this.isDefinitionType(m)){u=!0;break}}if(!u)for(let y of p){let m=y?.toString();m&&m.trim().length>0&&(n.has(m)||n.set(m,[]),n.get(m).push(a))}}else{let u=p?.toString();u&&u.trim().length>0&&(this.isDefinitionType(u)||(n.has(u)||n.set(u,[]),n.get(u).push(a)))}this.checkNestedTypes(i,a,n,a)}let s=new A(t);for(let[a,c]of n){if(this.builtInClasses.has(a)||o.has(a))continue;let i=await s.resolveEntityAsync(a,e);if(!(i&&this.isClassEntity(i.entity))){let u=Array.from(new Set(c)).sort();for(let y of u)r.push({ruleType:this.ruleName,severity:"Error",message:`Class '${a}' is not defined or imported`,suggestion:`Define '${a}' as a Class in this document, or import a namespace that contains it`,entityName:y,propertyName:"type",actualValue:a,expectedValue:"Defined or imported class"})}}return r}checkNestedTypes(e,t,r,n){if(typeof e=="object"&&e!==null&&!Array.isArray(e)){let o=e,s=o.type;if(s){let a=new Set(["Class","DatatypeProperty","ObjectProperty","AnnotationProperty"]);if(Array.isArray(s))for(let c of s){let i=c?.toString();i&&i.trim().length>0&&!a.has(i)&&(r.has(i)||r.set(i,[]),r.get(i).push(n))}else{let c=s?.toString();c&&c.trim().length>0&&!a.has(c)&&(r.has(c)||r.set(c,[]),r.get(c).push(n))}}for(let[a,c]of Object.entries(o))if(a!=="type"){let i=`${n}.${a}`;this.checkNestedTypes(c,t,r,i)}}else if(Array.isArray(e))for(let o=0;o<e.length;o++){let s=`${n}[${o}]`;this.checkNestedTypes(e[o],t,r,s)}}isClassEntity(e){if(!e)return!1;let t=e.type;if(!t)return!1;if(Array.isArray(t))for(let r of t){let n=r?.toString();if(n==="Class"||n&&n.endsWith(".Class"))return!0}else{let r=t?.toString();if(r==="Class"||r&&r.endsWith(".Class"))return!0}return!1}isDefinitionType(e){return!e||e.trim().length===0?!1:new Set(["Class","Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]).has(e)?!0:e.endsWith(".Class")||e.endsWith(".Property")||e.endsWith(".DatatypeProperty")||e.endsWith(".ObjectProperty")||e.endsWith(".AnnotationProperty")}};var He=class{parser;documentRules;repositoryRules;includeWarnings=!0;constructor(e){this.parser=e??new E,this.documentRules=[new se,new ae,new ie,new ce],this.repositoryRules=[new pe,new le,new ue,new ye,new me,new fe,new de,new ge,new he,new ke,new be,new Re,new ve,new Pe,new we,new Ie,new Ae,new De,new Se,new Ve]}async validateAsync(e,t){let r=new oe;for(let n of this.documentRules)try{let o=n.validate(e);this.addErrorsToResult(r,o)}catch(o){let s=new k;s.ruleType=n.ruleName,s.severity="Error",s.message=`Validation rule '${n.ruleName}' failed: ${o instanceof Error?o.message:String(o)}`,r.errors.push(s)}if(t){let n=[];for(let o of this.repositoryRules)try{let s=await o.validateAsync(e,t);this.addErrorsToResult(r,s)}catch(s){let a=s instanceof Error?s.message:String(s);n.push({ruleName:o.ruleName,cause:a})}if(n.length>0){let o=new Map;for(let{ruleName:s,cause:a}of n){let c=o.get(a);c?c.push(s):o.set(a,[s])}for(let[s,a]of o){let c=new k;c.ruleType=a[0],c.severity="Error",a.length===1?c.message=`Validation rule '${a[0]}' failed: ${s}`:c.message=`${s} (affects ${a.length} rules: ${a.join(", ")})`,r.errors.push(c)}}}return r.isValid=r.errors.length===0,r}async validateYamlAsync(e,t){let r=this.parser.parseWithErrors(e);if(!r.isValid){let n=new oe;n.isValid=!1;for(let o of r.errors){let s=new k;s.ruleType="ParseError",s.severity="Error",s.lineNumber=o.line,s.column=o.column,s.message=o.message,o.keyName&&(s.entityName=o.keyName),o.errorType==="DuplicateKey"&&(s.suggestion="All property names must be unique across the entire document. Rename one of the duplicate properties to make them unique."),n.errors.push(s)}return n}return await this.validateAsync(r.document,t)}addDocumentRule(e){this.documentRules.push(e)}addRepositoryRule(e){this.repositoryRules.push(e)}removeDocumentRule(e){let t=this.documentRules.findIndex(r=>r instanceof e);t>=0&&this.documentRules.splice(t,1)}removeRepositoryRule(e){let t=this.repositoryRules.findIndex(r=>r instanceof e);t>=0&&this.repositoryRules.splice(t,1)}addErrorsToResult(e,t){for(let r of t)r.severity==="Error"?e.errors.push(r):this.includeWarnings&&e.warnings.push(r)}};ee();ee();var qe=class{resourceResolver;constructor(e){this.resourceResolver=e}async buildFromNameAsync(e,t){return(await this.resourceResolver.resolveEntityAsync(e,t))?.uri??null}buildFromName(e,t,r){if(e.includes(".")){let o=e.split("."),s=o[0],a=o[1],c=this.findPackageNameForAlias(r,s);if(c){for(let i of t.values())if(i.entityName===a&&i.uri.package_===c)return i.uri}return null}let n=t.get(e);return n?n.uri:null}create(e,t,r,n){return new K(e,t,r,n)}findPackageNameForAlias(e,t){if(!e.metadata.imports)return null;for(let[r,n]of Object.entries(e.metadata.imports))for(let o of n)if(o.alias===t||!o.alias&&o.packageName===t)return o.packageName;return null}};ee();async function Ot(l,e){let t=[],r=await l.getAllDocumentsAsync();for(let n of r){let o=n.metadata.namespace_;if(!o)continue;let s=o.publisher,a=o.package_,c=o.version?`${o.version.major}.${o.version.minor}.${o.version.patch}`:"0.0.0";for(let[i,p]of Object.entries(n.body)){if(!p||typeof p!="object")continue;let u=p.type;!u||typeof u!="string"||u!=="Package"&&lr(u,e)&&t.push({entityName:i,entity:p,documentNamespace:`${s}/${a}@${c}`,publisher:s,package_:a,version:c})}}return t}function lr(l,e){let t=xt(l),r=xt(e);return t===r}function xt(l){let e=l.lastIndexOf(".");if(e!==-1)return l.substring(e+1);let t=l.lastIndexOf("/");return t!==-1?l.substring(t+1):l}function B(l,e){return l.major!==e.major?l.major-e.major:l.minor!==e.minor?l.minor-e.minor:l.patch-e.patch}function Ge(l,e){return l.major===e.major&&l.minor===e.minor&&l.patch===e.patch}function dt(l){return`${l.major}.${l.minor}.${l.patch}`}function gt(l,e,t){let r=`${l}.${e}.${t}`;return{major:l,minor:e,patch:t,toString:()=>r,equals:n=>n?.major===l&&n?.minor===e&&n?.patch===t,getHashCode:()=>l<<20|e<<10|t,compareTo:n=>l!==n.major?l-n.major:e!==n.minor?e-n.minor:t-n.patch}}function Ct(l){let e=/^(\d+)\.(\d+)\.(\d+)$/.exec(l);return e?gt(Number(e[1]),Number(e[2]),Number(e[3])):null}function ze(l,e){return B(l,e)>=0&&l.major===e.major&&l.minor===e.minor}function Xe(l,e){return e.major===0?B(l,e)>=0&&l.major===0&&l.minor===e.minor:B(l,e)>=0&&l.major===e.major}function Tt(l,e={}){let{requestedVersion:t}=e;if(l.length===0)return{chosen:null,alternatives:[],multipleVersionsPresent:!1,exactRequestedVersionMissing:!!t};if(t){let n=l.find(o=>{let s=o.metadata.namespace_?.version;return!!s&&dt(s)===t});return n?{chosen:n,alternatives:l.filter(o=>o!==n),multipleVersionsPresent:l.length>1,exactRequestedVersionMissing:!1}:{chosen:null,alternatives:l,multipleVersionsPresent:l.length>1,exactRequestedVersionMissing:!0}}if(l.length===1)return{chosen:l[0],alternatives:[],multipleVersionsPresent:!1,exactRequestedVersionMissing:!1};let r=[...l].sort((n,o)=>{let s=n.metadata.namespace_?.version,a=o.metadata.namespace_?.version;return!s&&!a?0:s?a?B(a,s):-1:1});return{chosen:r[0],alternatives:r.slice(1),multipleVersionsPresent:!0,exactRequestedVersionMissing:!1}}var ht=class{documents=new Map;documentContents=new Map;parser;constructor(e){this.parser=e}async getAllDocumentsAsync(){return Array.from(this.documents.values())}async getDocumentAsync(e){return this.documents.get(e)??null}async getDocumentsByNamespaceAsync(e,t){let r=[];for(let n of this.documents.values())n.metadata?.namespace_?.publisher===e&&n.metadata?.namespace_?.package_===t&&r.push(n);return r}async getHighestCompatibleVersionAsync(e,t){let r=[];for(let o of this.documents.values())o.metadata?.namespace_?.publisher===e&&o.metadata?.namespace_?.package_===t.packageName&&o.metadata?.namespace_?.version!==void 0&&r.push(o);if(r.length===0)return null;let n=r.filter(o=>{let s=o.metadata.namespace_.version;if(!s)return!1;switch(t.versionOperator){case 0:return Ge(s,t.version);case 1:return ze(s,t.version);case 2:return Xe(s,t.version);case 3:return B(s,t.minVersion)>=0;default:return!1}});return n.length===0?null:(n.sort((o,s)=>{let a=o.metadata.namespace_.version,c=s.metadata.namespace_.version;return!a&&!c?0:a?c?B(c,a):-1:1}),n[0])}async saveDocumentAsync(e,t){this.documents.set(t,e);let r=this.parser.save(e);this.documentContents.set(t,r)}async deleteDocumentAsync(e){this.documents.delete(e),this.documentContents.delete(e)}async clearNamespaceAsync(e,t){let r=[];for(let[n,o]of this.documents.entries())o.metadata?.namespace_?.publisher===e&&o.metadata?.namespace_?.package_===t&&r.push(n);for(let n of r)this.documents.delete(n),this.documentContents.delete(n)}async getAllDocumentReferencesAsync(){let e=[];for(let t of this.documents.values())t.metadata?.namespace_&&e.push({identifier:t.metadata.namespace_.toString(),uri:`kanonak://${t.metadata.namespace_}`,hasParseError:!1});return e}async getDocumentContentAsync(e){let t=this.documentContents.get(e);if(t!==void 0)return t;let r=this.documents.get(e);return r!==void 0?this.parser.save(r):null}async getDocumentUriAsync(e){let t=this.documents.get(e);return t?t.metadata?.namespace_?`kanonak://${t.metadata.namespace_}`:`kanonak://${e}`:null}};import{VersionOperator as Ye}from"@kanonak-protocol/types/document/models/enums";var ur="https://{publisher}/index.txt",yr="https://{publisher}/{package}/{version}.kan.yml",Nt={version:1},Ne=class{cache=new Map;async getConfig(e){let t=this.cache.get(e);if(t)return t;let r=await this.fetchConfig(e);return this.cache.set(e,r),r}async fetchConfig(e){let t=`https://${e}/.well-known/kanonak.json`,r;try{r=await fetch(t)}catch{return Nt}if(r.status===404)return Nt;if(!r.ok)throw new Error(`Failed to fetch publisher config: ${t} (${r.status} ${r.statusText})`);let n=await r.json();if(typeof n.version!="number")throw new Error(`Invalid publisher config at ${t}: missing or invalid "version" field`);let o={version:n.version};return typeof n.index=="string"&&(o.index=n.index),typeof n.package=="string"&&(o.package=n.package),(n.auth==="none"||n.auth==="oauth"||n.auth==="bearer")&&(o.auth=n.auth),o}resolveIndexUrl(e,t){let r=t.index??ur;return _t(r,{publisher:e})}resolvePackageUrl(e,t,r,n){let o=n.package??yr;return _t(o,{publisher:e,package:t,version:r})}};function _t(l,e){let t=l;for(let[n,o]of Object.entries(e))t=t.replaceAll(`{${n}}`,o);let r=t.match(/\{[a-z]+\}/);if(r)throw new Error(`Unresolved variable ${r[0]} in URL template: ${l}`);return t}var Ce=class l{indexCache=new Map;configResolver;fetchFn;constructor(e){this.configResolver=e?.configResolver??new Ne,this.fetchFn=e?.fetchFn}async resolveVersion(e,t){let r=await this.getPackageVersions(e,t.packageName);if(r.length===0)return null;let n=r.filter(o=>this.isVersionCompatible(o,t.version,t.versionOperator));return n.length===0?null:(n.sort((o,s)=>this.compareVersionStrings(s,o)),n[0])}async getHighestVersion(e,t){let r=await this.getPackageVersions(e,t);return r.length===0?null:[...r].sort((o,s)=>this.compareVersionStrings(s,o))[0]}async listLatestPackages(e){let t=this.indexCache.get(e);t||(t=await this.fetchIndex(e),this.indexCache.set(e,t));let r=[];for(let[n,o]of t){if(o.length===0)continue;let s=[...o].sort((a,c)=>this.compareVersionStrings(c,a));r.push({packageName:n,version:s[0]})}return r.sort((n,o)=>n.packageName.localeCompare(o.packageName)),r}async getPackageUrl(e,t,r){let n=await this.configResolver.getConfig(e);return this.configResolver.resolvePackageUrl(e,t,r,n)}async getPackageVersions(e,t){let r=this.indexCache.get(e);return r||(r=await this.fetchIndex(e),this.indexCache.set(e,r)),r.get(t)??[]}async fetchIndex(e){let t=await this.configResolver.getConfig(e),r=this.configResolver.resolveIndexUrl(e,t),n=this.fetchFn?await this.fetchFn(r,e):await fetch(r);if(!n.ok)throw new Error(`Failed to fetch publisher index: ${r} (${n.status} ${n.statusText})`);let o=await n.text();return l.parseIndex(o)}static parseIndex(e){let t=new Map;for(let r of e.split(`
|
|
44
|
-
`)){let n=r.trim();if(!n||n.startsWith("#"))continue;let o=n.indexOf("/");if(o===-1)continue;let s=n.substring(0,o),a=n.substring(o+1);if(!s||!a)continue;let c=t.get(s);c?c.push(a):t.set(s,[a])}return t}isVersionCompatible(e,t,r){let n=l.parseVersion(e);if(!n)return!1;switch(r){case Ye.Any:return!0;case Ye.Exact:return n.major===t.major&&n.minor===t.minor&&n.patch===t.patch;case Ye.Compatible:return n.major===t.major&&n.minor===t.minor&&n.patch>=t.patch;case Ye.Major:return n.major!==t.major?!1:n.minor>t.minor?!0:n.minor===t.minor?n.patch>=t.patch:!1;default:return!1}}static parseVersion(e){let t=e.split(".");if(t.length<2)return null;let r=parseInt(t[0],10),n=parseInt(t[1],10),o=t.length>=3?parseInt(t[2],10):0;return isNaN(r)||isNaN(n)||isNaN(o)?null:{major:r,minor:n,patch:o}}compareVersionStrings(e,t){let r=l.parseVersion(e),n=l.parseVersion(t);return!r&&!n?0:r?n?r.major!==n.major?r.major-n.major:r.minor!==n.minor?r.minor-n.minor:r.patch-n.patch:1:-1}};var kt=class{parser=new E;publisherIndex;documents=new Map;contentCache=new Map;fetchFn;onFetch;getFromCache;constructor(e){this.onFetch=e?.onFetch,this.getFromCache=e?.getFromCache,this.fetchFn=e?.fetchFn,this.publisherIndex=e?.fetchFn?new Ce({fetchFn:e.fetchFn}):new Ce}async getHighestCompatibleVersionAsync(e,t){let r=await this.publisherIndex.resolveVersion(e,t);if(!r)return null;let n=`${e}/${t.packageName}@${r}`,o=this.documents.get(n);if(o)return o;if(this.getFromCache){let p=this.getFromCache(e,t.packageName,r);if(p){let u=this.parser.parse(p);return this.documents.set(n,u),this.contentCache.set(n,p),u}}let s=await this.publisherIndex.getPackageUrl(e,t.packageName,r),a=this.fetchFn?await this.fetchFn(s,e):await fetch(s);if(!a.ok)throw new Error(`Failed to fetch Kanonak package: ${s} (${a.status} ${a.statusText})`);let c=await a.text();this.onFetch&&this.onFetch(e,t.packageName,r,c);let i=this.parser.parse(c);return this.documents.set(n,i),this.contentCache.set(n,c),i}async getAllDocumentsAsync(){return Array.from(this.documents.values())}async getDocumentAsync(e){return this.documents.get(e)??null}async getDocumentsByNamespaceAsync(e,t){return Array.from(this.documents.values()).filter(r=>{let n=r.metadata.namespace_;return n&&n.publisher===e&&n.package_===t})}async saveDocumentAsync(e,t){throw new Error("HttpKanonakDocumentRepository is read-only")}async deleteDocumentAsync(e){throw new Error("HttpKanonakDocumentRepository is read-only")}async clearNamespaceAsync(e,t){throw new Error("HttpKanonakDocumentRepository is read-only")}async getAllDocumentReferencesAsync(){return[]}async getDocumentContentAsync(e){return this.contentCache.get(e)??null}async getDocumentUriAsync(e){let t=e.match(/^(.+?)\/(.+?)@(.+)$/);if(!t)return null;let[,r,n,o]=t;return this.publisherIndex.getPackageUrl(r,n,o)}};import{CtlKanonakUriType as _e,PathSegmentType as bt}from"@kanonak-protocol/types/ctl/parsing/enums";var mr=/\.?([a-zA-Z_][a-zA-Z0-9_-]*|\[\d+\])/g;function fr(l){let e=l.split(".").map(Number),t=e[0]||0,r=e[1]||0,n=e[2]||0;return{major:t,minor:r,patch:n,toString:()=>`${t}.${r}.${n}`,equals:o=>o&&typeof o=="object"&&o.major===t&&o.minor===r&&o.patch===n,getHashCode:()=>t<<20|r<<10|n,compareTo:o=>t!==o.major?t-o.major:r!==o.minor?r-o.minor:n-o.patch}}var $e=class l{scheme="kanonak";publisher;package_;version;resourceName;path;rawUri;constructor(e){this.publisher=e.publisher,this.package_=e.package_,this.version=e.version,this.resourceName=e.resourceName,this.path=e.path??[],this.rawUri=e.rawUri}get uriType(){return this.path.length>0?_e.DeepLink:this.resourceName!=null?_e.Resource:this.version!=null?_e.VersionedPackage:this.package_!=null?_e.Package:_e.Publisher}get namespace_(){return this.package_==null?null:this.version==null?`${this.publisher}/${this.package_}`:`${this.publisher}/${this.package_}@${this.version}`}static parse(e){if(!e||e.trim().length===0)throw new Error("Kanonak URI string cannot be null or empty");if(!e.toLowerCase().startsWith("kanonak://"))throw new Error(`Invalid Kanonak URI: '${e}'. Must start with 'kanonak://'`);let t=e.substring(8);if(!t||t.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Publisher is required after 'kanonak://'`);let r=t.indexOf("#"),n=null,o;if(r>=0){if(o=t.substring(0,r),n=t.substring(r+1),!n||n.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Deep link path required after '#'`)}else o=t;let s,a=null,c=null,i=null,p=o.indexOf("@");if(p>=0){let y=o.substring(0,p),m=o.substring(p+1),f=y.indexOf("/");if(f<0)throw new Error(`Invalid Kanonak URI: '${e}'. Expected format: publisher/package@version/resource`);if(s=y.substring(0,f),a=y.substring(f+1),!s||s.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Publisher cannot be empty`);if(!a||a.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Package cannot be empty`);let d=m.indexOf("/");if(d<0)throw new Error(`Invalid Kanonak URI: '${e}'. CTL requires resource references (kanonak://publisher/package@version/resource)`);let g=m.substring(0,d);if(i=m.substring(d+1),!g||g.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Version required after '@'`);if(c=fr(g),!i||i.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Resource name cannot be empty`)}else{let y=o.split("/");if(y.length<3)throw new Error(`Invalid Kanonak URI: '${e}'. CTL requires resource references (kanonak://publisher/package/resource)`);if(y.length>3)throw new Error(`Invalid Kanonak URI: '${e}'. Too many path segments. Expected: publisher/package/resource`);if(s=y[0],a=y[1],i=y[2],!s||s.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Publisher cannot be empty`);if(!a||a.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Package cannot be empty`);if(!i||i.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Resource name cannot be empty`)}let u=[];return n!=null&&(u=dr(n,e)),new l({publisher:s,package_:a,version:c,resourceName:i,path:u,rawUri:e})}static tryParse(e){try{return l.parse(e)}catch{return null}}static isKanonakUri(e){return!!e&&e.trim().length>0&&e.toLowerCase().startsWith("kanonak://")}toString(){let e=`kanonak://${this.publisher}`;if(this.package_!=null&&(e+=`/${this.package_}`,this.version!=null&&(e+=`@${this.version}`),this.resourceName!=null&&(e+=`/${this.resourceName}`,this.path.length>0))){e+="#";let t=!0;for(let r of this.path)r.type_===bt.Index?e+=`[${r.index}]`:(t||(e+="."),e+=r.name),t=!1}return e}equals(e){return e instanceof l?this.rawUri.toLowerCase()===e.rawUri.toLowerCase():!1}getHashCode(){let e=0,t=this.rawUri.toLowerCase();for(let r=0;r<t.length;r++)e=(e<<5)-e+t.charCodeAt(r),e|=0;return e}};function dr(l,e){let t=[],r=new RegExp(mr.source,"g"),n=0,o;for(;(o=r.exec(l))!==null;){let s=o[1];if(s.startsWith("[")&&s.endsWith("]")){let a=s.substring(1,s.length-1),c=parseInt(a,10);if(isNaN(c))throw new Error(`Invalid Kanonak URI: '${e}'. Invalid array index: ${s}`);t.push({type_:bt.Index,index:c,toString:()=>`[${c}]`})}else t.push({type_:bt.Property,name:s,toString:()=>s});n+=o[0].length}if(n!==l.length)throw new Error(`Invalid Kanonak URI: '${e}'. Invalid path syntax in: ${l}`);return t}import{VersionOperator as Z}from"@kanonak-protocol/types/document/models/enums";import*as Lt from"js-yaml";var gr=/\[([^\]]+)\]\((kanonak:\/\/[^)]+)\)/gi,hr=/\[([^\]]+)\]\(kan:\/\/([^)]+)\)/gi,kr=/```[\s\S]*?```|`[^`]+`/g,br=/^---\s*\n([\s\S]*?)\n---\s*\n/;function Rr(l,e,t){let r=`${l}.${e}.${t}`;return{major:l,minor:e,patch:t,toString:()=>r,equals:n=>n?.major===l&&n?.minor===e&&n?.patch===t,getHashCode:()=>l<<20|e<<10|t,compareTo:n=>l!==n.major?l-n.major:e!==n.minor?e-n.minor:t-n.patch}}function vr(l,e,t,r,n){let o=r===Z.Compatible?"~":r===Z.Major?"^":r===Z.Exact?"=":"*",s=`${e} ${o} ${t}`;return{package_:s,publisher:l,packageName:e,versionOperator:r,version:t,alias:n,get minVersion(){return t},get maxVersion(){return t},toEmbeddedObject(){let a={package:e,version:t.toString()};return n&&(a.alias=n),r!==Z.Exact&&(a.match=o),a},toString(){return s}}}var Je=class{parse(e,t){if(e==null)throw new Error("Content cannot be null");e.charCodeAt(0)===65279&&(e=e.substring(1));let r=br.exec(e);return r?this.parseWithFrontmatter(e,r,t??null):this.parseInline(e,t??null)}async parseFileAsync(e){if(!e||e.trim().length===0)throw new Error("File path cannot be null or empty");let r=(await import("fs")).readFileSync(e,"utf-8");return this.parse(r,e)}parseWithFrontmatter(e,t,r){let n=t[1],o=e.substring(t[0].length),s=null,a=new Map;try{let i=Lt.load(n);if(!i)throw new Error("Frontmatter YAML is empty");if(!i.imports||!Array.isArray(i.imports))throw new Error("Frontmatter must contain an 'imports' sequence");let p={};for(let y of i.imports){if(!y||typeof y!="object")throw new Error("Each import entry must be a mapping with 'publisher' and 'packages'");let m=y.publisher?.toString();if(!m)throw new Error("Each import entry requires a 'publisher' property");if(!y.packages||!Array.isArray(y.packages))throw new Error(`Import entry for publisher '${m}' requires a 'packages' sequence`);p[m]||(p[m]=[]);for(let f of y.packages){if(!f||typeof f!="object")throw new Error(`Each package in publisher '${m}' must be a mapping`);let g=(f.version?.toString()??"1.0.0").split(".").map(Number),h=Rr(g[0]||0,g[1]||0,g[2]||0),b=f.match?.toString(),R=b==="^"?Z.Major:b==="~"?Z.Compatible:b==="*"?Z.Any:Z.Exact,v=vr(m,f.package?.toString()??"",h,R,f.alias?.toString()??null);p[m].push(v)}}let u=[];for(let y of Object.values(p))u.push(...y);s={namespace_:void 0,imports:p,get allImports(){return u}},a=this.buildAliasMap(p)}catch(i){let p={displayText:"(frontmatter)",rawUri:"",startOffset:0,endOffset:t[0].length,line:1,column:1,isResolved:!1,error:`Failed to parse frontmatter: ${i.message}`,get fullMarkdownLink(){return`[${this.displayText}](${this.rawUri})`}};return Rt({metadata:null,rawMarkdown:o,frontmatterLength:t[0].length,filePath:r,references:[p]})}let c=this.parseMarkdownBody(o,a,t[0].length);return Rt({metadata:s,rawMarkdown:o,frontmatterLength:t[0].length,filePath:r,references:c})}parseInline(e,t){let r=this.parseMarkdownBody(e,new Map,0);return Rt({metadata:null,rawMarkdown:e,frontmatterLength:0,filePath:t,references:r})}parseMarkdownBody(e,t,r){let n=[],o=Pr(e),s=new RegExp(gr.source,"gi"),a;for(;(a=s.exec(e))!==null;){if(Mt(a.index,o))continue;let i=a[1],p=a[2],{line:u,column:y}=Ut(e,a.index),m={displayText:i,rawUri:p,startOffset:a.index+r,endOffset:a.index+a[0].length+r,line:u,column:y,isResolved:!1,get fullMarkdownLink(){return`[${this.displayText}](${this.rawUri})`}};try{m.parsedUri=$e.parse(p)}catch(f){m.error=f.message}n.push(m)}let c=new RegExp(hr.source,"gi");for(;(a=c.exec(e))!==null;){if(Mt(a.index,o))continue;let i=a[1],p=a[2],{line:u,column:y}=Ut(e,a.index),m=null,f=null;try{m=wr(p,t)}catch(g){f=g.message}let d={displayText:i,rawUri:m??`kan://${p}`,startOffset:a.index+r,endOffset:a.index+a[0].length+r,line:u,column:y,isResolved:!1,error:f,get fullMarkdownLink(){return`[${this.displayText}](${this.rawUri})`}};if(m!=null&&f==null)try{d.parsedUri=$e.parse(m)}catch(g){d.error=g.message}n.push(d)}return n.sort((i,p)=>i.startOffset-p.startOffset),n}buildAliasMap(e){let t=new Map;for(let[r,n]of Object.entries(e))for(let o of n){let s=o.alias??o.packageName;t.set(s.toLowerCase(),{publisher:r,package_:o.packageName,version:o.version})}return t}};function Rt(l){return{metadata:l.metadata,get hasFrontmatter(){return l.metadata!=null},rawMarkdown:l.rawMarkdown,frontmatterLength:l.frontmatterLength,filePath:l.filePath,references:l.references,get referenceCount(){return l.references.length},get allReferencesResolved(){return l.references.every(e=>e.isResolved)},get unresolvedReferences(){return l.references.filter(e=>!e.isResolved)},get errorReferences(){return l.references.filter(e=>e.error!=null)}}}function Pr(l){let e=[],t=new RegExp(kr.source,"g"),r;for(;(r=t.exec(l))!==null;)e.push([r.index,r.index+r[0].length]);return e}function Mt(l,e){for(let[t,r]of e)if(l>=t&&l<r)return!0;return!1}function Ut(l,e){let t=1,r=1;for(let n=0;n<e&&n<l.length;n++)l[n]===`
|
|
45
|
-
`?(t++,r=1):r++;return{line:t,column:r}}function wr(l,e){if(!l||l.trim().length===0)throw new Error("kan:// link cannot be empty");if(e.size===0)throw new Error("kan:// links require frontmatter with imports");let t=null,r=l,n=l.indexOf(".");if(n>0&&(t=l.substring(0,n),r=l.substring(n+1),!r||r.trim().length===0))throw new Error(`Resource name required after alias '${t}.'`);if(t!=null){let o=e.get(t.toLowerCase());if(!o){let s=Array.from(e.keys()).join(", ");throw new Error(`Unknown alias: '${t}'. Available: ${s}`)}return`kanonak://${o.publisher}/${o.package_}@${o.version}/${r}`}else{let o=e.values().next().value;if(!o)throw new Error(`Cannot resolve '${r}': no imports defined`);return`kanonak://${o.publisher}/${o.package_}@${o.version}/${r}`}}import{CtlValidationErrorType as M,CtlValidationSeverity as Q}from"@kanonak-protocol/types/ctl/models/enums";import{CtlKanonakUriType as Ft,PathSegmentType as Bt}from"@kanonak-protocol/types/ctl/parsing/enums";var Ze=class{repository;constructor(e){if(!e)throw new Error("Repository is required for CTL validation");this.repository=e}async validateAsync(e){if(!e)throw new Error("Document cannot be null");let t=[],r=[];for(let o of e.references){if(!o.parsedUri){t.push({errorType:M.InvalidUri,severity:Q.Error,message:o.error??"Failed to parse Kanonak URI",reference:o,line:o.line,column:o.column,toString(){let s=this.line!=null?`(${this.line}:${this.column})`:"";return`${Q[this.severity]}: ${this.message} ${s}`.trim()}});continue}try{await this.resolveReference(o,t,r)}catch(s){t.push({errorType:M.ParseError,severity:Q.Error,message:`Error resolving reference: ${s.message}`,reference:o,line:o.line,column:o.column,toString(){let a=this.line!=null?`(${this.line}:${this.column})`:"";return`${Q[this.severity]}: ${this.message} ${a}`.trim()}})}}return{isValid:t.length===0,document:e,errors:t,warnings:r,get totalReferences(){return e.referenceCount},get resolvedReferences(){return e.references.filter(o=>o.isResolved).length},get summary(){if(t.length===0)return`All ${e.referenceCount} references validated`;let o=e.references.filter(s=>s.isResolved).length;return`${t.length} error(s), ${o}/${e.referenceCount} references resolved`}}}async resolveReference(e,t,r){let n=e.parsedUri;switch(n.uriType){case Ft.Resource:await this.resolveResource(e,t);break;case Ft.DeepLink:await this.resolveDeepLink(e,t);break;default:t.push({errorType:M.InvalidUri,severity:Q.Error,message:`Unsupported URI type: ${n.uriType}. CTL only supports resource references.`,reference:e,line:e.line,column:e.column,suggestion:"Use resource URIs: kanonak://publisher/package@version/resource",toString(){let o=this.line!=null?`(${this.line}:${this.column})`:"";return`${Q[this.severity]}: ${this.message} ${o}`.trim()}});break}}async resolveResource(e,t){let r=e.parsedUri,n=r.namespace_,o=await this.repository.getDocumentAsync(n);if(!o){t.push(this.createError(M.PackageNotFound,`Package not found: ${n}`,e));return}if(o.body&&o.body[r.resourceName])e.isResolved=!0;else{let s=o.body?Object.keys(o.body).slice(0,5):[];t.push(this.createError(M.EntityNotFound,`Resource not found: ${r.resourceName} in ${n}`,e,s.length>0?`Available resources: ${s.join(", ")}`:void 0))}}async resolveDeepLink(e,t){let r=e.parsedUri,n=r.namespace_,o=await this.repository.getDocumentAsync(n);if(!o){t.push(this.createError(M.PackageNotFound,`Package not found: ${n}`,e));return}if(!o.body||!o.body[r.resourceName]){t.push(this.createError(M.EntityNotFound,`Resource not found: ${r.resourceName} in ${n}`,e));return}let s=o.body[r.resourceName],a=r.resourceName;for(let c of r.path){if(s==null){t.push(this.createError(M.PathNotFound,`Path not found: ${a}`,e));return}if(c.type_===Bt.Property){let i=c.name;a+=`.${i}`;let p=Ir(s,i);if(p===void 0){let u=Dr(s);t.push(this.createError(M.PathNotFound,`Path not found: ${a}`,e,u));return}s=p}else if(c.type_===Bt.Index){let i=c.index;a+=`[${i}]`;let p=Ar(s,i);if(p===void 0){let u=Sr(s);t.push(this.createError(M.IndexOutOfBounds,`Index out of bounds: ${a}`,e,u));return}s=p}}e.isResolved=!0,e.resolvedValue=s}createError(e,t,r,n){return{errorType:e,severity:Q.Error,message:t,reference:r,line:r.line,column:r.column,suggestion:n,toString(){let o=this.line!=null?`(${this.line}:${this.column})`:"";return`${Q[this.severity]}: ${this.message} ${o}`.trim()}}}};function Ir(l,e){if(l&&typeof l=="object"&&!Array.isArray(l)){if(e in l)return l[e];let t=Object.keys(l).find(r=>r.toLowerCase()===e.toLowerCase());if(t)return l[t]}}function Ar(l,e){if(Array.isArray(l)&&e>=0&&e<l.length)return l[e]}function Dr(l){if(l&&typeof l=="object"&&!Array.isArray(l)){let e=Object.keys(l).slice(0,5);if(e.length>0)return`Available properties: ${e.join(", ")}`}}function Sr(l){if(Array.isArray(l))return l.length>0?`Collection has ${l.length} items (valid indices: 0-${l.length-1})`:"Collection is empty"}import{ResolvedResourceType as Ke}from"@kanonak-protocol/types/ctl/resolution/enums";var Vr=new Set(["kanonak.org/core-rdf","kanonak.org/core-rdfs","kanonak.org/core-owl","kanonak.org/core-xsd","kanonak.org/core-kanonak"]);var Qe=class{repository;constructor(e){if(!e)throw new Error("Repository is required for CTL graph resolution");this.repository=e}async resolveAsync(e,t=1e3){if(!e)throw new Error("Document cannot be null");let r=new Set,n=[],o=[],s=[],a=[],c=new Set;for(let d of e.references)d.parsedUri&&c.add(d.parsedUri.toString());let i=new Map,p=new Map,u=await this.repository.getAllDocumentsAsync();for(let d of u){let g=d.metadata?.namespace_?.toString();if(!g||!d.body)continue;let h=[];for(let[b,R]of Object.entries(d.body))if(R&&typeof R=="object"&&!Array.isArray(R)){let v=this.createMockSubjectKanonak(b,R,g),D=`kanonak://${g}/${b}`;i.has(D)||i.set(D,{entity:v,namespace:g}),h.push(v)}p.set(g,h)}let y=0,m=!1;for(let d of e.references){if(!d.parsedUri){a.push({reference:d.rawUri,reason:d.error??"Failed to parse URI"});continue}let g=d.parsedUri.toString();if(r.has(g))continue;let h=await this.resolveEntityRecursive(g,null,null,0,t,r,c,n,o,s,a,i,p);y=Math.max(y,h),h>=t&&(m=!0)}let f=xr(e.rawMarkdown);return{sourceFile:e.filePath??null,originalContent:e.rawMarkdown,title:f,directReferences:n,inheritedReferences:o,foundationTypes:s,get totalResourceCount(){return n.length+o.length+s.length},get allResources(){return[...n,...o,...s]},maxDepthReached:y,wasTruncated:m,unresolvedResources:a}}async resolveEntityRecursive(e,t,r,n,o,s,a,c,i,p,u,y,m){if(s.has(e)||(s.add(e),n>=o))return n;if(!t){let R=y.get(e);if(!R)return u.push({reference:e,reason:"Resource not found in workspace"}),n;t=R.entity}let f=t,d=f.namespace??f.namespace_??"";!r&&d&&(r=await this.repository.getDocumentAsync(d));let g=this.createResolvedResource(t,e,n,m);switch(this.classifyTier(e,d,a)){case 0:c.push(g);break;case 2:p.push(g);break;default:i.push(g);break}let b=n;for(let R of g.parentClasses){let v=this.resolveReferenceToUri(R,d,r);if(v&&!s.has(v)){let D=y.get(v),$=await this.resolveEntityRecursive(v,D?.entity??null,null,n+1,o,s,a,c,i,p,u,y,m);b=Math.max(b,$)}}for(let R of g.properties.filter(v=>v.isObjectProperty)){let v=this.resolveReferenceToUri(R.rangeType,d,r);if(v&&!s.has(v)){let D=y.get(v),$=await this.resolveEntityRecursive(v,D?.entity??null,null,n+1,o,s,a,c,i,p,u,y,m);b=Math.max(b,$)}}if(g.instanceOf_){let R=this.resolveReferenceToUri(g.instanceOf_,d,r);if(R&&!s.has(R)){let v=y.get(R),D=await this.resolveEntityRecursive(R,v?.entity??null,null,n+1,o,s,a,c,i,p,u,y,m);b=Math.max(b,D)}}return b}createResolvedResource(e,t,r,n){let o=e,s=o.name??"",a=o.namespace??o.namespace_??"",c=this.classifyEntityType(e),i=Wt(e),p=Kr(e),u=jr(e),y=[];if(c===Ke.Class){let m=n.get(a);m&&(y=Er(s,m))}return{name:s,kanonakUri:t,resource:e,resourceType:c,parentClass:p.length>0?p[0]:null,parentClasses:p,comment:i,properties:y,namespace_:a,resolutionDepth:r,instanceOf_:u}}classifyEntityType(e){if(w.isClassType(e))return Ke.Class;if(w.isAnnotationPropertyType(e))return Ke.AnnotationProperty;if(w.isDatatypePropertyType(e))return Ke.DatatypeProperty;if(w.isObjectPropertyType(e))return Ke.ObjectProperty;let t=w.getTypeUri(e);return t&&!w.isCoreOntologyType(t)?Ke.Instance:Ke.Other}classifyTier(e,t,r){return r.has(e)?0:$r(t)?2:1}resolveReferenceToUri(e,t,r){if(e.toLowerCase().startsWith("kanonak://"))return e;if(e.includes(".")&&r?.metadata){let n=e.indexOf("."),o=e.substring(0,n),s=e.substring(n+1);if(s){let a=r.metadata.allImports;if(a){for(let c of a)if((c.alias??c.packageName).toLowerCase()===o.toLowerCase())return`kanonak://${c.version?`${c.publisher}/${c.packageName}@${c.version}`:`${c.publisher}/${c.packageName}`}/${s}`}}}return!e.includes(".")&&t?`kanonak://${t}/${e}`:null}createMockSubjectKanonak(e,t,r){let n=[];for(let[o,s]of Object.entries(t))typeof s=="string"?o==="type"||o==="subClassOf"||o==="domain"||o==="range"||o==="subPropertyOf"?n.push({predicate:{subject:{name:o,publisher:"",package_:""}},object:{subject:{name:s,publisher:"",package_:""}}}):n.push({predicate:{subject:{name:o,publisher:"",package_:""}},object:s}):Array.isArray(s)&&n.push({predicate:{subject:{name:o,publisher:"",package_:""}},object:s.map(a=>typeof a=="string"?{subject:{name:a,publisher:"",package_:""}}:a)});return{name:e,namespace_:r,statement:n,entity:t}}};function $r(l){if(!l)return!1;let e=l.split("/");if(e.length<2)return!1;let t=e[0],r=e[1],n=r.includes("@")?r.split("@")[0]:r;return Vr.has(`${t}/${n}`)}function Wt(l){let e=l;if(e.entity&&typeof e.entity=="object")return e.entity.comment??null;if(e.statement&&Array.isArray(e.statement)){for(let t of e.statement)if(t.predicate?.subject?.name==="comment"&&typeof t.object=="string")return t.object}return null}function Kr(l){let e=[],t=l,r=t.name??"";if(t.entity&&typeof t.entity=="object"){let n=t.entity.subClassOf;if(typeof n=="string")n.toLowerCase()!==r.toLowerCase()&&e.push(n);else if(Array.isArray(n))for(let o of n){let s=typeof o=="string"?o:o?.subject?.name??o?.name;s&&s.toLowerCase()!==r.toLowerCase()&&e.push(s)}return e}if(t.statement&&Array.isArray(t.statement)){for(let n of t.statement)if(n.predicate?.subject?.name==="subClassOf"){if(n.object?.subject?.name){let o=n.object.subject.name;o.toLowerCase()!==r.toLowerCase()&&e.push(o)}else if(Array.isArray(n.object))for(let o of n.object){let s=o?.subject?.name??o?.name;s&&s.toLowerCase()!==r.toLowerCase()&&e.push(s)}}}return e}function jr(l){let e=w.getTypeUri(l);return e?w.isCoreOntologyType(e)?null:e.name:null}function Er(l,e){let t=[];for(let r of e){if(!w.isAnyPropertyType(r))continue;let n=r,o=[],s=[];if(n.entity&&typeof n.entity=="object"){let p=n.entity.domain;if(typeof p=="string")o.push(p);else if(Array.isArray(p))for(let y of p)o.push(typeof y=="string"?y:y?.name??String(y));let u=n.entity.range;if(typeof u=="string")s.push(u);else if(Array.isArray(u))for(let y of u)s.push(typeof y=="string"?y:y?.name??String(y))}if(!o.some(p=>p.toLowerCase()===l.toLowerCase()))continue;s.length===0&&s.push("unknown");let a=w.isObjectPropertyType(r),c=n.entity?.collection!=null,i=Wt(r);t.push({name:n.name??"",rangeTypes:s,domains:o,get rangeType(){return s.length>0?s.join(", "):"unknown"},isObjectProperty:a,isCollection:c,comment:i})}return t}function xr(l){let e=l.split(`
|
|
46
|
-
`);for(let t of e){let r=t.trim();if(r.startsWith("# ")&&!r.startsWith("## "))return r.substring(2).trim()}return null}import{ResolvedResourceType as O}from"@kanonak-protocol/types/ctl/resolution/enums";var
|
|
47
|
-
`)}generateAnchor(e){return e.toLowerCase()}renderInternalLink(e){return this.resolvedResourceNames.has(e.toLowerCase())?`[${e}](#${this.generateAnchor(e)})`:e}renderInternalLinks(e){return e.map(t=>this.renderInternalLink(t)).join(", ")}transformTemplateLinks(e){let t=/\[([^\]]+)\]\(can:\/\/([^)]+)\)/g;return e.replace(t,(r,n,o)=>{let s;if(o.includes("#"))s=o.substring(o.indexOf("#")+1);else{let a=o.lastIndexOf(".");s=a>=0?o.substring(a+1):o}return this.resolvedResourceNames.has(s.toLowerCase())?`[${n}](#${this.generateAnchor(s)})`:r})}renderSummary(e,t){e.push(`**Total Resources**: ${t.totalResourceCount}`),e.push(`- Direct: ${t.directReferences.length}`),e.push(`- Inherited: ${t.inheritedReferences.length}`),e.push(`- Foundation: ${t.foundationTypes.length}`),t.wasTruncated&&(e.push(""),e.push(`**Resolution was truncated at depth ${t.maxDepthReached}** - some resources may be missing.`),e.push("To include more resources, re-run with a higher depth limit: `kanonak ctl resolve <file> --depth 2000`")),e.push("")}renderQuickReference(e,t){let r=t.allResources;if(r.length===0)return;e.push("## Quick Reference"),e.push("");let n=r.filter(
|
|
48
|
-
Credential storage requires IndexedDB support in your browser.`))})}async function
|
|
43
|
+
3. Use separate properties instead of nesting`,expectedValue:`A simple value of type '${d}'`});else if(!this.validateDatatypeValue(d,l)){let g={ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:c,message:`Property '${c}' expects type '${d}' but instance '${o}' has value of type '${this.getValueTypeName(l)}'`,suggestion:`Provide a value of type '${d}'`,toString:()=>""};d&&(g.expectedValue=d),r.push(g)}}else if(f==="ObjectProperty")if(Array.isArray(l))for(let g=0;g<l.length;g++){let h=l[g];typeof h!="string"&&(typeof h!="object"||h===null||Array.isArray(h))&&r.push({ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:`${c}[${g}]`,message:`ObjectProperty '${c}' array item ${g} in instance '${o}' has invalid type '${this.getValueTypeName(h)}'`,suggestion:"Array items must be references (strings) or embedded objects (dictionaries)",expectedValue:"string or object"})}else typeof l!="string"&&(typeof l!="object"||l===null||Array.isArray(l))&&r.push({ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:c,message:`ObjectProperty '${c}' in instance '${o}' has invalid value type '${this.getValueTypeName(l)}'`,suggestion:"Value must be a reference (string), embedded object (dictionary), or array of these",expectedValue:`Reference to ${d} or embedded ${d} object`})}}return r}validateDatatypeValue(e,t){switch(e?.toLowerCase()){case"string":return typeof t=="string";case"integer":case"int":return typeof t=="number"&&Number.isInteger(t);case"decimal":return typeof t=="number";case"boolean":return typeof t=="boolean";case"float":case"double":return typeof t=="number";default:return!0}}getValueTypeName(e){return typeof e=="string"?"string":typeof e=="number"?Number.isInteger(e)?"integer":"decimal":typeof e=="boolean"?"boolean":Array.isArray(e)?"array":typeof e=="object"&&e!==null?"object":e===null?"null":e===void 0?"undefined":typeof e}getPropertyValue(e,t){if(t in e){let r=e[t];if(Array.isArray(r)){let n=[];for(let o of r)n.push(o?.toString()??"");return n.length>0?n[0]:void 0}return r?.toString()}}};var Ve=class{builtInClasses=new Set(["Resource","Class","Literal","Thing","Nothing","Property","DatatypeProperty","ObjectProperty","AnnotationProperty","FunctionalProperty","InverseFunctionalProperty","TransitiveProperty","SymmetricProperty"]);get ruleName(){return"ClassDefinition"}async validateAsync(e,t){let r=[],n=new Map,o=new Set;for(let[a,i]of Object.entries(e.body))if(typeof i=="object"&&i!==null&&!Array.isArray(i)){let l=i.type;if(l)if(Array.isArray(l))for(let u of l){let m=u?.toString();if(m==="Class"||m&&m.endsWith(".Class")){o.add(a);break}}else{let u=l?.toString();(u==="Class"||u&&u.endsWith(".Class"))&&o.add(a)}}for(let[a,i]of Object.entries(e.body))if(typeof i=="object"&&i!==null&&!Array.isArray(i)){let c=i,l=c.type;if(l)if(Array.isArray(l)){let u=!1;for(let m of l){let y=m?.toString();if(y&&this.isDefinitionType(y)){u=!0;break}}if(!u)for(let m of l){let y=m?.toString();y&&y.trim().length>0&&(n.has(y)||n.set(y,[]),n.get(y).push(a))}}else{let u=l?.toString();u&&u.trim().length>0&&(this.isDefinitionType(u)||(n.has(u)||n.set(u,[]),n.get(u).push(a)))}this.checkNestedTypes(c,a,n,a)}let s=new A(t);for(let[a,i]of n){if(this.builtInClasses.has(a)||o.has(a))continue;let c=await s.resolveEntityAsync(a,e);if(!(c&&this.isClassEntity(c.entity))){let u=Array.from(new Set(i)).sort();for(let m of u)r.push({ruleType:this.ruleName,severity:"Error",message:`Class '${a}' is not defined or imported`,suggestion:`Define '${a}' as a Class in this document, or import a namespace that contains it`,entityName:m,propertyName:"type",actualValue:a,expectedValue:"Defined or imported class"})}}return r}checkNestedTypes(e,t,r,n){if(typeof e=="object"&&e!==null&&!Array.isArray(e)){let o=e,s=o.type;if(s){let a=new Set(["Class","DatatypeProperty","ObjectProperty","AnnotationProperty"]);if(Array.isArray(s))for(let i of s){let c=i?.toString();c&&c.trim().length>0&&!a.has(c)&&(r.has(c)||r.set(c,[]),r.get(c).push(n))}else{let i=s?.toString();i&&i.trim().length>0&&!a.has(i)&&(r.has(i)||r.set(i,[]),r.get(i).push(n))}}for(let[a,i]of Object.entries(o))if(a!=="type"){let c=`${n}.${a}`;this.checkNestedTypes(i,t,r,c)}}else if(Array.isArray(e))for(let o=0;o<e.length;o++){let s=`${n}[${o}]`;this.checkNestedTypes(e[o],t,r,s)}}isClassEntity(e){if(!e)return!1;let t=e.type;if(!t)return!1;if(Array.isArray(t))for(let r of t){let n=r?.toString();if(n==="Class"||n&&n.endsWith(".Class"))return!0}else{let r=t?.toString();if(r==="Class"||r&&r.endsWith(".Class"))return!0}return!1}isDefinitionType(e){return!e||e.trim().length===0?!1:new Set(["Class","Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]).has(e)?!0:e.endsWith(".Class")||e.endsWith(".Property")||e.endsWith(".DatatypeProperty")||e.endsWith(".ObjectProperty")||e.endsWith(".AnnotationProperty")}};var He=class{parser;documentRules;repositoryRules;includeWarnings=!0;constructor(e){this.parser=e??new E,this.documentRules=[new se,new ae,new ie,new ce],this.repositoryRules=[new pe,new le,new ue,new me,new ye,new fe,new de,new ge,new he,new ke,new be,new Re,new ve,new Pe,new we,new Ie,new Ae,new De,new Se,new Ve]}async validateAsync(e,t){let r=new oe;for(let n of this.documentRules)try{let o=n.validate(e);this.addErrorsToResult(r,o)}catch(o){let s=new k;s.ruleType=n.ruleName,s.severity="Error",s.message=`Validation rule '${n.ruleName}' failed: ${o instanceof Error?o.message:String(o)}`,r.errors.push(s)}if(t){let n=[];for(let o of this.repositoryRules)try{let s=await o.validateAsync(e,t);this.addErrorsToResult(r,s)}catch(s){let a=s instanceof Error?s.message:String(s);n.push({ruleName:o.ruleName,cause:a})}if(n.length>0){let o=new Map;for(let{ruleName:s,cause:a}of n){let i=o.get(a);i?i.push(s):o.set(a,[s])}for(let[s,a]of o){let i=new k;i.ruleType=a[0],i.severity="Error",a.length===1?i.message=`Validation rule '${a[0]}' failed: ${s}`:i.message=`${s} (affects ${a.length} rules: ${a.join(", ")})`,r.errors.push(i)}}}return r.isValid=r.errors.length===0,r}async validateYamlAsync(e,t){let r=this.parser.parseWithErrors(e);if(!r.isValid){let n=new oe;n.isValid=!1;for(let o of r.errors){let s=new k;s.ruleType="ParseError",s.severity="Error",s.lineNumber=o.line,s.column=o.column,s.message=o.message,o.keyName&&(s.entityName=o.keyName),o.errorType==="DuplicateKey"&&(s.suggestion="All property names must be unique across the entire document. Rename one of the duplicate properties to make them unique."),n.errors.push(s)}return n}return await this.validateAsync(r.document,t)}addDocumentRule(e){this.documentRules.push(e)}addRepositoryRule(e){this.repositoryRules.push(e)}removeDocumentRule(e){let t=this.documentRules.findIndex(r=>r instanceof e);t>=0&&this.documentRules.splice(t,1)}removeRepositoryRule(e){let t=this.repositoryRules.findIndex(r=>r instanceof e);t>=0&&this.repositoryRules.splice(t,1)}addErrorsToResult(e,t){for(let r of t)r.severity==="Error"?e.errors.push(r):this.includeWarnings&&e.warnings.push(r)}};te();te();var qe=class{resourceResolver;constructor(e){this.resourceResolver=e}async buildFromNameAsync(e,t){return(await this.resourceResolver.resolveEntityAsync(e,t))?.uri??null}buildFromName(e,t,r){if(e.includes(".")){let o=e.split("."),s=o[0],a=o[1],i=this.findPackageNameForAlias(r,s);if(i){for(let c of t.values())if(c.entityName===a&&c.uri.package_===i)return c.uri}return null}let n=t.get(e);return n?n.uri:null}create(e,t,r,n){return new $(e,t,r,n)}findPackageNameForAlias(e,t){if(!e.metadata.imports)return null;for(let[r,n]of Object.entries(e.metadata.imports))for(let o of n)if(o.alias===t||!o.alias&&o.packageName===t)return o.packageName;return null}};te();async function Tt(p,e){let t=[],r=await p.getAllDocumentsAsync();for(let n of r){let o=n.metadata.namespace_;if(!o)continue;let s=o.publisher,a=o.package_,i=o.version?`${o.version.major}.${o.version.minor}.${o.version.patch}`:"0.0.0";for(let[c,l]of Object.entries(n.body)){if(!l||typeof l!="object")continue;let u=l.type;!u||typeof u!="string"||u!=="Package"&&dr(u,e)&&t.push({entityName:c,entity:l,documentNamespace:`${s}/${a}@${i}`,publisher:s,package_:a,version:i})}}return t}function dr(p,e){let t=Ct(p),r=Ct(e);return t===r}function Ct(p){let e=p.lastIndexOf(".");if(e!==-1)return p.substring(e+1);let t=p.lastIndexOf("/");return t!==-1?p.substring(t+1):p}function z(p,e){return p.major!==e.major?p.major-e.major:p.minor!==e.minor?p.minor-e.minor:p.patch-e.patch}function Ge(p,e){return p.major===e.major&&p.minor===e.minor&&p.patch===e.patch}function ht(p){return`${p.major}.${p.minor}.${p.patch}`}function kt(p,e,t){let r=`${p}.${e}.${t}`;return{major:p,minor:e,patch:t,toString:()=>r,equals:n=>n?.major===p&&n?.minor===e&&n?.patch===t,getHashCode:()=>p<<20|e<<10|t,compareTo:n=>p!==n.major?p-n.major:e!==n.minor?e-n.minor:t-n.patch}}function Nt(p){let e=/^(\d+)\.(\d+)\.(\d+)$/.exec(p);return e?kt(Number(e[1]),Number(e[2]),Number(e[3])):null}function ze(p,e){return z(p,e)>=0&&p.major===e.major&&p.minor===e.minor}function Xe(p,e){return e.major===0?z(p,e)>=0&&p.major===0&&p.minor===e.minor:z(p,e)>=0&&p.major===e.major}function _t(p,e={}){let{requestedVersion:t}=e;if(p.length===0)return{chosen:null,alternatives:[],multipleVersionsPresent:!1,exactRequestedVersionMissing:!!t};if(t){let n=p.find(o=>{let s=o.metadata.namespace_?.version;return!!s&&ht(s)===t});return n?{chosen:n,alternatives:p.filter(o=>o!==n),multipleVersionsPresent:p.length>1,exactRequestedVersionMissing:!1}:{chosen:null,alternatives:p,multipleVersionsPresent:p.length>1,exactRequestedVersionMissing:!0}}if(p.length===1)return{chosen:p[0],alternatives:[],multipleVersionsPresent:!1,exactRequestedVersionMissing:!1};let r=[...p].sort((n,o)=>{let s=n.metadata.namespace_?.version,a=o.metadata.namespace_?.version;return!s&&!a?0:s?a?z(a,s):-1:1});return{chosen:r[0],alternatives:r.slice(1),multipleVersionsPresent:!0,exactRequestedVersionMissing:!1}}var bt=class{documents=new Map;documentContents=new Map;parser;constructor(e){this.parser=e}async getAllDocumentsAsync(){return Array.from(this.documents.values())}async getDocumentAsync(e){return this.documents.get(e)??null}async getDocumentsByNamespaceAsync(e,t){let r=[];for(let n of this.documents.values())n.metadata?.namespace_?.publisher===e&&n.metadata?.namespace_?.package_===t&&r.push(n);return r}async getHighestCompatibleVersionAsync(e,t){let r=[];for(let o of this.documents.values())o.metadata?.namespace_?.publisher===e&&o.metadata?.namespace_?.package_===t.packageName&&o.metadata?.namespace_?.version!==void 0&&r.push(o);if(r.length===0)return null;let n=r.filter(o=>{let s=o.metadata.namespace_.version;if(!s)return!1;switch(t.versionOperator){case 0:return Ge(s,t.version);case 1:return ze(s,t.version);case 2:return Xe(s,t.version);case 3:return z(s,t.minVersion)>=0;default:return!1}});return n.length===0?null:(n.sort((o,s)=>{let a=o.metadata.namespace_.version,i=s.metadata.namespace_.version;return!a&&!i?0:a?i?z(i,a):-1:1}),n[0])}async saveDocumentAsync(e,t){this.documents.set(t,e);let r=this.parser.save(e);this.documentContents.set(t,r)}async deleteDocumentAsync(e){this.documents.delete(e),this.documentContents.delete(e)}async clearNamespaceAsync(e,t){let r=[];for(let[n,o]of this.documents.entries())o.metadata?.namespace_?.publisher===e&&o.metadata?.namespace_?.package_===t&&r.push(n);for(let n of r)this.documents.delete(n),this.documentContents.delete(n)}async getAllDocumentReferencesAsync(){let e=[];for(let t of this.documents.values())t.metadata?.namespace_&&e.push({identifier:t.metadata.namespace_.toString(),uri:`kanonak://${t.metadata.namespace_}`,hasParseError:!1});return e}async getDocumentContentAsync(e){let t=this.documentContents.get(e);if(t!==void 0)return t;let r=this.documents.get(e);return r!==void 0?this.parser.save(r):null}async getDocumentUriAsync(e){let t=this.documents.get(e);return t?t.metadata?.namespace_?`kanonak://${t.metadata.namespace_}`:`kanonak://${e}`:null}};import{VersionOperator as Ye}from"@kanonak-protocol/types/document/models/enums";var gr="https://{publisher}/index.txt",hr="https://{publisher}/{package}/{version}.kan.yml",Mt={version:1},Ne=class{cache=new Map;async getConfig(e){let t=this.cache.get(e);if(t)return t;let r=await this.fetchConfig(e);return this.cache.set(e,r),r}async fetchConfig(e){let t=`https://${e}/.well-known/kanonak.json`,r;try{r=await fetch(t)}catch{return Mt}if(r.status===404)return Mt;if(!r.ok)throw new Error(`Failed to fetch publisher config: ${t} (${r.status} ${r.statusText})`);let n=await r.json();if(typeof n.version!="number")throw new Error(`Invalid publisher config at ${t}: missing or invalid "version" field`);let o={version:n.version};return typeof n.index=="string"&&(o.index=n.index),typeof n.package=="string"&&(o.package=n.package),(n.auth==="none"||n.auth==="oauth"||n.auth==="bearer")&&(o.auth=n.auth),o}resolveIndexUrl(e,t){let r=t.index??gr;return Ut(r,{publisher:e})}resolvePackageUrl(e,t,r,n){let o=n.package??hr;return Ut(o,{publisher:e,package:t,version:r})}};function Ut(p,e){let t=p;for(let[n,o]of Object.entries(e))t=t.replaceAll(`{${n}}`,o);let r=t.match(/\{[a-z]+\}/);if(r)throw new Error(`Unresolved variable ${r[0]} in URL template: ${p}`);return t}var Ce=class p{indexCache=new Map;configResolver;fetchFn;constructor(e){this.configResolver=e?.configResolver??new Ne,this.fetchFn=e?.fetchFn}async resolveVersion(e,t){let r=await this.getPackageVersions(e,t.packageName);if(r.length===0)return null;let n=r.filter(o=>this.isVersionCompatible(o,t.version,t.versionOperator));return n.length===0?null:(n.sort((o,s)=>this.compareVersionStrings(s,o)),n[0])}async getHighestVersion(e,t){let r=await this.getPackageVersions(e,t);return r.length===0?null:[...r].sort((o,s)=>this.compareVersionStrings(s,o))[0]}async listLatestPackages(e){let t=this.indexCache.get(e);t||(t=await this.fetchIndex(e),this.indexCache.set(e,t));let r=[];for(let[n,o]of t){if(o.length===0)continue;let s=[...o].sort((a,i)=>this.compareVersionStrings(i,a));r.push({packageName:n,version:s[0]})}return r.sort((n,o)=>n.packageName.localeCompare(o.packageName)),r}async getPackageUrl(e,t,r){let n=await this.configResolver.getConfig(e);return this.configResolver.resolvePackageUrl(e,t,r,n)}async getPackageVersions(e,t){let r=this.indexCache.get(e);return r||(r=await this.fetchIndex(e),this.indexCache.set(e,r)),r.get(t)??[]}async fetchIndex(e){let t=await this.configResolver.getConfig(e),r=this.configResolver.resolveIndexUrl(e,t),n=this.fetchFn?await this.fetchFn(r,e):await fetch(r);if(!n.ok)throw new Error(`Failed to fetch publisher index: ${r} (${n.status} ${n.statusText})`);let o=await n.text();return p.parseIndex(o)}static parseIndex(e){let t=new Map;for(let r of e.split(`
|
|
44
|
+
`)){let n=r.trim();if(!n||n.startsWith("#"))continue;let o=n.indexOf("/");if(o===-1)continue;let s=n.substring(0,o),a=n.substring(o+1);if(!s||!a)continue;let i=t.get(s);i?i.push(a):t.set(s,[a])}return t}isVersionCompatible(e,t,r){let n=p.parseVersion(e);if(!n)return!1;switch(r){case Ye.Any:return!0;case Ye.Exact:return n.major===t.major&&n.minor===t.minor&&n.patch===t.patch;case Ye.Compatible:return n.major===t.major&&n.minor===t.minor&&n.patch>=t.patch;case Ye.Major:return n.major!==t.major?!1:n.minor>t.minor?!0:n.minor===t.minor?n.patch>=t.patch:!1;default:return!1}}static parseVersion(e){let t=e.split(".");if(t.length<2)return null;let r=parseInt(t[0],10),n=parseInt(t[1],10),o=t.length>=3?parseInt(t[2],10):0;return isNaN(r)||isNaN(n)||isNaN(o)?null:{major:r,minor:n,patch:o}}compareVersionStrings(e,t){let r=p.parseVersion(e),n=p.parseVersion(t);return!r&&!n?0:r?n?r.major!==n.major?r.major-n.major:r.minor!==n.minor?r.minor-n.minor:r.patch-n.patch:1:-1}};var Rt=class{parser=new E;publisherIndex;documents=new Map;contentCache=new Map;fetchFn;onFetch;getFromCache;constructor(e){this.onFetch=e?.onFetch,this.getFromCache=e?.getFromCache,this.fetchFn=e?.fetchFn,this.publisherIndex=e?.fetchFn?new Ce({fetchFn:e.fetchFn}):new Ce}async getHighestCompatibleVersionAsync(e,t){let r=await this.publisherIndex.resolveVersion(e,t);if(!r)return null;let n=`${e}/${t.packageName}@${r}`,o=this.documents.get(n);if(o)return o;if(this.getFromCache){let l=this.getFromCache(e,t.packageName,r);if(l){let u=this.parser.parse(l);return this.documents.set(n,u),this.contentCache.set(n,l),u}}let s=await this.publisherIndex.getPackageUrl(e,t.packageName,r),a=this.fetchFn?await this.fetchFn(s,e):await fetch(s);if(!a.ok)throw new Error(`Failed to fetch Kanonak package: ${s} (${a.status} ${a.statusText})`);let i=await a.text();this.onFetch&&this.onFetch(e,t.packageName,r,i);let c=this.parser.parse(i);return this.documents.set(n,c),this.contentCache.set(n,i),c}async getAllDocumentsAsync(){return Array.from(this.documents.values())}async getDocumentAsync(e){return this.documents.get(e)??null}async getDocumentsByNamespaceAsync(e,t){return Array.from(this.documents.values()).filter(r=>{let n=r.metadata.namespace_;return n&&n.publisher===e&&n.package_===t})}async saveDocumentAsync(e,t){throw new Error("HttpKanonakDocumentRepository is read-only")}async deleteDocumentAsync(e){throw new Error("HttpKanonakDocumentRepository is read-only")}async clearNamespaceAsync(e,t){throw new Error("HttpKanonakDocumentRepository is read-only")}async getAllDocumentReferencesAsync(){return[]}async getDocumentContentAsync(e){return this.contentCache.get(e)??null}async getDocumentUriAsync(e){let t=e.match(/^(.+?)\/(.+?)@(.+)$/);if(!t)return null;let[,r,n,o]=t;return this.publisherIndex.getPackageUrl(r,n,o)}};function Bt(p,e,t,r){let n=Lt(p);if(n.length>0){let a=n.find(i=>Je(i.format,e)&&Je(i.variant,t));return a?{transformation:a.transformation,source:"instance"}:void 0}let o=new Set,s=Rr(p);for(;s.length>0;){let a=s.shift(),i=wr(a.subject);if(o.has(i))continue;o.add(i);let c=Pr(r,a.subject);if(!c)continue;let u=Lt(c).find(m=>Je(m.format,e)&&Je(m.variant,t));if(u)return{transformation:u.transformation,source:{publisher:a.subject.publisher,package_:a.subject.package_,name:a.subject.name}};for(let m of vr(c))s.push(m)}}function Lt(p){let e=[];for(let t of p.statement)if(t instanceof _&&Ze(t,"kanonak.org","derivation","derivations"))for(let r of t.object??[]){if(!(r instanceof T))continue;let n=kr(r);n&&e.push(n)}return e}function kr(p){let e,t,r;for(let n of p.statement)n instanceof N?Ze(n,"kanonak.org","derivation","format")?e=Ft(n):Ze(n,"kanonak.org","derivation","variant")&&(t=Ft(n)):n instanceof B&&Ze(n,"kanonak.org","derivation","transformation")&&(r=br(n.object));if(!(!e||!r))return t||(t={publisher:"kanonak.org",package_:"derivation",name:"default"}),{format:e,variant:t,transformation:r}}function br(p){let e,t,r,n;for(let o of p.statement){if(!(o instanceof F))continue;let s=o.predicate?.subject?.name;s==="publisher"?e=o.object:s==="package"?t=o.object:s==="version"?r=o.object:s==="name"&&(n=o.object)}if(!(!e||!t||!r||!n))return{publisher:e,package_:t,version:r,name:n}}function Rr(p){let e=[];for(let t of p.statement)t instanceof N&&t.predicate?.subject?.name==="type"&&t.object instanceof w&&e.push(t.object);return e}function vr(p){let e=[];for(let t of p.statement)if(t instanceof N){if(t.predicate?.subject?.name!=="subClassOf")continue;t.object instanceof w&&e.push(t.object)}else if(t instanceof _){if(t.predicate?.subject?.name!=="subClassOf")continue;for(let r of t.object??[])r instanceof w&&e.push(r)}return e}function Pr(p,e){for(let t of p){if(!(t instanceof C)||t.name!==e.name)continue;if((t.namespace||"").startsWith(`${e.publisher}/${e.package_}@`))return t}}function Ze(p,e,t,r){let n=p.predicate?.subject;return n?n.publisher===e&&n.package_===t&&n.name===r:!1}function Ft(p){let e=p.object.subject;return{publisher:e.publisher,package_:e.package_,name:e.name}}function Je(p,e){return p.publisher===e.publisher&&p.package_===e.package_&&p.name===e.name}function wr(p){return`${p.publisher}/${p.package_}/${p.name}`}import{CtlKanonakUriType as _e,PathSegmentType as vt}from"@kanonak-protocol/types/ctl/parsing/enums";var Ir=/\.?([a-zA-Z_][a-zA-Z0-9_-]*|\[\d+\])/g;function Ar(p){let e=p.split(".").map(Number),t=e[0]||0,r=e[1]||0,n=e[2]||0;return{major:t,minor:r,patch:n,toString:()=>`${t}.${r}.${n}`,equals:o=>o&&typeof o=="object"&&o.major===t&&o.minor===r&&o.patch===n,getHashCode:()=>t<<20|r<<10|n,compareTo:o=>t!==o.major?t-o.major:r!==o.minor?r-o.minor:n-o.patch}}var Ke=class p{scheme="kanonak";publisher;package_;version;resourceName;path;rawUri;constructor(e){this.publisher=e.publisher,this.package_=e.package_,this.version=e.version,this.resourceName=e.resourceName,this.path=e.path??[],this.rawUri=e.rawUri}get uriType(){return this.path.length>0?_e.DeepLink:this.resourceName!=null?_e.Resource:this.version!=null?_e.VersionedPackage:this.package_!=null?_e.Package:_e.Publisher}get namespace_(){return this.package_==null?null:this.version==null?`${this.publisher}/${this.package_}`:`${this.publisher}/${this.package_}@${this.version}`}static parse(e){if(!e||e.trim().length===0)throw new Error("Kanonak URI string cannot be null or empty");if(!e.toLowerCase().startsWith("kanonak://"))throw new Error(`Invalid Kanonak URI: '${e}'. Must start with 'kanonak://'`);let t=e.substring(8);if(!t||t.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Publisher is required after 'kanonak://'`);let r=t.indexOf("#"),n=null,o;if(r>=0){if(o=t.substring(0,r),n=t.substring(r+1),!n||n.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Deep link path required after '#'`)}else o=t;let s,a=null,i=null,c=null,l=o.indexOf("@");if(l>=0){let m=o.substring(0,l),y=o.substring(l+1),f=m.indexOf("/");if(f<0)throw new Error(`Invalid Kanonak URI: '${e}'. Expected format: publisher/package@version/resource`);if(s=m.substring(0,f),a=m.substring(f+1),!s||s.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Publisher cannot be empty`);if(!a||a.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Package cannot be empty`);let d=y.indexOf("/");if(d<0)throw new Error(`Invalid Kanonak URI: '${e}'. CTL requires resource references (kanonak://publisher/package@version/resource)`);let g=y.substring(0,d);if(c=y.substring(d+1),!g||g.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Version required after '@'`);if(i=Ar(g),!c||c.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Resource name cannot be empty`)}else{let m=o.split("/");if(m.length<3)throw new Error(`Invalid Kanonak URI: '${e}'. CTL requires resource references (kanonak://publisher/package/resource)`);if(m.length>3)throw new Error(`Invalid Kanonak URI: '${e}'. Too many path segments. Expected: publisher/package/resource`);if(s=m[0],a=m[1],c=m[2],!s||s.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Publisher cannot be empty`);if(!a||a.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Package cannot be empty`);if(!c||c.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Resource name cannot be empty`)}let u=[];return n!=null&&(u=Dr(n,e)),new p({publisher:s,package_:a,version:i,resourceName:c,path:u,rawUri:e})}static tryParse(e){try{return p.parse(e)}catch{return null}}static isKanonakUri(e){return!!e&&e.trim().length>0&&e.toLowerCase().startsWith("kanonak://")}toString(){let e=`kanonak://${this.publisher}`;if(this.package_!=null&&(e+=`/${this.package_}`,this.version!=null&&(e+=`@${this.version}`),this.resourceName!=null&&(e+=`/${this.resourceName}`,this.path.length>0))){e+="#";let t=!0;for(let r of this.path)r.type_===vt.Index?e+=`[${r.index}]`:(t||(e+="."),e+=r.name),t=!1}return e}equals(e){return e instanceof p?this.rawUri.toLowerCase()===e.rawUri.toLowerCase():!1}getHashCode(){let e=0,t=this.rawUri.toLowerCase();for(let r=0;r<t.length;r++)e=(e<<5)-e+t.charCodeAt(r),e|=0;return e}};function Dr(p,e){let t=[],r=new RegExp(Ir.source,"g"),n=0,o;for(;(o=r.exec(p))!==null;){let s=o[1];if(s.startsWith("[")&&s.endsWith("]")){let a=s.substring(1,s.length-1),i=parseInt(a,10);if(isNaN(i))throw new Error(`Invalid Kanonak URI: '${e}'. Invalid array index: ${s}`);t.push({type_:vt.Index,index:i,toString:()=>`[${i}]`})}else t.push({type_:vt.Property,name:s,toString:()=>s});n+=o[0].length}if(n!==p.length)throw new Error(`Invalid Kanonak URI: '${e}'. Invalid path syntax in: ${p}`);return t}import{VersionOperator as Q}from"@kanonak-protocol/types/document/models/enums";import*as qt from"js-yaml";var Sr=/\[([^\]]+)\]\((kanonak:\/\/[^)]+)\)/gi,Vr=/\[([^\]]+)\]\(kan:\/\/([^)]+)\)/gi,Kr=/```[\s\S]*?```|`[^`]+`/g,$r=/^---\s*\n([\s\S]*?)\n---\s*\n/;function jr(p,e,t){let r=`${p}.${e}.${t}`;return{major:p,minor:e,patch:t,toString:()=>r,equals:n=>n?.major===p&&n?.minor===e&&n?.patch===t,getHashCode:()=>p<<20|e<<10|t,compareTo:n=>p!==n.major?p-n.major:e!==n.minor?e-n.minor:t-n.patch}}function Er(p,e,t,r,n){let o=r===Q.Compatible?"~":r===Q.Major?"^":r===Q.Exact?"=":"*",s=`${e} ${o} ${t}`;return{package_:s,publisher:p,packageName:e,versionOperator:r,version:t,alias:n,get minVersion(){return t},get maxVersion(){return t},toEmbeddedObject(){let a={package:e,version:t.toString()};return n&&(a.alias=n),r!==Q.Exact&&(a.match=o),a},toString(){return s}}}var Qe=class{parse(e,t){if(e==null)throw new Error("Content cannot be null");e.charCodeAt(0)===65279&&(e=e.substring(1));let r=$r.exec(e);return r?this.parseWithFrontmatter(e,r,t??null):this.parseInline(e,t??null)}async parseFileAsync(e){if(!e||e.trim().length===0)throw new Error("File path cannot be null or empty");let r=(await import("fs")).readFileSync(e,"utf-8");return this.parse(r,e)}parseWithFrontmatter(e,t,r){let n=t[1],o=e.substring(t[0].length),s=null,a=new Map;try{let c=qt.load(n);if(!c)throw new Error("Frontmatter YAML is empty");if(!c.imports||!Array.isArray(c.imports))throw new Error("Frontmatter must contain an 'imports' sequence");let l={};for(let m of c.imports){if(!m||typeof m!="object")throw new Error("Each import entry must be a mapping with 'publisher' and 'packages'");let y=m.publisher?.toString();if(!y)throw new Error("Each import entry requires a 'publisher' property");if(!m.packages||!Array.isArray(m.packages))throw new Error(`Import entry for publisher '${y}' requires a 'packages' sequence`);l[y]||(l[y]=[]);for(let f of m.packages){if(!f||typeof f!="object")throw new Error(`Each package in publisher '${y}' must be a mapping`);let g=(f.version?.toString()??"1.0.0").split(".").map(Number),h=jr(g[0]||0,g[1]||0,g[2]||0),b=f.match?.toString(),R=b==="^"?Q.Major:b==="~"?Q.Compatible:b==="*"?Q.Any:Q.Exact,v=Er(y,f.package?.toString()??"",h,R,f.alias?.toString()??null);l[y].push(v)}}let u=[];for(let m of Object.values(l))u.push(...m);s={namespace_:void 0,imports:l,get allImports(){return u}},a=this.buildAliasMap(l)}catch(c){let l={displayText:"(frontmatter)",rawUri:"",startOffset:0,endOffset:t[0].length,line:1,column:1,isResolved:!1,error:`Failed to parse frontmatter: ${c.message}`,get fullMarkdownLink(){return`[${this.displayText}](${this.rawUri})`}};return Pt({metadata:null,rawMarkdown:o,frontmatterLength:t[0].length,filePath:r,references:[l]})}let i=this.parseMarkdownBody(o,a,t[0].length);return Pt({metadata:s,rawMarkdown:o,frontmatterLength:t[0].length,filePath:r,references:i})}parseInline(e,t){let r=this.parseMarkdownBody(e,new Map,0);return Pt({metadata:null,rawMarkdown:e,frontmatterLength:0,filePath:t,references:r})}parseMarkdownBody(e,t,r){let n=[],o=xr(e),s=new RegExp(Sr.source,"gi"),a;for(;(a=s.exec(e))!==null;){if(Wt(a.index,o))continue;let c=a[1],l=a[2],{line:u,column:m}=Ht(e,a.index),y={displayText:c,rawUri:l,startOffset:a.index+r,endOffset:a.index+a[0].length+r,line:u,column:m,isResolved:!1,get fullMarkdownLink(){return`[${this.displayText}](${this.rawUri})`}};try{y.parsedUri=Ke.parse(l)}catch(f){y.error=f.message}n.push(y)}let i=new RegExp(Vr.source,"gi");for(;(a=i.exec(e))!==null;){if(Wt(a.index,o))continue;let c=a[1],l=a[2],{line:u,column:m}=Ht(e,a.index),y=null,f=null;try{y=Or(l,t)}catch(g){f=g.message}let d={displayText:c,rawUri:y??`kan://${l}`,startOffset:a.index+r,endOffset:a.index+a[0].length+r,line:u,column:m,isResolved:!1,error:f,get fullMarkdownLink(){return`[${this.displayText}](${this.rawUri})`}};if(y!=null&&f==null)try{d.parsedUri=Ke.parse(y)}catch(g){d.error=g.message}n.push(d)}return n.sort((c,l)=>c.startOffset-l.startOffset),n}buildAliasMap(e){let t=new Map;for(let[r,n]of Object.entries(e))for(let o of n){let s=o.alias??o.packageName;t.set(s.toLowerCase(),{publisher:r,package_:o.packageName,version:o.version})}return t}};function Pt(p){return{metadata:p.metadata,get hasFrontmatter(){return p.metadata!=null},rawMarkdown:p.rawMarkdown,frontmatterLength:p.frontmatterLength,filePath:p.filePath,references:p.references,get referenceCount(){return p.references.length},get allReferencesResolved(){return p.references.every(e=>e.isResolved)},get unresolvedReferences(){return p.references.filter(e=>!e.isResolved)},get errorReferences(){return p.references.filter(e=>e.error!=null)}}}function xr(p){let e=[],t=new RegExp(Kr.source,"g"),r;for(;(r=t.exec(p))!==null;)e.push([r.index,r.index+r[0].length]);return e}function Wt(p,e){for(let[t,r]of e)if(p>=t&&p<r)return!0;return!1}function Ht(p,e){let t=1,r=1;for(let n=0;n<e&&n<p.length;n++)p[n]===`
|
|
45
|
+
`?(t++,r=1):r++;return{line:t,column:r}}function Or(p,e){if(!p||p.trim().length===0)throw new Error("kan:// link cannot be empty");if(e.size===0)throw new Error("kan:// links require frontmatter with imports");let t=null,r=p,n=p.indexOf(".");if(n>0&&(t=p.substring(0,n),r=p.substring(n+1),!r||r.trim().length===0))throw new Error(`Resource name required after alias '${t}.'`);if(t!=null){let o=e.get(t.toLowerCase());if(!o){let s=Array.from(e.keys()).join(", ");throw new Error(`Unknown alias: '${t}'. Available: ${s}`)}return`kanonak://${o.publisher}/${o.package_}@${o.version}/${r}`}else{let o=e.values().next().value;if(!o)throw new Error(`Cannot resolve '${r}': no imports defined`);return`kanonak://${o.publisher}/${o.package_}@${o.version}/${r}`}}import{CtlValidationErrorType as H,CtlValidationSeverity as ee}from"@kanonak-protocol/types/ctl/models/enums";import{CtlKanonakUriType as Gt,PathSegmentType as zt}from"@kanonak-protocol/types/ctl/parsing/enums";var et=class{repository;constructor(e){if(!e)throw new Error("Repository is required for CTL validation");this.repository=e}async validateAsync(e){if(!e)throw new Error("Document cannot be null");let t=[],r=[];for(let o of e.references){if(!o.parsedUri){t.push({errorType:H.InvalidUri,severity:ee.Error,message:o.error??"Failed to parse Kanonak URI",reference:o,line:o.line,column:o.column,toString(){let s=this.line!=null?`(${this.line}:${this.column})`:"";return`${ee[this.severity]}: ${this.message} ${s}`.trim()}});continue}try{await this.resolveReference(o,t,r)}catch(s){t.push({errorType:H.ParseError,severity:ee.Error,message:`Error resolving reference: ${s.message}`,reference:o,line:o.line,column:o.column,toString(){let a=this.line!=null?`(${this.line}:${this.column})`:"";return`${ee[this.severity]}: ${this.message} ${a}`.trim()}})}}return{isValid:t.length===0,document:e,errors:t,warnings:r,get totalReferences(){return e.referenceCount},get resolvedReferences(){return e.references.filter(o=>o.isResolved).length},get summary(){if(t.length===0)return`All ${e.referenceCount} references validated`;let o=e.references.filter(s=>s.isResolved).length;return`${t.length} error(s), ${o}/${e.referenceCount} references resolved`}}}async resolveReference(e,t,r){let n=e.parsedUri;switch(n.uriType){case Gt.Resource:await this.resolveResource(e,t);break;case Gt.DeepLink:await this.resolveDeepLink(e,t);break;default:t.push({errorType:H.InvalidUri,severity:ee.Error,message:`Unsupported URI type: ${n.uriType}. CTL only supports resource references.`,reference:e,line:e.line,column:e.column,suggestion:"Use resource URIs: kanonak://publisher/package@version/resource",toString(){let o=this.line!=null?`(${this.line}:${this.column})`:"";return`${ee[this.severity]}: ${this.message} ${o}`.trim()}});break}}async resolveResource(e,t){let r=e.parsedUri,n=r.namespace_,o=await this.repository.getDocumentAsync(n);if(!o){t.push(this.createError(H.PackageNotFound,`Package not found: ${n}`,e));return}if(o.body&&o.body[r.resourceName])e.isResolved=!0;else{let s=o.body?Object.keys(o.body).slice(0,5):[];t.push(this.createError(H.EntityNotFound,`Resource not found: ${r.resourceName} in ${n}`,e,s.length>0?`Available resources: ${s.join(", ")}`:void 0))}}async resolveDeepLink(e,t){let r=e.parsedUri,n=r.namespace_,o=await this.repository.getDocumentAsync(n);if(!o){t.push(this.createError(H.PackageNotFound,`Package not found: ${n}`,e));return}if(!o.body||!o.body[r.resourceName]){t.push(this.createError(H.EntityNotFound,`Resource not found: ${r.resourceName} in ${n}`,e));return}let s=o.body[r.resourceName],a=r.resourceName;for(let i of r.path){if(s==null){t.push(this.createError(H.PathNotFound,`Path not found: ${a}`,e));return}if(i.type_===zt.Property){let c=i.name;a+=`.${c}`;let l=Cr(s,c);if(l===void 0){let u=Nr(s);t.push(this.createError(H.PathNotFound,`Path not found: ${a}`,e,u));return}s=l}else if(i.type_===zt.Index){let c=i.index;a+=`[${c}]`;let l=Tr(s,c);if(l===void 0){let u=_r(s);t.push(this.createError(H.IndexOutOfBounds,`Index out of bounds: ${a}`,e,u));return}s=l}}e.isResolved=!0,e.resolvedValue=s}createError(e,t,r,n){return{errorType:e,severity:ee.Error,message:t,reference:r,line:r.line,column:r.column,suggestion:n,toString(){let o=this.line!=null?`(${this.line}:${this.column})`:"";return`${ee[this.severity]}: ${this.message} ${o}`.trim()}}}};function Cr(p,e){if(p&&typeof p=="object"&&!Array.isArray(p)){if(e in p)return p[e];let t=Object.keys(p).find(r=>r.toLowerCase()===e.toLowerCase());if(t)return p[t]}}function Tr(p,e){if(Array.isArray(p)&&e>=0&&e<p.length)return p[e]}function Nr(p){if(p&&typeof p=="object"&&!Array.isArray(p)){let e=Object.keys(p).slice(0,5);if(e.length>0)return`Available properties: ${e.join(", ")}`}}function _r(p){if(Array.isArray(p))return p.length>0?`Collection has ${p.length} items (valid indices: 0-${p.length-1})`:"Collection is empty"}import{ResolvedResourceType as $e}from"@kanonak-protocol/types/ctl/resolution/enums";var Mr=new Set(["kanonak.org/core-rdf","kanonak.org/core-rdfs","kanonak.org/core-owl","kanonak.org/core-xsd","kanonak.org/core-kanonak"]);var tt=class{repository;constructor(e){if(!e)throw new Error("Repository is required for CTL graph resolution");this.repository=e}async resolveAsync(e,t=1e3){if(!e)throw new Error("Document cannot be null");let r=new Set,n=[],o=[],s=[],a=[],i=new Set;for(let d of e.references)d.parsedUri&&i.add(d.parsedUri.toString());let c=new Map,l=new Map,u=await this.repository.getAllDocumentsAsync();for(let d of u){let g=d.metadata?.namespace_?.toString();if(!g||!d.body)continue;let h=[];for(let[b,R]of Object.entries(d.body))if(R&&typeof R=="object"&&!Array.isArray(R)){let v=this.createMockSubjectKanonak(b,R,g),D=`kanonak://${g}/${b}`;c.has(D)||c.set(D,{entity:v,namespace:g}),h.push(v)}l.set(g,h)}let m=0,y=!1;for(let d of e.references){if(!d.parsedUri){a.push({reference:d.rawUri,reason:d.error??"Failed to parse URI"});continue}let g=d.parsedUri.toString();if(r.has(g))continue;let h=await this.resolveEntityRecursive(g,null,null,0,t,r,i,n,o,s,a,c,l);m=Math.max(m,h),h>=t&&(y=!0)}let f=Wr(e.rawMarkdown);return{sourceFile:e.filePath??null,originalContent:e.rawMarkdown,title:f,directReferences:n,inheritedReferences:o,foundationTypes:s,get totalResourceCount(){return n.length+o.length+s.length},get allResources(){return[...n,...o,...s]},maxDepthReached:m,wasTruncated:y,unresolvedResources:a}}async resolveEntityRecursive(e,t,r,n,o,s,a,i,c,l,u,m,y){if(s.has(e)||(s.add(e),n>=o))return n;if(!t){let R=m.get(e);if(!R)return u.push({reference:e,reason:"Resource not found in workspace"}),n;t=R.entity}let f=t,d=f.namespace??f.namespace_??"";!r&&d&&(r=await this.repository.getDocumentAsync(d));let g=this.createResolvedResource(t,e,n,y);switch(this.classifyTier(e,d,a)){case 0:i.push(g);break;case 2:l.push(g);break;default:c.push(g);break}let b=n;for(let R of g.parentClasses){let v=this.resolveReferenceToUri(R,d,r);if(v&&!s.has(v)){let D=m.get(v),K=await this.resolveEntityRecursive(v,D?.entity??null,null,n+1,o,s,a,i,c,l,u,m,y);b=Math.max(b,K)}}for(let R of g.properties.filter(v=>v.isObjectProperty)){let v=this.resolveReferenceToUri(R.rangeType,d,r);if(v&&!s.has(v)){let D=m.get(v),K=await this.resolveEntityRecursive(v,D?.entity??null,null,n+1,o,s,a,i,c,l,u,m,y);b=Math.max(b,K)}}if(g.instanceOf_){let R=this.resolveReferenceToUri(g.instanceOf_,d,r);if(R&&!s.has(R)){let v=m.get(R),D=await this.resolveEntityRecursive(R,v?.entity??null,null,n+1,o,s,a,i,c,l,u,m,y);b=Math.max(b,D)}}return b}createResolvedResource(e,t,r,n){let o=e,s=o.name??"",a=o.namespace??o.namespace_??"",i=this.classifyEntityType(e),c=Xt(e),l=Lr(e),u=Fr(e),m=[];if(i===$e.Class){let y=n.get(a);y&&(m=Br(s,y))}return{name:s,kanonakUri:t,resource:e,resourceType:i,parentClass:l.length>0?l[0]:null,parentClasses:l,comment:c,properties:m,namespace_:a,resolutionDepth:r,instanceOf_:u}}classifyEntityType(e){if(I.isClassType(e))return $e.Class;if(I.isAnnotationPropertyType(e))return $e.AnnotationProperty;if(I.isDatatypePropertyType(e))return $e.DatatypeProperty;if(I.isObjectPropertyType(e))return $e.ObjectProperty;let t=I.getTypeUri(e);return t&&!I.isCoreOntologyType(t)?$e.Instance:$e.Other}classifyTier(e,t,r){return r.has(e)?0:Ur(t)?2:1}resolveReferenceToUri(e,t,r){if(e.toLowerCase().startsWith("kanonak://"))return e;if(e.includes(".")&&r?.metadata){let n=e.indexOf("."),o=e.substring(0,n),s=e.substring(n+1);if(s){let a=r.metadata.allImports;if(a){for(let i of a)if((i.alias??i.packageName).toLowerCase()===o.toLowerCase())return`kanonak://${i.version?`${i.publisher}/${i.packageName}@${i.version}`:`${i.publisher}/${i.packageName}`}/${s}`}}}return!e.includes(".")&&t?`kanonak://${t}/${e}`:null}createMockSubjectKanonak(e,t,r){let n=[];for(let[o,s]of Object.entries(t))typeof s=="string"?o==="type"||o==="subClassOf"||o==="domain"||o==="range"||o==="subPropertyOf"?n.push({predicate:{subject:{name:o,publisher:"",package_:""}},object:{subject:{name:s,publisher:"",package_:""}}}):n.push({predicate:{subject:{name:o,publisher:"",package_:""}},object:s}):Array.isArray(s)&&n.push({predicate:{subject:{name:o,publisher:"",package_:""}},object:s.map(a=>typeof a=="string"?{subject:{name:a,publisher:"",package_:""}}:a)});return{name:e,namespace_:r,statement:n,entity:t}}};function Ur(p){if(!p)return!1;let e=p.split("/");if(e.length<2)return!1;let t=e[0],r=e[1],n=r.includes("@")?r.split("@")[0]:r;return Mr.has(`${t}/${n}`)}function Xt(p){let e=p;if(e.entity&&typeof e.entity=="object")return e.entity.comment??null;if(e.statement&&Array.isArray(e.statement)){for(let t of e.statement)if(t.predicate?.subject?.name==="comment"&&typeof t.object=="string")return t.object}return null}function Lr(p){let e=[],t=p,r=t.name??"";if(t.entity&&typeof t.entity=="object"){let n=t.entity.subClassOf;if(typeof n=="string")n.toLowerCase()!==r.toLowerCase()&&e.push(n);else if(Array.isArray(n))for(let o of n){let s=typeof o=="string"?o:o?.subject?.name??o?.name;s&&s.toLowerCase()!==r.toLowerCase()&&e.push(s)}return e}if(t.statement&&Array.isArray(t.statement)){for(let n of t.statement)if(n.predicate?.subject?.name==="subClassOf"){if(n.object?.subject?.name){let o=n.object.subject.name;o.toLowerCase()!==r.toLowerCase()&&e.push(o)}else if(Array.isArray(n.object))for(let o of n.object){let s=o?.subject?.name??o?.name;s&&s.toLowerCase()!==r.toLowerCase()&&e.push(s)}}}return e}function Fr(p){let e=I.getTypeUri(p);return e?I.isCoreOntologyType(e)?null:e.name:null}function Br(p,e){let t=[];for(let r of e){if(!I.isAnyPropertyType(r))continue;let n=r,o=[],s=[];if(n.entity&&typeof n.entity=="object"){let l=n.entity.domain;if(typeof l=="string")o.push(l);else if(Array.isArray(l))for(let m of l)o.push(typeof m=="string"?m:m?.name??String(m));let u=n.entity.range;if(typeof u=="string")s.push(u);else if(Array.isArray(u))for(let m of u)s.push(typeof m=="string"?m:m?.name??String(m))}if(!o.some(l=>l.toLowerCase()===p.toLowerCase()))continue;s.length===0&&s.push("unknown");let a=I.isObjectPropertyType(r),i=n.entity?.collection!=null,c=Xt(r);t.push({name:n.name??"",rangeTypes:s,domains:o,get rangeType(){return s.length>0?s.join(", "):"unknown"},isObjectProperty:a,isCollection:i,comment:c})}return t}function Wr(p){let e=p.split(`
|
|
46
|
+
`);for(let t of e){let r=t.trim();if(r.startsWith("# ")&&!r.startsWith("## "))return r.substring(2).trim()}return null}import{ResolvedResourceType as O}from"@kanonak-protocol/types/ctl/resolution/enums";var nt=class{resolvedResourceNames=new Set;render(e){if(!e)throw new Error("Graph cannot be null");this.resolvedResourceNames=new Set(e.allResources.map(r=>r.name.toLowerCase()));let t=[];return t.push(this.transformTemplateLinks(e.originalContent)),t.push(""),t.push("---"),t.push(""),t.push("# Kanonak Resource Reference"),t.push(""),this.renderSummary(t,e),this.renderHierarchyDiagram(t,e),this.renderQuickReference(t,e),this.renderTier(t,"Direct References",e.directReferences,"Resources explicitly referenced in this template."),this.renderTier(t,"Inherited References",e.inheritedReferences,"Parent classes, property types, and other dependencies of directly referenced entities."),this.renderTier(t,"Foundation Types",e.foundationTypes,"Core ontology types that form the base of the type hierarchy."),e.unresolvedResources.length>0&&this.renderUnresolved(t,e.unresolvedResources),t.join(`
|
|
47
|
+
`)}generateAnchor(e){return e.toLowerCase()}renderInternalLink(e){return this.resolvedResourceNames.has(e.toLowerCase())?`[${e}](#${this.generateAnchor(e)})`:e}renderInternalLinks(e){return e.map(t=>this.renderInternalLink(t)).join(", ")}transformTemplateLinks(e){let t=/\[([^\]]+)\]\(can:\/\/([^)]+)\)/g;return e.replace(t,(r,n,o)=>{let s;if(o.includes("#"))s=o.substring(o.indexOf("#")+1);else{let a=o.lastIndexOf(".");s=a>=0?o.substring(a+1):o}return this.resolvedResourceNames.has(s.toLowerCase())?`[${n}](#${this.generateAnchor(s)})`:r})}renderSummary(e,t){e.push(`**Total Resources**: ${t.totalResourceCount}`),e.push(`- Direct: ${t.directReferences.length}`),e.push(`- Inherited: ${t.inheritedReferences.length}`),e.push(`- Foundation: ${t.foundationTypes.length}`),t.wasTruncated&&(e.push(""),e.push(`**Resolution was truncated at depth ${t.maxDepthReached}** - some resources may be missing.`),e.push("To include more resources, re-run with a higher depth limit: `kanonak ctl resolve <file> --depth 2000`")),e.push("")}renderQuickReference(e,t){let r=t.allResources;if(r.length===0)return;e.push("## Quick Reference"),e.push("");let n=r.filter(l=>l.resourceType===O.Class),o=r.filter(l=>l.resourceType===O.AnnotationProperty),s=r.filter(l=>l.resourceType===O.DatatypeProperty),a=r.filter(l=>l.resourceType===O.ObjectProperty),i=r.filter(l=>l.resourceType===O.Instance);if(n.length>0){e.push(`### Classes (${n.length})`),e.push(""),e.push("| Class | Extends | Properties |"),e.push("|-------|---------|------------|");for(let l of[...n].sort((u,m)=>u.name.localeCompare(m.name))){let u=this.renderInternalLink(l.name),m=l.parentClasses.length>0?this.renderInternalLinks(l.parentClasses):"-";e.push(`| ${u} | ${m} | ${l.properties.length} |`)}e.push("")}let c=[...o,...s,...a];if(c.length>0){e.push(`### Properties (${c.length})`),e.push(""),e.push("| Property | Type | Description |"),e.push("|----------|------|-------------|");for(let l of[...c].sort((u,m)=>u.name.localeCompare(m.name))){let u=this.renderInternalLink(l.name),m=Yt(l.resourceType),y=Hr(l.comment??"");e.push(`| ${u} | ${m} | ${y} |`)}e.push("")}if(i.length>0){let l=new Map;for(let u of i){let m=u.instanceOf_??"Unknown";l.has(m)||l.set(m,[]),l.get(m).push(u)}e.push("### Resources by Type"),e.push(""),e.push("| Type | Resources |"),e.push("|------|-----------|");for(let[u,m]of[...l.entries()].sort((y,f)=>y[0].localeCompare(f[0]))){let y=this.renderInternalLink(u),f=this.renderInternalLinks(m.map(d=>d.name));e.push(`| ${y} | ${f} |`)}e.push("")}}renderHierarchyDiagram(e,t){let r=t.allResources.filter(a=>a.resourceType===O.Class);if(r.length===0)return;let n=r.filter(a=>a.parentClasses.length>0);if(n.length===0)return;let o=new Set;for(let a of n)for(let i of a.parentClasses)o.add(i.toLowerCase());let s=new Set(r.map(a=>a.name.toLowerCase()));e.push("## Type Hierarchy"),e.push(""),e.push("```mermaid"),e.push("flowchart TB");for(let a of[...r].sort((i,c)=>i.name.localeCompare(c.name))){let i=rt(a.name);e.push(` ${i}["${a.name}"]`)}for(let a of[...o])if(!s.has(a)){let i=a;for(let l of n)for(let u of l.parentClasses)u.toLowerCase()===a&&(i=u);let c=rt(i);e.push(` ${c}["${i}"]:::external`)}e.push("");for(let a of n){let i=rt(a.name);for(let c of a.parentClasses){let l=rt(c);e.push(` ${l} --> ${i}`)}}e.push(""),e.push(" classDef external fill:#f9f9f9,stroke:#999,stroke-dasharray: 5 5"),e.push("```"),e.push("")}renderTier(e,t,r,n){if(r.length!==0){e.push(`## ${t} (${r.length})`),e.push(""),e.push(`*${n}*`),e.push("");for(let o of[...r].sort((s,a)=>s.name.localeCompare(a.name)))this.renderEntity(e,o)}}renderEntity(e,t){let r=this.generateAnchor(t.name);if(e.push(`### ${t.name}`),e.push(`<a id="${r}"></a>`),e.push(""),e.push("| Attribute | Value |"),e.push("|-----------|-------|"),e.push(`| **URI** | \`${t.kanonakUri}\` |`),e.push(`| **Type** | ${Yt(t.resourceType)} |`),t.parentClasses.length>0){let n=this.renderInternalLinks(t.parentClasses);e.push(`| **Extends** | ${n} |`)}if(t.instanceOf_){let n=this.renderInternalLink(t.instanceOf_);e.push(`| **Instance of** | ${n} |`)}e.push(""),t.comment&&(e.push(t.comment),e.push("")),t.resourceType===O.Class&&t.properties.length>0&&this.renderPropertiesTable(e,t.properties),e.push("---"),e.push("")}renderPropertiesTable(e,t){e.push("| Property | Type | Description |"),e.push("|----------|------|-------------|");for(let r of[...t].sort((n,o)=>n.name.localeCompare(o.name))){let o=r.rangeTypes.map(a=>{let i=this.renderInternalLink(a);return r.isObjectProperty?`-> ${i}`:i}).join(", ");r.isCollection&&(o=`${o}[]`);let s=(r.comment??"").replace(/\|/g,"\\|").replace(/\n/g," ").replace(/\r/g,"");e.push(`| ${r.name} | ${o} | ${s} |`)}e.push("")}renderUnresolved(e,t){e.push(`## Unresolved References (${t.length})`),e.push(""),e.push("*The following references could not be resolved:*"),e.push("");for(let r of t)e.push(`- \`${r.reference}\`: ${r.reason}`);e.push("")}};function Yt(p){switch(p){case O.Class:return"Class";case O.AnnotationProperty:return"Annotation Property";case O.DatatypeProperty:return"Datatype Property";case O.ObjectProperty:return"Object Property";case O.Instance:return"Instance";default:return"Other"}}function Hr(p){return p?(p=p.replace(/\|/g,"\\|").replace(/\n/g," ").replace(/\r/g,""),p.length<=50?p:p.substring(0,47)+"..."):""}function rt(p){return p.replace(/[^a-zA-Z0-9]/g,"_")}import{CtlValidationErrorType as qr,CtlValidationSeverity as Gr}from"@kanonak-protocol/types/ctl/models/enums";import{CtlKanonakUriType as zr,PathSegmentType as Xr}from"@kanonak-protocol/types/ctl/parsing/enums";import{ResolvedResourceType as Yr}from"@kanonak-protocol/types/ctl/resolution/enums";function wt(p){if(!p.expiresAt)return!1;let e=new Date(p.expiresAt),t=300*1e3;return e.getTime()<=Date.now()+t}function Jt(p){return!!p.accessToken&&!wt(p)}function X(p){let e=p.replace(/^https?:\/\//,"").replace(/^git:\/\//,"").replace(/\/+$/,"").trim();if(!e)throw new Error("Publisher host cannot be empty");return e}var Zt="kanonak-credentials",q="credentials",Jr=1,Te=class{async get(e){let t=X(e),r=await ot();return new Promise((n,o)=>{let s=r.transaction(q,"readonly"),i=s.objectStore(q).get(t);i.onsuccess=()=>n(i.result??null),i.onerror=()=>o(new Error(`IndexedDB read failed for '${t}': ${i.error?.message}`)),s.oncomplete=()=>r.close()})}async store(e,t){let r=X(e),n=await ot();return new Promise((o,s)=>{let a=n.transaction(q,"readwrite"),c=a.objectStore(q).put(t,r);c.onsuccess=()=>o(),c.onerror=()=>s(new Error(`IndexedDB write failed for '${r}': ${c.error?.message}`)),a.oncomplete=()=>n.close()})}async remove(e){let t=X(e),r=await ot();return new Promise((n,o)=>{let s=r.transaction(q,"readwrite"),i=s.objectStore(q).delete(t);i.onsuccess=()=>n(),i.onerror=()=>o(new Error(`IndexedDB delete failed for '${t}': ${i.error?.message}`)),s.oncomplete=()=>r.close()})}async list(){let e=await ot();return new Promise((t,r)=>{let n=e.transaction(q,"readonly"),s=n.objectStore(q).getAllKeys();s.onsuccess=()=>t(s.result??[]),s.onerror=()=>r(new Error(`IndexedDB list failed: ${s.error?.message}`)),n.oncomplete=()=>e.close()})}};function ot(){return new Promise((p,e)=>{let t=indexedDB.open(Zt,Jr);t.onupgradeneeded=()=>{let r=t.result;r.objectStoreNames.contains(q)||r.createObjectStore(q)},t.onsuccess=()=>p(t.result),t.onerror=()=>e(new Error(`Failed to open IndexedDB '${Zt}': ${t.error?.message}
|
|
48
|
+
Credential storage requires IndexedDB support in your browser.`))})}async function er(){let p=await crypto.subtle.generateKey({name:"ECDSA",namedCurve:"P-256"},!1,["sign"]),e=await crypto.subtle.exportKey("jwk",p.publicKey);return{signingKey:p.privateKey,publicKeyJwk:e}}async function st(){let p=await crypto.subtle.generateKey({name:"ECDSA",namedCurve:"P-256"},!0,["sign"]),e=await crypto.subtle.exportKey("jwk",p.publicKey),t=await crypto.subtle.exportKey("jwk",p.privateKey);return{keys:{signingKey:p.privateKey,publicKeyJwk:e},dpopKeyPair:{publicKey:e,privateKey:t}}}async function at(p){return{signingKey:await crypto.subtle.importKey("jwk",p.privateKey,{name:"ECDSA",namedCurve:"P-256"},!1,["sign"]),publicKeyJwk:p.publicKey}}async function it(p,e,t,r,n){let o={alg:"ES256",typ:"dpop+jwt",jwk:{kty:p.publicKeyJwk.kty,crv:p.publicKeyJwk.crv,x:p.publicKeyJwk.x,y:p.publicKeyJwk.y}},s={jti:crypto.randomUUID(),htm:e.toUpperCase(),htu:t,iat:Math.floor(Date.now()/1e3)};return r&&(s.ath=await Qr(r)),n&&(s.nonce=n),await Zr(o,s,p.signingKey)}function ct(p){return!p||p.length===0?!1:p.some(e=>e.toUpperCase()==="ES256")}async function Zr(p,e,t){let r=Qt(JSON.stringify(p)),n=Qt(JSON.stringify(e)),o=new TextEncoder().encode(`${r}.${n}`),s=await crypto.subtle.sign({name:"ECDSA",hash:"SHA-256"},t,o),a=It(s);return`${r}.${n}.${a}`}async function Qr(p){let e=new TextEncoder().encode(p),t=await crypto.subtle.digest("SHA-256",e);return It(t)}function Qt(p){let e=new TextEncoder().encode(p);return It(e.buffer)}function It(p){let e=new Uint8Array(p),t="";for(let r=0;r<e.length;r++)t+=String.fromCharCode(e[r]);return btoa(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}var en=300*1e3,pt=class{credentialBackend;callbackUrl;constructor(e){this.credentialBackend=new Te,this.callbackUrl=e??`${window.location.origin}/browser/callback.html`}async authorize(e){let t=X(e),r=await this.discover(t);if(!r)return{success:!1,error:`No OAuth discovery endpoint found for '${t}'.`};if(!r.authorizationEndpoint||!r.tokenEndpoint)return{success:!1,error:`OAuth metadata incomplete for '${t}'.`};let n=ct(r.dpopSigningAlgValuesSupported),o=null,s=null;if(n){let h=await st();o=h.keys,s=h.dpopKeyPair}let a=await this.credentialBackend.get(t),i=a?.clientId??null,c=a?.clientSecret??null;if(!i&&r.registrationEndpoint){let h=await this.registerClient(r.registrationEndpoint);if(!h)return{success:!1,error:`Dynamic client registration failed for '${t}'.`};i=h.clientId,c=h.clientSecret??null}if(!i)return{success:!1,error:`No OAuth client credentials for '${t}'.`};let l=tn(),u=await rn(l),m=nn(),y=on(r.authorizationEndpoint,i,this.callbackUrl,m,u),f=await this.openAuthPopup(y,m);if(!f)return{success:!1,error:"Authorization timed out or was cancelled."};if(f.error)return{success:!1,error:`Authorization failed: ${f.error}`};if(!f.code)return{success:!1,error:"No authorization code received."};if(f.state!==m)return{success:!1,error:"State mismatch \u2014 possible CSRF attack."};let d=await this.exchangeCode(r.tokenEndpoint,i,c,f.code,this.callbackUrl,l,o);if(!d)return{success:!1,error:"Token exchange failed."};let g={clientId:i,clientSecret:c,accessToken:d.accessToken??null,refreshToken:d.refreshToken??null,expiresAt:d.expiresIn?new Date(Date.now()+d.expiresIn*1e3).toISOString():null,tokenEndpoint:r.tokenEndpoint,dpopKeyPair:s};return await this.credentialBackend.store(t,g),{success:!0,host:t}}async getCredentialWithKeys(e){let t=await this.credentialBackend.get(e);if(!t)return null;let r=null;return t.dpopKeyPair&&(r=await at(t.dpopKeyPair)),{credential:t,dpopKeys:r}}async logout(e){let t=X(e);return await this.credentialBackend.remove(t),{success:!0,host:t}}async listAuthenticated(){return this.credentialBackend.list()}async discover(e){for(let t of[`https://${e}/.well-known/oauth-authorization-server`,`https://${e}/.well-known/openid-configuration`])try{let r=await fetch(t);if(!r.ok)continue;let n=await r.json();return{issuer:Me(n.issuer),authorizationEndpoint:Me(n.authorization_endpoint),tokenEndpoint:Me(n.token_endpoint),registrationEndpoint:Me(n.registration_endpoint),revocationEndpoint:Me(n.revocation_endpoint),dpopSigningAlgValuesSupported:tr(n.dpop_signing_alg_values_supported),codeChallengeMethodsSupported:tr(n.code_challenge_methods_supported)}}catch{continue}return null}async registerClient(e){try{let t=await fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({client_name:"Kanonak Browser",redirect_uris:[this.callbackUrl],grant_types:["authorization_code","refresh_token"],response_types:["code"],token_endpoint_auth_method:"none"})});if(!t.ok)return null;let r=await t.json(),n=r.client_id;return n?{clientId:n,clientSecret:r.client_secret}:null}catch{return null}}openAuthPopup(e,t){return new Promise(r=>{let n=window.open(e,"kanonak-auth","width=500,height=700,menubar=no,toolbar=no,location=yes,status=no");if(!n){r(null);return}let o=setTimeout(()=>{i(),r(null)},en),s=c=>{c.origin===window.location.origin&&(!c.data||c.data.type!=="kanonak-auth-callback"||(i(),r({code:c.data.code??void 0,state:c.data.state??void 0,error:c.data.error??void 0})))},a=setInterval(()=>{n.closed&&(i(),r(null))},500),i=()=>{clearTimeout(o),clearInterval(a),window.removeEventListener("message",s);try{n.close()}catch{}};window.addEventListener("message",s)})}async exchangeCode(e,t,r,n,o,s,a){let i=new URLSearchParams({grant_type:"authorization_code",client_id:t,code:n,redirect_uri:o,code_verifier:s});r&&i.set("client_secret",r);let c={"Content-Type":"application/x-www-form-urlencoded"};a&&(c.DPoP=await it(a,"POST",e));try{let l=await fetch(e,{method:"POST",headers:c,body:i.toString()});if(!l.ok)return null;let u=await l.json();return{accessToken:u.access_token,refreshToken:u.refresh_token,expiresIn:typeof u.expires_in=="number"?u.expires_in:void 0}}catch{return null}}};function tn(){let p=new Uint8Array(32);return crypto.getRandomValues(p),At(p.buffer)}async function rn(p){let e=new TextEncoder().encode(p),t=await crypto.subtle.digest("SHA-256",e);return At(t)}function nn(){let p=new Uint8Array(16);return crypto.getRandomValues(p),At(p.buffer)}function on(p,e,t,r,n){let o=new URLSearchParams({client_id:e,response_type:"code",redirect_uri:t,state:r,code_challenge:n,code_challenge_method:"S256"});return`${p}?${o}`}function At(p){let e=new Uint8Array(p),t="";for(let r=0;r<e.length;r++)t+=String.fromCharCode(e[r]);return btoa(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/,"")}function Me(p){return typeof p=="string"?p:null}function tr(p){return Array.isArray(p)?p.filter(e=>typeof e=="string"):null}export{Pe as AmbiguousReferenceRule,ne as BooleanStatement,Te as BrowserCredentialBackend,pt as BrowserOAuthFlow,Ve as ClassDefinitionRule,ye as ClassHierarchyCycleRule,tt as CtlGraphResolver,Ke as CtlKanonakUri,zr as CtlKanonakUriType,nt as CtlMarkdownRenderer,Qe as CtlParser,qr as CtlValidationErrorType,Gr as CtlValidationSeverity,et as CtlValidator,Y as DefinedKanonak,Re as DefinitionPropertyReferenceRule,dt as EdgeType,T as EmbeddedKanonak,pe as EmbeddedKanonakTypeRule,B as EmbeddedStatement,Be as GraphBuilder,Rt as HttpKanonakDocumentRepository,le as ImportExistenceRule,bt as InMemoryKanonakDocumentRepository,be as InstancePropertyReferenceRule,U as Kanonak,Oe as KanonakDocumentPositions,Ee as KanonakObjectParser,He as KanonakObjectValidator,E as KanonakParser,$ as KanonakUri,qe as KanonakUriBuilder,_ as ListStatement,ke as NamespaceImportCycleRule,se as NamespacePrefixRule,ft as NodeType,re as NumberStatement,Ie as ObjectPropertyImportRule,Ae as ObjectPropertyValueValidationRule,k as OntologyValidationError,oe as OntologyValidationResult,Xr as PathSegmentType,De as PropertyDomainRule,fe as PropertyHierarchyCycleRule,Le as PropertyMetadata,we as PropertyRangeReferenceRule,de as PropertyRangeRequiredRule,ie as PropertyTypeSpecificityRule,Se as PropertyValueTypeRule,Ne as PublisherConfigResolver,Ce as PublisherIndex,w as ReferenceKanonak,N as ReferenceStatement,Yr as ResolvedResourceType,ae as ResourceNamingRule,A as ResourceResolver,I as ResourceTypeClassifier,L as ScalarStatement,x as Statement,F as StringStatement,ge as SubClassOfReferenceRule,he as SubPropertyOfReferenceRule,C as SubjectKanonak,ce as SubjectKanonakTypeRequiredRule,me as TypeAmbiguityRule,J as TypeResolver,ue as UnresolvedReferenceRule,We as ValidationContext,P as ValidationSeverity,ve as XsdImportRule,ct as browserServerSupportsDPoP,z as compareVersions,it as createBrowserDPoPProof,kt as createVersion,Bt as findDerivation,Tt as findInstancesByType,ht as formatVersion,st as generateBrowserDPoPKeyPair,er as generateBrowserDPoPKeys,Jt as hasValidToken,at as importDPoPKeys,ze as isCompatibleVersion,wt as isExpired,Xe as isMajorCompatible,X as normalizeHost,Nt as parseVersionString,Kt as parseWithPositions,_t as pickHighestDocument,Ge as versionsEqual};
|