@kanonak-protocol/sdk 3.8.0 → 3.9.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.js +1 -1
- package/dist/index.js +1 -1
- package/dist/parsing/index.js +1 -1
- package/dist/reasoning/index.js +1 -1
- package/dist/resolution/index.js +1 -1
- package/dist/validation/index.js +1 -1
- package/package.json +2 -2
package/dist/browser.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
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(`
|
|
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(!a.includes(".")&&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(!i.includes(".")&&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
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_AUGMENTATION_PATTERN=/^[a-zA-Z][a-zA-Z0-9_-]*\.[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)){let s=p.VALID_AUGMENTATION_PATTERN.test(n);if(!s&&!r&&p.RESERVED_WORDS.has(n.toLowerCase())){let a=new k;a.ruleType=this.ruleName,a.severity="Error",a.entityName=n,a.message=`Entity name '${n}' is a reserved word and cannot be used.`,a.suggestion="Choose a different name that doesn't conflict with Kanonak reserved words.",t.push(a);continue}if(!s&&!p.VALID_NAME_PATTERN.test(n)){let a;/^\d/.test(n)?a="Entity names must start with a letter, not a number.":n.includes(" ")?a="Entity names cannot contain spaces. Use camelCase or underscores instead.":a="Entity names must start with a letter and contain only letters, numbers, and underscores.";let i=new k;i.ruleType=this.ruleName,i.severity="Error",i.entityName=n,i.message=`Invalid entity name '${n}'. ${a}`,i.suggestion=a,t.push(i)}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)||r.includes("."))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
|
|
package/dist/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
var sn=Object.defineProperty;var an=(i,e)=>()=>(i&&(e=i(i=0)),e);var cn=(i,e)=>{for(var t in e)sn(i,t,{get:e[t],enumerable:!0})};var hr={};cn(hr,{KanonakUri:()=>T});function yn(i,e,t){return{major:i,minor:e,patch:t,toString:()=>`${i}.${e}.${t}`,equals:r=>!r||typeof r!="object"?!1:r.major===i&&r.minor===e&&r.patch===t,getHashCode:()=>i<<20|e<<10|t,compareTo:r=>i!==r.major?i-r.major:e!==r.minor?e-r.minor:t-r.patch}}var T,le=an(()=>{"use strict";T=class i{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 i(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 p=c.split(".").map(Number),l=yn(p[0]||0,p[1]||0,p[2]||0);return new i(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}`}}});function F(i,e){return i.major!==e.major?i.major-e.major:i.minor!==e.minor?i.minor-e.minor:i.patch-e.patch}function _e(i,e){return i.major===e.major&&i.minor===e.minor&&i.patch===e.patch}function Gt(i){return`${i.major}.${i.minor}.${i.patch}`}function zt(i,e,t){let r=`${i}.${e}.${t}`;return{major:i,minor:e,patch:t,toString:()=>r,equals:n=>n?.major===i&&n?.minor===e&&n?.patch===t,getHashCode:()=>i<<20|e<<10|t,compareTo:n=>i!==n.major?i-n.major:e!==n.minor?e-n.minor:t-n.patch}}function mr(i){let e=/^(\d+)\.(\d+)\.(\d+)$/.exec(i);return e?zt(Number(e[1]),Number(e[2]),Number(e[3])):null}function Ue(i,e){return F(i,e)>=0&&i.major===e.major&&i.minor===e.minor}function Le(i,e){return e.major===0?F(i,e)>=0&&i.major===0&&i.minor===e.minor:F(i,e)>=0&&i.major===e.major}function yr(i,e={}){let{requestedVersion:t}=e;if(i.length===0)return{chosen:null,alternatives:[],multipleVersionsPresent:!1,exactRequestedVersionMissing:!!t};if(t){let n=i.find(o=>{let s=o.metadata.namespace_?.version;return!!s&&Gt(s)===t});return n?{chosen:n,alternatives:i.filter(o=>o!==n),multipleVersionsPresent:i.length>1,exactRequestedVersionMissing:!1}:{chosen:null,alternatives:i,multipleVersionsPresent:i.length>1,exactRequestedVersionMissing:!0}}if(i.length===1)return{chosen:i[0],alternatives:[],multipleVersionsPresent:!1,exactRequestedVersionMissing:!1};let r=[...i].sort((n,o)=>{let s=n.metadata.namespace_?.version,a=o.metadata.namespace_?.version;return!s&&!a?0:s?a?F(a,s):-1:1});return{chosen:r[0],alternatives:r.slice(1),multipleVersionsPresent:!0,exactRequestedVersionMissing:!1}}var mt=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 _e(s,t.version);case 1:return Ue(s,t.version);case 2:return Le(s,t.version);case 3:return F(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?F(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*as K from"fs/promises";import*as D from"path";import{pathToFileURL as fr}from"url";import*as yt from"js-yaml";var $=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=yt.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),yt.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 p=0;p<s.length;p++)c=(c<<5)-c+s.charCodeAt(p);for(let p=0;p<o.length;p++)c=(c<<5)-c+o.charCodeAt(p);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),p=e.alias;return{package_:`${r} ${n} ${s.toString()}`,publisher:t,packageName:r,versionOperator:a,version:s,alias:p,minVersion:s,maxVersion:c,toEmbeddedObject:()=>{let l={package:r,match:n,version:s.toString()};return p&&(l.alias=p),l},toString:()=>p?`${r} ${n} ${s.toString()} as ${p}`:`${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 l=c[1].trim(),u=c[2],m=this.parseVersion(c[3].trim()),y=c[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 p=e.match(/^(.+?)\s*([~^=*])\s*(.+)$/);if(p){let l=p[1].trim(),u=p[2],m=this.parseVersion(p[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 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 ce=class{rootPath;recursive;parser;documentCache;filePathsByIdentifier;cacheInitialized=!1;cacheInitPromise=null;parsingErrors=new Map;constructor(e,t=!0,r){if(!e||e.trim().length===0)throw new Error("Root path cannot be null or empty");this.rootPath=D.resolve(e),this.recursive=t,this.parser=r??new $,this.documentCache=new Map,this.filePathsByIdentifier=new Map}async getAllDocumentsAsync(){await this.ensureCacheInitialized();let e=new Set(this.documentCache.values());return Array.from(e)}async getDocumentAsync(e){await this.ensureCacheInitialized();let t=this.documentCache.get(e);if(t)return t;let r=D.join(this.rootPath,e);if(t=this.documentCache.get(r),t)return t;for(let n of[".kan.yml",".yml",".yaml"])if(!e.endsWith(n)){let o=e+n;if(t=this.documentCache.get(o),t)return t;let s=D.join(this.rootPath,o);if(t=this.documentCache.get(s),t)return t}return null}async getDocumentsByNamespaceAsync(e,t){await this.ensureCacheInitialized();let r=new Set(this.documentCache.values());return Array.from(r).filter(n=>n.metadata.namespace_?.publisher===e&&n.metadata.namespace_?.package_===t)}async getHighestCompatibleVersionAsync(e,t){await this.ensureCacheInitialized();let r=new Set(this.documentCache.values()),n=Array.from(r).filter(s=>s.metadata?.namespace_?.publisher===e&&s.metadata?.namespace_?.package_===t.packageName&&s.metadata?.namespace_?.version!==void 0);if(n.length===0)return null;let o=n.filter(s=>{let a=s.metadata.namespace_.version;switch(t.versionOperator){case 0:return _e(a,t.version);case 1:return Ue(a,t.version);case 2:return Le(a,t.version);case 3:return F(a,t.minVersion)>=0;default:return!1}});return o.length===0?null:(o.sort((s,a)=>{let c=s.metadata.namespace_.version,p=a.metadata.namespace_.version;return F(p,c)}),o[0])}async saveDocumentAsync(e,t){let r,n=e.metadata.namespace_?.toString();if(n&&n.includes("@")&&n.includes("/")){let c=n.split("/"),p=c[0],u=c[1].replace("@","@")+".kan.yml";r=D.join(this.rootPath,p,u)}else r=D.join(this.rootPath,t),!r.endsWith(".yml")&&!r.endsWith(".yaml")&&!r.endsWith(".kan.yml")&&(r+=".kan.yml");let o=D.dirname(r);await K.mkdir(o,{recursive:!0});let s=this.parser.save(e);await K.writeFile(r,s,"utf8"),n&&this.documentCache.set(n,e),this.documentCache.set(r,e);let a=D.relative(this.rootPath,r);this.documentCache.set(a,e)}async deleteDocumentAsync(e){let t=await this.getDocumentAsync(e);if(!t)return;let r=this.filePathsByIdentifier.get(e);if(!r)return;try{await K.unlink(r)}catch{}let n=t.metadata.namespace_?.toString();n&&this.documentCache.delete(n),this.documentCache.delete(e),this.documentCache.delete(r);let o=D.relative(this.rootPath,r);this.documentCache.delete(o)}async clearNamespaceAsync(e,t){await this.ensureCacheInitialized();let r=[];for(let[o,s]of this.documentCache.entries()){let a=s.metadata.namespace_?.toString()||"";a.includes(e)&&a.includes(t)&&r.push([o,s])}let n=D.join(this.rootPath,e);try{let o=await K.readdir(n);for(let s of o)s.includes(t)&&s.endsWith(".kan.yml")&&await K.unlink(D.join(n,s))}catch{}for(let[o]of r)this.documentCache.delete(o)}async getAllDocumentReferencesAsync(){await this.ensureCacheInitialized();let e=new Set(this.filePathsByIdentifier.values()),t=[];for(let r of e){let n=fr(r).toString(),o;for(let[c,p]of this.documentCache.entries())if(this.filePathsByIdentifier.get(c)===r&&p.metadata.namespace_){o=p.metadata.namespace_.toString();break}let s=o??D.relative(this.rootPath,r),a=this.parsingErrors.has(r);t.push({identifier:s,uri:n,hasParseError:a})}return t}async getDocumentContentAsync(e){await this.ensureCacheInitialized();let t=this.filePathsByIdentifier.get(e);if(!t)try{await K.access(e),t=e}catch{let r=D.join(this.rootPath,e);try{await K.access(r),t=r}catch{return null}}try{return await K.readFile(t,"utf8")}catch{return null}}async getDocumentUriAsync(e){await this.ensureCacheInitialized();let t=this.filePathsByIdentifier.get(e);if(!t)try{await K.access(e),t=e}catch{let r=D.join(this.rootPath,e);try{await K.access(r),t=r}catch{return null}}return fr(t).toString()}async refreshAsync(){this.documentCache.clear(),this.filePathsByIdentifier.clear(),this.parsingErrors.clear(),this.cacheInitialized=!1,this.cacheInitPromise=null,await this.ensureCacheInitialized()}async ensureCacheInitialized(){if(!this.cacheInitialized){if(this.cacheInitPromise){await this.cacheInitPromise;return}this.cacheInitPromise=this.loadDocuments(),await this.cacheInitPromise,this.cacheInitialized=!0}}async loadDocuments(){try{await K.mkdir(this.rootPath,{recursive:!0})}catch{}let t=(await this.findYamlFiles(this.rootPath,this.recursive)).map(async n=>{try{let o=await K.readFile(n,"utf8"),s=this.parser.parse(o);return{filePath:n,document:s,error:null}}catch(o){return{filePath:n,document:null,error:o instanceof Error?o.message:String(o)}}}),r=await Promise.all(t);for(let{filePath:n,document:o,error:s}of r){let a=D.relative(this.rootPath,n);if(o&&o.metadata.namespace_){let c=o.metadata.namespace_.toString();this.documentCache.set(c,o),this.documentCache.set(n,o),this.documentCache.set(a,o),this.filePathsByIdentifier.set(c,n),this.filePathsByIdentifier.set(n,n),this.filePathsByIdentifier.set(a,n)}else this.filePathsByIdentifier.set(n,n),this.filePathsByIdentifier.set(a,n);s&&this.parsingErrors.set(n,s)}}async findYamlFiles(e,t){let r=[];try{let n=await K.readdir(e,{withFileTypes:!0});for(let o of n){let s=D.join(e,o.name);if(o.isDirectory()&&t){let a=await this.findYamlFiles(s,t);r.push(...a)}else o.isFile()&&o.name.endsWith(".kan.yml")&&r.push(s)}}catch{}return r}};import*as Me from"fs";var Xt=(r=>(r.NotFound="NotFound",r.Workspace="Workspace",r.Cache="Cache",r))(Xt||{}),Fe=class{cache;workspace;constructor(e,t,r){let n=r??new $;Me.existsSync(e)||Me.mkdirSync(e,{recursive:!0}),Me.existsSync(t)||Me.mkdirSync(t,{recursive:!0}),this.cache=new ce(e,!0,n),this.workspace=new ce(t,!0,n)}getCache(){return this.cache}getWorkspace(){return this.workspace}async getAllDocumentsAsync(){let e=await this.workspace.getAllDocumentsAsync(),t=await this.cache.getAllDocumentsAsync(),r=new Map;for(let n of t)if(n.metadata.namespace_){let o=n.metadata.namespace_.toString();r.set(o,n)}for(let n of e)if(n.metadata.namespace_){let o=n.metadata.namespace_.toString();r.set(o,n)}return Array.from(r.values())}async getDocumentAsync(e){let t=await this.workspace.getDocumentAsync(e);return t||await this.cache.getDocumentAsync(e)}async getDocumentsByNamespaceAsync(e,t){let r=await this.workspace.getDocumentsByNamespaceAsync(e,t),n=await this.cache.getDocumentsByNamespaceAsync(e,t),o=new Map;for(let s of n)if(s.metadata.namespace_?.version){let a=s.metadata.namespace_.version.toString();o.set(a,s)}for(let s of r)if(s.metadata.namespace_?.version){let a=s.metadata.namespace_.version.toString();o.set(a,s)}return Array.from(o.values())}async getHighestCompatibleVersionAsync(e,t){let r=await this.workspace.getHighestCompatibleVersionAsync(e,t);return r||await this.cache.getHighestCompatibleVersionAsync(e,t)}async saveDocumentAsync(e,t){await this.workspace.saveDocumentAsync(e,t)}async saveToCacheAsync(e,t){await this.cache.saveDocumentAsync(e,t)}async deleteDocumentAsync(e){await this.workspace.deleteDocumentAsync(e)}async clearNamespaceAsync(e,t){await this.workspace.clearNamespaceAsync(e,t)}async getAllDocumentReferencesAsync(){let e=await this.workspace.getAllDocumentReferencesAsync(),t=await this.cache.getAllDocumentReferencesAsync(),r=[];return r.push(...e),r.push(...t),r}async getDocumentContentAsync(e){let t=await this.workspace.getDocumentContentAsync(e);return t||await this.cache.getDocumentContentAsync(e)}async getDocumentUriAsync(e){let t=await this.workspace.getDocumentUriAsync(e);return t||await this.cache.getDocumentUriAsync(e)}async getDocumentLocationAsync(e){return await this.workspace.getDocumentAsync(e)?"Workspace":await this.cache.getDocumentAsync(e)?"Cache":"NotFound"}};import{homedir as pn}from"os";import{join as ln}from"path";function Qe(){let i=process.env.KANONAK_PACKAGE_CACHE;return i||ln(pn(),".kanonak","packages")}var ft=class i{static createComposite(e,t,r){let n=e??Qe(),o=t??".";return new Fe(n,o,r)}static createFromEnvironment(e){let t=Qe(),r=process.env.KANONAK_WORKSPACE_PATH??".";return i.createComposite(t,r,e)}};import{VersionOperator as dt}from"@kanonak-protocol/types/document/models/enums";var un="https://{publisher}/index.txt",mn="https://{publisher}/{package}/{version}.kan.yml",dr={version:1},Be=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 dr}if(r.status===404)return dr;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??un;return gr(r,{publisher:e})}resolvePackageUrl(e,t,r,n){let o=n.package??mn;return gr(o,{publisher:e,package:t,version:r})}};function gr(i,e){let t=i;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: ${i}`);return t}var pe=class i{indexCache=new Map;configResolver;fetchFn;constructor(e){this.configResolver=e?.configResolver??new Be,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 i.parseIndex(o)}static parseIndex(e){let t=new Map;for(let r of e.split(`
|
|
2
|
-
`)){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=i.parseVersion(e);if(!n)return!1;switch(r){case dt.Any:return!0;case dt.Exact:return n.major===t.major&&n.minor===t.minor&&n.patch===t.patch;case dt.Compatible:return n.major===t.major&&n.minor===t.minor&&n.patch>=t.patch;case dt.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=i.parseVersion(e),n=i.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 gt=class{parser=new $;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 pe({fetchFn:e.fetchFn}):new pe}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 c=await a.text();this.onFetch&&this.onFetch(e,t.packageName,r,c);let p=this.parser.parse(c);return this.documents.set(n,p),this.contentCache.set(n,c),p}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)}};var z=class{};var re=class extends z{statement=[]};var N=class extends re{namespace;name;icon};var _=class extends re{name};le();var w=class i extends z{subject;static parse(e){let t=new i;return t.subject=T.parse(e),t}};var Z=class extends z{value};var B=class{predicate;object};var X=class extends B{};var W=class i extends X{static parse(e,t){let r=new i;return r.predicate=w.parse(e),r.object=t,r}};var Q=class i extends X{static parse(e,t){let r=new i;return r.predicate=w.parse(e),r.object=t,r}};var ee=class extends X{};var U=class i extends B{static parse(e,t){let r=new i;return r.predicate=w.parse(e),r.object=w.parse(t),r}};var H=class extends B{};var L=class extends B{};le();function E(i){if(Array.isArray(i))return i.map(t=>t?.toString()??"").filter(t=>t.length>0);let e=i?.toString();return e?[e]:[]}var j=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 p=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 T(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,a,p),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,p)=>c+p.length,0);this.logger?.debug?.(`Processing ${a} import(s) for ${o}`);for(let[c,p]of Object.entries(e.metadata.imports))for(let l of p)try{this.logger?.debug?.(`Resolving import: ${c}/${l.packageName}`);let u=await this.repository.getHighestCompatibleVersionAsync(c,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: ${c}/${l.packageName}`)}catch(u){let m=u;throw this.logger?.error?.(`Failed to process import ${c}/${l.packageName} for namespace ${o}. Error: ${m.message}`,m),new Error(`Failed to process import ${c}/${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[c,p]of Object.entries(e.body))if(p&&typeof p=="object"&&!Array.isArray(p)&&!n.has(c)){let l=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 T(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,c,l),entity:p,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((p,l)=>p+l.length,0);this.logger?.debug?.(`Processing ${c} import(s) for ${o}`);for(let[p,l]of Object.entries(e.metadata.imports))for(let u of l)try{this.logger?.debug?.(`Resolving import: ${p}/${u.packageName}`);let m=await this.repository.getHighestCompatibleVersionAsync(p,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: ${p}/${u.packageName}`)}catch(m){let y=m;throw this.logger?.error?.(`Failed to process import ${p}/${u.packageName} for namespace ${o}. Error: ${y.message}`,y),new Error(`Failed to process import ${p}/${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=E(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=E(s);for(let c of a)if(c===t||await this.isSubpropertyOfRecursiveAsync(c,t,r,n))return!0}return!1}};var ne=class i{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"&&i.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 i.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 oe=class{constructor(e){}async parseKanonaks(e){let t=[],r=await e.getAllDocumentsAsync(),n=new j(e),o=new ne(n);for(let c of r){let p=c.metadata.namespace_?.toString()??"";for(let[l,u]of Object.entries(c.body)){let m=new N,y=this.resolveCanonicalEntity(l,c,p);m.namespace=y.namespace,m.name=y.name,m.statement=[];let f=await this.parseStatements(u,c,n,o,e);m.statement.push(...f),t.push(m)}}let s=new Map,a=[];for(let c of t)if(c instanceof N){let p=`${c.namespace}/${c.name}`,l=s.get(p);l?l.statement.push(...c.statement):(s.set(p,c),a.push(c))}else a.push(c);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,c]of Object.entries(t.metadata.imports))for(let p of c)if((p.alias??p.packageName)===o){let u=p.version;return{namespace:`${a}/${p.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,c]of Object.entries(e))try{let p=await this.getPropertyMetadata(a,t,r,o,n);if(!p)continue;let l=await this.parsePropertyValue(a,c,p,t,r,n);l&&s.push(l)}catch(p){console.error(`Error parsing property ${a}:`,p)}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()??"",p=c.includes(".")?c.substring(c.lastIndexOf(".")+1):c;if(!new Set(["Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]).has(p))return;let u=o.getPropertyTypeClassification(c),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 W.parse(e,t.toISOString());if(typeof t=="string")return W.parse(e,t);if(typeof t=="number")return Q.parse(e,t);if(typeof t=="boolean"){let n=new ee;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 c=new U;return c.predicate=w.parse(e),c.object=a,c}if(typeof t=="object"&&!Array.isArray(t)){let a=new _;if(a.statement=await this.parseStatements(t,n,o,s,{}),a.statement.length>0){let l=new H;return l.predicate=w.parse(e),l.object=a,l}let c=[];for(let[l,u]of Object.entries(t))if(typeof u=="object"&&u!==null&&!Array.isArray(u)){let m=new _;m.name=l,m.statement=await this.parseStatements(u,n,o,s,{}),c.push(m)}else if(typeof u=="string"){let m=await this.resolveReference(u,n,o);m&&c.push(m)}if(c.length>0){let l=new L;return l.predicate=w.parse(e),l.object=c,l}let p=new H;return p.predicate=w.parse(e),p.object=a,p}}async parseListValue(e,t,r,n,o,s){let a=[],c=r.propertyType==="DatatypeProperty";for(let l of t){if(c&&(typeof l=="string"||typeof l=="number"||typeof l=="boolean")){let u=new Z;u.value=l,a.push(u);continue}if(c&&l instanceof Date){let u=new Z;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 _;u.statement=await this.parseStatements(l,n,o,s,{}),a.push(u)}}let p=new L;return p.predicate=w.parse(e),p.object=a,p}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(()=>(le(),hr)),a=o.version??{major:0,minor:0,patch:0,toString:()=>"0.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};if(e.includes(".")){let p=e.indexOf("."),l=e.substring(0,p),u=e.substring(p+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 c=new w;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 N&&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 N&&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 $().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[p,l]=this.convertStatementToProperty(c);p&&l!==null&&l!==void 0&&(a[p]=l),this.collectImportsFromStatement(c,e,o)}n.body[s.name]=a}return n}convertStatementToProperty(e){if(e instanceof W)return[e.predicate.subject.name,e.object];if(e instanceof Q)return[e.predicate.subject.name,e.object];if(e instanceof ee)return[e.predicate.subject.name,e.object];if(e instanceof U)return[e.predicate.subject.name,e.object.subject.name];if(e instanceof L){let t=this.convertKanonakListToValue(e.object);return[e.predicate.subject.name,t]}else if(e instanceof H){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.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 fn=new Set(["kanonak.org/core-rdf","kanonak.org/core-rdfs","kanonak.org/core-owl","kanonak.org/core-xsd","kanonak.org/core-kanonak"]),kr={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 Y(i){let e=i;if(e.entity&&typeof e.entity=="object"){let t=e.entity.type;if(typeof t=="string"){let r=kr[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=kr[r.name];if(n)return{publisher:n.publisher,package_:n.package_,name:r.name}}return r}}return null}function te(i,e){return fn.has(`${i}/${e}`)}var I=class i{static getTypeUri(e){return Y(e)}static isCoreOntologyType(e){return te(e.publisher,e.package_)}static isClassType(e){let t=Y(e);return t?te(t.publisher,t.package_)&&t.name==="Class":!1}static isDatatypeType(e){let t=Y(e);return t?te(t.publisher,t.package_)&&t.name==="Datatype":!1}static isDatatypePropertyType(e){let t=Y(e);return t?te(t.publisher,t.package_)&&t.name==="DatatypeProperty":!1}static isObjectPropertyType(e){let t=Y(e);return t?te(t.publisher,t.package_)&&t.name==="ObjectProperty":!1}static isAnnotationPropertyType(e){let t=Y(e);return t?te(t.publisher,t.package_)&&t.name==="AnnotationProperty":!1}static isGenericPropertyType(e){let t=Y(e);return t?te(t.publisher,t.package_)&&t.name==="Property":!1}static isAnyPropertyType(e){let t=Y(e);return!t||!te(t.publisher,t.package_)?!1:t.name==="Property"||t.name==="DatatypeProperty"||t.name==="ObjectProperty"||t.name==="AnnotationProperty"}static isSchemaDefinitionType(e){let t=Y(e);return!t||!te(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(i.isSchemaDefinitionType(e))return!1;let r=Y(e);return r?t.has(r.name):!1}};var Jt=(a=>(a.Class="Class",a.DatatypeProperty="DatatypeProperty",a.ObjectProperty="ObjectProperty",a.AnnotationProperty="AnnotationProperty",a.Instance="Instance",a.Datatype="Datatype",a.Unknown="Unknown",a))(Jt||{}),Zt=(a=>(a.InstanceOf="instanceOf",a.SubClassOf="subClassOf",a.Domain="domain",a.Range="range",a.ObjectRelationship="objectRelationship",a.SubPropertyOf="subPropertyOf",a.PropertyValue="propertyValue",a))(Zt||{}),ht=class{static async buildFromRepository(e){let r=await new oe().parseKanonaks(e),n=await e.getAllDocumentsAsync(),o=[],s=[],a=new Set,c=new Set,p=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))&&c.add(m.name))}for(let u of n)for(let[m,y]of Object.entries(u.body))c.has(m)&&y?.range&&typeof y.range=="string"&&p.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=br(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 V=b;I.isClassType(V)?R="Class":I.isObjectPropertyType(V)?R="ObjectProperty":I.isDatatypePropertyType(V)?R="DatatypeProperty":I.isAnnotationPropertyType(V)?R="AnnotationProperty":I.isDatatypeType(V)?R="Datatype":I.isGenericPropertyType(V)?R="ObjectProperty":I.isInstanceOfKnownClass(V,a)&&(R="Instance")}let v=y&&f?`${y}/${g}@${f}`:g,x={};for(let[V,qt]of Object.entries(h))V!=="type"&&(typeof qt!="object"||qt===null)&&(x[V]=qt);o.push({id:v,label:h.label??g,type:R,namespace:y,properties:x}),Rr(v,h,R,a,c,s,y,f,d),Yt(v,h,c,p,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,c=new Set,p=new Map,l=br(e);for(let[y,f]of Object.entries(e.body)){let d=f?.type;d&&(gn(d,l)&&a.add(y),hn(d,l)&&(c.add(y),f.range&&typeof f.range=="string"&&p.set(y,f.range)))}for(let[y,f]of Object.entries(e.body)){if(!f||typeof f!="object")continue;let d=f.type,g=kn(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}),Rr(h,f,g,a,c,r,s,o,l),Yt(h,f,c,p,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 br(i,e){let t=new Map;if(i.metadata?.imports)for(let[r,n]of Object.entries(i.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 vr={"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"},dn=new Set(["kanonak.org/core-owl/ObjectProperty","kanonak.org/core-owl/DatatypeProperty","kanonak.org/core-owl/AnnotationProperty","kanonak.org/core-rdf/Property"]);function Qt(i,e){if(i.includes(".")){let t=i.indexOf("."),r=i.substring(0,t),n=i.substring(t+1),o=e.get(r);if(o)return`${o.publisher}/${o.package_}/${n}`}return null}function gn(i,e){let t=Qt(i,e);return t?vr[t]==="Class":!1}function hn(i,e){let t=Qt(i,e);return t?dn.has(t):!1}function kn(i,e,t,r){if(!i||i==="Package")return"Unknown";let n=Qt(i,r);if(n){let s=vr[n];if(s)return s;let a=n.split("/").pop()?.split("@")[0]??"";return t.has(a)?"Instance":"Unknown"}let o=i.split(".").pop()??i;return t.has(o)?"Instance":"Unknown"}var Pr=new Set(["type","label","comment","version","publisher","imports","license","match","alias","package"]);function Rr(i,e,t,r,n,o,s,a,c){let p=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:i,target:se(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:i,target:se(d,s,a,c),type:"subPropertyOf",label:"subPropertyOf"})}if(t==="Instance"&&p){let f=p.split(".").pop()??p;o.push({source:i,target:se(f,s,a,c),type:"instanceOf",label:"type"})}if(t==="Instance")for(let[f,d]of Object.entries(e)){if(Pr.has(f)||!n.has(f))continue;let g=Array.isArray(d)?d:[d];for(let h of g)typeof h=="string"&&bn(h)&&o.push({source:i,target:se(h,s,a,c),type:"propertyValue",label:f,propertyId:se(f,s,a,c)})}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:se(f,s,a,c),target:se(d,s,a,c),type:"objectRelationship",label:e.label??i.split("/").pop()??"",propertyId:i})}}function Yt(i,e,t,r,n,o,s,a,c){for(let[p,l]of Object.entries(e)){if(Pr.has(p)||typeof l!="object"||l===null||Array.isArray(l))continue;let u=l,m=`${i}/${p}`,y=r.get(p),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}/${p}@${a}`:p;o.push({source:i,target:m,type:"propertyValue",label:p,propertyId:t.has(p)?g:void 0}),y&&o.push({source:m,target:se(f,s,a,c),type:"instanceOf",label:"type (inferred)"}),Yt(m,u,t,r,n,o,s,a,c)}}function bn(i){return!(!i||i.includes(" ")||i.includes(`
|
|
2
|
+
`)){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=i.parseVersion(e);if(!n)return!1;switch(r){case dt.Any:return!0;case dt.Exact:return n.major===t.major&&n.minor===t.minor&&n.patch===t.patch;case dt.Compatible:return n.major===t.major&&n.minor===t.minor&&n.patch>=t.patch;case dt.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=i.parseVersion(e),n=i.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 gt=class{parser=new $;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 pe({fetchFn:e.fetchFn}):new pe}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 c=await a.text();this.onFetch&&this.onFetch(e,t.packageName,r,c);let p=this.parser.parse(c);return this.documents.set(n,p),this.contentCache.set(n,c),p}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)}};var z=class{};var re=class extends z{statement=[]};var N=class extends re{namespace;name;icon};var _=class extends re{name};le();var w=class i extends z{subject;static parse(e){let t=new i;return t.subject=T.parse(e),t}};var Z=class extends z{value};var B=class{predicate;object};var X=class extends B{};var W=class i extends X{static parse(e,t){let r=new i;return r.predicate=w.parse(e),r.object=t,r}};var Q=class i extends X{static parse(e,t){let r=new i;return r.predicate=w.parse(e),r.object=t,r}};var ee=class extends X{};var U=class i extends B{static parse(e,t){let r=new i;return r.predicate=w.parse(e),r.object=w.parse(t),r}};var H=class extends B{};var L=class extends B{};le();function E(i){if(Array.isArray(i))return i.map(t=>t?.toString()??"").filter(t=>t.length>0);let e=i?.toString();return e?[e]:[]}var j=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(!a.includes(".")&&c&&typeof c=="object"&&!Array.isArray(c)){let p=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 T(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,a,p),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,p)=>c+p.length,0);this.logger?.debug?.(`Processing ${a} import(s) for ${o}`);for(let[c,p]of Object.entries(e.metadata.imports))for(let l of p)try{this.logger?.debug?.(`Resolving import: ${c}/${l.packageName}`);let u=await this.repository.getHighestCompatibleVersionAsync(c,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: ${c}/${l.packageName}`)}catch(u){let m=u;throw this.logger?.error?.(`Failed to process import ${c}/${l.packageName} for namespace ${o}. Error: ${m.message}`,m),new Error(`Failed to process import ${c}/${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[c,p]of Object.entries(e.body))if(!c.includes(".")&&p&&typeof p=="object"&&!Array.isArray(p)&&!n.has(c)){let l=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 T(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,c,l),entity:p,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((p,l)=>p+l.length,0);this.logger?.debug?.(`Processing ${c} import(s) for ${o}`);for(let[p,l]of Object.entries(e.metadata.imports))for(let u of l)try{this.logger?.debug?.(`Resolving import: ${p}/${u.packageName}`);let m=await this.repository.getHighestCompatibleVersionAsync(p,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: ${p}/${u.packageName}`)}catch(m){let y=m;throw this.logger?.error?.(`Failed to process import ${p}/${u.packageName} for namespace ${o}. Error: ${y.message}`,y),new Error(`Failed to process import ${p}/${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=E(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=E(s);for(let c of a)if(c===t||await this.isSubpropertyOfRecursiveAsync(c,t,r,n))return!0}return!1}};var ne=class i{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"&&i.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 i.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 oe=class{constructor(e){}async parseKanonaks(e){let t=[],r=await e.getAllDocumentsAsync(),n=new j(e),o=new ne(n);for(let c of r){let p=c.metadata.namespace_?.toString()??"";for(let[l,u]of Object.entries(c.body)){let m=new N,y=this.resolveCanonicalEntity(l,c,p);m.namespace=y.namespace,m.name=y.name,m.statement=[];let f=await this.parseStatements(u,c,n,o,e);m.statement.push(...f),t.push(m)}}let s=new Map,a=[];for(let c of t)if(c instanceof N){let p=`${c.namespace}/${c.name}`,l=s.get(p);l?l.statement.push(...c.statement):(s.set(p,c),a.push(c))}else a.push(c);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,c]of Object.entries(t.metadata.imports))for(let p of c)if((p.alias??p.packageName)===o){let u=p.version;return{namespace:`${a}/${p.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,c]of Object.entries(e))try{let p=await this.getPropertyMetadata(a,t,r,o,n);if(!p)continue;let l=await this.parsePropertyValue(a,c,p,t,r,n);l&&s.push(l)}catch(p){console.error(`Error parsing property ${a}:`,p)}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()??"",p=c.includes(".")?c.substring(c.lastIndexOf(".")+1):c;if(!new Set(["Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]).has(p))return;let u=o.getPropertyTypeClassification(c),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 W.parse(e,t.toISOString());if(typeof t=="string")return W.parse(e,t);if(typeof t=="number")return Q.parse(e,t);if(typeof t=="boolean"){let n=new ee;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 c=new U;return c.predicate=w.parse(e),c.object=a,c}if(typeof t=="object"&&!Array.isArray(t)){let a=new _;if(a.statement=await this.parseStatements(t,n,o,s,{}),a.statement.length>0){let l=new H;return l.predicate=w.parse(e),l.object=a,l}let c=[];for(let[l,u]of Object.entries(t))if(typeof u=="object"&&u!==null&&!Array.isArray(u)){let m=new _;m.name=l,m.statement=await this.parseStatements(u,n,o,s,{}),c.push(m)}else if(typeof u=="string"){let m=await this.resolveReference(u,n,o);m&&c.push(m)}if(c.length>0){let l=new L;return l.predicate=w.parse(e),l.object=c,l}let p=new H;return p.predicate=w.parse(e),p.object=a,p}}async parseListValue(e,t,r,n,o,s){let a=[],c=r.propertyType==="DatatypeProperty";for(let l of t){if(c&&(typeof l=="string"||typeof l=="number"||typeof l=="boolean")){let u=new Z;u.value=l,a.push(u);continue}if(c&&l instanceof Date){let u=new Z;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 _;u.statement=await this.parseStatements(l,n,o,s,{}),a.push(u)}}let p=new L;return p.predicate=w.parse(e),p.object=a,p}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(()=>(le(),hr)),a=o.version??{major:0,minor:0,patch:0,toString:()=>"0.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};if(e.includes(".")){let p=e.indexOf("."),l=e.substring(0,p),u=e.substring(p+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 c=new w;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 N&&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 N&&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 $().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[p,l]=this.convertStatementToProperty(c);p&&l!==null&&l!==void 0&&(a[p]=l),this.collectImportsFromStatement(c,e,o)}n.body[s.name]=a}return n}convertStatementToProperty(e){if(e instanceof W)return[e.predicate.subject.name,e.object];if(e instanceof Q)return[e.predicate.subject.name,e.object];if(e instanceof ee)return[e.predicate.subject.name,e.object];if(e instanceof U)return[e.predicate.subject.name,e.object.subject.name];if(e instanceof L){let t=this.convertKanonakListToValue(e.object);return[e.predicate.subject.name,t]}else if(e instanceof H){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.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 fn=new Set(["kanonak.org/core-rdf","kanonak.org/core-rdfs","kanonak.org/core-owl","kanonak.org/core-xsd","kanonak.org/core-kanonak"]),kr={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 Y(i){let e=i;if(e.entity&&typeof e.entity=="object"){let t=e.entity.type;if(typeof t=="string"){let r=kr[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=kr[r.name];if(n)return{publisher:n.publisher,package_:n.package_,name:r.name}}return r}}return null}function te(i,e){return fn.has(`${i}/${e}`)}var I=class i{static getTypeUri(e){return Y(e)}static isCoreOntologyType(e){return te(e.publisher,e.package_)}static isClassType(e){let t=Y(e);return t?te(t.publisher,t.package_)&&t.name==="Class":!1}static isDatatypeType(e){let t=Y(e);return t?te(t.publisher,t.package_)&&t.name==="Datatype":!1}static isDatatypePropertyType(e){let t=Y(e);return t?te(t.publisher,t.package_)&&t.name==="DatatypeProperty":!1}static isObjectPropertyType(e){let t=Y(e);return t?te(t.publisher,t.package_)&&t.name==="ObjectProperty":!1}static isAnnotationPropertyType(e){let t=Y(e);return t?te(t.publisher,t.package_)&&t.name==="AnnotationProperty":!1}static isGenericPropertyType(e){let t=Y(e);return t?te(t.publisher,t.package_)&&t.name==="Property":!1}static isAnyPropertyType(e){let t=Y(e);return!t||!te(t.publisher,t.package_)?!1:t.name==="Property"||t.name==="DatatypeProperty"||t.name==="ObjectProperty"||t.name==="AnnotationProperty"}static isSchemaDefinitionType(e){let t=Y(e);return!t||!te(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(i.isSchemaDefinitionType(e))return!1;let r=Y(e);return r?t.has(r.name):!1}};var Jt=(a=>(a.Class="Class",a.DatatypeProperty="DatatypeProperty",a.ObjectProperty="ObjectProperty",a.AnnotationProperty="AnnotationProperty",a.Instance="Instance",a.Datatype="Datatype",a.Unknown="Unknown",a))(Jt||{}),Zt=(a=>(a.InstanceOf="instanceOf",a.SubClassOf="subClassOf",a.Domain="domain",a.Range="range",a.ObjectRelationship="objectRelationship",a.SubPropertyOf="subPropertyOf",a.PropertyValue="propertyValue",a))(Zt||{}),ht=class{static async buildFromRepository(e){let r=await new oe().parseKanonaks(e),n=await e.getAllDocumentsAsync(),o=[],s=[],a=new Set,c=new Set,p=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))&&c.add(m.name))}for(let u of n)for(let[m,y]of Object.entries(u.body))c.has(m)&&y?.range&&typeof y.range=="string"&&p.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=br(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 V=b;I.isClassType(V)?R="Class":I.isObjectPropertyType(V)?R="ObjectProperty":I.isDatatypePropertyType(V)?R="DatatypeProperty":I.isAnnotationPropertyType(V)?R="AnnotationProperty":I.isDatatypeType(V)?R="Datatype":I.isGenericPropertyType(V)?R="ObjectProperty":I.isInstanceOfKnownClass(V,a)&&(R="Instance")}let v=y&&f?`${y}/${g}@${f}`:g,x={};for(let[V,qt]of Object.entries(h))V!=="type"&&(typeof qt!="object"||qt===null)&&(x[V]=qt);o.push({id:v,label:h.label??g,type:R,namespace:y,properties:x}),Rr(v,h,R,a,c,s,y,f,d),Yt(v,h,c,p,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,c=new Set,p=new Map,l=br(e);for(let[y,f]of Object.entries(e.body)){let d=f?.type;d&&(gn(d,l)&&a.add(y),hn(d,l)&&(c.add(y),f.range&&typeof f.range=="string"&&p.set(y,f.range)))}for(let[y,f]of Object.entries(e.body)){if(!f||typeof f!="object")continue;let d=f.type,g=kn(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}),Rr(h,f,g,a,c,r,s,o,l),Yt(h,f,c,p,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 br(i,e){let t=new Map;if(i.metadata?.imports)for(let[r,n]of Object.entries(i.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 vr={"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"},dn=new Set(["kanonak.org/core-owl/ObjectProperty","kanonak.org/core-owl/DatatypeProperty","kanonak.org/core-owl/AnnotationProperty","kanonak.org/core-rdf/Property"]);function Qt(i,e){if(i.includes(".")){let t=i.indexOf("."),r=i.substring(0,t),n=i.substring(t+1),o=e.get(r);if(o)return`${o.publisher}/${o.package_}/${n}`}return null}function gn(i,e){let t=Qt(i,e);return t?vr[t]==="Class":!1}function hn(i,e){let t=Qt(i,e);return t?dn.has(t):!1}function kn(i,e,t,r){if(!i||i==="Package")return"Unknown";let n=Qt(i,r);if(n){let s=vr[n];if(s)return s;let a=n.split("/").pop()?.split("@")[0]??"";return t.has(a)?"Instance":"Unknown"}let o=i.split(".").pop()??i;return t.has(o)?"Instance":"Unknown"}var Pr=new Set(["type","label","comment","version","publisher","imports","license","match","alias","package"]);function Rr(i,e,t,r,n,o,s,a,c){let p=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:i,target:se(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:i,target:se(d,s,a,c),type:"subPropertyOf",label:"subPropertyOf"})}if(t==="Instance"&&p){let f=p.split(".").pop()??p;o.push({source:i,target:se(f,s,a,c),type:"instanceOf",label:"type"})}if(t==="Instance")for(let[f,d]of Object.entries(e)){if(Pr.has(f)||!n.has(f))continue;let g=Array.isArray(d)?d:[d];for(let h of g)typeof h=="string"&&bn(h)&&o.push({source:i,target:se(h,s,a,c),type:"propertyValue",label:f,propertyId:se(f,s,a,c)})}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:se(f,s,a,c),target:se(d,s,a,c),type:"objectRelationship",label:e.label??i.split("/").pop()??"",propertyId:i})}}function Yt(i,e,t,r,n,o,s,a,c){for(let[p,l]of Object.entries(e)){if(Pr.has(p)||typeof l!="object"||l===null||Array.isArray(l))continue;let u=l,m=`${i}/${p}`,y=r.get(p),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}/${p}@${a}`:p;o.push({source:i,target:m,type:"propertyValue",label:p,propertyId:t.has(p)?g:void 0}),y&&o.push({source:m,target:se(f,s,a,c),type:"instanceOf",label:"type (inferred)"}),Yt(m,u,t,r,n,o,s,a,c)}}function bn(i){return!(!i||i.includes(" ")||i.includes(`
|
|
3
3
|
`)||i.startsWith("http://")||i.startsWith("https://")||/^\d{4}-\d{2}/.test(i)||/^\d+(\.\d+)?$/.test(i))}function se(i,e,t,r){if(i.includes("@")&&i.includes("/"))return i;if(i.includes(".")){let n=i.indexOf("."),o=i.substring(0,n),s=i.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}/${i}@${t}`:i}function We(i){return`${i.publisher}/${i.package_}/${i.name}`}function C(i,e,t){return`${i}/${e}/${t}`}function et(i){return`${i.s}|${i.p}|${er(i.o)}`}function er(i){switch(i.kind){case"uri":return`u:${i.key}`;case"literal":return`l:${i.datatype}:${i.lexical}`;case"blank":return`b:${i.id}`}}function A(i,e,t){return{s:i,p:e,o:{kind:"uri",key:t}}}var He=class{all=new Set;byPIdx=new Map;bySPIdx=new Map;byPOIdx=new Map;tripleList=[];add(e){let t=et(e);return this.all.has(t)?!1:(this.all.add(t),this.tripleList.push(e),tr(this.byPIdx,e.p,e),tr(this.bySPIdx,`${e.s}|${e.p}`,e),e.o.kind==="uri"&&tr(this.byPOIdx,`${e.p}|${e.o.key}`,e),!0)}has(e){return this.all.has(et(e))}size(){return this.tripleList.length}snapshot(){return this.tripleList.slice()}byPredicate(e){let t=this.byPIdx.get(e);return t?t.slice():[]}bySubjectPredicate(e,t){let r=this.bySPIdx.get(`${e}|${t}`);return r?r.slice():[]}byPredicateObject(e,t){let r=this.byPOIdx.get(`${e}|${t}`);return r?r.slice():[]}subjectsWithPredicateObject(e,t){let r=this.byPOIdx.get(`${e}|${t}`);if(!r)return[];let n=new Set;for(let o of r)n.add(o.s);return Array.from(n)}uriObjectsOf(e,t){let r=this.bySPIdx.get(`${e}|${t}`);if(!r)return[];let n=new Set;for(let o of r)o.o.kind==="uri"&&n.add(o.o.key);return Array.from(n)}hasUri(e,t,r){return this.all.has(`${e}|${t}|u:${r}`)}hasTriple(e,t,r){return this.all.has(`${e}|${t}|${er(r)}`)}};function tr(i,e,t){let r=i.get(e);r?r.push(t):i.set(e,[t])}var qe=class{type=C("kanonak.org","core-rdf","type");subClassOf=C("kanonak.org","core-rdf","subClassOf");subPropertyOf=C("kanonak.org","core-rdf","subPropertyOf");domain=C("kanonak.org","core-rdf","domain");range=C("kanonak.org","core-rdf","range");equivalentClass=C("kanonak.org","core-owl","equivalentClass");equivalentProperty=C("kanonak.org","core-owl","equivalentProperty");inverseOf=C("kanonak.org","core-owl","inverseOf");sameAs=C("kanonak.org","core-owl","sameAs");transitiveProperty=C("kanonak.org","core-owl","TransitiveProperty");symmetricProperty=C("kanonak.org","core-owl","SymmetricProperty")};var Rn={name:"rdfs2",apply(i,e){let t=!1;for(let r of i.byPredicate(e.domain)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of i.byPredicate(n))i.add(A(s.s,e.type,o))&&(t=!0)}return t}},vn={name:"rdfs3",apply(i,e){let t=!1;for(let r of i.byPredicate(e.range)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of i.byPredicate(n))s.o.kind==="uri"&&i.add(A(s.o.key,e.type,o))&&(t=!0)}return t}},Pn={name:"rdfs5",apply(i,e){let t=!1;for(let r of i.byPredicate(e.subPropertyOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of i.bySubjectPredicate(o,e.subPropertyOf))s.o.kind==="uri"&&i.add(A(n,e.subPropertyOf,s.o.key))&&(t=!0)}return t}},wn={name:"rdfs7",apply(i,e){let t=!1;for(let r of i.byPredicate(e.subPropertyOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of i.byPredicate(n)){let a={s:s.s,p:o,o:s.o};i.add(a)&&(t=!0)}}return t}},In={name:"rdfs9",apply(i,e){let t=!1;for(let r of i.byPredicate(e.subClassOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of i.byPredicateObject(e.type,n))i.add(A(s.s,e.type,o))&&(t=!0)}return t}},Sn={name:"rdfs11",apply(i,e){let t=!1;for(let r of i.byPredicate(e.subClassOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of i.bySubjectPredicate(o,e.subClassOf))s.o.kind==="uri"&&i.add(A(n,e.subClassOf,s.o.key))&&(t=!0)}return t}},tt=[Rn,vn,Pn,wn,In,Sn];var An={name:"prp-trp",apply(i,e){let t=!1,r=i.subjectsWithPredicateObject(e.type,e.transitiveProperty);for(let n of r){let o=i.byPredicate(n);for(let s of o){if(s.o.kind!=="uri")continue;let a=s.o.key;for(let c of i.bySubjectPredicate(a,n))c.o.kind==="uri"&&s.s!==c.o.key&&i.add(A(s.s,n,c.o.key))&&(t=!0)}}return t}},Dn={name:"prp-symp",apply(i,e){let t=!1,r=i.subjectsWithPredicateObject(e.type,e.symmetricProperty);for(let n of r)for(let o of i.byPredicate(n))o.o.kind==="uri"&&i.add(A(o.o.key,n,o.s))&&(t=!0);return t}},Kn={name:"prp-inv1",apply(i,e){let t=!1;for(let r of i.byPredicate(e.inverseOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of i.byPredicate(n))s.o.kind==="uri"&&i.add(A(s.o.key,o,s.s))&&(t=!0)}return t}},Cn={name:"prp-inv2",apply(i,e){let t=!1;for(let r of i.byPredicate(e.inverseOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of i.byPredicate(o))s.o.kind==="uri"&&i.add(A(s.o.key,n,s.s))&&(t=!0)}return t}},$n={name:"prp-eqp1",apply(i,e){let t=!1;for(let r of i.byPredicate(e.equivalentProperty)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of i.byPredicate(n))i.add({s:s.s,p:o,o:s.o})&&(t=!0)}return t}},jn={name:"prp-eqp2",apply(i,e){let t=!1;for(let r of i.byPredicate(e.equivalentProperty)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of i.byPredicate(o))i.add({s:s.s,p:n,o:s.o})&&(t=!0)}return t}},xn={name:"cax-eqc1",apply(i,e){let t=!1;for(let r of i.byPredicate(e.equivalentClass)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of i.byPredicateObject(e.type,n))i.add(A(s.s,e.type,o))&&(t=!0)}return t}},En={name:"cax-eqc2",apply(i,e){let t=!1;for(let r of i.byPredicate(e.equivalentClass)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of i.byPredicateObject(e.type,o))i.add(A(s.s,e.type,n))&&(t=!0)}return t}},On={name:"eq-rep-s",apply(i,e){let t=!1;for(let r of i.byPredicate(e.sameAs)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o){for(let s of i.snapshot())s.s===n&&i.add({s:o,p:s.p,o:s.o})&&(t=!0);for(let s of i.snapshot())s.s===o&&i.add({s:n,p:s.p,o:s.o})&&(t=!0)}}return t}},Vn={name:"eq-rep-o",apply(i,e){let t=!1;for(let r of i.byPredicate(e.sameAs)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of i.snapshot())s.o.kind==="uri"&&(s.o.key===n?i.add(A(s.s,s.p,o))&&(t=!0):s.o.key===o&&i.add(A(s.s,s.p,n))&&(t=!0))}return t}},rt=[An,Dn,Kn,Cn,$n,jn,xn,En,On,Vn];var ze=class{constructor(e,t){this.store=e;this.vocabulary=t}store;vocabulary;getInstancesOfClass(e){let t=Ge(e);return this.store.subjectsWithPredicateObject(this.vocabulary.type,t)}getSubclasses(e){let t=Ge(e);return this.store.subjectsWithPredicateObject(this.vocabulary.subClassOf,t).filter(n=>n!==t)}getSuperclasses(e){let t=Ge(e);return this.store.uriObjectsOf(t,this.vocabulary.subClassOf).filter(r=>r!==t)}getTypesOfIndividual(e){return this.store.uriObjectsOf(Ge(e),this.vocabulary.type)}isInstanceOf(e,t){return this.store.hasUri(Ge(e),this.vocabulary.type,Ge(t))}triples(){return this.store.snapshot()}size(){return this.store.size()}};function Ge(i){return typeof i=="string"?i:C(i.publisher,i.package_,i.name)}var kt=class{vocabulary;profile;maxIterations;constructor(e={}){this.vocabulary=e.vocabulary??new qe,this.profile=e.profile??"owl-rl-classification",this.maxIterations=e.maxIterations??100}async reason(e){let t=new He,n=await new oe().parseKanonaks(e),o=new rr;for(let c of n)if(c instanceof N){let p=Tn(c);if(!p)continue;for(let l of c.statement)this.emitStatement(p,l,t,o)}let s=[...tt];this.profile==="owl-rl-classification"&&s.push(...rt);let a=0;for(;a<this.maxIterations;){let c=!1;for(let p of s)p.apply(t,this.vocabulary)&&(c=!0);if(!c)break;a++}return new ze(t,this.vocabulary)}emitStatement(e,t,r,n){let o=Nn(t);if(o){if(t instanceof W){r.add({s:e,p:o,o:{kind:"literal",lexical:t.object,datatype:"string"}});return}if(t instanceof Q){r.add({s:e,p:o,o:{kind:"literal",lexical:String(t.object),datatype:"number"}});return}if(t instanceof ee){r.add({s:e,p:o,o:{kind:"literal",lexical:String(t.object),datatype:"boolean"}});return}if(t instanceof U){let s=We(t.object.subject);r.add(A(e,o,s));return}if(t instanceof H){let s=n.next();r.add({s:e,p:o,o:{kind:"blank",id:s}}),this.emitEmbedded(s,t.object,r,n);return}if(t instanceof L){for(let s of t.object??[])this.emitListItem(e,o,s,r,n);return}}}emitListItem(e,t,r,n,o){if(r instanceof w)n.add(A(e,t,We(r.subject)));else if(r instanceof _){let s=o.next();n.add({s:e,p:t,o:{kind:"blank",id:s}}),this.emitEmbedded(s,r,n,o)}else if(r instanceof Z){let s=typeof r.value=="number"?"number":typeof r.value=="boolean"?"boolean":"string";n.add({s:e,p:t,o:{kind:"literal",lexical:String(r.value),datatype:s}})}}emitEmbedded(e,t,r,n){let o=`_:${e}`;for(let s of t.statement)this.emitStatement(o,s,r,n)}},rr=class{counter=0;next(){return`b${this.counter++}`}};function Tn(i){let e=i.namespace??"",t=e.indexOf("@"),r=t===-1?e:e.substring(0,t),n=r.indexOf("/");if(n===-1)return null;let o=r.substring(0,n),s=r.substring(n+1);return!o||!s||!i.name?null:C(o,s,i.name)}function Nn(i){let e=i.predicate;return e?.subject?We(e.subject):null}import _n from"ignore";import*as Rt from"fs";import*as Xe from"path";var bt=class{ignoreInstance;basePath;constructor(e){this.basePath=e;let t=Xe.join(e,".gitignore");if(Rt.existsSync(t))try{let r=Rt.readFileSync(t,"utf8");this.ignoreInstance=_n(),this.ignoreInstance.add(r)}catch{this.ignoreInstance=null}else this.ignoreInstance=null}shouldIgnore(e){if(!this.ignoreInstance)return!1;let r=Xe.relative(this.basePath,e).split(Xe.sep).join("/");return this.ignoreInstance.ignores(r)}};var vt=class{propertyUri;propertyType;range;isImported;definedInNamespace};import{parseDocument as Un,LineCounter as Ln,isMap as Ye,isPair as O,isScalar as M,isSeq as Pt}from"yaml";var Je=class i{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 i,r=new Ln,n=Un(e,{lineCounter:r});if(n.errors.length>0||!Ye(n.contents))return t;or(n.contents,[],r,t);for(let o of n.contents.items){if(!O(o)||!M(o.key))continue;let s=String(o.key.value),a=o.key.range;if(!a)continue;t.entities.set(s,G(a,r));let c=o.value,p=c&&typeof c=="object"&&"range"in c?c.range:void 0;if(p?t.entityBlocks.set(s,G([a[0],a[1],p[2]],r)):t.entityBlocks.set(s,G(a,r)),Ye(o.value)){let l=new Map,u=new Map,m=new Map;for(let f of o.value.items){if(!O(f)||!M(f.key))continue;let d=String(f.key.value),g=f.key.range;g&&l.set(d,G(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,G(b,r))}if(Pt(h)){let b=[];for(let R of h.items)R&&typeof R=="object"&&"range"in R&&Array.isArray(R.range)&&b.push(G(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=Mn(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(nr(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,p]of o)nr(p,e,t)&&(!a||wr(p,a))&&(s=c,a=p);if(n)for(let[c,p]of n)nr(p,e,t)&&(!a||wr(p,a))&&(s=c,a=p);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 Mn(i,e){let t=[];if(!Ye(i))return t;let r=i.items.find(n=>O(n)&&M(n.key)&&String(n.key.value)==="imports");if(!r||!O(r)||!Pt(r.value))return t;for(let n of r.value.items){if(!Ye(n))continue;let o=n.items.find(c=>O(c)&&M(c.key)&&String(c.key.value)==="publisher");if(!o||!O(o)||!M(o.value))continue;let s=String(o.value.value),a=n.items.find(c=>O(c)&&M(c.key)&&String(c.key.value)==="packages");if(!(!a||!O(a)||!Pt(a.value)))for(let c of a.value.items){if(!Ye(c))continue;let p=c.items.find(g=>O(g)&&M(g.key)&&String(g.key.value)==="package");if(!p||!O(p)||!M(p.value)||!p.value.range)continue;let l=String(p.value.value),u=c.items.find(g=>O(g)&&M(g.key)&&String(g.key.value)==="version"),m=u&&O(u)&&M(u.value)?String(u.value.value):"",y=c.items.find(g=>O(g)&&M(g.key)&&String(g.key.value)==="alias"),f=y&&O(y)&&M(y.value)?String(y.value.value):void 0,d=f!==void 0?{publisher:s,package_:l,version:m,alias:f,position:G(p.value.range,e)}:{publisher:s,package_:l,version:m,position:G(p.value.range,e)};t.push(d)}}return t}function nr(i,e,t){return!(e<i.line||e>i.endLine||e===i.line&&t<i.column||e===i.endLine&&t>i.endColumn)}function wr(i,e){let t=i.endLine-i.line,r=e.endLine-e.line;if(t!==r)return t<r;let n=i.endLine===i.line?i.endColumn-i.column:Number.MAX_SAFE_INTEGER,o=e.endLine===e.line?e.endColumn-e.column:Number.MAX_SAFE_INTEGER;return n<o}function or(i,e,t,r){if(Ye(i)){for(let n of i.items){if(!O(n)||!M(n.key))continue;let o=String(n.key.value),s=[...e,o],a=JSON.stringify(s);n.key.range&&r.setNestedKeyPosition(a,G(n.key.range,t));let c=n.value,p=Ir(c);p&&r.setNestedValuePosition(a,G(p,t)),or(c,s,t,r)}return}if(Pt(i)){for(let n=0;n<i.items.length;n++){let o=i.items[n],s=[...e,n],a=JSON.stringify(s),c=Ir(o);c&&r.setNestedValuePosition(a,G(c,t)),or(o,s,t,r)}return}}function Ir(i){if(!i||typeof i!="object"||!("range"in i))return;let e=i.range;return Array.isArray(e)&&e.length>=3?e:void 0}function G(i,e){let t=e.linePos(i[0]),r=e.linePos(i[2]);return{line:t.line-1,column:t.col-1,endLine:r.line-1,endColumn:r.col-1}}function Sr(i,e){let r=(e??new $).parse(i),n=Je.fromContent(i);return{document:r,positions:n}}le();le();var wt=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 p of t.values())if(p.entityName===a&&p.uri.package_===c)return p.uri}return null}let n=t.get(e);return n?n.uri:null}create(e,t,r,n){return new T(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}};le();function Ar(i){if(!i||i.trim().length===0)throw new Error("Kanonak address string cannot be null or empty");let e=i.trim(),t=e.split("/");if(t.length===1){let r=t[0];if(!r)throw new Error(`Invalid Kanonak address: "${i}". Expected publisher, publisher/package[@version], or publisher/package[@version]/name.`);if(r.includes("@"))throw new Error(`Invalid Kanonak address: "${i}". A bare publisher cannot carry an @version qualifier \u2014 versions belong to packages.`);return{kind:"publisher",publisher:r}}if(t.length===2){let[r,n]=t;if(!r||!n)throw new Error(`Invalid Kanonak address: "${i}". Expected publisher/package[@version].`);let o=n.indexOf("@");if(o===-1)return{kind:"package",publisher:r,package_:n};let s=n.substring(0,o),a=n.substring(o+1);if(!s||!a)throw new Error(`Invalid Kanonak address: "${i}". Expected publisher/package[@version].`);let c=Fn(a);return{kind:"package",publisher:r,package_:s,version:c}}return{kind:"resource",uri:T.parse(e)}}function Dr(i){switch(i.kind){case"publisher":return i.publisher;case"package":return i.version?`${i.publisher}/${i.package_}@${i.version.major}.${i.version.minor}.${i.version.patch}`:`${i.publisher}/${i.package_}`;case"resource":return i.uri.toString()}}function Fn(i){let e=i.split(".").map(Number);return Bn(e[0]||0,e[1]||0,e[2]||0)}function Bn(i,e,t){return{major:i,minor:e,patch:t,toString:()=>`${i}.${e}.${t}`,equals:r=>!r||typeof r!="object"?!1:r.major===i&&r.minor===e&&r.patch===t,getHashCode:()=>i<<20|e<<10|t,compareTo:r=>i!==r.major?i-r.major:e!==r.minor?e-r.minor:t-r.patch}}async function Cr(i,e){let t=[],r=await i.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[p,l]of Object.entries(n.body)){if(!l||typeof l!="object")continue;let u=l.type;!u||typeof u!="string"||u!=="Package"&&Wn(u,e)&&t.push({entityName:p,entity:l,documentNamespace:`${s}/${a}@${c}`,publisher:s,package_:a,version:c})}}return t}function Wn(i,e){let t=Kr(i),r=Kr(e);return t===r}function Kr(i){let e=i.lastIndexOf(".");if(e!==-1)return i.substring(e+1);let t=i.lastIndexOf("/");return t!==-1?i.substring(t+1):i}var ue=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 It=class i{resolvedDocuments=[];currentEntityPath;withPath(e){let t=new i;return t.resolvedDocuments=this.resolvedDocuments,t.currentEntityPath=e,t}};var me=class i{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&&i.NAMESPACE_PREFIX_PATTERN.test(s)){let a=this.getSuggestionForPrefixedValue(s),c=e.split(".")[0],p=new k;p.ruleType=this.ruleName,p.severity="Error",p.entityName=c,p.propertyName=e,p.actualValue=n,p.expectedValue=a,p.message=`Invalid namespace prefix '${s}'. Use '${a}' without prefix.`,p.suggestion="Kanonak YAML uses simple type names. Namespace resolution is handled through imports.",r.push(p)}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 ye=class i{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_AUGMENTATION_PATTERN=/^[a-zA-Z][a-zA-Z0-9_-]*\.[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)){let s=i.VALID_AUGMENTATION_PATTERN.test(n);if(!s&&!r&&i.RESERVED_WORDS.has(n.toLowerCase())){let a=new k;a.ruleType=this.ruleName,a.severity="Error",a.entityName=n,a.message=`Entity name '${n}' is a reserved word and cannot be used.`,a.suggestion="Choose a different name that doesn't conflict with Kanonak reserved words.",t.push(a);continue}if(!s&&!i.VALID_NAME_PATTERN.test(n)){let a;/^\d/.test(n)?a="Entity names must start with a letter, not a number.":n.includes(" ")?a="Entity names cannot contain spaces. Use camelCase or underscores instead.":a="Entity names must start with a letter and contain only letters, numbers, and underscores.";let c=new k;c.ruleType=this.ruleName,c.severity="Error",c.entityName=n,c.message=`Invalid entity name '${n}'. ${a}`,c.suggestion=a,t.push(c)}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(!i.VALID_PROPERTIES.has(n)&&!i.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 fe=class i{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 c=[];if(Array.isArray(a))for(let p of a){let l=p?.toString();l&&l==="Property"&&!r&&c.push(l)}else{let p=a?.toString();p&&p==="Property"&&!r&&c.push(p)}for(let p of c){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=p,m.expectedValue=u,m.message=`Invalid property type '${p}'. 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":i.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 de=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)||r.includes("."))continue;let o=n,s="type"in o,a=o.type?.toString().trim();if(!s||!a){let c=new k;c.ruleType=this.ruleName,c.severity="Error",c.entityName=r,c.propertyName="type",c.message=`Subject Kanonak '${r}' must have a 'type' property.`,c.suggestion=`Add a type statement like:
|
|
4
4
|
type: Scene
|
|
5
5
|
|
package/dist/parsing/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var ee=Object.defineProperty;var te=(p,e)=>()=>(p&&(e=p(p=0)),e);var ne=(p,e)=>{for(var t in e)ee(p,t,{get:e[t],enumerable:!0})};var J={};ne(J,{KanonakUri:()=>R});function re(p,e,t){return{major:p,minor:e,patch:t,toString:()=>`${p}.${e}.${t}`,equals:n=>!n||typeof n!="object"?!1: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}}var R,q=te(()=>{"use strict";R=class p{constructor(e,t,n,r){this.publisher=e;this.package_=t;this.name=n;this.version=r}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[n,r,o]=t;if(!n||!r||!o)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let s=r.indexOf("@");if(s===-1)return new p(n,r,o,void 0);let i=r.substring(0,s),a=r.substring(s+1);if(!i||!a)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let c=a.split(".").map(Number),u=re(c[0]||0,c[1]||0,c[2]||0);return new p(n,i,o,u)}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 F from"js-yaml";var w=class{parse(e){let t=this.parseWithErrors(e);if(!t.isValid){let n=t.errors[0];throw new Error(`YAML parse error at line ${n.line}, column ${n.column}: ${n.message}`)}return t.document}parseWithErrors(e){let t=[],n;try{e=e.replace(/^\uFEFF/,"");let r=F.load(e);if(!r||typeof r!="object")return n={metadata:this.createEmptyMetadata(),body:{},toString:()=>"KanonakDocument(empty)"},{document:n,errors:t,isValid:!0};let o=this.extractMetadata(r),s=this.extractBody(r,o);return n={metadata:o,body:s,toString:function(){return this.metadata.namespace_?`KanonakDocument(${this.metadata.namespace_.publisher}/${this.metadata.namespace_.package_})`:"KanonakDocument(no namespace)"}},{document:n,errors:t,isValid:!0}}catch(r){let o=r,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 n=e.metadata.namespace_,r={type:"Package",publisher:n.publisher};n.version&&(r.version=`${n.version.major}.${n.version.minor}.${n.version.patch}`),e.metadata.imports&&(r.imports=this.serializeImports(e.metadata.imports)),t[n.package_]=r}return Object.assign(t,e.body),F.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 n=[];for(let r of Object.values(t))n.push(...r);return n},enumerable:!0,configurable:!0}),e}createVersion(e,t,n){return{major:e,minor:t,patch:n,toString:()=>`${e}.${t}.${n}`,equals:o=>!o||typeof o!="object"?!1:o.major===e&&o.minor===t&&o.patch===n,getHashCode:()=>e<<20|t<<10|n,compareTo:o=>e!==o.major?e-o.major:t!==o.minor?t-o.minor:n-o.patch}}extractMetadata(e){let t=this.createEmptyMetadata();for(let[n,r]of Object.entries(e))if(r&&typeof r=="object"&&r.type==="Package"){t.type_="Package";let o=n,s=r.publisher,i=r.version?this.parseVersion(r.version):void 0;return s&&o&&(t.namespace_={publisher:s,package_:o,version:i,toString:function(){return`${this.publisher}/${this.package_}@${this.version?.major??1}.${this.version?.minor??0}.${this.version?.patch??0}`},equals:a=>!a||typeof a!="object"?!1:a.publisher===s&&a.package_===o&&(!i||!a.version||i.equals(a.version)),getHashCode:()=>{let a=0;for(let c=0;c<s.length;c++)a=(a<<5)-a+s.charCodeAt(c);for(let c=0;c<o.length;c++)a=(a<<5)-a+o.charCodeAt(c);return a|0}}),r.imports&&Array.isArray(r.imports)&&(t.imports=this.parseImportsV3(r.imports)),this.addAllImportsGetter(t)}if(e.kanonak&&typeof e.kanonak=="object"){let n=e.kanonak;return(n.publisher||n.package||n.version)&&(t.namespace_=this.parseNamespace(n)),n.imports&&typeof n.imports=="object"&&(t.imports=this.parseImportsLegacy(n.imports)),this.addAllImportsGetter(t)}return t}extractBody(e,t){let n={},r;for(let[o,s]of Object.entries(e))if(s&&typeof s=="object"&&s.type==="Package"){r=o;break}for(let[o,s]of Object.entries(e))o!==r&&o!=="kanonak"&&o!=="namespace"&&o!=="imports"&&(n[o]=s);return n}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:i=>!i||typeof i!="object"?!1:i.publisher===o[1]&&i.package_===o[2]&&(!s||!i.version||s.equals(i.version)),getHashCode:()=>{let i=0;for(let a=0;a<o[1].length;a++)i=(i<<5)-i+o[1].charCodeAt(a);for(let a=0;a<o[2].length;a++)i=(i<<5)-i+o[2].charCodeAt(a);return i|0}}}}let t=e.publisher||"",n=e.package||"",r=e.version?this.parseVersion(e.version):this.createVersion(1,0,0);return{publisher:t,package_:n,version:r,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_===n&&(!r||!o.version||r.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<n.length;s++)o=(o<<5)-o+n.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 n of e)if(!(!n||typeof n!="object"))if(n.packages&&Array.isArray(n.packages)){let r=n.publisher;if(!r)throw new Error("PublisherImport requires 'publisher' property");t[r]||(t[r]=[]);for(let o of n.packages){if(!o||typeof o!="object")continue;let s=this.parseImportFromEmbeddedObject(o,r);t[r].push(s)}}else{let r=this.parseImportFromEmbeddedObject(n,n.publisher),o=r.publisher||"";t[o]||(t[o]=[]),t[o].push(r)}return t}parseImportsLegacy(e){let t={};for(let[n,r]of Object.entries(e))Array.isArray(r)&&(t[n]=r.map(o=>this.parseImport(o,n)));return t}parseImportFromEmbeddedObject(e,t){let n=e.package;if(!n)throw new Error("Import requires 'package' property");let r=e.match;if(!r)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),i=this.parseVersionOperator(r),a=this.calculateMaxVersion(r,s),c=e.alias;return{package_:`${n} ${r} ${s.toString()}`,publisher:t,packageName:n,versionOperator:i,version:s,alias:c,minVersion:s,maxVersion:a,toEmbeddedObject:()=>{let u={package:n,match:r,version:s.toString()};return c&&(u.alias=c),u},toString:()=>c?`${n} ${r} ${s.toString()} as ${c}`:`${n} ${r} ${s.toString()}`}}parseImport(e,t){if(typeof e=="string"){let a=e.match(/^(.+?)\s*([~^=*])\s*(\S+)\s+as\s+(\S+)$/);if(a){let u=a[1].trim(),m=a[2],l=this.parseVersion(a[3].trim()),f=a[4].trim(),g=this.parseVersionOperator(m),h=this.calculateMaxVersion(m,l);return{package_:e,publisher:t,packageName:u,versionOperator:g,version:l,alias:f,minVersion:l,maxVersion:h,toEmbeddedObject:()=>{let d={package:u,match:m,version:l.toString()};return f&&(d.alias=f),d},toString:()=>`${u} ${m} ${l.toString()} as ${f}`}}let c=e.match(/^(.+?)\s*([~^=*])\s*(.+)$/);if(c){let u=c[1].trim(),m=c[2],l=this.parseVersion(c[3].trim()),f=this.parseVersionOperator(m),g=this.calculateMaxVersion(m,l);return{package_:e,publisher:t,packageName:u,versionOperator:f,version:l,alias:void 0,minVersion:l,maxVersion:g,toEmbeddedObject:()=>({package:u,match:m,version:l.toString()}),toString:()=>`${u} ${m} ${l.toString()}`}}}let n=this.parseVersionOperator(e.operator||"~"),r=this.parseVersion(e.version||"1.0.0"),o=e.packageName||e.package||"",s=["=","~","^","*"][n],i=this.calculateMaxVersion(e.operator||"~",r);return{package_:e.package||"",publisher:t,packageName:o,versionOperator:n,version:r,alias:e.alias,minVersion:r,maxVersion:i,toEmbeddedObject:()=>{let a={package:o,match:s,version:r.toString()};return e.alias&&(a.alias=e.alias),a},toString:()=>`${o} ${s} ${r.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[n,r]of Object.entries(e)){let o={publisher:n,packages:r.map(s=>{let i=["=","~","^","*"][s.versionOperator],a={package:s.packageName,match:i,version:`${s.version.major}.${s.version.minor}.${s.version.patch}`};return s.alias&&(a.alias=s.alias),a})};t.push(o)}return t}};var K=class{};var A=class extends K{statement=[]};var $=class extends A{namespace;name;icon};var E=class extends A{name};q();var y=class p extends K{subject;static parse(e){let t=new p;return t.subject=R.parse(e),t}};var _=class extends K{value};var S=class{predicate;object};var I=class extends S{};var j=class p extends I{static parse(e,t){let n=new p;return n.predicate=y.parse(e),n.object=t,n}};var N=class p extends I{static parse(e,t){let n=new p;return n.predicate=y.parse(e),n.object=t,n}};var L=class extends I{};var C=class p extends S{static parse(e,t){let n=new p;return n.predicate=y.parse(e),n.object=y.parse(t),n}};var V=class extends S{};var D=class extends S{};q();function H(p){if(Array.isArray(p))return p.map(t=>t?.toString()??"").filter(t=>t.length>0);let e=p?.toString();return e?[e]:[]}var W=class{cache=new Map;repository;logger;constructor(e,t){this.repository=e,this.logger=t}async resolveEntityAsync(e,t){let n=t.metadata?.namespace_?.toString()??"unknown",r=this.cache.get(n);if(r){let s=r.get(e);if(s)return s}let o=await this.buildEntityIndexAsyncInternal(t,new Set,"");return this.cache.set(n,o),o.get(e)??null}async resolveAllEntitiesAsync(e,t){let n=await this.buildAllEntitiesIndexAsync(t,new Set,"");if(e.includes(".")){let r=e.split("."),o=r[0],s=r[1],i=await this.findDocumentForAlias(t,o);return i?await this.resolveAllEntitiesAsync(s,i):[]}return n.filter(r=>r.entityName===e)}async buildAllEntitiesIndexAsync(e,t,n){let r=[],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)`),r;t.add(o);let s=n.length===0?o:`${n} \u2192 ${o}`;for(let[i,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let c=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};r.push({entityName:i,uri:new R(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,i,c),entity:a,definedInNamespace:o,isImported:n.length>0,importPath:s})}if(this.logger?.debug?.(`Collected ${r.length} entities from ${o}`),e.metadata?.imports){let i=Object.values(e.metadata.imports).reduce((a,c)=>a+c.length,0);this.logger?.debug?.(`Processing ${i} import(s) for ${o}`);for(let[a,c]of Object.entries(e.metadata.imports))for(let u of c)try{this.logger?.debug?.(`Resolving import: ${a}/${u.packageName}`);let m=await this.repository.getHighestCompatibleVersionAsync(a,u);if(m){this.logger?.debug?.(`Successfully loaded import: ${m.metadata?.namespace_?.toString()}`);let l=await this.buildAllEntitiesIndexAsync(m,t,s);r.push(...l),this.logger?.debug?.(`Added ${l.length} entities from import ${m.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${a}/${u.packageName}`)}catch(m){let l=m;throw this.logger?.error?.(`Failed to process import ${a}/${u.packageName} for namespace ${o}. Error: ${l.message}`,l),new Error(`Failed to process import ${a}/${u.packageName} for namespace ${o}. See inner exception for details.`,{cause:m})}}return r}async buildEntityIndexAsync(e){return await this.buildEntityIndexAsyncInternal(e,new Set,"")}async buildEntityIndexAsyncInternal(e,t,n){let r=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)`),r;t.add(o);let s=n.length===0?o:`${n} \u2192 ${o}`,i=0;for(let[a,c]of Object.entries(e.body))if(c&&typeof c=="object"&&!Array.isArray(c)&&!r.has(a)){let u=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};r.set(a,{entityName:a,uri:new R(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,a,u),entity:c,definedInNamespace:o,isImported:n.length>0,importPath:s}),i++}if(this.logger?.debug?.(`Indexed ${i} entities from ${o}`),e.metadata?.imports){let a=Object.values(e.metadata.imports).reduce((c,u)=>c+u.length,0);this.logger?.debug?.(`Processing ${a} import(s) for ${o}`);for(let[c,u]of Object.entries(e.metadata.imports))for(let m of u)try{this.logger?.debug?.(`Resolving import: ${c}/${m.packageName}`);let l=await this.repository.getHighestCompatibleVersionAsync(c,m);if(l){this.logger?.debug?.(`Successfully loaded import: ${l.metadata?.namespace_?.toString()}`);let f=await this.buildEntityIndexAsyncInternal(l,t,s),g=0;for(let[h,d]of f.entries())if(r.has(h)||(r.set(h,d),g++),m.alias&&!h.includes(".")){let P=`${m.alias}.${h}`;r.has(P)||(r.set(P,d),g++)}this.logger?.debug?.(`Merged ${g} entities from import ${l.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${c}/${m.packageName}`)}catch(l){let f=l;throw this.logger?.error?.(`Failed to process import ${c}/${m.packageName} for namespace ${o}. Error: ${f.message}`,f),new Error(`Failed to process import ${c}/${m.packageName} for namespace ${o}. See inner exception for details.`,{cause:l})}}return r}async findDocumentForAlias(e,t){if(!e.metadata?.imports)return null;for(let[n,r]of Object.entries(e.metadata.imports))for(let o of r){if(o.alias===t)return await this.repository.getHighestCompatibleVersionAsync(n,o);if(!o.alias&&o.packageName===t)return await this.repository.getHighestCompatibleVersionAsync(n,o)}return null}clearCache(){this.cache.clear()}clearCacheForDocument(e){this.cache.delete(e)}async isSubclassOfAsync(e,t,n){if(e===t)return!0;let r=new Set;return await this.isSubclassOfRecursiveAsync(e,t,n,r)}async isSubclassOfRecursiveAsync(e,t,n,r){if(r.has(e))return!1;r.add(e);let o=await this.resolveEntityAsync(e,n);if(!o?.entity)return!1;let s=o.entity.subClassOf;if(s){let i=H(s);for(let a of i)if(a===t||await this.isSubclassOfRecursiveAsync(a,t,n,r))return!0}return!1}async isSubpropertyOfAsync(e,t,n){if(e===t)return!0;let r=new Set;return await this.isSubpropertyOfRecursiveAsync(e,t,n,r)}async isSubpropertyOfRecursiveAsync(e,t,n,r){if(r.has(e))return!1;r.add(e);let o=await this.resolveEntityAsync(e,n);if(!o?.entity)return!1;let s=o.entity.subPropertyOf;if(s){let i=H(s);for(let a of i)if(a===t||await this.isSubpropertyOfRecursiveAsync(a,t,n,r))return!0}return!1}};var U=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 n=await this.resourceResolver.resolveEntityAsync(e,t);if(n){let r=n.entity.type;if(r){let o=String(r);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 Y=class{constructor(e){}async parseKanonaks(e){let t=[],n=await e.getAllDocumentsAsync(),r=new W(e),o=new U(r);for(let a of n){let c=a.metadata.namespace_?.toString()??"";for(let[u,m]of Object.entries(a.body)){let l=new $,f=this.resolveCanonicalEntity(u,a,c);l.namespace=f.namespace,l.name=f.name,l.statement=[];let g=await this.parseStatements(m,a,r,o,e);l.statement.push(...g),t.push(l)}}let s=new Map,i=[];for(let a of t)if(a instanceof $){let c=`${a.namespace}/${a.name}`,u=s.get(c);u?u.statement.push(...a.statement):(s.set(c,a),i.push(a))}else i.push(a);return i}resolveCanonicalEntity(e,t,n){if(!e.includes(".")||!t.metadata?.imports)return{namespace:n,name:e};let r=e.indexOf("."),o=e.substring(0,r),s=e.substring(r+1);for(let[i,a]of Object.entries(t.metadata.imports))for(let c of a)if((c.alias??c.packageName)===o){let m=c.version;return{namespace:`${i}/${c.packageName}@${m.major}.${m.minor}.${m.patch}`,name:s}}return{namespace:n,name:e}}async parseStatements(e,t,n,r,o){let s=[];if(typeof e!="object"||e===null||Array.isArray(e))return s;for(let[i,a]of Object.entries(e))try{let c=await this.getPropertyMetadata(i,t,n,o,r);if(!c)continue;let u=await this.parsePropertyValue(i,a,c,t,n,r);u&&s.push(u)}catch(c){console.error(`Error parsing property ${i}:`,c)}return s}async getPropertyMetadata(e,t,n,r,o){let s=await n.resolveEntityAsync(e,t);if(!s)return;let i=s.entity,a=i.type?.toString()??"",c=a.includes(".")?a.substring(a.lastIndexOf(".")+1):a;if(!new Set(["Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]).has(c))return;let m=o.getPropertyTypeClassification(a),l=i.range?.toString(),f;if(m==="ObjectProperty")f="ObjectProperty";else if(m==="DatatypeProperty")f="DatatypeProperty";else{let h=l&&l.includes(".")?l.substring(l.lastIndexOf(".")+1):l??"";(l?o.isKnownXsdDatatypeName(l):!1)||h==="Literal"?f="DatatypeProperty":f="ObjectProperty"}return{propertyUri:s.uri.toString(),propertyType:f,range:l,isImported:s.isImported,definedInNamespace:s.definedInNamespace}}async parsePropertyValue(e,t,n,r,o,s){let i=n.propertyUri;if(t!=null){if(Array.isArray(t))return this.parseListValue(i,t,n,r,o,s);if(n.propertyType==="DatatypeProperty")return this.parseDatatypeValue(i,t,n);if(n.propertyType==="ObjectProperty")return this.parseObjectValue(i,t,n,r,o,s)}}parseDatatypeValue(e,t,n){if(t instanceof Date)return j.parse(e,t.toISOString());if(typeof t=="string")return j.parse(e,t);if(typeof t=="number")return N.parse(e,t);if(typeof t=="boolean"){let r=new L;return r.predicate=y.parse(e),r.object=t,r}}async parseObjectValue(e,t,n,r,o,s){if(typeof t=="string"){let i=await this.resolveReference(t,r,o);if(!i)return;let a=new C;return a.predicate=y.parse(e),a.object=i,a}if(typeof t=="object"&&!Array.isArray(t)){let i=new E;if(i.statement=await this.parseStatements(t,r,o,s,{}),i.statement.length>0){let u=new V;return u.predicate=y.parse(e),u.object=i,u}let a=[];for(let[u,m]of Object.entries(t))if(typeof m=="object"&&m!==null&&!Array.isArray(m)){let l=new E;l.name=u,l.statement=await this.parseStatements(m,r,o,s,{}),a.push(l)}else if(typeof m=="string"){let l=await this.resolveReference(m,r,o);l&&a.push(l)}if(a.length>0){let u=new D;return u.predicate=y.parse(e),u.object=a,u}let c=new V;return c.predicate=y.parse(e),c.object=i,c}}async parseListValue(e,t,n,r,o,s){let i=[],a=n.propertyType==="DatatypeProperty";for(let u of t){if(a&&(typeof u=="string"||typeof u=="number"||typeof u=="boolean")){let m=new _;m.value=u,i.push(m);continue}if(a&&u instanceof Date){let m=new _;m.value=u.toISOString(),i.push(m);continue}if(typeof u=="string"){let m=await this.resolveReference(u,r,o);m&&i.push(m)}else if(typeof u=="object"&&u!==null&&!Array.isArray(u)){let m=new E;m.statement=await this.parseStatements(u,r,o,s,{}),i.push(m)}}let c=new D;return c.predicate=y.parse(e),c.object=i,c}async resolveReference(e,t,n){let r=await n.resolveEntityAsync(e,t);if(r){let s=new y;return s.subject=r.uri,s}let o=t.metadata?.namespace_;if(o){let{KanonakUri:s}=await Promise.resolve().then(()=>(q(),J)),i=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("."),u=e.substring(0,c),m=e.substring(c+1);if(t.metadata?.imports){for(let[l,f]of Object.entries(t.metadata.imports))for(let g of f)if((g.alias??g.packageName)===u){let d=new y;return d.subject=new s(l,g.packageName,m,g.version),d}}}let a=new y;return a.subject=new s(o.publisher,o.package_,e,i),a}return null}async saveKanonaks(e,t){let n=new Map;for(let r of e)r instanceof $&&r.namespace&&(n.has(r.namespace)||n.set(r.namespace,[]),n.get(r.namespace).push(r));for(let[r,o]of n){let s=await this.convertKanonaksToDocument(r,o),i=`${r.split("@")[0]}.yml`;await t.saveDocumentAsync(s,i)}}async serializeToYaml(e,t){let n=e.filter(s=>s instanceof $&&s.namespace===t);if(n.length===0)throw new Error(`No kanonaks found with namespace '${t}'`);let r=await this.convertKanonaksToDocument(t,n);return new w().save(r)}async convertKanonaksToDocument(e,t){let r={metadata:{namespace_:e,get allImports(){if(!this.imports)return[];let s=[];for(let i of Object.values(this.imports))s.push(...i);return s}},body:{}},o=new Map;for(let s of t){let i={};for(let a of s.statement){let[c,u]=this.convertStatementToProperty(a);c&&u!==null&&u!==void 0&&(i[c]=u),this.collectImportsFromStatement(a,e,o)}r.body[s.name]=i}return r}convertStatementToProperty(e){if(e instanceof j)return[e.predicate.subject.name,e.object];if(e instanceof N)return[e.predicate.subject.name,e.object];if(e instanceof L)return[e.predicate.subject.name,e.object];if(e instanceof C)return[e.predicate.subject.name,e.object.subject.name];if(e instanceof D){let t=this.convertKanonakListToValue(e.object);return[e.predicate.subject.name,t]}else if(e instanceof V){let t=this.convertEmbeddedKanonakToValue(e.object);return[e.predicate.subject.name,t]}return[null,null]}convertKanonakListToValue(e){let t=[];for(let n of e)n instanceof y?t.push(n.subject.name):n instanceof E&&t.push(this.convertEmbeddedKanonakToValue(n));return t}convertEmbeddedKanonakToValue(e){let t={};for(let n of e.statement){let[r,o]=this.convertStatementToProperty(n);r&&o!==null&&o!==void 0&&(t[r]=o)}return t}collectImportsFromStatement(e,t,n){}};var B=class{propertyUri;propertyType;range;isImported;definedInNamespace};import{parseDocument as oe,LineCounter as se,isMap as x,isPair as k,isScalar as b,isSeq as X}from"yaml";var T=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,n=new se,r=oe(e,{lineCounter:n});if(r.errors.length>0||!x(r.contents))return t;G(r.contents,[],n,t);for(let o of r.contents.items){if(!k(o)||!b(o.key))continue;let s=String(o.key.value),i=o.key.range;if(!i)continue;t.entities.set(s,v(i,n));let a=o.value,c=a&&typeof a=="object"&&"range"in a?a.range:void 0;if(c?t.entityBlocks.set(s,v([i[0],i[1],c[2]],n)):t.entityBlocks.set(s,v(i,n)),x(o.value)){let u=new Map,m=new Map,l=new Map;for(let g of o.value.items){if(!k(g)||!b(g.key))continue;let h=String(g.key.value),d=g.key.range;d&&u.set(h,v(d,n));let P=g.value;if(P&&typeof P=="object"&&"range"in P&&Array.isArray(P.range)){let O=P.range;m.set(h,v(O,n))}if(X(P)){let O=[];for(let M of P.items)M&&typeof M=="object"&&"range"in M&&Array.isArray(M.range)&&O.push(v(M.range,n));O.length>0&&l.set(h,O)}}u.size>0&&t.properties.set(s,u),m.size>0&&t.propertyValues.set(s,m),l.size>0&&t.valueListItems.set(s,l);let f=ae(o.value,n);f.length>0&&t.importPackages.set(s,f)}}return t}getEntityPosition(e){return this.entities.get(e)}getEntityBlockPosition(e){return this.entityBlocks.get(e)}findEntityAtPosition(e,t){for(let[n,r]of this.entityBlocks)if(z(r,e,t))return n}findPropertyAtPosition(e,t){let n=this.findEntityAtPosition(e,t);if(!n)return;let r=this.properties.get(n),o=this.propertyValues.get(n);if(!r&&!o)return{entityName:n};let s,i;if(o)for(let[a,c]of o)z(c,e,t)&&(!i||Q(c,i))&&(s=a,i=c);if(r)for(let[a,c]of r)z(c,e,t)&&(!i||Q(c,i))&&(s=a,i=c);return s?{entityName:n,propertyName:s}:{entityName:n}}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,n]of this.importPackages)for(let r of n)e.push({entityName:t,entry:r});return e}findPropertySourceName(e,t){let n=this.properties.get(e);if(n){if(n.has(t))return t;for(let r of n.keys()){let o=r.lastIndexOf(".");if((o===-1?r:r.substring(o+1))===t)return r}}}getListItemPosition(e,t,n){let r=this.valueListItems.get(e)?.get(t);if(!(!r||n<0||n>=r.length))return r[n]}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,n){if(e){if(t!==void 0){if(n!==void 0){let s=this.getListItemPosition(e,t,n);if(s)return s}let r=this.getPropertyValuePosition(e,t);if(r)return r;let o=this.getPropertyPosition(e,t);if(o)return o}return this.getEntityPosition(e)}}};function ae(p,e){let t=[];if(!x(p))return t;let n=p.items.find(r=>k(r)&&b(r.key)&&String(r.key.value)==="imports");if(!n||!k(n)||!X(n.value))return t;for(let r of n.value.items){if(!x(r))continue;let o=r.items.find(a=>k(a)&&b(a.key)&&String(a.key.value)==="publisher");if(!o||!k(o)||!b(o.value))continue;let s=String(o.value.value),i=r.items.find(a=>k(a)&&b(a.key)&&String(a.key.value)==="packages");if(!(!i||!k(i)||!X(i.value)))for(let a of i.value.items){if(!x(a))continue;let c=a.items.find(d=>k(d)&&b(d.key)&&String(d.key.value)==="package");if(!c||!k(c)||!b(c.value)||!c.value.range)continue;let u=String(c.value.value),m=a.items.find(d=>k(d)&&b(d.key)&&String(d.key.value)==="version"),l=m&&k(m)&&b(m.value)?String(m.value.value):"",f=a.items.find(d=>k(d)&&b(d.key)&&String(d.key.value)==="alias"),g=f&&k(f)&&b(f.value)?String(f.value.value):void 0,h=g!==void 0?{publisher:s,package_:u,version:l,alias:g,position:v(c.value.range,e)}:{publisher:s,package_:u,version:l,position:v(c.value.range,e)};t.push(h)}}return t}function z(p,e,t){return!(e<p.line||e>p.endLine||e===p.line&&t<p.column||e===p.endLine&&t>p.endColumn)}function Q(p,e){let t=p.endLine-p.line,n=e.endLine-e.line;if(t!==n)return t<n;let r=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 r<o}function G(p,e,t,n){if(x(p)){for(let r of p.items){if(!k(r)||!b(r.key))continue;let o=String(r.key.value),s=[...e,o],i=JSON.stringify(s);r.key.range&&n.setNestedKeyPosition(i,v(r.key.range,t));let a=r.value,c=Z(a);c&&n.setNestedValuePosition(i,v(c,t)),G(a,s,t,n)}return}if(X(p)){for(let r=0;r<p.items.length;r++){let o=p.items[r],s=[...e,r],i=JSON.stringify(s),a=Z(o);a&&n.setNestedValuePosition(i,v(a,t)),G(o,s,t,n)}return}}function Z(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 v(p,e){let t=e.linePos(p[0]),n=e.linePos(p[2]);return{line:t.line-1,column:t.col-1,endLine:n.line-1,endColumn:n.col-1}}function ie(p,e){let n=(e??new w).parse(p),r=T.fromContent(p);return{document:n,positions:r}}export{T as KanonakDocumentPositions,Y as KanonakObjectParser,w as KanonakParser,B as PropertyMetadata,ie as parseWithPositions};
|
|
1
|
+
var ee=Object.defineProperty;var te=(p,e)=>()=>(p&&(e=p(p=0)),e);var ne=(p,e)=>{for(var t in e)ee(p,t,{get:e[t],enumerable:!0})};var J={};ne(J,{KanonakUri:()=>R});function re(p,e,t){return{major:p,minor:e,patch:t,toString:()=>`${p}.${e}.${t}`,equals:n=>!n||typeof n!="object"?!1: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}}var R,q=te(()=>{"use strict";R=class p{constructor(e,t,n,r){this.publisher=e;this.package_=t;this.name=n;this.version=r}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[n,r,o]=t;if(!n||!r||!o)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let s=r.indexOf("@");if(s===-1)return new p(n,r,o,void 0);let i=r.substring(0,s),a=r.substring(s+1);if(!i||!a)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let c=a.split(".").map(Number),u=re(c[0]||0,c[1]||0,c[2]||0);return new p(n,i,o,u)}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 F from"js-yaml";var w=class{parse(e){let t=this.parseWithErrors(e);if(!t.isValid){let n=t.errors[0];throw new Error(`YAML parse error at line ${n.line}, column ${n.column}: ${n.message}`)}return t.document}parseWithErrors(e){let t=[],n;try{e=e.replace(/^\uFEFF/,"");let r=F.load(e);if(!r||typeof r!="object")return n={metadata:this.createEmptyMetadata(),body:{},toString:()=>"KanonakDocument(empty)"},{document:n,errors:t,isValid:!0};let o=this.extractMetadata(r),s=this.extractBody(r,o);return n={metadata:o,body:s,toString:function(){return this.metadata.namespace_?`KanonakDocument(${this.metadata.namespace_.publisher}/${this.metadata.namespace_.package_})`:"KanonakDocument(no namespace)"}},{document:n,errors:t,isValid:!0}}catch(r){let o=r,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 n=e.metadata.namespace_,r={type:"Package",publisher:n.publisher};n.version&&(r.version=`${n.version.major}.${n.version.minor}.${n.version.patch}`),e.metadata.imports&&(r.imports=this.serializeImports(e.metadata.imports)),t[n.package_]=r}return Object.assign(t,e.body),F.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 n=[];for(let r of Object.values(t))n.push(...r);return n},enumerable:!0,configurable:!0}),e}createVersion(e,t,n){return{major:e,minor:t,patch:n,toString:()=>`${e}.${t}.${n}`,equals:o=>!o||typeof o!="object"?!1:o.major===e&&o.minor===t&&o.patch===n,getHashCode:()=>e<<20|t<<10|n,compareTo:o=>e!==o.major?e-o.major:t!==o.minor?t-o.minor:n-o.patch}}extractMetadata(e){let t=this.createEmptyMetadata();for(let[n,r]of Object.entries(e))if(r&&typeof r=="object"&&r.type==="Package"){t.type_="Package";let o=n,s=r.publisher,i=r.version?this.parseVersion(r.version):void 0;return s&&o&&(t.namespace_={publisher:s,package_:o,version:i,toString:function(){return`${this.publisher}/${this.package_}@${this.version?.major??1}.${this.version?.minor??0}.${this.version?.patch??0}`},equals:a=>!a||typeof a!="object"?!1:a.publisher===s&&a.package_===o&&(!i||!a.version||i.equals(a.version)),getHashCode:()=>{let a=0;for(let c=0;c<s.length;c++)a=(a<<5)-a+s.charCodeAt(c);for(let c=0;c<o.length;c++)a=(a<<5)-a+o.charCodeAt(c);return a|0}}),r.imports&&Array.isArray(r.imports)&&(t.imports=this.parseImportsV3(r.imports)),this.addAllImportsGetter(t)}if(e.kanonak&&typeof e.kanonak=="object"){let n=e.kanonak;return(n.publisher||n.package||n.version)&&(t.namespace_=this.parseNamespace(n)),n.imports&&typeof n.imports=="object"&&(t.imports=this.parseImportsLegacy(n.imports)),this.addAllImportsGetter(t)}return t}extractBody(e,t){let n={},r;for(let[o,s]of Object.entries(e))if(s&&typeof s=="object"&&s.type==="Package"){r=o;break}for(let[o,s]of Object.entries(e))o!==r&&o!=="kanonak"&&o!=="namespace"&&o!=="imports"&&(n[o]=s);return n}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:i=>!i||typeof i!="object"?!1:i.publisher===o[1]&&i.package_===o[2]&&(!s||!i.version||s.equals(i.version)),getHashCode:()=>{let i=0;for(let a=0;a<o[1].length;a++)i=(i<<5)-i+o[1].charCodeAt(a);for(let a=0;a<o[2].length;a++)i=(i<<5)-i+o[2].charCodeAt(a);return i|0}}}}let t=e.publisher||"",n=e.package||"",r=e.version?this.parseVersion(e.version):this.createVersion(1,0,0);return{publisher:t,package_:n,version:r,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_===n&&(!r||!o.version||r.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<n.length;s++)o=(o<<5)-o+n.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 n of e)if(!(!n||typeof n!="object"))if(n.packages&&Array.isArray(n.packages)){let r=n.publisher;if(!r)throw new Error("PublisherImport requires 'publisher' property");t[r]||(t[r]=[]);for(let o of n.packages){if(!o||typeof o!="object")continue;let s=this.parseImportFromEmbeddedObject(o,r);t[r].push(s)}}else{let r=this.parseImportFromEmbeddedObject(n,n.publisher),o=r.publisher||"";t[o]||(t[o]=[]),t[o].push(r)}return t}parseImportsLegacy(e){let t={};for(let[n,r]of Object.entries(e))Array.isArray(r)&&(t[n]=r.map(o=>this.parseImport(o,n)));return t}parseImportFromEmbeddedObject(e,t){let n=e.package;if(!n)throw new Error("Import requires 'package' property");let r=e.match;if(!r)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),i=this.parseVersionOperator(r),a=this.calculateMaxVersion(r,s),c=e.alias;return{package_:`${n} ${r} ${s.toString()}`,publisher:t,packageName:n,versionOperator:i,version:s,alias:c,minVersion:s,maxVersion:a,toEmbeddedObject:()=>{let u={package:n,match:r,version:s.toString()};return c&&(u.alias=c),u},toString:()=>c?`${n} ${r} ${s.toString()} as ${c}`:`${n} ${r} ${s.toString()}`}}parseImport(e,t){if(typeof e=="string"){let a=e.match(/^(.+?)\s*([~^=*])\s*(\S+)\s+as\s+(\S+)$/);if(a){let u=a[1].trim(),m=a[2],l=this.parseVersion(a[3].trim()),f=a[4].trim(),g=this.parseVersionOperator(m),h=this.calculateMaxVersion(m,l);return{package_:e,publisher:t,packageName:u,versionOperator:g,version:l,alias:f,minVersion:l,maxVersion:h,toEmbeddedObject:()=>{let d={package:u,match:m,version:l.toString()};return f&&(d.alias=f),d},toString:()=>`${u} ${m} ${l.toString()} as ${f}`}}let c=e.match(/^(.+?)\s*([~^=*])\s*(.+)$/);if(c){let u=c[1].trim(),m=c[2],l=this.parseVersion(c[3].trim()),f=this.parseVersionOperator(m),g=this.calculateMaxVersion(m,l);return{package_:e,publisher:t,packageName:u,versionOperator:f,version:l,alias:void 0,minVersion:l,maxVersion:g,toEmbeddedObject:()=>({package:u,match:m,version:l.toString()}),toString:()=>`${u} ${m} ${l.toString()}`}}}let n=this.parseVersionOperator(e.operator||"~"),r=this.parseVersion(e.version||"1.0.0"),o=e.packageName||e.package||"",s=["=","~","^","*"][n],i=this.calculateMaxVersion(e.operator||"~",r);return{package_:e.package||"",publisher:t,packageName:o,versionOperator:n,version:r,alias:e.alias,minVersion:r,maxVersion:i,toEmbeddedObject:()=>{let a={package:o,match:s,version:r.toString()};return e.alias&&(a.alias=e.alias),a},toString:()=>`${o} ${s} ${r.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[n,r]of Object.entries(e)){let o={publisher:n,packages:r.map(s=>{let i=["=","~","^","*"][s.versionOperator],a={package:s.packageName,match:i,version:`${s.version.major}.${s.version.minor}.${s.version.patch}`};return s.alias&&(a.alias=s.alias),a})};t.push(o)}return t}};var K=class{};var A=class extends K{statement=[]};var $=class extends A{namespace;name;icon};var E=class extends A{name};q();var y=class p extends K{subject;static parse(e){let t=new p;return t.subject=R.parse(e),t}};var _=class extends K{value};var S=class{predicate;object};var I=class extends S{};var j=class p extends I{static parse(e,t){let n=new p;return n.predicate=y.parse(e),n.object=t,n}};var N=class p extends I{static parse(e,t){let n=new p;return n.predicate=y.parse(e),n.object=t,n}};var L=class extends I{};var C=class p extends S{static parse(e,t){let n=new p;return n.predicate=y.parse(e),n.object=y.parse(t),n}};var V=class extends S{};var D=class extends S{};q();function H(p){if(Array.isArray(p))return p.map(t=>t?.toString()??"").filter(t=>t.length>0);let e=p?.toString();return e?[e]:[]}var W=class{cache=new Map;repository;logger;constructor(e,t){this.repository=e,this.logger=t}async resolveEntityAsync(e,t){let n=t.metadata?.namespace_?.toString()??"unknown",r=this.cache.get(n);if(r){let s=r.get(e);if(s)return s}let o=await this.buildEntityIndexAsyncInternal(t,new Set,"");return this.cache.set(n,o),o.get(e)??null}async resolveAllEntitiesAsync(e,t){let n=await this.buildAllEntitiesIndexAsync(t,new Set,"");if(e.includes(".")){let r=e.split("."),o=r[0],s=r[1],i=await this.findDocumentForAlias(t,o);return i?await this.resolveAllEntitiesAsync(s,i):[]}return n.filter(r=>r.entityName===e)}async buildAllEntitiesIndexAsync(e,t,n){let r=[],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)`),r;t.add(o);let s=n.length===0?o:`${n} \u2192 ${o}`;for(let[i,a]of Object.entries(e.body))if(!i.includes(".")&&a&&typeof a=="object"&&!Array.isArray(a)){let c=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};r.push({entityName:i,uri:new R(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,i,c),entity:a,definedInNamespace:o,isImported:n.length>0,importPath:s})}if(this.logger?.debug?.(`Collected ${r.length} entities from ${o}`),e.metadata?.imports){let i=Object.values(e.metadata.imports).reduce((a,c)=>a+c.length,0);this.logger?.debug?.(`Processing ${i} import(s) for ${o}`);for(let[a,c]of Object.entries(e.metadata.imports))for(let u of c)try{this.logger?.debug?.(`Resolving import: ${a}/${u.packageName}`);let m=await this.repository.getHighestCompatibleVersionAsync(a,u);if(m){this.logger?.debug?.(`Successfully loaded import: ${m.metadata?.namespace_?.toString()}`);let l=await this.buildAllEntitiesIndexAsync(m,t,s);r.push(...l),this.logger?.debug?.(`Added ${l.length} entities from import ${m.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${a}/${u.packageName}`)}catch(m){let l=m;throw this.logger?.error?.(`Failed to process import ${a}/${u.packageName} for namespace ${o}. Error: ${l.message}`,l),new Error(`Failed to process import ${a}/${u.packageName} for namespace ${o}. See inner exception for details.`,{cause:m})}}return r}async buildEntityIndexAsync(e){return await this.buildEntityIndexAsyncInternal(e,new Set,"")}async buildEntityIndexAsyncInternal(e,t,n){let r=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)`),r;t.add(o);let s=n.length===0?o:`${n} \u2192 ${o}`,i=0;for(let[a,c]of Object.entries(e.body))if(!a.includes(".")&&c&&typeof c=="object"&&!Array.isArray(c)&&!r.has(a)){let u=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};r.set(a,{entityName:a,uri:new R(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,a,u),entity:c,definedInNamespace:o,isImported:n.length>0,importPath:s}),i++}if(this.logger?.debug?.(`Indexed ${i} entities from ${o}`),e.metadata?.imports){let a=Object.values(e.metadata.imports).reduce((c,u)=>c+u.length,0);this.logger?.debug?.(`Processing ${a} import(s) for ${o}`);for(let[c,u]of Object.entries(e.metadata.imports))for(let m of u)try{this.logger?.debug?.(`Resolving import: ${c}/${m.packageName}`);let l=await this.repository.getHighestCompatibleVersionAsync(c,m);if(l){this.logger?.debug?.(`Successfully loaded import: ${l.metadata?.namespace_?.toString()}`);let f=await this.buildEntityIndexAsyncInternal(l,t,s),g=0;for(let[h,d]of f.entries())if(r.has(h)||(r.set(h,d),g++),m.alias&&!h.includes(".")){let P=`${m.alias}.${h}`;r.has(P)||(r.set(P,d),g++)}this.logger?.debug?.(`Merged ${g} entities from import ${l.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${c}/${m.packageName}`)}catch(l){let f=l;throw this.logger?.error?.(`Failed to process import ${c}/${m.packageName} for namespace ${o}. Error: ${f.message}`,f),new Error(`Failed to process import ${c}/${m.packageName} for namespace ${o}. See inner exception for details.`,{cause:l})}}return r}async findDocumentForAlias(e,t){if(!e.metadata?.imports)return null;for(let[n,r]of Object.entries(e.metadata.imports))for(let o of r){if(o.alias===t)return await this.repository.getHighestCompatibleVersionAsync(n,o);if(!o.alias&&o.packageName===t)return await this.repository.getHighestCompatibleVersionAsync(n,o)}return null}clearCache(){this.cache.clear()}clearCacheForDocument(e){this.cache.delete(e)}async isSubclassOfAsync(e,t,n){if(e===t)return!0;let r=new Set;return await this.isSubclassOfRecursiveAsync(e,t,n,r)}async isSubclassOfRecursiveAsync(e,t,n,r){if(r.has(e))return!1;r.add(e);let o=await this.resolveEntityAsync(e,n);if(!o?.entity)return!1;let s=o.entity.subClassOf;if(s){let i=H(s);for(let a of i)if(a===t||await this.isSubclassOfRecursiveAsync(a,t,n,r))return!0}return!1}async isSubpropertyOfAsync(e,t,n){if(e===t)return!0;let r=new Set;return await this.isSubpropertyOfRecursiveAsync(e,t,n,r)}async isSubpropertyOfRecursiveAsync(e,t,n,r){if(r.has(e))return!1;r.add(e);let o=await this.resolveEntityAsync(e,n);if(!o?.entity)return!1;let s=o.entity.subPropertyOf;if(s){let i=H(s);for(let a of i)if(a===t||await this.isSubpropertyOfRecursiveAsync(a,t,n,r))return!0}return!1}};var U=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 n=await this.resourceResolver.resolveEntityAsync(e,t);if(n){let r=n.entity.type;if(r){let o=String(r);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 Y=class{constructor(e){}async parseKanonaks(e){let t=[],n=await e.getAllDocumentsAsync(),r=new W(e),o=new U(r);for(let a of n){let c=a.metadata.namespace_?.toString()??"";for(let[u,m]of Object.entries(a.body)){let l=new $,f=this.resolveCanonicalEntity(u,a,c);l.namespace=f.namespace,l.name=f.name,l.statement=[];let g=await this.parseStatements(m,a,r,o,e);l.statement.push(...g),t.push(l)}}let s=new Map,i=[];for(let a of t)if(a instanceof $){let c=`${a.namespace}/${a.name}`,u=s.get(c);u?u.statement.push(...a.statement):(s.set(c,a),i.push(a))}else i.push(a);return i}resolveCanonicalEntity(e,t,n){if(!e.includes(".")||!t.metadata?.imports)return{namespace:n,name:e};let r=e.indexOf("."),o=e.substring(0,r),s=e.substring(r+1);for(let[i,a]of Object.entries(t.metadata.imports))for(let c of a)if((c.alias??c.packageName)===o){let m=c.version;return{namespace:`${i}/${c.packageName}@${m.major}.${m.minor}.${m.patch}`,name:s}}return{namespace:n,name:e}}async parseStatements(e,t,n,r,o){let s=[];if(typeof e!="object"||e===null||Array.isArray(e))return s;for(let[i,a]of Object.entries(e))try{let c=await this.getPropertyMetadata(i,t,n,o,r);if(!c)continue;let u=await this.parsePropertyValue(i,a,c,t,n,r);u&&s.push(u)}catch(c){console.error(`Error parsing property ${i}:`,c)}return s}async getPropertyMetadata(e,t,n,r,o){let s=await n.resolveEntityAsync(e,t);if(!s)return;let i=s.entity,a=i.type?.toString()??"",c=a.includes(".")?a.substring(a.lastIndexOf(".")+1):a;if(!new Set(["Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]).has(c))return;let m=o.getPropertyTypeClassification(a),l=i.range?.toString(),f;if(m==="ObjectProperty")f="ObjectProperty";else if(m==="DatatypeProperty")f="DatatypeProperty";else{let h=l&&l.includes(".")?l.substring(l.lastIndexOf(".")+1):l??"";(l?o.isKnownXsdDatatypeName(l):!1)||h==="Literal"?f="DatatypeProperty":f="ObjectProperty"}return{propertyUri:s.uri.toString(),propertyType:f,range:l,isImported:s.isImported,definedInNamespace:s.definedInNamespace}}async parsePropertyValue(e,t,n,r,o,s){let i=n.propertyUri;if(t!=null){if(Array.isArray(t))return this.parseListValue(i,t,n,r,o,s);if(n.propertyType==="DatatypeProperty")return this.parseDatatypeValue(i,t,n);if(n.propertyType==="ObjectProperty")return this.parseObjectValue(i,t,n,r,o,s)}}parseDatatypeValue(e,t,n){if(t instanceof Date)return j.parse(e,t.toISOString());if(typeof t=="string")return j.parse(e,t);if(typeof t=="number")return N.parse(e,t);if(typeof t=="boolean"){let r=new L;return r.predicate=y.parse(e),r.object=t,r}}async parseObjectValue(e,t,n,r,o,s){if(typeof t=="string"){let i=await this.resolveReference(t,r,o);if(!i)return;let a=new C;return a.predicate=y.parse(e),a.object=i,a}if(typeof t=="object"&&!Array.isArray(t)){let i=new E;if(i.statement=await this.parseStatements(t,r,o,s,{}),i.statement.length>0){let u=new V;return u.predicate=y.parse(e),u.object=i,u}let a=[];for(let[u,m]of Object.entries(t))if(typeof m=="object"&&m!==null&&!Array.isArray(m)){let l=new E;l.name=u,l.statement=await this.parseStatements(m,r,o,s,{}),a.push(l)}else if(typeof m=="string"){let l=await this.resolveReference(m,r,o);l&&a.push(l)}if(a.length>0){let u=new D;return u.predicate=y.parse(e),u.object=a,u}let c=new V;return c.predicate=y.parse(e),c.object=i,c}}async parseListValue(e,t,n,r,o,s){let i=[],a=n.propertyType==="DatatypeProperty";for(let u of t){if(a&&(typeof u=="string"||typeof u=="number"||typeof u=="boolean")){let m=new _;m.value=u,i.push(m);continue}if(a&&u instanceof Date){let m=new _;m.value=u.toISOString(),i.push(m);continue}if(typeof u=="string"){let m=await this.resolveReference(u,r,o);m&&i.push(m)}else if(typeof u=="object"&&u!==null&&!Array.isArray(u)){let m=new E;m.statement=await this.parseStatements(u,r,o,s,{}),i.push(m)}}let c=new D;return c.predicate=y.parse(e),c.object=i,c}async resolveReference(e,t,n){let r=await n.resolveEntityAsync(e,t);if(r){let s=new y;return s.subject=r.uri,s}let o=t.metadata?.namespace_;if(o){let{KanonakUri:s}=await Promise.resolve().then(()=>(q(),J)),i=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("."),u=e.substring(0,c),m=e.substring(c+1);if(t.metadata?.imports){for(let[l,f]of Object.entries(t.metadata.imports))for(let g of f)if((g.alias??g.packageName)===u){let d=new y;return d.subject=new s(l,g.packageName,m,g.version),d}}}let a=new y;return a.subject=new s(o.publisher,o.package_,e,i),a}return null}async saveKanonaks(e,t){let n=new Map;for(let r of e)r instanceof $&&r.namespace&&(n.has(r.namespace)||n.set(r.namespace,[]),n.get(r.namespace).push(r));for(let[r,o]of n){let s=await this.convertKanonaksToDocument(r,o),i=`${r.split("@")[0]}.yml`;await t.saveDocumentAsync(s,i)}}async serializeToYaml(e,t){let n=e.filter(s=>s instanceof $&&s.namespace===t);if(n.length===0)throw new Error(`No kanonaks found with namespace '${t}'`);let r=await this.convertKanonaksToDocument(t,n);return new w().save(r)}async convertKanonaksToDocument(e,t){let r={metadata:{namespace_:e,get allImports(){if(!this.imports)return[];let s=[];for(let i of Object.values(this.imports))s.push(...i);return s}},body:{}},o=new Map;for(let s of t){let i={};for(let a of s.statement){let[c,u]=this.convertStatementToProperty(a);c&&u!==null&&u!==void 0&&(i[c]=u),this.collectImportsFromStatement(a,e,o)}r.body[s.name]=i}return r}convertStatementToProperty(e){if(e instanceof j)return[e.predicate.subject.name,e.object];if(e instanceof N)return[e.predicate.subject.name,e.object];if(e instanceof L)return[e.predicate.subject.name,e.object];if(e instanceof C)return[e.predicate.subject.name,e.object.subject.name];if(e instanceof D){let t=this.convertKanonakListToValue(e.object);return[e.predicate.subject.name,t]}else if(e instanceof V){let t=this.convertEmbeddedKanonakToValue(e.object);return[e.predicate.subject.name,t]}return[null,null]}convertKanonakListToValue(e){let t=[];for(let n of e)n instanceof y?t.push(n.subject.name):n instanceof E&&t.push(this.convertEmbeddedKanonakToValue(n));return t}convertEmbeddedKanonakToValue(e){let t={};for(let n of e.statement){let[r,o]=this.convertStatementToProperty(n);r&&o!==null&&o!==void 0&&(t[r]=o)}return t}collectImportsFromStatement(e,t,n){}};var B=class{propertyUri;propertyType;range;isImported;definedInNamespace};import{parseDocument as oe,LineCounter as se,isMap as x,isPair as k,isScalar as b,isSeq as X}from"yaml";var T=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,n=new se,r=oe(e,{lineCounter:n});if(r.errors.length>0||!x(r.contents))return t;G(r.contents,[],n,t);for(let o of r.contents.items){if(!k(o)||!b(o.key))continue;let s=String(o.key.value),i=o.key.range;if(!i)continue;t.entities.set(s,v(i,n));let a=o.value,c=a&&typeof a=="object"&&"range"in a?a.range:void 0;if(c?t.entityBlocks.set(s,v([i[0],i[1],c[2]],n)):t.entityBlocks.set(s,v(i,n)),x(o.value)){let u=new Map,m=new Map,l=new Map;for(let g of o.value.items){if(!k(g)||!b(g.key))continue;let h=String(g.key.value),d=g.key.range;d&&u.set(h,v(d,n));let P=g.value;if(P&&typeof P=="object"&&"range"in P&&Array.isArray(P.range)){let O=P.range;m.set(h,v(O,n))}if(X(P)){let O=[];for(let M of P.items)M&&typeof M=="object"&&"range"in M&&Array.isArray(M.range)&&O.push(v(M.range,n));O.length>0&&l.set(h,O)}}u.size>0&&t.properties.set(s,u),m.size>0&&t.propertyValues.set(s,m),l.size>0&&t.valueListItems.set(s,l);let f=ae(o.value,n);f.length>0&&t.importPackages.set(s,f)}}return t}getEntityPosition(e){return this.entities.get(e)}getEntityBlockPosition(e){return this.entityBlocks.get(e)}findEntityAtPosition(e,t){for(let[n,r]of this.entityBlocks)if(z(r,e,t))return n}findPropertyAtPosition(e,t){let n=this.findEntityAtPosition(e,t);if(!n)return;let r=this.properties.get(n),o=this.propertyValues.get(n);if(!r&&!o)return{entityName:n};let s,i;if(o)for(let[a,c]of o)z(c,e,t)&&(!i||Q(c,i))&&(s=a,i=c);if(r)for(let[a,c]of r)z(c,e,t)&&(!i||Q(c,i))&&(s=a,i=c);return s?{entityName:n,propertyName:s}:{entityName:n}}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,n]of this.importPackages)for(let r of n)e.push({entityName:t,entry:r});return e}findPropertySourceName(e,t){let n=this.properties.get(e);if(n){if(n.has(t))return t;for(let r of n.keys()){let o=r.lastIndexOf(".");if((o===-1?r:r.substring(o+1))===t)return r}}}getListItemPosition(e,t,n){let r=this.valueListItems.get(e)?.get(t);if(!(!r||n<0||n>=r.length))return r[n]}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,n){if(e){if(t!==void 0){if(n!==void 0){let s=this.getListItemPosition(e,t,n);if(s)return s}let r=this.getPropertyValuePosition(e,t);if(r)return r;let o=this.getPropertyPosition(e,t);if(o)return o}return this.getEntityPosition(e)}}};function ae(p,e){let t=[];if(!x(p))return t;let n=p.items.find(r=>k(r)&&b(r.key)&&String(r.key.value)==="imports");if(!n||!k(n)||!X(n.value))return t;for(let r of n.value.items){if(!x(r))continue;let o=r.items.find(a=>k(a)&&b(a.key)&&String(a.key.value)==="publisher");if(!o||!k(o)||!b(o.value))continue;let s=String(o.value.value),i=r.items.find(a=>k(a)&&b(a.key)&&String(a.key.value)==="packages");if(!(!i||!k(i)||!X(i.value)))for(let a of i.value.items){if(!x(a))continue;let c=a.items.find(d=>k(d)&&b(d.key)&&String(d.key.value)==="package");if(!c||!k(c)||!b(c.value)||!c.value.range)continue;let u=String(c.value.value),m=a.items.find(d=>k(d)&&b(d.key)&&String(d.key.value)==="version"),l=m&&k(m)&&b(m.value)?String(m.value.value):"",f=a.items.find(d=>k(d)&&b(d.key)&&String(d.key.value)==="alias"),g=f&&k(f)&&b(f.value)?String(f.value.value):void 0,h=g!==void 0?{publisher:s,package_:u,version:l,alias:g,position:v(c.value.range,e)}:{publisher:s,package_:u,version:l,position:v(c.value.range,e)};t.push(h)}}return t}function z(p,e,t){return!(e<p.line||e>p.endLine||e===p.line&&t<p.column||e===p.endLine&&t>p.endColumn)}function Q(p,e){let t=p.endLine-p.line,n=e.endLine-e.line;if(t!==n)return t<n;let r=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 r<o}function G(p,e,t,n){if(x(p)){for(let r of p.items){if(!k(r)||!b(r.key))continue;let o=String(r.key.value),s=[...e,o],i=JSON.stringify(s);r.key.range&&n.setNestedKeyPosition(i,v(r.key.range,t));let a=r.value,c=Z(a);c&&n.setNestedValuePosition(i,v(c,t)),G(a,s,t,n)}return}if(X(p)){for(let r=0;r<p.items.length;r++){let o=p.items[r],s=[...e,r],i=JSON.stringify(s),a=Z(o);a&&n.setNestedValuePosition(i,v(a,t)),G(o,s,t,n)}return}}function Z(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 v(p,e){let t=e.linePos(p[0]),n=e.linePos(p[2]);return{line:t.line-1,column:t.col-1,endLine:n.line-1,endColumn:n.col-1}}function ie(p,e){let n=(e??new w).parse(p),r=T.fromContent(p);return{document:n,positions:r}}export{T as KanonakDocumentPositions,Y as KanonakObjectParser,w as KanonakParser,B as PropertyMetadata,ie as parseWithPositions};
|
package/dist/reasoning/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var te=Object.defineProperty;var re=(s,e)=>()=>(s&&(e=s(s=0)),e);var ne=(s,e)=>{for(var t in e)te(s,t,{get:e[t],enumerable:!0})};var ee={};ne(ee,{KanonakUri:()=>P});function oe(s,e,t){return{major:s,minor:e,patch:t,toString:()=>`${s}.${e}.${t}`,equals:r=>!r||typeof r!="object"?!1:r.major===s&&r.minor===e&&r.patch===t,getHashCode:()=>s<<20|e<<10|t,compareTo:r=>s!==r.major?s-r.major:e!==r.minor?e-r.minor:t-r.patch}}var P,C=re(()=>{"use strict";P=class s{constructor(e,t,r,o){this.publisher=e;this.package_=t;this.name=r;this.version=o}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,o,n]=t;if(!r||!o||!n)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let a=o.indexOf("@");if(a===-1)return new s(r,o,n,void 0);let c=o.substring(0,a),i=o.substring(a+1);if(!c||!i)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let p=i.split(".").map(Number),l=oe(p[0]||0,p[1]||0,p[2]||0);return new s(r,c,n,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}`}}});var S=class{};var V=class extends S{statement=[]};var v=class extends V{namespace;name;icon};var R=class extends V{name};C();var d=class s extends S{subject;static parse(e){let t=new s;return t.subject=P.parse(e),t}};var w=class extends S{value};var k=class{predicate;object};var I=class extends k{};var $=class s extends I{static parse(e,t){let r=new s;return r.predicate=d.parse(e),r.object=t,r}};var x=class s extends I{static parse(e,t){let r=new s;return r.predicate=d.parse(e),r.object=t,r}};var A=class extends I{};var E=class s extends k{static parse(e,t){let r=new s;return r.predicate=d.parse(e),r.object=d.parse(t),r}};var j=class extends k{};var O=class extends k{};C();function B(s){if(Array.isArray(s))return s.map(t=>t?.toString()??"").filter(t=>t.length>0);let e=s?.toString();return e?[e]:[]}var M=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",o=this.cache.get(r);if(o){let a=o.get(e);if(a)return a}let n=await this.buildEntityIndexAsyncInternal(t,new Set,"");return this.cache.set(r,n),n.get(e)??null}async resolveAllEntitiesAsync(e,t){let r=await this.buildAllEntitiesIndexAsync(t,new Set,"");if(e.includes(".")){let o=e.split("."),n=o[0],a=o[1],c=await this.findDocumentForAlias(t,n);return c?await this.resolveAllEntitiesAsync(a,c):[]}return r.filter(o=>o.entityName===e)}async buildAllEntitiesIndexAsync(e,t,r){let o=[],n=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building ALL entities index for namespace: ${n}`),t.has(n))return this.logger?.debug?.(`Skipping ${n} - already visited (circular import prevention)`),o;t.add(n);let a=r.length===0?n:`${r} \u2192 ${n}`;for(let[c,i]of Object.entries(e.body))if(i&&typeof i=="object"&&!Array.isArray(i)){let p=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};o.push({entityName:c,uri:new P(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,c,p),entity:i,definedInNamespace:n,isImported:r.length>0,importPath:a})}if(this.logger?.debug?.(`Collected ${o.length} entities from ${n}`),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 ${n}`);for(let[i,p]of Object.entries(e.metadata.imports))for(let l of p)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 f=await this.buildAllEntitiesIndexAsync(u,t,a);o.push(...f),this.logger?.debug?.(`Added ${f.length} entities from import ${u.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${i}/${l.packageName}`)}catch(u){let f=u;throw this.logger?.error?.(`Failed to process import ${i}/${l.packageName} for namespace ${n}. Error: ${f.message}`,f),new Error(`Failed to process import ${i}/${l.packageName} for namespace ${n}. See inner exception for details.`,{cause:u})}}return o}async buildEntityIndexAsync(e){return await this.buildEntityIndexAsyncInternal(e,new Set,"")}async buildEntityIndexAsyncInternal(e,t,r){let o=new Map,n=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building entity index for namespace: ${n}`),t.has(n))return this.logger?.debug?.(`Skipping ${n} - already visited (circular import prevention)`),o;t.add(n);let a=r.length===0?n:`${r} \u2192 ${n}`,c=0;for(let[i,p]of Object.entries(e.body))if(p&&typeof p=="object"&&!Array.isArray(p)&&!o.has(i)){let l=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};o.set(i,{entityName:i,uri:new P(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,i,l),entity:p,definedInNamespace:n,isImported:r.length>0,importPath:a}),c++}if(this.logger?.debug?.(`Indexed ${c} entities from ${n}`),e.metadata?.imports){let i=Object.values(e.metadata.imports).reduce((p,l)=>p+l.length,0);this.logger?.debug?.(`Processing ${i} import(s) for ${n}`);for(let[p,l]of Object.entries(e.metadata.imports))for(let u of l)try{this.logger?.debug?.(`Resolving import: ${p}/${u.packageName}`);let f=await this.repository.getHighestCompatibleVersionAsync(p,u);if(f){this.logger?.debug?.(`Successfully loaded import: ${f.metadata?.namespace_?.toString()}`);let m=await this.buildEntityIndexAsyncInternal(f,t,a),b=0;for(let[h,K]of m.entries())if(o.has(h)||(o.set(h,K),b++),u.alias&&!h.includes(".")){let z=`${u.alias}.${h}`;o.has(z)||(o.set(z,K),b++)}this.logger?.debug?.(`Merged ${b} entities from import ${f.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${p}/${u.packageName}`)}catch(f){let m=f;throw this.logger?.error?.(`Failed to process import ${p}/${u.packageName} for namespace ${n}. Error: ${m.message}`,m),new Error(`Failed to process import ${p}/${u.packageName} for namespace ${n}. See inner exception for details.`,{cause:f})}}return o}async findDocumentForAlias(e,t){if(!e.metadata?.imports)return null;for(let[r,o]of Object.entries(e.metadata.imports))for(let n of o){if(n.alias===t)return await this.repository.getHighestCompatibleVersionAsync(r,n);if(!n.alias&&n.packageName===t)return await this.repository.getHighestCompatibleVersionAsync(r,n)}return null}clearCache(){this.cache.clear()}clearCacheForDocument(e){this.cache.delete(e)}async isSubclassOfAsync(e,t,r){if(e===t)return!0;let o=new Set;return await this.isSubclassOfRecursiveAsync(e,t,r,o)}async isSubclassOfRecursiveAsync(e,t,r,o){if(o.has(e))return!1;o.add(e);let n=await this.resolveEntityAsync(e,r);if(!n?.entity)return!1;let a=n.entity.subClassOf;if(a){let c=B(a);for(let i of c)if(i===t||await this.isSubclassOfRecursiveAsync(i,t,r,o))return!0}return!1}async isSubpropertyOfAsync(e,t,r){if(e===t)return!0;let o=new Set;return await this.isSubpropertyOfRecursiveAsync(e,t,r,o)}async isSubpropertyOfRecursiveAsync(e,t,r,o){if(o.has(e))return!1;o.add(e);let n=await this.resolveEntityAsync(e,r);if(!n?.entity)return!1;let a=n.entity.subPropertyOf;if(a){let c=B(a);for(let i of c)if(i===t||await this.isSubpropertyOfRecursiveAsync(i,t,r,o))return!0}return!1}};var N=class s{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"&&s.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 s.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 o=r.entity.type;if(o){let n=String(o);return n==="Class"||n==="rdfs.Class"||n.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))}};import*as F from"js-yaml";var q=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 o=F.load(e);if(!o||typeof o!="object")return r={metadata:this.createEmptyMetadata(),body:{},toString:()=>"KanonakDocument(empty)"},{document:r,errors:t,isValid:!0};let n=this.extractMetadata(o),a=this.extractBody(o,n);return r={metadata:n,body:a,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(o){let n=o,a={message:n.message||"Unknown parse error",line:n.mark?.line??0,column:n.mark?.column??0,errorType:n.name==="YAMLException"?"SyntaxError":"Unknown",toString:()=>`${n.name==="YAMLException"?"SyntaxError":"Unknown"} at line ${n.mark?.line??0}: ${n.message||"Unknown parse error"}`};return t.push(a),{document:void 0,errors:t,isValid:!1}}}save(e){let t={};if(e.metadata.namespace_){let r=e.metadata.namespace_,o={type:"Package",publisher:r.publisher};r.version&&(o.version=`${r.version.major}.${r.version.minor}.${r.version.patch}`),e.metadata.imports&&(o.imports=this.serializeImports(e.metadata.imports)),t[r.package_]=o}return Object.assign(t,e.body),F.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 o of Object.values(t))r.push(...o);return r},enumerable:!0,configurable:!0}),e}createVersion(e,t,r){return{major:e,minor:t,patch:r,toString:()=>`${e}.${t}.${r}`,equals:n=>!n||typeof n!="object"?!1:n.major===e&&n.minor===t&&n.patch===r,getHashCode:()=>e<<20|t<<10|r,compareTo:n=>e!==n.major?e-n.major:t!==n.minor?t-n.minor:r-n.patch}}extractMetadata(e){let t=this.createEmptyMetadata();for(let[r,o]of Object.entries(e))if(o&&typeof o=="object"&&o.type==="Package"){t.type_="Package";let n=r,a=o.publisher,c=o.version?this.parseVersion(o.version):void 0;return a&&n&&(t.namespace_={publisher:a,package_:n,version:c,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===a&&i.package_===n&&(!c||!i.version||c.equals(i.version)),getHashCode:()=>{let i=0;for(let p=0;p<a.length;p++)i=(i<<5)-i+a.charCodeAt(p);for(let p=0;p<n.length;p++)i=(i<<5)-i+n.charCodeAt(p);return i|0}}),o.imports&&Array.isArray(o.imports)&&(t.imports=this.parseImportsV3(o.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={},o;for(let[n,a]of Object.entries(e))if(a&&typeof a=="object"&&a.type==="Package"){o=n;break}for(let[n,a]of Object.entries(e))n!==o&&n!=="kanonak"&&n!=="namespace"&&n!=="imports"&&(r[n]=a);return r}parseNamespace(e){if(typeof e=="string"){let n=e.match(/^([^/]+)\/([^@]+)(?:@(.+))?$/);if(n){let a=n[3]?this.parseVersion(n[3]):this.createVersion(1,0,0);return{publisher:n[1],package_:n[2],version:a,toString:()=>e,equals:c=>!c||typeof c!="object"?!1:c.publisher===n[1]&&c.package_===n[2]&&(!a||!c.version||a.equals(c.version)),getHashCode:()=>{let c=0;for(let i=0;i<n[1].length;i++)c=(c<<5)-c+n[1].charCodeAt(i);for(let i=0;i<n[2].length;i++)c=(c<<5)-c+n[2].charCodeAt(i);return c|0}}}}let t=e.publisher||"",r=e.package||"",o=e.version?this.parseVersion(e.version):this.createVersion(1,0,0);return{publisher:t,package_:r,version:o,toString:function(){return`${this.publisher}/${this.package_}@${this.version?.major??1}.${this.version?.minor??0}.${this.version?.patch??0}`},equals:n=>!n||typeof n!="object"?!1:n.publisher===t&&n.package_===r&&(!o||!n.version||o.equals(n.version)),getHashCode:()=>{let n=0;for(let a=0;a<t.length;a++)n=(n<<5)-n+t.charCodeAt(a);for(let a=0;a<r.length;a++)n=(n<<5)-n+r.charCodeAt(a);return n|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 o=r.publisher;if(!o)throw new Error("PublisherImport requires 'publisher' property");t[o]||(t[o]=[]);for(let n of r.packages){if(!n||typeof n!="object")continue;let a=this.parseImportFromEmbeddedObject(n,o);t[o].push(a)}}else{let o=this.parseImportFromEmbeddedObject(r,r.publisher),n=o.publisher||"";t[n]||(t[n]=[]),t[n].push(o)}return t}parseImportsLegacy(e){let t={};for(let[r,o]of Object.entries(e))Array.isArray(o)&&(t[r]=o.map(n=>this.parseImport(n,r)));return t}parseImportFromEmbeddedObject(e,t){let r=e.package;if(!r)throw new Error("Import requires 'package' property");let o=e.match;if(!o)throw new Error("Import requires 'match' property");let n=e.version;if(!n)throw new Error("Import requires 'version' property");let a=this.parseVersion(n),c=this.parseVersionOperator(o),i=this.calculateMaxVersion(o,a),p=e.alias;return{package_:`${r} ${o} ${a.toString()}`,publisher:t,packageName:r,versionOperator:c,version:a,alias:p,minVersion:a,maxVersion:i,toEmbeddedObject:()=>{let l={package:r,match:o,version:a.toString()};return p&&(l.alias=p),l},toString:()=>p?`${r} ${o} ${a.toString()} as ${p}`:`${r} ${o} ${a.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],f=this.parseVersion(i[3].trim()),m=i[4].trim(),b=this.parseVersionOperator(u),h=this.calculateMaxVersion(u,f);return{package_:e,publisher:t,packageName:l,versionOperator:b,version:f,alias:m,minVersion:f,maxVersion:h,toEmbeddedObject:()=>{let K={package:l,match:u,version:f.toString()};return m&&(K.alias=m),K},toString:()=>`${l} ${u} ${f.toString()} as ${m}`}}let p=e.match(/^(.+?)\s*([~^=*])\s*(.+)$/);if(p){let l=p[1].trim(),u=p[2],f=this.parseVersion(p[3].trim()),m=this.parseVersionOperator(u),b=this.calculateMaxVersion(u,f);return{package_:e,publisher:t,packageName:l,versionOperator:m,version:f,alias:void 0,minVersion:f,maxVersion:b,toEmbeddedObject:()=>({package:l,match:u,version:f.toString()}),toString:()=>`${l} ${u} ${f.toString()}`}}}let r=this.parseVersionOperator(e.operator||"~"),o=this.parseVersion(e.version||"1.0.0"),n=e.packageName||e.package||"",a=["=","~","^","*"][r],c=this.calculateMaxVersion(e.operator||"~",o);return{package_:e.package||"",publisher:t,packageName:n,versionOperator:r,version:o,alias:e.alias,minVersion:o,maxVersion:c,toEmbeddedObject:()=>{let i={package:n,match:a,version:o.toString()};return e.alias&&(i.alias=e.alias),i},toString:()=>`${n} ${a} ${o.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,o]of Object.entries(e)){let n={publisher:r,packages:o.map(a=>{let c=["=","~","^","*"][a.versionOperator],i={package:a.packageName,match:c,version:`${a.version.major}.${a.version.minor}.${a.version.patch}`};return a.alias&&(i.alias=a.alias),i})};t.push(n)}return t}};var W=class{constructor(e){}async parseKanonaks(e){let t=[],r=await e.getAllDocumentsAsync(),o=new M(e),n=new N(o);for(let i of r){let p=i.metadata.namespace_?.toString()??"";for(let[l,u]of Object.entries(i.body)){let f=new v,m=this.resolveCanonicalEntity(l,i,p);f.namespace=m.namespace,f.name=m.name,f.statement=[];let b=await this.parseStatements(u,i,o,n,e);f.statement.push(...b),t.push(f)}}let a=new Map,c=[];for(let i of t)if(i instanceof v){let p=`${i.namespace}/${i.name}`,l=a.get(p);l?l.statement.push(...i.statement):(a.set(p,i),c.push(i))}else c.push(i);return c}resolveCanonicalEntity(e,t,r){if(!e.includes(".")||!t.metadata?.imports)return{namespace:r,name:e};let o=e.indexOf("."),n=e.substring(0,o),a=e.substring(o+1);for(let[c,i]of Object.entries(t.metadata.imports))for(let p of i)if((p.alias??p.packageName)===n){let u=p.version;return{namespace:`${c}/${p.packageName}@${u.major}.${u.minor}.${u.patch}`,name:a}}return{namespace:r,name:e}}async parseStatements(e,t,r,o,n){let a=[];if(typeof e!="object"||e===null||Array.isArray(e))return a;for(let[c,i]of Object.entries(e))try{let p=await this.getPropertyMetadata(c,t,r,n,o);if(!p)continue;let l=await this.parsePropertyValue(c,i,p,t,r,o);l&&a.push(l)}catch(p){console.error(`Error parsing property ${c}:`,p)}return a}async getPropertyMetadata(e,t,r,o,n){let a=await r.resolveEntityAsync(e,t);if(!a)return;let c=a.entity,i=c.type?.toString()??"",p=i.includes(".")?i.substring(i.lastIndexOf(".")+1):i;if(!new Set(["Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]).has(p))return;let u=n.getPropertyTypeClassification(i),f=c.range?.toString(),m;if(u==="ObjectProperty")m="ObjectProperty";else if(u==="DatatypeProperty")m="DatatypeProperty";else{let h=f&&f.includes(".")?f.substring(f.lastIndexOf(".")+1):f??"";(f?n.isKnownXsdDatatypeName(f):!1)||h==="Literal"?m="DatatypeProperty":m="ObjectProperty"}return{propertyUri:a.uri.toString(),propertyType:m,range:f,isImported:a.isImported,definedInNamespace:a.definedInNamespace}}async parsePropertyValue(e,t,r,o,n,a){let c=r.propertyUri;if(t!=null){if(Array.isArray(t))return this.parseListValue(c,t,r,o,n,a);if(r.propertyType==="DatatypeProperty")return this.parseDatatypeValue(c,t,r);if(r.propertyType==="ObjectProperty")return this.parseObjectValue(c,t,r,o,n,a)}}parseDatatypeValue(e,t,r){if(t instanceof Date)return $.parse(e,t.toISOString());if(typeof t=="string")return $.parse(e,t);if(typeof t=="number")return x.parse(e,t);if(typeof t=="boolean"){let o=new A;return o.predicate=d.parse(e),o.object=t,o}}async parseObjectValue(e,t,r,o,n,a){if(typeof t=="string"){let c=await this.resolveReference(t,o,n);if(!c)return;let i=new E;return i.predicate=d.parse(e),i.object=c,i}if(typeof t=="object"&&!Array.isArray(t)){let c=new R;if(c.statement=await this.parseStatements(t,o,n,a,{}),c.statement.length>0){let l=new j;return l.predicate=d.parse(e),l.object=c,l}let i=[];for(let[l,u]of Object.entries(t))if(typeof u=="object"&&u!==null&&!Array.isArray(u)){let f=new R;f.name=l,f.statement=await this.parseStatements(u,o,n,a,{}),i.push(f)}else if(typeof u=="string"){let f=await this.resolveReference(u,o,n);f&&i.push(f)}if(i.length>0){let l=new O;return l.predicate=d.parse(e),l.object=i,l}let p=new j;return p.predicate=d.parse(e),p.object=c,p}}async parseListValue(e,t,r,o,n,a){let c=[],i=r.propertyType==="DatatypeProperty";for(let l of t){if(i&&(typeof l=="string"||typeof l=="number"||typeof l=="boolean")){let u=new w;u.value=l,c.push(u);continue}if(i&&l instanceof Date){let u=new w;u.value=l.toISOString(),c.push(u);continue}if(typeof l=="string"){let u=await this.resolveReference(l,o,n);u&&c.push(u)}else if(typeof l=="object"&&l!==null&&!Array.isArray(l)){let u=new R;u.statement=await this.parseStatements(l,o,n,a,{}),c.push(u)}}let p=new O;return p.predicate=d.parse(e),p.object=c,p}async resolveReference(e,t,r){let o=await r.resolveEntityAsync(e,t);if(o){let a=new d;return a.subject=o.uri,a}let n=t.metadata?.namespace_;if(n){let{KanonakUri:a}=await Promise.resolve().then(()=>(C(),ee)),c=n.version??{major:0,minor:0,patch:0,toString:()=>"0.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};if(e.includes(".")){let p=e.indexOf("."),l=e.substring(0,p),u=e.substring(p+1);if(t.metadata?.imports){for(let[f,m]of Object.entries(t.metadata.imports))for(let b of m)if((b.alias??b.packageName)===l){let K=new d;return K.subject=new a(f,b.packageName,u,b.version),K}}}let i=new d;return i.subject=new a(n.publisher,n.package_,e,c),i}return null}async saveKanonaks(e,t){let r=new Map;for(let o of e)o instanceof v&&o.namespace&&(r.has(o.namespace)||r.set(o.namespace,[]),r.get(o.namespace).push(o));for(let[o,n]of r){let a=await this.convertKanonaksToDocument(o,n),c=`${o.split("@")[0]}.yml`;await t.saveDocumentAsync(a,c)}}async serializeToYaml(e,t){let r=e.filter(a=>a instanceof v&&a.namespace===t);if(r.length===0)throw new Error(`No kanonaks found with namespace '${t}'`);let o=await this.convertKanonaksToDocument(t,r);return new q().save(o)}async convertKanonaksToDocument(e,t){let o={metadata:{namespace_:e,get allImports(){if(!this.imports)return[];let a=[];for(let c of Object.values(this.imports))a.push(...c);return a}},body:{}},n=new Map;for(let a of t){let c={};for(let i of a.statement){let[p,l]=this.convertStatementToProperty(i);p&&l!==null&&l!==void 0&&(c[p]=l),this.collectImportsFromStatement(i,e,n)}o.body[a.name]=c}return o}convertStatementToProperty(e){if(e instanceof $)return[e.predicate.subject.name,e.object];if(e instanceof x)return[e.predicate.subject.name,e.object];if(e instanceof A)return[e.predicate.subject.name,e.object];if(e instanceof E)return[e.predicate.subject.name,e.object.subject.name];if(e instanceof O){let t=this.convertKanonakListToValue(e.object);return[e.predicate.subject.name,t]}else if(e instanceof j){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 d?t.push(r.subject.name):r instanceof R&&t.push(this.convertEmbeddedKanonakToValue(r));return t}convertEmbeddedKanonakToValue(e){let t={};for(let r of e.statement){let[o,n]=this.convertStatementToProperty(r);o&&n!==null&&n!==void 0&&(t[o]=n)}return t}collectImportsFromStatement(e,t,r){}};function U(s){return`${s.publisher}/${s.package_}/${s.name}`}function g(s,e,t){return`${s}/${e}/${t}`}function H(s){return`${s.s}|${s.p}|${G(s.o)}`}function G(s){switch(s.kind){case"uri":return`u:${s.key}`;case"literal":return`l:${s.datatype}:${s.lexical}`;case"blank":return`b:${s.id}`}}function y(s,e,t){return{s,p:e,o:{kind:"uri",key:t}}}var D=class{all=new Set;byPIdx=new Map;bySPIdx=new Map;byPOIdx=new Map;tripleList=[];add(e){let t=H(e);return this.all.has(t)?!1:(this.all.add(t),this.tripleList.push(e),J(this.byPIdx,e.p,e),J(this.bySPIdx,`${e.s}|${e.p}`,e),e.o.kind==="uri"&&J(this.byPOIdx,`${e.p}|${e.o.key}`,e),!0)}has(e){return this.all.has(H(e))}size(){return this.tripleList.length}snapshot(){return this.tripleList.slice()}byPredicate(e){let t=this.byPIdx.get(e);return t?t.slice():[]}bySubjectPredicate(e,t){let r=this.bySPIdx.get(`${e}|${t}`);return r?r.slice():[]}byPredicateObject(e,t){let r=this.byPOIdx.get(`${e}|${t}`);return r?r.slice():[]}subjectsWithPredicateObject(e,t){let r=this.byPOIdx.get(`${e}|${t}`);if(!r)return[];let o=new Set;for(let n of r)o.add(n.s);return Array.from(o)}uriObjectsOf(e,t){let r=this.bySPIdx.get(`${e}|${t}`);if(!r)return[];let o=new Set;for(let n of r)n.o.kind==="uri"&&o.add(n.o.key);return Array.from(o)}hasUri(e,t,r){return this.all.has(`${e}|${t}|u:${r}`)}hasTriple(e,t,r){return this.all.has(`${e}|${t}|${G(r)}`)}};function J(s,e,t){let r=s.get(e);r?r.push(t):s.set(e,[t])}var _=class{type=g("kanonak.org","core-rdf","type");subClassOf=g("kanonak.org","core-rdf","subClassOf");subPropertyOf=g("kanonak.org","core-rdf","subPropertyOf");domain=g("kanonak.org","core-rdf","domain");range=g("kanonak.org","core-rdf","range");equivalentClass=g("kanonak.org","core-owl","equivalentClass");equivalentProperty=g("kanonak.org","core-owl","equivalentProperty");inverseOf=g("kanonak.org","core-owl","inverseOf");sameAs=g("kanonak.org","core-owl","sameAs");transitiveProperty=g("kanonak.org","core-owl","TransitiveProperty");symmetricProperty=g("kanonak.org","core-owl","SymmetricProperty")};var ae={name:"rdfs2",apply(s,e){let t=!1;for(let r of s.byPredicate(e.domain)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;for(let a of s.byPredicate(o))s.add(y(a.s,e.type,n))&&(t=!0)}return t}},se={name:"rdfs3",apply(s,e){let t=!1;for(let r of s.byPredicate(e.range)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;for(let a of s.byPredicate(o))a.o.kind==="uri"&&s.add(y(a.o.key,e.type,n))&&(t=!0)}return t}},ie={name:"rdfs5",apply(s,e){let t=!1;for(let r of s.byPredicate(e.subPropertyOf)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;for(let a of s.bySubjectPredicate(n,e.subPropertyOf))a.o.kind==="uri"&&s.add(y(o,e.subPropertyOf,a.o.key))&&(t=!0)}return t}},ce={name:"rdfs7",apply(s,e){let t=!1;for(let r of s.byPredicate(e.subPropertyOf)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n)for(let a of s.byPredicate(o)){let c={s:a.s,p:n,o:a.o};s.add(c)&&(t=!0)}}return t}},pe={name:"rdfs9",apply(s,e){let t=!1;for(let r of s.byPredicate(e.subClassOf)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n)for(let a of s.byPredicateObject(e.type,o))s.add(y(a.s,e.type,n))&&(t=!0)}return t}},le={name:"rdfs11",apply(s,e){let t=!1;for(let r of s.byPredicate(e.subClassOf)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;for(let a of s.bySubjectPredicate(n,e.subClassOf))a.o.kind==="uri"&&s.add(y(o,e.subClassOf,a.o.key))&&(t=!0)}return t}},X=[ae,se,ie,ce,pe,le];var ue={name:"prp-trp",apply(s,e){let t=!1,r=s.subjectsWithPredicateObject(e.type,e.transitiveProperty);for(let o of r){let n=s.byPredicate(o);for(let a of n){if(a.o.kind!=="uri")continue;let c=a.o.key;for(let i of s.bySubjectPredicate(c,o))i.o.kind==="uri"&&a.s!==i.o.key&&s.add(y(a.s,o,i.o.key))&&(t=!0)}}return t}},fe={name:"prp-symp",apply(s,e){let t=!1,r=s.subjectsWithPredicateObject(e.type,e.symmetricProperty);for(let o of r)for(let n of s.byPredicate(o))n.o.kind==="uri"&&s.add(y(n.o.key,o,n.s))&&(t=!0);return t}},me={name:"prp-inv1",apply(s,e){let t=!1;for(let r of s.byPredicate(e.inverseOf)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;for(let a of s.byPredicate(o))a.o.kind==="uri"&&s.add(y(a.o.key,n,a.s))&&(t=!0)}return t}},de={name:"prp-inv2",apply(s,e){let t=!1;for(let r of s.byPredicate(e.inverseOf)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;for(let a of s.byPredicate(n))a.o.kind==="uri"&&s.add(y(a.o.key,o,a.s))&&(t=!0)}return t}},ye={name:"prp-eqp1",apply(s,e){let t=!1;for(let r of s.byPredicate(e.equivalentProperty)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n)for(let a of s.byPredicate(o))s.add({s:a.s,p:n,o:a.o})&&(t=!0)}return t}},ge={name:"prp-eqp2",apply(s,e){let t=!1;for(let r of s.byPredicate(e.equivalentProperty)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n)for(let a of s.byPredicate(n))s.add({s:a.s,p:o,o:a.o})&&(t=!0)}return t}},be={name:"cax-eqc1",apply(s,e){let t=!1;for(let r of s.byPredicate(e.equivalentClass)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n)for(let a of s.byPredicateObject(e.type,o))s.add(y(a.s,e.type,n))&&(t=!0)}return t}},ke={name:"cax-eqc2",apply(s,e){let t=!1;for(let r of s.byPredicate(e.equivalentClass)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n)for(let a of s.byPredicateObject(e.type,n))s.add(y(a.s,e.type,o))&&(t=!0)}return t}},he={name:"eq-rep-s",apply(s,e){let t=!1;for(let r of s.byPredicate(e.sameAs)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n){for(let a of s.snapshot())a.s===o&&s.add({s:n,p:a.p,o:a.o})&&(t=!0);for(let a of s.snapshot())a.s===n&&s.add({s:o,p:a.p,o:a.o})&&(t=!0)}}return t}},Ke={name:"eq-rep-o",apply(s,e){let t=!1;for(let r of s.byPredicate(e.sameAs)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n)for(let a of s.snapshot())a.o.kind==="uri"&&(a.o.key===o?s.add(y(a.s,a.p,n))&&(t=!0):a.o.key===n&&s.add(y(a.s,a.p,o))&&(t=!0))}return t}},Y=[ue,fe,me,de,ye,ge,be,ke,he,Ke];var L=class{constructor(e,t){this.store=e;this.vocabulary=t}store;vocabulary;getInstancesOfClass(e){let t=T(e);return this.store.subjectsWithPredicateObject(this.vocabulary.type,t)}getSubclasses(e){let t=T(e);return this.store.subjectsWithPredicateObject(this.vocabulary.subClassOf,t).filter(o=>o!==t)}getSuperclasses(e){let t=T(e);return this.store.uriObjectsOf(t,this.vocabulary.subClassOf).filter(r=>r!==t)}getTypesOfIndividual(e){return this.store.uriObjectsOf(T(e),this.vocabulary.type)}isInstanceOf(e,t){return this.store.hasUri(T(e),this.vocabulary.type,T(t))}triples(){return this.store.snapshot()}size(){return this.store.size()}};function T(s){return typeof s=="string"?s:g(s.publisher,s.package_,s.name)}var Q=class{vocabulary;profile;maxIterations;constructor(e={}){this.vocabulary=e.vocabulary??new _,this.profile=e.profile??"owl-rl-classification",this.maxIterations=e.maxIterations??100}async reason(e){let t=new D,o=await new W().parseKanonaks(e),n=new Z;for(let i of o)if(i instanceof v){let p=ve(i);if(!p)continue;for(let l of i.statement)this.emitStatement(p,l,t,n)}let a=[...X];this.profile==="owl-rl-classification"&&a.push(...Y);let c=0;for(;c<this.maxIterations;){let i=!1;for(let p of a)p.apply(t,this.vocabulary)&&(i=!0);if(!i)break;c++}return new L(t,this.vocabulary)}emitStatement(e,t,r,o){let n=Re(t);if(n){if(t instanceof $){r.add({s:e,p:n,o:{kind:"literal",lexical:t.object,datatype:"string"}});return}if(t instanceof x){r.add({s:e,p:n,o:{kind:"literal",lexical:String(t.object),datatype:"number"}});return}if(t instanceof A){r.add({s:e,p:n,o:{kind:"literal",lexical:String(t.object),datatype:"boolean"}});return}if(t instanceof E){let a=U(t.object.subject);r.add(y(e,n,a));return}if(t instanceof j){let a=o.next();r.add({s:e,p:n,o:{kind:"blank",id:a}}),this.emitEmbedded(a,t.object,r,o);return}if(t instanceof O){for(let a of t.object??[])this.emitListItem(e,n,a,r,o);return}}}emitListItem(e,t,r,o,n){if(r instanceof d)o.add(y(e,t,U(r.subject)));else if(r instanceof R){let a=n.next();o.add({s:e,p:t,o:{kind:"blank",id:a}}),this.emitEmbedded(a,r,o,n)}else if(r instanceof w){let a=typeof r.value=="number"?"number":typeof r.value=="boolean"?"boolean":"string";o.add({s:e,p:t,o:{kind:"literal",lexical:String(r.value),datatype:a}})}}emitEmbedded(e,t,r,o){let n=`_:${e}`;for(let a of t.statement)this.emitStatement(n,a,r,o)}},Z=class{counter=0;next(){return`b${this.counter++}`}};function ve(s){let e=s.namespace??"",t=e.indexOf("@"),r=t===-1?e:e.substring(0,t),o=r.indexOf("/");if(o===-1)return null;let n=r.substring(0,o),a=r.substring(o+1);return!n||!a||!s.name?null:g(n,a,s.name)}function Re(s){let e=s.predicate;return e?.subject?U(e.subject):null}export{_ as KanonakVocabulary,Y as OWL_RL_CLASSIFICATION_RULES,X as RDFS_RULES,Q as Reasoner,L as ReasoningResult,D as TripleStore,g as makeUriKey,H as tripleKey,U as uriKey,y as uriTriple};
|
|
1
|
+
var te=Object.defineProperty;var re=(s,e)=>()=>(s&&(e=s(s=0)),e);var ne=(s,e)=>{for(var t in e)te(s,t,{get:e[t],enumerable:!0})};var ee={};ne(ee,{KanonakUri:()=>P});function oe(s,e,t){return{major:s,minor:e,patch:t,toString:()=>`${s}.${e}.${t}`,equals:r=>!r||typeof r!="object"?!1:r.major===s&&r.minor===e&&r.patch===t,getHashCode:()=>s<<20|e<<10|t,compareTo:r=>s!==r.major?s-r.major:e!==r.minor?e-r.minor:t-r.patch}}var P,C=re(()=>{"use strict";P=class s{constructor(e,t,r,o){this.publisher=e;this.package_=t;this.name=r;this.version=o}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,o,n]=t;if(!r||!o||!n)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let a=o.indexOf("@");if(a===-1)return new s(r,o,n,void 0);let c=o.substring(0,a),i=o.substring(a+1);if(!c||!i)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let p=i.split(".").map(Number),l=oe(p[0]||0,p[1]||0,p[2]||0);return new s(r,c,n,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}`}}});var S=class{};var V=class extends S{statement=[]};var v=class extends V{namespace;name;icon};var R=class extends V{name};C();var d=class s extends S{subject;static parse(e){let t=new s;return t.subject=P.parse(e),t}};var w=class extends S{value};var k=class{predicate;object};var I=class extends k{};var $=class s extends I{static parse(e,t){let r=new s;return r.predicate=d.parse(e),r.object=t,r}};var x=class s extends I{static parse(e,t){let r=new s;return r.predicate=d.parse(e),r.object=t,r}};var A=class extends I{};var E=class s extends k{static parse(e,t){let r=new s;return r.predicate=d.parse(e),r.object=d.parse(t),r}};var j=class extends k{};var O=class extends k{};C();function B(s){if(Array.isArray(s))return s.map(t=>t?.toString()??"").filter(t=>t.length>0);let e=s?.toString();return e?[e]:[]}var M=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",o=this.cache.get(r);if(o){let a=o.get(e);if(a)return a}let n=await this.buildEntityIndexAsyncInternal(t,new Set,"");return this.cache.set(r,n),n.get(e)??null}async resolveAllEntitiesAsync(e,t){let r=await this.buildAllEntitiesIndexAsync(t,new Set,"");if(e.includes(".")){let o=e.split("."),n=o[0],a=o[1],c=await this.findDocumentForAlias(t,n);return c?await this.resolveAllEntitiesAsync(a,c):[]}return r.filter(o=>o.entityName===e)}async buildAllEntitiesIndexAsync(e,t,r){let o=[],n=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building ALL entities index for namespace: ${n}`),t.has(n))return this.logger?.debug?.(`Skipping ${n} - already visited (circular import prevention)`),o;t.add(n);let a=r.length===0?n:`${r} \u2192 ${n}`;for(let[c,i]of Object.entries(e.body))if(!c.includes(".")&&i&&typeof i=="object"&&!Array.isArray(i)){let p=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};o.push({entityName:c,uri:new P(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,c,p),entity:i,definedInNamespace:n,isImported:r.length>0,importPath:a})}if(this.logger?.debug?.(`Collected ${o.length} entities from ${n}`),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 ${n}`);for(let[i,p]of Object.entries(e.metadata.imports))for(let l of p)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 f=await this.buildAllEntitiesIndexAsync(u,t,a);o.push(...f),this.logger?.debug?.(`Added ${f.length} entities from import ${u.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${i}/${l.packageName}`)}catch(u){let f=u;throw this.logger?.error?.(`Failed to process import ${i}/${l.packageName} for namespace ${n}. Error: ${f.message}`,f),new Error(`Failed to process import ${i}/${l.packageName} for namespace ${n}. See inner exception for details.`,{cause:u})}}return o}async buildEntityIndexAsync(e){return await this.buildEntityIndexAsyncInternal(e,new Set,"")}async buildEntityIndexAsyncInternal(e,t,r){let o=new Map,n=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building entity index for namespace: ${n}`),t.has(n))return this.logger?.debug?.(`Skipping ${n} - already visited (circular import prevention)`),o;t.add(n);let a=r.length===0?n:`${r} \u2192 ${n}`,c=0;for(let[i,p]of Object.entries(e.body))if(!i.includes(".")&&p&&typeof p=="object"&&!Array.isArray(p)&&!o.has(i)){let l=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};o.set(i,{entityName:i,uri:new P(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,i,l),entity:p,definedInNamespace:n,isImported:r.length>0,importPath:a}),c++}if(this.logger?.debug?.(`Indexed ${c} entities from ${n}`),e.metadata?.imports){let i=Object.values(e.metadata.imports).reduce((p,l)=>p+l.length,0);this.logger?.debug?.(`Processing ${i} import(s) for ${n}`);for(let[p,l]of Object.entries(e.metadata.imports))for(let u of l)try{this.logger?.debug?.(`Resolving import: ${p}/${u.packageName}`);let f=await this.repository.getHighestCompatibleVersionAsync(p,u);if(f){this.logger?.debug?.(`Successfully loaded import: ${f.metadata?.namespace_?.toString()}`);let m=await this.buildEntityIndexAsyncInternal(f,t,a),b=0;for(let[h,K]of m.entries())if(o.has(h)||(o.set(h,K),b++),u.alias&&!h.includes(".")){let z=`${u.alias}.${h}`;o.has(z)||(o.set(z,K),b++)}this.logger?.debug?.(`Merged ${b} entities from import ${f.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${p}/${u.packageName}`)}catch(f){let m=f;throw this.logger?.error?.(`Failed to process import ${p}/${u.packageName} for namespace ${n}. Error: ${m.message}`,m),new Error(`Failed to process import ${p}/${u.packageName} for namespace ${n}. See inner exception for details.`,{cause:f})}}return o}async findDocumentForAlias(e,t){if(!e.metadata?.imports)return null;for(let[r,o]of Object.entries(e.metadata.imports))for(let n of o){if(n.alias===t)return await this.repository.getHighestCompatibleVersionAsync(r,n);if(!n.alias&&n.packageName===t)return await this.repository.getHighestCompatibleVersionAsync(r,n)}return null}clearCache(){this.cache.clear()}clearCacheForDocument(e){this.cache.delete(e)}async isSubclassOfAsync(e,t,r){if(e===t)return!0;let o=new Set;return await this.isSubclassOfRecursiveAsync(e,t,r,o)}async isSubclassOfRecursiveAsync(e,t,r,o){if(o.has(e))return!1;o.add(e);let n=await this.resolveEntityAsync(e,r);if(!n?.entity)return!1;let a=n.entity.subClassOf;if(a){let c=B(a);for(let i of c)if(i===t||await this.isSubclassOfRecursiveAsync(i,t,r,o))return!0}return!1}async isSubpropertyOfAsync(e,t,r){if(e===t)return!0;let o=new Set;return await this.isSubpropertyOfRecursiveAsync(e,t,r,o)}async isSubpropertyOfRecursiveAsync(e,t,r,o){if(o.has(e))return!1;o.add(e);let n=await this.resolveEntityAsync(e,r);if(!n?.entity)return!1;let a=n.entity.subPropertyOf;if(a){let c=B(a);for(let i of c)if(i===t||await this.isSubpropertyOfRecursiveAsync(i,t,r,o))return!0}return!1}};var N=class s{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"&&s.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 s.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 o=r.entity.type;if(o){let n=String(o);return n==="Class"||n==="rdfs.Class"||n.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))}};import*as F from"js-yaml";var q=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 o=F.load(e);if(!o||typeof o!="object")return r={metadata:this.createEmptyMetadata(),body:{},toString:()=>"KanonakDocument(empty)"},{document:r,errors:t,isValid:!0};let n=this.extractMetadata(o),a=this.extractBody(o,n);return r={metadata:n,body:a,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(o){let n=o,a={message:n.message||"Unknown parse error",line:n.mark?.line??0,column:n.mark?.column??0,errorType:n.name==="YAMLException"?"SyntaxError":"Unknown",toString:()=>`${n.name==="YAMLException"?"SyntaxError":"Unknown"} at line ${n.mark?.line??0}: ${n.message||"Unknown parse error"}`};return t.push(a),{document:void 0,errors:t,isValid:!1}}}save(e){let t={};if(e.metadata.namespace_){let r=e.metadata.namespace_,o={type:"Package",publisher:r.publisher};r.version&&(o.version=`${r.version.major}.${r.version.minor}.${r.version.patch}`),e.metadata.imports&&(o.imports=this.serializeImports(e.metadata.imports)),t[r.package_]=o}return Object.assign(t,e.body),F.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 o of Object.values(t))r.push(...o);return r},enumerable:!0,configurable:!0}),e}createVersion(e,t,r){return{major:e,minor:t,patch:r,toString:()=>`${e}.${t}.${r}`,equals:n=>!n||typeof n!="object"?!1:n.major===e&&n.minor===t&&n.patch===r,getHashCode:()=>e<<20|t<<10|r,compareTo:n=>e!==n.major?e-n.major:t!==n.minor?t-n.minor:r-n.patch}}extractMetadata(e){let t=this.createEmptyMetadata();for(let[r,o]of Object.entries(e))if(o&&typeof o=="object"&&o.type==="Package"){t.type_="Package";let n=r,a=o.publisher,c=o.version?this.parseVersion(o.version):void 0;return a&&n&&(t.namespace_={publisher:a,package_:n,version:c,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===a&&i.package_===n&&(!c||!i.version||c.equals(i.version)),getHashCode:()=>{let i=0;for(let p=0;p<a.length;p++)i=(i<<5)-i+a.charCodeAt(p);for(let p=0;p<n.length;p++)i=(i<<5)-i+n.charCodeAt(p);return i|0}}),o.imports&&Array.isArray(o.imports)&&(t.imports=this.parseImportsV3(o.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={},o;for(let[n,a]of Object.entries(e))if(a&&typeof a=="object"&&a.type==="Package"){o=n;break}for(let[n,a]of Object.entries(e))n!==o&&n!=="kanonak"&&n!=="namespace"&&n!=="imports"&&(r[n]=a);return r}parseNamespace(e){if(typeof e=="string"){let n=e.match(/^([^/]+)\/([^@]+)(?:@(.+))?$/);if(n){let a=n[3]?this.parseVersion(n[3]):this.createVersion(1,0,0);return{publisher:n[1],package_:n[2],version:a,toString:()=>e,equals:c=>!c||typeof c!="object"?!1:c.publisher===n[1]&&c.package_===n[2]&&(!a||!c.version||a.equals(c.version)),getHashCode:()=>{let c=0;for(let i=0;i<n[1].length;i++)c=(c<<5)-c+n[1].charCodeAt(i);for(let i=0;i<n[2].length;i++)c=(c<<5)-c+n[2].charCodeAt(i);return c|0}}}}let t=e.publisher||"",r=e.package||"",o=e.version?this.parseVersion(e.version):this.createVersion(1,0,0);return{publisher:t,package_:r,version:o,toString:function(){return`${this.publisher}/${this.package_}@${this.version?.major??1}.${this.version?.minor??0}.${this.version?.patch??0}`},equals:n=>!n||typeof n!="object"?!1:n.publisher===t&&n.package_===r&&(!o||!n.version||o.equals(n.version)),getHashCode:()=>{let n=0;for(let a=0;a<t.length;a++)n=(n<<5)-n+t.charCodeAt(a);for(let a=0;a<r.length;a++)n=(n<<5)-n+r.charCodeAt(a);return n|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 o=r.publisher;if(!o)throw new Error("PublisherImport requires 'publisher' property");t[o]||(t[o]=[]);for(let n of r.packages){if(!n||typeof n!="object")continue;let a=this.parseImportFromEmbeddedObject(n,o);t[o].push(a)}}else{let o=this.parseImportFromEmbeddedObject(r,r.publisher),n=o.publisher||"";t[n]||(t[n]=[]),t[n].push(o)}return t}parseImportsLegacy(e){let t={};for(let[r,o]of Object.entries(e))Array.isArray(o)&&(t[r]=o.map(n=>this.parseImport(n,r)));return t}parseImportFromEmbeddedObject(e,t){let r=e.package;if(!r)throw new Error("Import requires 'package' property");let o=e.match;if(!o)throw new Error("Import requires 'match' property");let n=e.version;if(!n)throw new Error("Import requires 'version' property");let a=this.parseVersion(n),c=this.parseVersionOperator(o),i=this.calculateMaxVersion(o,a),p=e.alias;return{package_:`${r} ${o} ${a.toString()}`,publisher:t,packageName:r,versionOperator:c,version:a,alias:p,minVersion:a,maxVersion:i,toEmbeddedObject:()=>{let l={package:r,match:o,version:a.toString()};return p&&(l.alias=p),l},toString:()=>p?`${r} ${o} ${a.toString()} as ${p}`:`${r} ${o} ${a.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],f=this.parseVersion(i[3].trim()),m=i[4].trim(),b=this.parseVersionOperator(u),h=this.calculateMaxVersion(u,f);return{package_:e,publisher:t,packageName:l,versionOperator:b,version:f,alias:m,minVersion:f,maxVersion:h,toEmbeddedObject:()=>{let K={package:l,match:u,version:f.toString()};return m&&(K.alias=m),K},toString:()=>`${l} ${u} ${f.toString()} as ${m}`}}let p=e.match(/^(.+?)\s*([~^=*])\s*(.+)$/);if(p){let l=p[1].trim(),u=p[2],f=this.parseVersion(p[3].trim()),m=this.parseVersionOperator(u),b=this.calculateMaxVersion(u,f);return{package_:e,publisher:t,packageName:l,versionOperator:m,version:f,alias:void 0,minVersion:f,maxVersion:b,toEmbeddedObject:()=>({package:l,match:u,version:f.toString()}),toString:()=>`${l} ${u} ${f.toString()}`}}}let r=this.parseVersionOperator(e.operator||"~"),o=this.parseVersion(e.version||"1.0.0"),n=e.packageName||e.package||"",a=["=","~","^","*"][r],c=this.calculateMaxVersion(e.operator||"~",o);return{package_:e.package||"",publisher:t,packageName:n,versionOperator:r,version:o,alias:e.alias,minVersion:o,maxVersion:c,toEmbeddedObject:()=>{let i={package:n,match:a,version:o.toString()};return e.alias&&(i.alias=e.alias),i},toString:()=>`${n} ${a} ${o.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,o]of Object.entries(e)){let n={publisher:r,packages:o.map(a=>{let c=["=","~","^","*"][a.versionOperator],i={package:a.packageName,match:c,version:`${a.version.major}.${a.version.minor}.${a.version.patch}`};return a.alias&&(i.alias=a.alias),i})};t.push(n)}return t}};var W=class{constructor(e){}async parseKanonaks(e){let t=[],r=await e.getAllDocumentsAsync(),o=new M(e),n=new N(o);for(let i of r){let p=i.metadata.namespace_?.toString()??"";for(let[l,u]of Object.entries(i.body)){let f=new v,m=this.resolveCanonicalEntity(l,i,p);f.namespace=m.namespace,f.name=m.name,f.statement=[];let b=await this.parseStatements(u,i,o,n,e);f.statement.push(...b),t.push(f)}}let a=new Map,c=[];for(let i of t)if(i instanceof v){let p=`${i.namespace}/${i.name}`,l=a.get(p);l?l.statement.push(...i.statement):(a.set(p,i),c.push(i))}else c.push(i);return c}resolveCanonicalEntity(e,t,r){if(!e.includes(".")||!t.metadata?.imports)return{namespace:r,name:e};let o=e.indexOf("."),n=e.substring(0,o),a=e.substring(o+1);for(let[c,i]of Object.entries(t.metadata.imports))for(let p of i)if((p.alias??p.packageName)===n){let u=p.version;return{namespace:`${c}/${p.packageName}@${u.major}.${u.minor}.${u.patch}`,name:a}}return{namespace:r,name:e}}async parseStatements(e,t,r,o,n){let a=[];if(typeof e!="object"||e===null||Array.isArray(e))return a;for(let[c,i]of Object.entries(e))try{let p=await this.getPropertyMetadata(c,t,r,n,o);if(!p)continue;let l=await this.parsePropertyValue(c,i,p,t,r,o);l&&a.push(l)}catch(p){console.error(`Error parsing property ${c}:`,p)}return a}async getPropertyMetadata(e,t,r,o,n){let a=await r.resolveEntityAsync(e,t);if(!a)return;let c=a.entity,i=c.type?.toString()??"",p=i.includes(".")?i.substring(i.lastIndexOf(".")+1):i;if(!new Set(["Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]).has(p))return;let u=n.getPropertyTypeClassification(i),f=c.range?.toString(),m;if(u==="ObjectProperty")m="ObjectProperty";else if(u==="DatatypeProperty")m="DatatypeProperty";else{let h=f&&f.includes(".")?f.substring(f.lastIndexOf(".")+1):f??"";(f?n.isKnownXsdDatatypeName(f):!1)||h==="Literal"?m="DatatypeProperty":m="ObjectProperty"}return{propertyUri:a.uri.toString(),propertyType:m,range:f,isImported:a.isImported,definedInNamespace:a.definedInNamespace}}async parsePropertyValue(e,t,r,o,n,a){let c=r.propertyUri;if(t!=null){if(Array.isArray(t))return this.parseListValue(c,t,r,o,n,a);if(r.propertyType==="DatatypeProperty")return this.parseDatatypeValue(c,t,r);if(r.propertyType==="ObjectProperty")return this.parseObjectValue(c,t,r,o,n,a)}}parseDatatypeValue(e,t,r){if(t instanceof Date)return $.parse(e,t.toISOString());if(typeof t=="string")return $.parse(e,t);if(typeof t=="number")return x.parse(e,t);if(typeof t=="boolean"){let o=new A;return o.predicate=d.parse(e),o.object=t,o}}async parseObjectValue(e,t,r,o,n,a){if(typeof t=="string"){let c=await this.resolveReference(t,o,n);if(!c)return;let i=new E;return i.predicate=d.parse(e),i.object=c,i}if(typeof t=="object"&&!Array.isArray(t)){let c=new R;if(c.statement=await this.parseStatements(t,o,n,a,{}),c.statement.length>0){let l=new j;return l.predicate=d.parse(e),l.object=c,l}let i=[];for(let[l,u]of Object.entries(t))if(typeof u=="object"&&u!==null&&!Array.isArray(u)){let f=new R;f.name=l,f.statement=await this.parseStatements(u,o,n,a,{}),i.push(f)}else if(typeof u=="string"){let f=await this.resolveReference(u,o,n);f&&i.push(f)}if(i.length>0){let l=new O;return l.predicate=d.parse(e),l.object=i,l}let p=new j;return p.predicate=d.parse(e),p.object=c,p}}async parseListValue(e,t,r,o,n,a){let c=[],i=r.propertyType==="DatatypeProperty";for(let l of t){if(i&&(typeof l=="string"||typeof l=="number"||typeof l=="boolean")){let u=new w;u.value=l,c.push(u);continue}if(i&&l instanceof Date){let u=new w;u.value=l.toISOString(),c.push(u);continue}if(typeof l=="string"){let u=await this.resolveReference(l,o,n);u&&c.push(u)}else if(typeof l=="object"&&l!==null&&!Array.isArray(l)){let u=new R;u.statement=await this.parseStatements(l,o,n,a,{}),c.push(u)}}let p=new O;return p.predicate=d.parse(e),p.object=c,p}async resolveReference(e,t,r){let o=await r.resolveEntityAsync(e,t);if(o){let a=new d;return a.subject=o.uri,a}let n=t.metadata?.namespace_;if(n){let{KanonakUri:a}=await Promise.resolve().then(()=>(C(),ee)),c=n.version??{major:0,minor:0,patch:0,toString:()=>"0.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};if(e.includes(".")){let p=e.indexOf("."),l=e.substring(0,p),u=e.substring(p+1);if(t.metadata?.imports){for(let[f,m]of Object.entries(t.metadata.imports))for(let b of m)if((b.alias??b.packageName)===l){let K=new d;return K.subject=new a(f,b.packageName,u,b.version),K}}}let i=new d;return i.subject=new a(n.publisher,n.package_,e,c),i}return null}async saveKanonaks(e,t){let r=new Map;for(let o of e)o instanceof v&&o.namespace&&(r.has(o.namespace)||r.set(o.namespace,[]),r.get(o.namespace).push(o));for(let[o,n]of r){let a=await this.convertKanonaksToDocument(o,n),c=`${o.split("@")[0]}.yml`;await t.saveDocumentAsync(a,c)}}async serializeToYaml(e,t){let r=e.filter(a=>a instanceof v&&a.namespace===t);if(r.length===0)throw new Error(`No kanonaks found with namespace '${t}'`);let o=await this.convertKanonaksToDocument(t,r);return new q().save(o)}async convertKanonaksToDocument(e,t){let o={metadata:{namespace_:e,get allImports(){if(!this.imports)return[];let a=[];for(let c of Object.values(this.imports))a.push(...c);return a}},body:{}},n=new Map;for(let a of t){let c={};for(let i of a.statement){let[p,l]=this.convertStatementToProperty(i);p&&l!==null&&l!==void 0&&(c[p]=l),this.collectImportsFromStatement(i,e,n)}o.body[a.name]=c}return o}convertStatementToProperty(e){if(e instanceof $)return[e.predicate.subject.name,e.object];if(e instanceof x)return[e.predicate.subject.name,e.object];if(e instanceof A)return[e.predicate.subject.name,e.object];if(e instanceof E)return[e.predicate.subject.name,e.object.subject.name];if(e instanceof O){let t=this.convertKanonakListToValue(e.object);return[e.predicate.subject.name,t]}else if(e instanceof j){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 d?t.push(r.subject.name):r instanceof R&&t.push(this.convertEmbeddedKanonakToValue(r));return t}convertEmbeddedKanonakToValue(e){let t={};for(let r of e.statement){let[o,n]=this.convertStatementToProperty(r);o&&n!==null&&n!==void 0&&(t[o]=n)}return t}collectImportsFromStatement(e,t,r){}};function U(s){return`${s.publisher}/${s.package_}/${s.name}`}function g(s,e,t){return`${s}/${e}/${t}`}function H(s){return`${s.s}|${s.p}|${G(s.o)}`}function G(s){switch(s.kind){case"uri":return`u:${s.key}`;case"literal":return`l:${s.datatype}:${s.lexical}`;case"blank":return`b:${s.id}`}}function y(s,e,t){return{s,p:e,o:{kind:"uri",key:t}}}var D=class{all=new Set;byPIdx=new Map;bySPIdx=new Map;byPOIdx=new Map;tripleList=[];add(e){let t=H(e);return this.all.has(t)?!1:(this.all.add(t),this.tripleList.push(e),J(this.byPIdx,e.p,e),J(this.bySPIdx,`${e.s}|${e.p}`,e),e.o.kind==="uri"&&J(this.byPOIdx,`${e.p}|${e.o.key}`,e),!0)}has(e){return this.all.has(H(e))}size(){return this.tripleList.length}snapshot(){return this.tripleList.slice()}byPredicate(e){let t=this.byPIdx.get(e);return t?t.slice():[]}bySubjectPredicate(e,t){let r=this.bySPIdx.get(`${e}|${t}`);return r?r.slice():[]}byPredicateObject(e,t){let r=this.byPOIdx.get(`${e}|${t}`);return r?r.slice():[]}subjectsWithPredicateObject(e,t){let r=this.byPOIdx.get(`${e}|${t}`);if(!r)return[];let o=new Set;for(let n of r)o.add(n.s);return Array.from(o)}uriObjectsOf(e,t){let r=this.bySPIdx.get(`${e}|${t}`);if(!r)return[];let o=new Set;for(let n of r)n.o.kind==="uri"&&o.add(n.o.key);return Array.from(o)}hasUri(e,t,r){return this.all.has(`${e}|${t}|u:${r}`)}hasTriple(e,t,r){return this.all.has(`${e}|${t}|${G(r)}`)}};function J(s,e,t){let r=s.get(e);r?r.push(t):s.set(e,[t])}var _=class{type=g("kanonak.org","core-rdf","type");subClassOf=g("kanonak.org","core-rdf","subClassOf");subPropertyOf=g("kanonak.org","core-rdf","subPropertyOf");domain=g("kanonak.org","core-rdf","domain");range=g("kanonak.org","core-rdf","range");equivalentClass=g("kanonak.org","core-owl","equivalentClass");equivalentProperty=g("kanonak.org","core-owl","equivalentProperty");inverseOf=g("kanonak.org","core-owl","inverseOf");sameAs=g("kanonak.org","core-owl","sameAs");transitiveProperty=g("kanonak.org","core-owl","TransitiveProperty");symmetricProperty=g("kanonak.org","core-owl","SymmetricProperty")};var ae={name:"rdfs2",apply(s,e){let t=!1;for(let r of s.byPredicate(e.domain)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;for(let a of s.byPredicate(o))s.add(y(a.s,e.type,n))&&(t=!0)}return t}},se={name:"rdfs3",apply(s,e){let t=!1;for(let r of s.byPredicate(e.range)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;for(let a of s.byPredicate(o))a.o.kind==="uri"&&s.add(y(a.o.key,e.type,n))&&(t=!0)}return t}},ie={name:"rdfs5",apply(s,e){let t=!1;for(let r of s.byPredicate(e.subPropertyOf)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;for(let a of s.bySubjectPredicate(n,e.subPropertyOf))a.o.kind==="uri"&&s.add(y(o,e.subPropertyOf,a.o.key))&&(t=!0)}return t}},ce={name:"rdfs7",apply(s,e){let t=!1;for(let r of s.byPredicate(e.subPropertyOf)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n)for(let a of s.byPredicate(o)){let c={s:a.s,p:n,o:a.o};s.add(c)&&(t=!0)}}return t}},pe={name:"rdfs9",apply(s,e){let t=!1;for(let r of s.byPredicate(e.subClassOf)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n)for(let a of s.byPredicateObject(e.type,o))s.add(y(a.s,e.type,n))&&(t=!0)}return t}},le={name:"rdfs11",apply(s,e){let t=!1;for(let r of s.byPredicate(e.subClassOf)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;for(let a of s.bySubjectPredicate(n,e.subClassOf))a.o.kind==="uri"&&s.add(y(o,e.subClassOf,a.o.key))&&(t=!0)}return t}},X=[ae,se,ie,ce,pe,le];var ue={name:"prp-trp",apply(s,e){let t=!1,r=s.subjectsWithPredicateObject(e.type,e.transitiveProperty);for(let o of r){let n=s.byPredicate(o);for(let a of n){if(a.o.kind!=="uri")continue;let c=a.o.key;for(let i of s.bySubjectPredicate(c,o))i.o.kind==="uri"&&a.s!==i.o.key&&s.add(y(a.s,o,i.o.key))&&(t=!0)}}return t}},fe={name:"prp-symp",apply(s,e){let t=!1,r=s.subjectsWithPredicateObject(e.type,e.symmetricProperty);for(let o of r)for(let n of s.byPredicate(o))n.o.kind==="uri"&&s.add(y(n.o.key,o,n.s))&&(t=!0);return t}},me={name:"prp-inv1",apply(s,e){let t=!1;for(let r of s.byPredicate(e.inverseOf)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;for(let a of s.byPredicate(o))a.o.kind==="uri"&&s.add(y(a.o.key,n,a.s))&&(t=!0)}return t}},de={name:"prp-inv2",apply(s,e){let t=!1;for(let r of s.byPredicate(e.inverseOf)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;for(let a of s.byPredicate(n))a.o.kind==="uri"&&s.add(y(a.o.key,o,a.s))&&(t=!0)}return t}},ye={name:"prp-eqp1",apply(s,e){let t=!1;for(let r of s.byPredicate(e.equivalentProperty)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n)for(let a of s.byPredicate(o))s.add({s:a.s,p:n,o:a.o})&&(t=!0)}return t}},ge={name:"prp-eqp2",apply(s,e){let t=!1;for(let r of s.byPredicate(e.equivalentProperty)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n)for(let a of s.byPredicate(n))s.add({s:a.s,p:o,o:a.o})&&(t=!0)}return t}},be={name:"cax-eqc1",apply(s,e){let t=!1;for(let r of s.byPredicate(e.equivalentClass)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n)for(let a of s.byPredicateObject(e.type,o))s.add(y(a.s,e.type,n))&&(t=!0)}return t}},ke={name:"cax-eqc2",apply(s,e){let t=!1;for(let r of s.byPredicate(e.equivalentClass)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n)for(let a of s.byPredicateObject(e.type,n))s.add(y(a.s,e.type,o))&&(t=!0)}return t}},he={name:"eq-rep-s",apply(s,e){let t=!1;for(let r of s.byPredicate(e.sameAs)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n){for(let a of s.snapshot())a.s===o&&s.add({s:n,p:a.p,o:a.o})&&(t=!0);for(let a of s.snapshot())a.s===n&&s.add({s:o,p:a.p,o:a.o})&&(t=!0)}}return t}},Ke={name:"eq-rep-o",apply(s,e){let t=!1;for(let r of s.byPredicate(e.sameAs)){if(r.o.kind!=="uri")continue;let o=r.s,n=r.o.key;if(o!==n)for(let a of s.snapshot())a.o.kind==="uri"&&(a.o.key===o?s.add(y(a.s,a.p,n))&&(t=!0):a.o.key===n&&s.add(y(a.s,a.p,o))&&(t=!0))}return t}},Y=[ue,fe,me,de,ye,ge,be,ke,he,Ke];var L=class{constructor(e,t){this.store=e;this.vocabulary=t}store;vocabulary;getInstancesOfClass(e){let t=T(e);return this.store.subjectsWithPredicateObject(this.vocabulary.type,t)}getSubclasses(e){let t=T(e);return this.store.subjectsWithPredicateObject(this.vocabulary.subClassOf,t).filter(o=>o!==t)}getSuperclasses(e){let t=T(e);return this.store.uriObjectsOf(t,this.vocabulary.subClassOf).filter(r=>r!==t)}getTypesOfIndividual(e){return this.store.uriObjectsOf(T(e),this.vocabulary.type)}isInstanceOf(e,t){return this.store.hasUri(T(e),this.vocabulary.type,T(t))}triples(){return this.store.snapshot()}size(){return this.store.size()}};function T(s){return typeof s=="string"?s:g(s.publisher,s.package_,s.name)}var Q=class{vocabulary;profile;maxIterations;constructor(e={}){this.vocabulary=e.vocabulary??new _,this.profile=e.profile??"owl-rl-classification",this.maxIterations=e.maxIterations??100}async reason(e){let t=new D,o=await new W().parseKanonaks(e),n=new Z;for(let i of o)if(i instanceof v){let p=ve(i);if(!p)continue;for(let l of i.statement)this.emitStatement(p,l,t,n)}let a=[...X];this.profile==="owl-rl-classification"&&a.push(...Y);let c=0;for(;c<this.maxIterations;){let i=!1;for(let p of a)p.apply(t,this.vocabulary)&&(i=!0);if(!i)break;c++}return new L(t,this.vocabulary)}emitStatement(e,t,r,o){let n=Re(t);if(n){if(t instanceof $){r.add({s:e,p:n,o:{kind:"literal",lexical:t.object,datatype:"string"}});return}if(t instanceof x){r.add({s:e,p:n,o:{kind:"literal",lexical:String(t.object),datatype:"number"}});return}if(t instanceof A){r.add({s:e,p:n,o:{kind:"literal",lexical:String(t.object),datatype:"boolean"}});return}if(t instanceof E){let a=U(t.object.subject);r.add(y(e,n,a));return}if(t instanceof j){let a=o.next();r.add({s:e,p:n,o:{kind:"blank",id:a}}),this.emitEmbedded(a,t.object,r,o);return}if(t instanceof O){for(let a of t.object??[])this.emitListItem(e,n,a,r,o);return}}}emitListItem(e,t,r,o,n){if(r instanceof d)o.add(y(e,t,U(r.subject)));else if(r instanceof R){let a=n.next();o.add({s:e,p:t,o:{kind:"blank",id:a}}),this.emitEmbedded(a,r,o,n)}else if(r instanceof w){let a=typeof r.value=="number"?"number":typeof r.value=="boolean"?"boolean":"string";o.add({s:e,p:t,o:{kind:"literal",lexical:String(r.value),datatype:a}})}}emitEmbedded(e,t,r,o){let n=`_:${e}`;for(let a of t.statement)this.emitStatement(n,a,r,o)}},Z=class{counter=0;next(){return`b${this.counter++}`}};function ve(s){let e=s.namespace??"",t=e.indexOf("@"),r=t===-1?e:e.substring(0,t),o=r.indexOf("/");if(o===-1)return null;let n=r.substring(0,o),a=r.substring(o+1);return!n||!a||!s.name?null:g(n,a,s.name)}function Re(s){let e=s.predicate;return e?.subject?U(e.subject):null}export{_ as KanonakVocabulary,Y as OWL_RL_CLASSIFICATION_RULES,X as RDFS_RULES,Q as Reasoner,L as ReasoningResult,D as TripleStore,g as makeUriKey,H as tripleKey,U as uriKey,y as uriTriple};
|
package/dist/resolution/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var g=class t{constructor(e,r,n,s){this.publisher=e;this.package_=r;this.name=n;this.version=s}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 r=e.split("/");if(r.length!==3)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let[n,s,o]=r;if(!n||!s||!o)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let a=s.indexOf("@");if(a===-1)return new t(n,s,o,void 0);let c=s.substring(0,a),i=s.substring(a+1);if(!c||!i)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let u=i.split(".").map(Number),p=D(u[0]||0,u[1]||0,u[2]||0);return new t(n,c,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}`}};function D(t,e,r){return{major:t,minor:e,patch:r,toString:()=>`${t}.${e}.${r}`,equals:n=>!n||typeof n!="object"?!1:n.major===t&&n.minor===e&&n.patch===r,getHashCode:()=>t<<20|e<<10|r,compareTo:n=>t!==n.major?t-n.major:e!==n.minor?e-n.minor:r-n.patch}}function b(t){if(Array.isArray(t))return t.map(r=>r?.toString()??"").filter(r=>r.length>0);let e=t?.toString();return e?[e]:[]}var k=class{cache=new Map;repository;logger;constructor(e,r){this.repository=e,this.logger=r}async resolveEntityAsync(e,r){let n=r.metadata?.namespace_?.toString()??"unknown",s=this.cache.get(n);if(s){let a=s.get(e);if(a)return a}let o=await this.buildEntityIndexAsyncInternal(r,new Set,"");return this.cache.set(n,o),o.get(e)??null}async resolveAllEntitiesAsync(e,r){let n=await this.buildAllEntitiesIndexAsync(r,new Set,"");if(e.includes(".")){let s=e.split("."),o=s[0],a=s[1],c=await this.findDocumentForAlias(r,o);return c?await this.resolveAllEntitiesAsync(a,c):[]}return n.filter(s=>s.entityName===e)}async buildAllEntitiesIndexAsync(e,r,n){let s=[],o=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building ALL entities index for namespace: ${o}`),r.has(o))return this.logger?.debug?.(`Skipping ${o} - already visited (circular import prevention)`),s;r.add(o);let a=n.length===0?o:`${n} \u2192 ${o}`;for(let[c,i]of Object.entries(e.body))if(i&&typeof i=="object"&&!Array.isArray(i)){let u=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};s.push({entityName:c,uri:new g(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,c,u),entity:i,definedInNamespace:o,isImported:n.length>0,importPath:a})}if(this.logger?.debug?.(`Collected ${s.length} entities from ${o}`),e.metadata?.imports){let c=Object.values(e.metadata.imports).reduce((i,u)=>i+u.length,0);this.logger?.debug?.(`Processing ${c} import(s) for ${o}`);for(let[i,u]of Object.entries(e.metadata.imports))for(let p of u)try{this.logger?.debug?.(`Resolving import: ${i}/${p.packageName}`);let l=await this.repository.getHighestCompatibleVersionAsync(i,p);if(l){this.logger?.debug?.(`Successfully loaded import: ${l.metadata?.namespace_?.toString()}`);let m=await this.buildAllEntitiesIndexAsync(l,r,a);s.push(...m),this.logger?.debug?.(`Added ${m.length} entities from import ${l.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${i}/${p.packageName}`)}catch(l){let m=l;throw this.logger?.error?.(`Failed to process import ${i}/${p.packageName} for namespace ${o}. Error: ${m.message}`,m),new Error(`Failed to process import ${i}/${p.packageName} for namespace ${o}. See inner exception for details.`,{cause:l})}}return s}async buildEntityIndexAsync(e){return await this.buildEntityIndexAsyncInternal(e,new Set,"")}async buildEntityIndexAsyncInternal(e,r,n){let s=new Map,o=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building entity index for namespace: ${o}`),r.has(o))return this.logger?.debug?.(`Skipping ${o} - already visited (circular import prevention)`),s;r.add(o);let a=n.length===0?o:`${n} \u2192 ${o}`,c=0;for(let[i,u]of Object.entries(e.body))if(u&&typeof u=="object"&&!Array.isArray(u)&&!s.has(i)){let p=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};s.set(i,{entityName:i,uri:new g(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,i,p),entity:u,definedInNamespace:o,isImported:n.length>0,importPath:a}),c++}if(this.logger?.debug?.(`Indexed ${c} entities from ${o}`),e.metadata?.imports){let i=Object.values(e.metadata.imports).reduce((u,p)=>u+p.length,0);this.logger?.debug?.(`Processing ${i} import(s) for ${o}`);for(let[u,p]of Object.entries(e.metadata.imports))for(let l of p)try{this.logger?.debug?.(`Resolving import: ${u}/${l.packageName}`);let m=await this.repository.getHighestCompatibleVersionAsync(u,l);if(m){this.logger?.debug?.(`Successfully loaded import: ${m.metadata?.namespace_?.toString()}`);let d=await this.buildEntityIndexAsyncInternal(m,r,a),h=0;for(let[y,$]of d.entries())if(s.has(y)||(s.set(y,$),h++),l.alias&&!y.includes(".")){let x=`${l.alias}.${y}`;s.has(x)||(s.set(x,$),h++)}this.logger?.debug?.(`Merged ${h} entities from import ${m.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${u}/${l.packageName}`)}catch(m){let d=m;throw this.logger?.error?.(`Failed to process import ${u}/${l.packageName} for namespace ${o}. Error: ${d.message}`,d),new Error(`Failed to process import ${u}/${l.packageName} for namespace ${o}. See inner exception for details.`,{cause:m})}}return s}async findDocumentForAlias(e,r){if(!e.metadata?.imports)return null;for(let[n,s]of Object.entries(e.metadata.imports))for(let o of s){if(o.alias===r)return await this.repository.getHighestCompatibleVersionAsync(n,o);if(!o.alias&&o.packageName===r)return await this.repository.getHighestCompatibleVersionAsync(n,o)}return null}clearCache(){this.cache.clear()}clearCacheForDocument(e){this.cache.delete(e)}async isSubclassOfAsync(e,r,n){if(e===r)return!0;let s=new Set;return await this.isSubclassOfRecursiveAsync(e,r,n,s)}async isSubclassOfRecursiveAsync(e,r,n,s){if(s.has(e))return!1;s.add(e);let o=await this.resolveEntityAsync(e,n);if(!o?.entity)return!1;let a=o.entity.subClassOf;if(a){let c=b(a);for(let i of c)if(i===r||await this.isSubclassOfRecursiveAsync(i,r,n,s))return!0}return!1}async isSubpropertyOfAsync(e,r,n){if(e===r)return!0;let s=new Set;return await this.isSubpropertyOfRecursiveAsync(e,r,n,s)}async isSubpropertyOfRecursiveAsync(e,r,n,s){if(s.has(e))return!1;s.add(e);let o=await this.resolveEntityAsync(e,n);if(!o?.entity)return!1;let a=o.entity.subPropertyOf;if(a){let c=b(a);for(let i of c)if(i===r||await this.isSubpropertyOfRecursiveAsync(i,r,n,s))return!0}return!1}};var v=class{resourceResolver;constructor(e){this.resourceResolver=e}async buildFromNameAsync(e,r){return(await this.resourceResolver.resolveEntityAsync(e,r))?.uri??null}buildFromName(e,r,n){if(e.includes(".")){let o=e.split("."),a=o[0],c=o[1],i=this.findPackageNameForAlias(n,a);if(i){for(let u of r.values())if(u.entityName===c&&u.uri.package_===i)return u.uri}return null}let s=r.get(e);return s?s.uri:null}create(e,r,n,s){return new g(e,r,n,s)}findPackageNameForAlias(e,r){if(!e.metadata.imports)return null;for(let[n,s]of Object.entries(e.metadata.imports))for(let o of s)if(o.alias===r||!o.alias&&o.packageName===r)return o.packageName;return null}};function V(t){if(!t||t.trim().length===0)throw new Error("Kanonak address string cannot be null or empty");let e=t.trim(),r=e.split("/");if(r.length===1){let n=r[0];if(!n)throw new Error(`Invalid Kanonak address: "${t}". Expected publisher, publisher/package[@version], or publisher/package[@version]/name.`);if(n.includes("@"))throw new Error(`Invalid Kanonak address: "${t}". A bare publisher cannot carry an @version qualifier \u2014 versions belong to packages.`);return{kind:"publisher",publisher:n}}if(r.length===2){let[n,s]=r;if(!n||!s)throw new Error(`Invalid Kanonak address: "${t}". Expected publisher/package[@version].`);let o=s.indexOf("@");if(o===-1)return{kind:"package",publisher:n,package_:s};let a=s.substring(0,o),c=s.substring(o+1);if(!a||!c)throw new Error(`Invalid Kanonak address: "${t}". Expected publisher/package[@version].`);let i=S(c);return{kind:"package",publisher:n,package_:a,version:i}}return{kind:"resource",uri:g.parse(e)}}function P(t){switch(t.kind){case"publisher":return t.publisher;case"package":return t.version?`${t.publisher}/${t.package_}@${t.version.major}.${t.version.minor}.${t.version.patch}`:`${t.publisher}/${t.package_}`;case"resource":return t.uri.toString()}}function S(t){let e=t.split(".").map(Number);return I(e[0]||0,e[1]||0,e[2]||0)}function I(t,e,r){return{major:t,minor:e,patch:r,toString:()=>`${t}.${e}.${r}`,equals:n=>!n||typeof n!="object"?!1:n.major===t&&n.minor===e&&n.patch===r,getHashCode:()=>t<<20|e<<10|r,compareTo:n=>t!==n.major?t-n.major:e!==n.minor?e-n.minor:r-n.patch}}var R=class t{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"&&t.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 r=e.includes(".")?e.split(".")[1]:e;return t.KNOWN_XSD_DATATYPES.has(r.toLowerCase())}async isClassTypeAsync(e,r){if(this.isKnownXsdDatatypeName(e))return!1;let n=await this.resourceResolver.resolveEntityAsync(e,r);if(n){let s=n.entity.type;if(s){let o=String(s);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,r){return!!(e==="DatatypeProperty"||e==="Property"&&this.isXsdDatatype(r)||e==="Property"&&this.isLiteralType(r))}isEffectiveObjectProperty(e,r){return!!(e==="ObjectProperty"||e==="Property"&&r&&!this.isXsdDatatype(r)&&!this.isLiteralType(r))}};async function E(t,e){let r=[],n=await t.getAllDocumentsAsync();for(let s of n){let o=s.metadata.namespace_;if(!o)continue;let a=o.publisher,c=o.package_,i=o.version?`${o.version.major}.${o.version.minor}.${o.version.patch}`:"0.0.0";for(let[u,p]of Object.entries(s.body)){if(!p||typeof p!="object")continue;let l=p.type;!l||typeof l!="string"||l!=="Package"&&_(l,e)&&r.push({entityName:u,entity:p,documentNamespace:`${a}/${c}@${i}`,publisher:a,package_:c,version:i})}}return r}function _(t,e){let r=w(t),n=w(e);return r===n}function w(t){let e=t.lastIndexOf(".");if(e!==-1)return t.substring(e+1);let r=t.lastIndexOf("/");return r!==-1?t.substring(r+1):t}function f(t,e){return t.major!==e.major?t.major-e.major:t.minor!==e.minor?t.minor-e.minor:t.patch-e.patch}function j(t,e){return t.major===e.major&&t.minor===e.minor&&t.patch===e.patch}function A(t){return`${t.major}.${t.minor}.${t.patch}`}function K(t,e,r){let n=`${t}.${e}.${r}`;return{major:t,minor:e,patch:r,toString:()=>n,equals:s=>s?.major===t&&s?.minor===e&&s?.patch===r,getHashCode:()=>t<<20|e<<10|r,compareTo:s=>t!==s.major?t-s.major:e!==s.minor?e-s.minor:r-s.patch}}function O(t){let e=/^(\d+)\.(\d+)\.(\d+)$/.exec(t);return e?K(Number(e[1]),Number(e[2]),Number(e[3])):null}function C(t,e){return f(t,e)>=0&&t.major===e.major&&t.minor===e.minor}function N(t,e){return e.major===0?f(t,e)>=0&&t.major===0&&t.minor===e.minor:f(t,e)>=0&&t.major===e.major}function M(t,e={}){let{requestedVersion:r}=e;if(t.length===0)return{chosen:null,alternatives:[],multipleVersionsPresent:!1,exactRequestedVersionMissing:!!r};if(r){let s=t.find(o=>{let a=o.metadata.namespace_?.version;return!!a&&A(a)===r});return s?{chosen:s,alternatives:t.filter(o=>o!==s),multipleVersionsPresent:t.length>1,exactRequestedVersionMissing:!1}:{chosen:null,alternatives:t,multipleVersionsPresent:t.length>1,exactRequestedVersionMissing:!0}}if(t.length===1)return{chosen:t[0],alternatives:[],multipleVersionsPresent:!1,exactRequestedVersionMissing:!1};let n=[...t].sort((s,o)=>{let a=s.metadata.namespace_?.version,c=o.metadata.namespace_?.version;return!a&&!c?0:a?c?f(c,a):-1:1});return{chosen:n[0],alternatives:n.slice(1),multipleVersionsPresent:!0,exactRequestedVersionMissing:!1}}export{g as KanonakUri,v as KanonakUriBuilder,k as ResourceResolver,R as TypeResolver,f as compareVersions,K as createVersion,E as findInstancesByType,P as formatKanonakAddress,A as formatVersion,C as isCompatibleVersion,N as isMajorCompatible,V as parseKanonakAddress,O as parseVersionString,M as pickHighestDocument,j as versionsEqual};
|
|
1
|
+
var g=class t{constructor(e,r,n,s){this.publisher=e;this.package_=r;this.name=n;this.version=s}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 r=e.split("/");if(r.length!==3)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let[n,s,o]=r;if(!n||!s||!o)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let a=s.indexOf("@");if(a===-1)return new t(n,s,o,void 0);let c=s.substring(0,a),i=s.substring(a+1);if(!c||!i)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let u=i.split(".").map(Number),p=D(u[0]||0,u[1]||0,u[2]||0);return new t(n,c,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}`}};function D(t,e,r){return{major:t,minor:e,patch:r,toString:()=>`${t}.${e}.${r}`,equals:n=>!n||typeof n!="object"?!1:n.major===t&&n.minor===e&&n.patch===r,getHashCode:()=>t<<20|e<<10|r,compareTo:n=>t!==n.major?t-n.major:e!==n.minor?e-n.minor:r-n.patch}}function b(t){if(Array.isArray(t))return t.map(r=>r?.toString()??"").filter(r=>r.length>0);let e=t?.toString();return e?[e]:[]}var k=class{cache=new Map;repository;logger;constructor(e,r){this.repository=e,this.logger=r}async resolveEntityAsync(e,r){let n=r.metadata?.namespace_?.toString()??"unknown",s=this.cache.get(n);if(s){let a=s.get(e);if(a)return a}let o=await this.buildEntityIndexAsyncInternal(r,new Set,"");return this.cache.set(n,o),o.get(e)??null}async resolveAllEntitiesAsync(e,r){let n=await this.buildAllEntitiesIndexAsync(r,new Set,"");if(e.includes(".")){let s=e.split("."),o=s[0],a=s[1],c=await this.findDocumentForAlias(r,o);return c?await this.resolveAllEntitiesAsync(a,c):[]}return n.filter(s=>s.entityName===e)}async buildAllEntitiesIndexAsync(e,r,n){let s=[],o=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building ALL entities index for namespace: ${o}`),r.has(o))return this.logger?.debug?.(`Skipping ${o} - already visited (circular import prevention)`),s;r.add(o);let a=n.length===0?o:`${n} \u2192 ${o}`;for(let[c,i]of Object.entries(e.body))if(!c.includes(".")&&i&&typeof i=="object"&&!Array.isArray(i)){let u=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};s.push({entityName:c,uri:new g(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,c,u),entity:i,definedInNamespace:o,isImported:n.length>0,importPath:a})}if(this.logger?.debug?.(`Collected ${s.length} entities from ${o}`),e.metadata?.imports){let c=Object.values(e.metadata.imports).reduce((i,u)=>i+u.length,0);this.logger?.debug?.(`Processing ${c} import(s) for ${o}`);for(let[i,u]of Object.entries(e.metadata.imports))for(let p of u)try{this.logger?.debug?.(`Resolving import: ${i}/${p.packageName}`);let l=await this.repository.getHighestCompatibleVersionAsync(i,p);if(l){this.logger?.debug?.(`Successfully loaded import: ${l.metadata?.namespace_?.toString()}`);let m=await this.buildAllEntitiesIndexAsync(l,r,a);s.push(...m),this.logger?.debug?.(`Added ${m.length} entities from import ${l.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${i}/${p.packageName}`)}catch(l){let m=l;throw this.logger?.error?.(`Failed to process import ${i}/${p.packageName} for namespace ${o}. Error: ${m.message}`,m),new Error(`Failed to process import ${i}/${p.packageName} for namespace ${o}. See inner exception for details.`,{cause:l})}}return s}async buildEntityIndexAsync(e){return await this.buildEntityIndexAsyncInternal(e,new Set,"")}async buildEntityIndexAsyncInternal(e,r,n){let s=new Map,o=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building entity index for namespace: ${o}`),r.has(o))return this.logger?.debug?.(`Skipping ${o} - already visited (circular import prevention)`),s;r.add(o);let a=n.length===0?o:`${n} \u2192 ${o}`,c=0;for(let[i,u]of Object.entries(e.body))if(!i.includes(".")&&u&&typeof u=="object"&&!Array.isArray(u)&&!s.has(i)){let p=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};s.set(i,{entityName:i,uri:new g(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,i,p),entity:u,definedInNamespace:o,isImported:n.length>0,importPath:a}),c++}if(this.logger?.debug?.(`Indexed ${c} entities from ${o}`),e.metadata?.imports){let i=Object.values(e.metadata.imports).reduce((u,p)=>u+p.length,0);this.logger?.debug?.(`Processing ${i} import(s) for ${o}`);for(let[u,p]of Object.entries(e.metadata.imports))for(let l of p)try{this.logger?.debug?.(`Resolving import: ${u}/${l.packageName}`);let m=await this.repository.getHighestCompatibleVersionAsync(u,l);if(m){this.logger?.debug?.(`Successfully loaded import: ${m.metadata?.namespace_?.toString()}`);let d=await this.buildEntityIndexAsyncInternal(m,r,a),h=0;for(let[y,$]of d.entries())if(s.has(y)||(s.set(y,$),h++),l.alias&&!y.includes(".")){let x=`${l.alias}.${y}`;s.has(x)||(s.set(x,$),h++)}this.logger?.debug?.(`Merged ${h} entities from import ${m.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${u}/${l.packageName}`)}catch(m){let d=m;throw this.logger?.error?.(`Failed to process import ${u}/${l.packageName} for namespace ${o}. Error: ${d.message}`,d),new Error(`Failed to process import ${u}/${l.packageName} for namespace ${o}. See inner exception for details.`,{cause:m})}}return s}async findDocumentForAlias(e,r){if(!e.metadata?.imports)return null;for(let[n,s]of Object.entries(e.metadata.imports))for(let o of s){if(o.alias===r)return await this.repository.getHighestCompatibleVersionAsync(n,o);if(!o.alias&&o.packageName===r)return await this.repository.getHighestCompatibleVersionAsync(n,o)}return null}clearCache(){this.cache.clear()}clearCacheForDocument(e){this.cache.delete(e)}async isSubclassOfAsync(e,r,n){if(e===r)return!0;let s=new Set;return await this.isSubclassOfRecursiveAsync(e,r,n,s)}async isSubclassOfRecursiveAsync(e,r,n,s){if(s.has(e))return!1;s.add(e);let o=await this.resolveEntityAsync(e,n);if(!o?.entity)return!1;let a=o.entity.subClassOf;if(a){let c=b(a);for(let i of c)if(i===r||await this.isSubclassOfRecursiveAsync(i,r,n,s))return!0}return!1}async isSubpropertyOfAsync(e,r,n){if(e===r)return!0;let s=new Set;return await this.isSubpropertyOfRecursiveAsync(e,r,n,s)}async isSubpropertyOfRecursiveAsync(e,r,n,s){if(s.has(e))return!1;s.add(e);let o=await this.resolveEntityAsync(e,n);if(!o?.entity)return!1;let a=o.entity.subPropertyOf;if(a){let c=b(a);for(let i of c)if(i===r||await this.isSubpropertyOfRecursiveAsync(i,r,n,s))return!0}return!1}};var v=class{resourceResolver;constructor(e){this.resourceResolver=e}async buildFromNameAsync(e,r){return(await this.resourceResolver.resolveEntityAsync(e,r))?.uri??null}buildFromName(e,r,n){if(e.includes(".")){let o=e.split("."),a=o[0],c=o[1],i=this.findPackageNameForAlias(n,a);if(i){for(let u of r.values())if(u.entityName===c&&u.uri.package_===i)return u.uri}return null}let s=r.get(e);return s?s.uri:null}create(e,r,n,s){return new g(e,r,n,s)}findPackageNameForAlias(e,r){if(!e.metadata.imports)return null;for(let[n,s]of Object.entries(e.metadata.imports))for(let o of s)if(o.alias===r||!o.alias&&o.packageName===r)return o.packageName;return null}};function V(t){if(!t||t.trim().length===0)throw new Error("Kanonak address string cannot be null or empty");let e=t.trim(),r=e.split("/");if(r.length===1){let n=r[0];if(!n)throw new Error(`Invalid Kanonak address: "${t}". Expected publisher, publisher/package[@version], or publisher/package[@version]/name.`);if(n.includes("@"))throw new Error(`Invalid Kanonak address: "${t}". A bare publisher cannot carry an @version qualifier \u2014 versions belong to packages.`);return{kind:"publisher",publisher:n}}if(r.length===2){let[n,s]=r;if(!n||!s)throw new Error(`Invalid Kanonak address: "${t}". Expected publisher/package[@version].`);let o=s.indexOf("@");if(o===-1)return{kind:"package",publisher:n,package_:s};let a=s.substring(0,o),c=s.substring(o+1);if(!a||!c)throw new Error(`Invalid Kanonak address: "${t}". Expected publisher/package[@version].`);let i=S(c);return{kind:"package",publisher:n,package_:a,version:i}}return{kind:"resource",uri:g.parse(e)}}function P(t){switch(t.kind){case"publisher":return t.publisher;case"package":return t.version?`${t.publisher}/${t.package_}@${t.version.major}.${t.version.minor}.${t.version.patch}`:`${t.publisher}/${t.package_}`;case"resource":return t.uri.toString()}}function S(t){let e=t.split(".").map(Number);return I(e[0]||0,e[1]||0,e[2]||0)}function I(t,e,r){return{major:t,minor:e,patch:r,toString:()=>`${t}.${e}.${r}`,equals:n=>!n||typeof n!="object"?!1:n.major===t&&n.minor===e&&n.patch===r,getHashCode:()=>t<<20|e<<10|r,compareTo:n=>t!==n.major?t-n.major:e!==n.minor?e-n.minor:r-n.patch}}var R=class t{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"&&t.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 r=e.includes(".")?e.split(".")[1]:e;return t.KNOWN_XSD_DATATYPES.has(r.toLowerCase())}async isClassTypeAsync(e,r){if(this.isKnownXsdDatatypeName(e))return!1;let n=await this.resourceResolver.resolveEntityAsync(e,r);if(n){let s=n.entity.type;if(s){let o=String(s);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,r){return!!(e==="DatatypeProperty"||e==="Property"&&this.isXsdDatatype(r)||e==="Property"&&this.isLiteralType(r))}isEffectiveObjectProperty(e,r){return!!(e==="ObjectProperty"||e==="Property"&&r&&!this.isXsdDatatype(r)&&!this.isLiteralType(r))}};async function E(t,e){let r=[],n=await t.getAllDocumentsAsync();for(let s of n){let o=s.metadata.namespace_;if(!o)continue;let a=o.publisher,c=o.package_,i=o.version?`${o.version.major}.${o.version.minor}.${o.version.patch}`:"0.0.0";for(let[u,p]of Object.entries(s.body)){if(!p||typeof p!="object")continue;let l=p.type;!l||typeof l!="string"||l!=="Package"&&_(l,e)&&r.push({entityName:u,entity:p,documentNamespace:`${a}/${c}@${i}`,publisher:a,package_:c,version:i})}}return r}function _(t,e){let r=w(t),n=w(e);return r===n}function w(t){let e=t.lastIndexOf(".");if(e!==-1)return t.substring(e+1);let r=t.lastIndexOf("/");return r!==-1?t.substring(r+1):t}function f(t,e){return t.major!==e.major?t.major-e.major:t.minor!==e.minor?t.minor-e.minor:t.patch-e.patch}function j(t,e){return t.major===e.major&&t.minor===e.minor&&t.patch===e.patch}function A(t){return`${t.major}.${t.minor}.${t.patch}`}function K(t,e,r){let n=`${t}.${e}.${r}`;return{major:t,minor:e,patch:r,toString:()=>n,equals:s=>s?.major===t&&s?.minor===e&&s?.patch===r,getHashCode:()=>t<<20|e<<10|r,compareTo:s=>t!==s.major?t-s.major:e!==s.minor?e-s.minor:r-s.patch}}function O(t){let e=/^(\d+)\.(\d+)\.(\d+)$/.exec(t);return e?K(Number(e[1]),Number(e[2]),Number(e[3])):null}function C(t,e){return f(t,e)>=0&&t.major===e.major&&t.minor===e.minor}function N(t,e){return e.major===0?f(t,e)>=0&&t.major===0&&t.minor===e.minor:f(t,e)>=0&&t.major===e.major}function M(t,e={}){let{requestedVersion:r}=e;if(t.length===0)return{chosen:null,alternatives:[],multipleVersionsPresent:!1,exactRequestedVersionMissing:!!r};if(r){let s=t.find(o=>{let a=o.metadata.namespace_?.version;return!!a&&A(a)===r});return s?{chosen:s,alternatives:t.filter(o=>o!==s),multipleVersionsPresent:t.length>1,exactRequestedVersionMissing:!1}:{chosen:null,alternatives:t,multipleVersionsPresent:t.length>1,exactRequestedVersionMissing:!0}}if(t.length===1)return{chosen:t[0],alternatives:[],multipleVersionsPresent:!1,exactRequestedVersionMissing:!1};let n=[...t].sort((s,o)=>{let a=s.metadata.namespace_?.version,c=o.metadata.namespace_?.version;return!a&&!c?0:a?c?f(c,a):-1:1});return{chosen:n[0],alternatives:n.slice(1),multipleVersionsPresent:!0,exactRequestedVersionMissing:!1}}export{g as KanonakUri,v as KanonakUriBuilder,k as ResourceResolver,R as TypeResolver,f as compareVersions,K as createVersion,E as findInstancesByType,P as formatKanonakAddress,A as formatVersion,C as isCompatibleVersion,N as isMajorCompatible,V as parseKanonakAddress,O as parseVersionString,M as pickHighestDocument,j as versionsEqual};
|
package/dist/validation/index.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
var P=class{isValid=!1;errors=[];warnings=[];get totalIssues(){return this.errors.length+this.warnings.length}};var b=(o=>(o.Warning="Warning",o.Error="Error",o))(b||{});var h=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 ee=class d{resolvedDocuments=[];currentEntityPath;withPath(e){let o=new d;return o.resolvedDocuments=this.resolvedDocuments,o.currentEntityPath=e,o}};import*as G from"js-yaml";var Z=class{parse(e){let o=this.parseWithErrors(e);if(!o.isValid){let t=o.errors[0];throw new Error(`YAML parse error at line ${t.line}, column ${t.column}: ${t.message}`)}return o.document}parseWithErrors(e){let o=[],t;try{e=e.replace(/^\uFEFF/,"");let n=G.load(e);if(!n||typeof n!="object")return t={metadata:this.createEmptyMetadata(),body:{},toString:()=>"KanonakDocument(empty)"},{document:t,errors:o,isValid:!0};let r=this.extractMetadata(n),i=this.extractBody(n,r);return t={metadata:r,body:i,toString:function(){return this.metadata.namespace_?`KanonakDocument(${this.metadata.namespace_.publisher}/${this.metadata.namespace_.package_})`:"KanonakDocument(no namespace)"}},{document:t,errors:o,isValid:!0}}catch(n){let r=n,i={message:r.message||"Unknown parse error",line:r.mark?.line??0,column:r.mark?.column??0,errorType:r.name==="YAMLException"?"SyntaxError":"Unknown",toString:()=>`${r.name==="YAMLException"?"SyntaxError":"Unknown"} at line ${r.mark?.line??0}: ${r.message||"Unknown parse error"}`};return o.push(i),{document:void 0,errors:o,isValid:!1}}}save(e){let o={};if(e.metadata.namespace_){let t=e.metadata.namespace_,n={type:"Package",publisher:t.publisher};t.version&&(n.version=`${t.version.major}.${t.version.minor}.${t.version.patch}`),e.metadata.imports&&(n.imports=this.serializeImports(e.metadata.imports)),o[t.package_]=n}return Object.assign(o,e.body),G.dump(o,{indent:2,noRefs:!0,sortKeys:!1})}createEmptyMetadata(){return{get allImports(){return[]}}}addAllImportsGetter(e){let o=e.imports;return Object.defineProperty(e,"allImports",{get:function(){if(!o)return[];let t=[];for(let n of Object.values(o))t.push(...n);return t},enumerable:!0,configurable:!0}),e}createVersion(e,o,t){return{major:e,minor:o,patch:t,toString:()=>`${e}.${o}.${t}`,equals:r=>!r||typeof r!="object"?!1:r.major===e&&r.minor===o&&r.patch===t,getHashCode:()=>e<<20|o<<10|t,compareTo:r=>e!==r.major?e-r.major:o!==r.minor?o-r.minor:t-r.patch}}extractMetadata(e){let o=this.createEmptyMetadata();for(let[t,n]of Object.entries(e))if(n&&typeof n=="object"&&n.type==="Package"){o.type_="Package";let r=t,i=n.publisher,a=n.version?this.parseVersion(n.version):void 0;return i&&r&&(o.namespace_={publisher:i,package_:r,version:a,toString:function(){return`${this.publisher}/${this.package_}@${this.version?.major??1}.${this.version?.minor??0}.${this.version?.patch??0}`},equals:p=>!p||typeof p!="object"?!1:p.publisher===i&&p.package_===r&&(!a||!p.version||a.equals(p.version)),getHashCode:()=>{let p=0;for(let s=0;s<i.length;s++)p=(p<<5)-p+i.charCodeAt(s);for(let s=0;s<r.length;s++)p=(p<<5)-p+r.charCodeAt(s);return p|0}}),n.imports&&Array.isArray(n.imports)&&(o.imports=this.parseImportsV3(n.imports)),this.addAllImportsGetter(o)}if(e.kanonak&&typeof e.kanonak=="object"){let t=e.kanonak;return(t.publisher||t.package||t.version)&&(o.namespace_=this.parseNamespace(t)),t.imports&&typeof t.imports=="object"&&(o.imports=this.parseImportsLegacy(t.imports)),this.addAllImportsGetter(o)}return o}extractBody(e,o){let t={},n;for(let[r,i]of Object.entries(e))if(i&&typeof i=="object"&&i.type==="Package"){n=r;break}for(let[r,i]of Object.entries(e))r!==n&&r!=="kanonak"&&r!=="namespace"&&r!=="imports"&&(t[r]=i);return t}parseNamespace(e){if(typeof e=="string"){let r=e.match(/^([^/]+)\/([^@]+)(?:@(.+))?$/);if(r){let i=r[3]?this.parseVersion(r[3]):this.createVersion(1,0,0);return{publisher:r[1],package_:r[2],version:i,toString:()=>e,equals:a=>!a||typeof a!="object"?!1:a.publisher===r[1]&&a.package_===r[2]&&(!i||!a.version||i.equals(a.version)),getHashCode:()=>{let a=0;for(let p=0;p<r[1].length;p++)a=(a<<5)-a+r[1].charCodeAt(p);for(let p=0;p<r[2].length;p++)a=(a<<5)-a+r[2].charCodeAt(p);return a|0}}}}let o=e.publisher||"",t=e.package||"",n=e.version?this.parseVersion(e.version):this.createVersion(1,0,0);return{publisher:o,package_:t,version:n,toString:function(){return`${this.publisher}/${this.package_}@${this.version?.major??1}.${this.version?.minor??0}.${this.version?.patch??0}`},equals:r=>!r||typeof r!="object"?!1:r.publisher===o&&r.package_===t&&(!n||!r.version||n.equals(r.version)),getHashCode:()=>{let r=0;for(let i=0;i<o.length;i++)r=(r<<5)-r+o.charCodeAt(i);for(let i=0;i<t.length;i++)r=(r<<5)-r+t.charCodeAt(i);return r|0}}}parseVersion(e){if(typeof e=="string"){let o=e.split(".").map(Number);return this.createVersion(o[0]||0,o[1]||0,o[2]||0)}return this.createVersion(e.major||0,e.minor||0,e.patch||0)}parseImportsV3(e){let o={};for(let t of e)if(!(!t||typeof t!="object"))if(t.packages&&Array.isArray(t.packages)){let n=t.publisher;if(!n)throw new Error("PublisherImport requires 'publisher' property");o[n]||(o[n]=[]);for(let r of t.packages){if(!r||typeof r!="object")continue;let i=this.parseImportFromEmbeddedObject(r,n);o[n].push(i)}}else{let n=this.parseImportFromEmbeddedObject(t,t.publisher),r=n.publisher||"";o[r]||(o[r]=[]),o[r].push(n)}return o}parseImportsLegacy(e){let o={};for(let[t,n]of Object.entries(e))Array.isArray(n)&&(o[t]=n.map(r=>this.parseImport(r,t)));return o}parseImportFromEmbeddedObject(e,o){let t=e.package;if(!t)throw new Error("Import requires 'package' property");let n=e.match;if(!n)throw new Error("Import requires 'match' property");let r=e.version;if(!r)throw new Error("Import requires 'version' property");let i=this.parseVersion(r),a=this.parseVersionOperator(n),p=this.calculateMaxVersion(n,i),s=e.alias;return{package_:`${t} ${n} ${i.toString()}`,publisher:o,packageName:t,versionOperator:a,version:i,alias:s,minVersion:i,maxVersion:p,toEmbeddedObject:()=>{let c={package:t,match:n,version:i.toString()};return s&&(c.alias=s),c},toString:()=>s?`${t} ${n} ${i.toString()} as ${s}`:`${t} ${n} ${i.toString()}`}}parseImport(e,o){if(typeof e=="string"){let p=e.match(/^(.+?)\s*([~^=*])\s*(\S+)\s+as\s+(\S+)$/);if(p){let c=p[1].trim(),l=p[2],y=this.parseVersion(p[3].trim()),u=p[4].trim(),m=this.parseVersionOperator(l),f=this.calculateMaxVersion(l,y);return{package_:e,publisher:o,packageName:c,versionOperator:m,version:y,alias:u,minVersion:y,maxVersion:f,toEmbeddedObject:()=>{let g={package:c,match:l,version:y.toString()};return u&&(g.alias=u),g},toString:()=>`${c} ${l} ${y.toString()} as ${u}`}}let s=e.match(/^(.+?)\s*([~^=*])\s*(.+)$/);if(s){let c=s[1].trim(),l=s[2],y=this.parseVersion(s[3].trim()),u=this.parseVersionOperator(l),m=this.calculateMaxVersion(l,y);return{package_:e,publisher:o,packageName:c,versionOperator:u,version:y,alias:void 0,minVersion:y,maxVersion:m,toEmbeddedObject:()=>({package:c,match:l,version:y.toString()}),toString:()=>`${c} ${l} ${y.toString()}`}}}let t=this.parseVersionOperator(e.operator||"~"),n=this.parseVersion(e.version||"1.0.0"),r=e.packageName||e.package||"",i=["=","~","^","*"][t],a=this.calculateMaxVersion(e.operator||"~",n);return{package_:e.package||"",publisher:o,packageName:r,versionOperator:t,version:n,alias:e.alias,minVersion:n,maxVersion:a,toEmbeddedObject:()=>{let p={package:r,match:i,version:n.toString()};return e.alias&&(p.alias=e.alias),p},toString:()=>`${r} ${i} ${n.toString()}`}}parseVersionOperator(e){switch(e){case"=":return 0;case"~":return 1;case"^":return 2;case"*":return 3;default:return 1}}calculateMaxVersion(e,o){switch(e){case"~":return this.createVersion(o.major,o.minor+1,0);case"^":return o.major===0?this.createVersion(0,o.minor+1,0):this.createVersion(o.major+1,0,0);default:return this.createVersion(999,999,999)}}serializeImports(e){let o=[];for(let[t,n]of Object.entries(e)){let r={publisher:t,packages:n.map(i=>{let a=["=","~","^","*"][i.versionOperator],p={package:i.packageName,match:a,version:`${i.version.major}.${i.version.minor}.${i.version.patch}`};return i.alias&&(p.alias=i.alias),p})};o.push(r)}return o}};var I=class d{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 o=[];for(let[t,n]of Object.entries(e.body))n&&typeof n=="object"&&!Array.isArray(n)&&this.validateEntity(t,n,o);return o}validateEntity(e,o,t){for(let[n,r]of Object.entries(o)){let i=r?.toString()??"";if(i&&d.NAMESPACE_PREFIX_PATTERN.test(i)){let a=this.getSuggestionForPrefixedValue(i),p=e.split(".")[0],s=new h;s.ruleType=this.ruleName,s.severity="Error",s.entityName=p,s.propertyName=e,s.actualValue=n,s.expectedValue=a,s.message=`Invalid namespace prefix '${i}'. Use '${a}' without prefix.`,s.suggestion="Kanonak YAML uses simple type names. Namespace resolution is handled through imports.",t.push(s)}r&&typeof r=="object"&&!Array.isArray(r)&&this.validateEntity(`${e}.${n}`,r,t)}}getSuggestionForPrefixedValue(e){let o=e.toLowerCase();if(o==="rdfs:class"||o==="owl:class")return"Class";if(o==="rdfs:property"||o==="rdf:property")return"DatatypeProperty or ObjectProperty";if(o.startsWith("xsd:"))return e.substring(4);let t=e.indexOf(":");return t>=0?e.substring(t+1):e}};var D=class d{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_AUGMENTATION_PATTERN=/^[a-zA-Z][a-zA-Z0-9_-]*\.[a-zA-Z][a-zA-Z0-9_-]*$/;static VALID_PROPERTY_NAME_PATTERN=/^[a-zA-Z][a-zA-Z0-9_.]*$/;ruleName="ResourceNaming";validate(e){let o=[],t=e.metadata?.namespace_?.publisher==="kanonak.org"&&e.metadata?.namespace_?.package_?.startsWith("core-");for(let[n,r]of Object.entries(e.body)){let i=d.VALID_AUGMENTATION_PATTERN.test(n);if(!i&&!t&&d.RESERVED_WORDS.has(n.toLowerCase())){let a=new h;a.ruleType=this.ruleName,a.severity="Error",a.entityName=n,a.message=`Entity name '${n}' is a reserved word and cannot be used.`,a.suggestion="Choose a different name that doesn't conflict with Kanonak reserved words.",o.push(a);continue}if(!i&&!d.VALID_NAME_PATTERN.test(n)){let a;/^\d/.test(n)?a="Entity names must start with a letter, not a number.":n.includes(" ")?a="Entity names cannot contain spaces. Use camelCase or underscores instead.":a="Entity names must start with a letter and contain only letters, numbers, and underscores.";let p=new h;p.ruleType=this.ruleName,p.severity="Error",p.entityName=n,p.message=`Invalid entity name '${n}'. ${a}`,p.suggestion=a,o.push(p)}r&&typeof r=="object"&&!Array.isArray(r)&&this.validatePropertyNames(n,r,o)}return o}validatePropertyNames(e,o,t){for(let n of Object.keys(o))if(!d.VALID_PROPERTIES.has(n)&&!d.VALID_PROPERTY_NAME_PATTERN.test(n)){let r=new h;r.ruleType=this.ruleName,r.severity="Warning",r.entityName=e,r.propertyName=n,r.message=`Property name '${n}' in entity '${e}' doesn't follow naming conventions.`,r.suggestion="Property names should start with a letter and contain only letters, numbers, and underscores.",t.push(r)}}};var O=class d{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 o=[];if(e.metadata?.namespace_?.publisher==="kanonak.org"&&e.metadata?.namespace_?.package_?.startsWith("core-"))return o;let t=this.isPropertyDefinedAsClass(e);for(let[n,r]of Object.entries(e.body))if(r&&typeof r=="object"&&!Array.isArray(r)){let i=r,a=i.type;if(a){let p=[];if(Array.isArray(a))for(let s of a){let c=s?.toString();c&&c==="Property"&&!t&&p.push(c)}else{let s=a?.toString();s&&s==="Property"&&!t&&p.push(s)}for(let s of p){let c=this.getPropertyValue(i,"range"),l=this.determinePropertyType(c),y=new h;y.ruleType=this.ruleName,y.severity="Error",y.entityName=n,y.propertyName="type",y.actualValue=s,y.expectedValue=l,y.message=`Invalid property type '${s}'. Use '${l}' instead.`,y.suggestion="Properties should specify their type: DatatypeProperty for data values, ObjectProperty for relationships.",o.push(y)}}}return o}determinePropertyType(e){return!e||e.trim().length===0?"DatatypeProperty or ObjectProperty":d.XSD_TYPES.has(e.toLowerCase())?"DatatypeProperty":/^[A-Z]/.test(e)?"ObjectProperty":"DatatypeProperty or ObjectProperty"}getPropertyValue(e,o){let t=e[o];return t?t.toString():null}isPropertyDefinedAsClass(e){let o=e.body.Property;if(o&&typeof o=="object"&&!Array.isArray(o)){let n=o.type;if(n){let r=n.toString();return r==="Class"||r.endsWith(".Class")}}return!1}};var $=class{get ruleName(){return"SubjectKanonakTypeRequired"}validate(e){let o=[];for(let[t,n]of Object.entries(e.body)){if(typeof n!="object"||n===null||Array.isArray(n)||t.includes("."))continue;let r=n,i="type"in r,a=r.type?.toString().trim();if(!i||!a){let p=new h;p.ruleType=this.ruleName,p.severity="Error",p.entityName=t,p.propertyName="type",p.message=`Subject Kanonak '${t}' must have a 'type' property.`,p.suggestion=`Add a type statement like:
|
|
2
2
|
type: Scene
|
|
3
3
|
|
|
4
|
-
Only embedded objects can infer type from their parent property's range. Subject Kanonaks (top-level entities) must explicitly declare their type.`,p.expectedValue="A valid class name (Scene, Character, Story, etc.)",o.push(p)}}return o}};var Y=class d{constructor(e,o,t,n){this.publisher=e;this.package_=o;this.name=t;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 o=e.split("/");if(o.length!==3)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let[t,n,r]=o;if(!t||!n||!r)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let i=n.indexOf("@");if(i===-1)return new d(t,n,r,void 0);let a=n.substring(0,i),p=n.substring(i+1);if(!a||!p)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let s=p.split(".").map(Number),c=oe(s[0]||0,s[1]||0,s[2]||0);return new d(t,a,r,c)}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}`}};function oe(d,e,o){return{major:d,minor:e,patch:o,toString:()=>`${d}.${e}.${o}`,equals:t=>!t||typeof t!="object"?!1:t.major===d&&t.minor===e&&t.patch===o,getHashCode:()=>d<<20|e<<10|o,compareTo:t=>d!==t.major?d-t.major:e!==t.minor?e-t.minor:o-t.patch}}function k(d){if(Array.isArray(d))return d.map(o=>o?.toString()??"").filter(o=>o.length>0);let e=d?.toString();return e?[e]:[]}var A=class{cache=new Map;repository;logger;constructor(e,o){this.repository=e,this.logger=o}async resolveEntityAsync(e,o){let t=o.metadata?.namespace_?.toString()??"unknown",n=this.cache.get(t);if(n){let i=n.get(e);if(i)return i}let r=await this.buildEntityIndexAsyncInternal(o,new Set,"");return this.cache.set(t,r),r.get(e)??null}async resolveAllEntitiesAsync(e,o){let t=await this.buildAllEntitiesIndexAsync(o,new Set,"");if(e.includes(".")){let n=e.split("."),r=n[0],i=n[1],a=await this.findDocumentForAlias(o,r);return a?await this.resolveAllEntitiesAsync(i,a):[]}return t.filter(n=>n.entityName===e)}async buildAllEntitiesIndexAsync(e,o,t){let n=[],r=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building ALL entities index for namespace: ${r}`),o.has(r))return this.logger?.debug?.(`Skipping ${r} - already visited (circular import prevention)`),n;o.add(r);let i=t.length===0?r:`${t} \u2192 ${r}`;for(let[a,p]of Object.entries(e.body))if(p&&typeof p=="object"&&!Array.isArray(p)){let s=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 Y(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,a,s),entity:p,definedInNamespace:r,isImported:t.length>0,importPath:i})}if(this.logger?.debug?.(`Collected ${n.length} entities from ${r}`),e.metadata?.imports){let a=Object.values(e.metadata.imports).reduce((p,s)=>p+s.length,0);this.logger?.debug?.(`Processing ${a} import(s) for ${r}`);for(let[p,s]of Object.entries(e.metadata.imports))for(let c of s)try{this.logger?.debug?.(`Resolving import: ${p}/${c.packageName}`);let l=await this.repository.getHighestCompatibleVersionAsync(p,c);if(l){this.logger?.debug?.(`Successfully loaded import: ${l.metadata?.namespace_?.toString()}`);let y=await this.buildAllEntitiesIndexAsync(l,o,i);n.push(...y),this.logger?.debug?.(`Added ${y.length} entities from import ${l.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${p}/${c.packageName}`)}catch(l){let y=l;throw this.logger?.error?.(`Failed to process import ${p}/${c.packageName} for namespace ${r}. Error: ${y.message}`,y),new Error(`Failed to process import ${p}/${c.packageName} for namespace ${r}. See inner exception for details.`,{cause:l})}}return n}async buildEntityIndexAsync(e){return await this.buildEntityIndexAsyncInternal(e,new Set,"")}async buildEntityIndexAsyncInternal(e,o,t){let n=new Map,r=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building entity index for namespace: ${r}`),o.has(r))return this.logger?.debug?.(`Skipping ${r} - already visited (circular import prevention)`),n;o.add(r);let i=t.length===0?r:`${t} \u2192 ${r}`,a=0;for(let[p,s]of Object.entries(e.body))if(s&&typeof s=="object"&&!Array.isArray(s)&&!n.has(p)){let c=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};n.set(p,{entityName:p,uri:new Y(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,p,c),entity:s,definedInNamespace:r,isImported:t.length>0,importPath:i}),a++}if(this.logger?.debug?.(`Indexed ${a} entities from ${r}`),e.metadata?.imports){let p=Object.values(e.metadata.imports).reduce((s,c)=>s+c.length,0);this.logger?.debug?.(`Processing ${p} import(s) for ${r}`);for(let[s,c]of Object.entries(e.metadata.imports))for(let l of c)try{this.logger?.debug?.(`Resolving import: ${s}/${l.packageName}`);let y=await this.repository.getHighestCompatibleVersionAsync(s,l);if(y){this.logger?.debug?.(`Successfully loaded import: ${y.metadata?.namespace_?.toString()}`);let u=await this.buildEntityIndexAsyncInternal(y,o,i),m=0;for(let[f,g]of u.entries())if(n.has(f)||(n.set(f,g),m++),l.alias&&!f.includes(".")){let R=`${l.alias}.${f}`;n.has(R)||(n.set(R,g),m++)}this.logger?.debug?.(`Merged ${m} entities from import ${y.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${s}/${l.packageName}`)}catch(y){let u=y;throw this.logger?.error?.(`Failed to process import ${s}/${l.packageName} for namespace ${r}. Error: ${u.message}`,u),new Error(`Failed to process import ${s}/${l.packageName} for namespace ${r}. See inner exception for details.`,{cause:y})}}return n}async findDocumentForAlias(e,o){if(!e.metadata?.imports)return null;for(let[t,n]of Object.entries(e.metadata.imports))for(let r of n){if(r.alias===o)return await this.repository.getHighestCompatibleVersionAsync(t,r);if(!r.alias&&r.packageName===o)return await this.repository.getHighestCompatibleVersionAsync(t,r)}return null}clearCache(){this.cache.clear()}clearCacheForDocument(e){this.cache.delete(e)}async isSubclassOfAsync(e,o,t){if(e===o)return!0;let n=new Set;return await this.isSubclassOfRecursiveAsync(e,o,t,n)}async isSubclassOfRecursiveAsync(e,o,t,n){if(n.has(e))return!1;n.add(e);let r=await this.resolveEntityAsync(e,t);if(!r?.entity)return!1;let i=r.entity.subClassOf;if(i){let a=k(i);for(let p of a)if(p===o||await this.isSubclassOfRecursiveAsync(p,o,t,n))return!0}return!1}async isSubpropertyOfAsync(e,o,t){if(e===o)return!0;let n=new Set;return await this.isSubpropertyOfRecursiveAsync(e,o,t,n)}async isSubpropertyOfRecursiveAsync(e,o,t,n){if(n.has(e))return!1;n.add(e);let r=await this.resolveEntityAsync(e,t);if(!r?.entity)return!1;let i=r.entity.subPropertyOf;if(i){let a=k(i);for(let p of a)if(p===o||await this.isSubpropertyOfRecursiveAsync(p,o,t,n))return!0}return!1}};var w=class{get ruleName(){return"EmbeddedKanonakType"}async validateAsync(e,o){let t=[],n=new A(o),r=await this.buildPropertyRangeMap(e,n);for(let[i,a]of Object.entries(e.body))typeof a=="object"&&a!==null&&!Array.isArray(a)&&await this.checkEmbeddedTypes(i,a,void 0,r,n,e,t,0);return t}async checkEmbeddedTypes(e,o,t,n,r,i,a,p){if(p>0){let s=o.type;if(s!=null){let c=await this.validateEmbeddedType(e,String(s),t,r,i);c&&a.push(c)}}for(let[s,c]of Object.entries(o)){let l=this.localName(s),y=n.has(l)?n.get(l):t;if(typeof c=="object"&&c!==null)if(Array.isArray(c))for(let u=0;u<c.length;u++){let m=c[u];typeof m=="object"&&m!==null&&!Array.isArray(m)&&await this.checkEmbeddedTypes(`${e}.${s}[${u}]`,m,y,n,r,i,a,p+1)}else await this.checkEmbeddedTypes(`${e}.${s}`,c,y,n,r,i,a,p+1)}}async validateEmbeddedType(e,o,t,n,r){if(o.length===0||!t)return null;let i=this.localName(o),a=this.localName(t);if(a==="Resource"||a==="Class")return null;let p=e.split(".")[0];if(i===a){let c=new h;return c.ruleType=this.ruleName,c.severity="Warning",c.entityName=p,c.propertyName=e,c.actualValue=o,c.expectedValue=t,c.message=`Embedded object at '${e}' declares 'type: ${o}', which equals the parent property's range '${t}'. The declaration is redundant \u2014 the type is already inferred from the property's range.`,c.suggestion=`Remove the 'type: ${o}' line, or keep it if explicitness is preferred over concision.`,c}if(await n.isSubclassOfAsync(o,t,r)||(i!==o||a!==t)&&await n.isSubclassOfAsync(i,a,r))return null;let s=new h;return s.ruleType=this.ruleName,s.severity="Error",s.entityName=p,s.propertyName=e,s.actualValue=o,s.expectedValue=t,s.message=`Embedded object at '${e}' has 'type: ${o}', which is not a subclass of the parent property's range '${t}'.`,s.suggestion=`Either remove the 'type: ${o}' line (so the type is inferred from the property's range '${t}'), or add 'subClassOf: ${t}' to the '${o}' class definition so the relationship holds.`,s}localName(e){let o=e.lastIndexOf(".");return o<0||o===e.length-1?e:e.substring(o+1)}async buildPropertyRangeMap(e,o){let t=new Map,n=await o.buildEntityIndexAsync(e);for(let[r,i]of n){let a=i.entity.type;if(a==null)continue;let p=String(a),s=this.localName(p);if(!(s==="Property"||s==="DatatypeProperty"||s==="ObjectProperty"||s==="AnnotationProperty"))continue;let l=i.entity.range;if(l==null)continue;let y=String(l);y.length!==0&&t.set(this.localName(r),y)}return t}};var E=class{ruleName="ImportExistence";async validateAsync(e,o){let t=[];if(!e.metadata?.imports)return t;let n=await o.getAllDocumentsAsync();for(let[r,i]of Object.entries(e.metadata.imports))for(let a of i)if(!await o.getHighestCompatibleVersionAsync(r,a)){let s=await this.determineImportErrorAsync(o,r,a,n),c=new h;c.ruleType=this.ruleName,c.severity="Error",c.message=s.message,c.suggestion=s.suggestion,c.entityName=`Import: ${r}/${a.packageName}`,c.actualValue=a.toString(),c.expectedValue=s.expectedValue,t.push(c)}return t}async determineImportErrorAsync(e,o,t,n){let r=await e.getDocumentsByNamespaceAsync(o,t.packageName);if(r.length===0){let s=n.filter(u=>u.metadata.namespace_?.publisher===o).map(u=>u.metadata.namespace_.package_).filter((u,m,f)=>f.indexOf(u)===m),c=this.findSimilarPackages(t.packageName,s),l=`Import '${o}/${t.package_}' not found - package does not exist`,y=c.length>0?`Did you mean: ${c.slice(0,3).join(", ")}?`:s.length>0?`Available packages in ${o}: ${s.slice(0,5).join(", ")}`:`No packages found for publisher '${o}'. Verify the publisher name is correct.`;return{message:l,suggestion:y,expectedValue:"Existing package"}}let a=r.filter(s=>s.metadata.namespace_?.version).map(s=>s.metadata.namespace_.version.toString()).sort().join(", "),p=this.getAcceptableVersionRange(t);return{message:`Import '${o}/${t.toString()}' version mismatch - no compatible version found`,suggestion:`Available versions: ${a}. Required: ${p}`,expectedValue:p}}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,o){if(o.length===0)return[];let t=o.filter(i=>i.toLowerCase().includes(e.toLowerCase())||e.toLowerCase().includes(i.toLowerCase()));if(t.length>0)return t.sort((i,a)=>i.length-a.length);let n=o.map(i=>({package:i,distance:this.levenshteinDistance(e.toLowerCase(),i.toLowerCase())})).sort((i,a)=>i.distance-a.distance),r=Math.max(3,Math.floor(e.length*.4));return n.filter(i=>i.distance<=r).map(i=>i.package)}levenshteinDistance(e,o){if(!e||e.length===0)return o?.length??0;if(!o||o.length===0)return e.length;let t=e.length,n=o.length,r=Array(t+1).fill(null).map(()=>Array(n+1).fill(0));for(let i=0;i<=t;i++)r[i][0]=i;for(let i=0;i<=n;i++)r[0][i]=i;for(let i=1;i<=t;i++)for(let a=1;a<=n;a++){let p=e[i-1]===o[a-1]?0:1;r[i][a]=Math.min(Math.min(r[i-1][a]+1,r[i][a-1]+1),r[i-1][a-1]+p)}return r[t][n]}};var S=class{ruleName="UnresolvedReference";async validateAsync(e,o){let t=[],n=new A(o),r=await n.buildEntityIndexAsync(e),i=new Set;for(let[a,p]of r.entries()){let s=p.entity.type;if(s){let c=s.toString();(c==="ObjectProperty"||c.endsWith(".ObjectProperty"))&&i.add(a)}}for(let[a,p]of Object.entries(e.body)){if(!p||typeof p!="object"||Array.isArray(p))continue;let s=p,c=this.getPropertyValue(s,"type");if(!(!c||c==="Class"||c.endsWith("Property")||c==="AnnotationProperty"))for(let[l,y]of Object.entries(s))l==="type"||l==="label"||l==="comment"||!(i.has(l)||Array.from(i).some(m=>m.endsWith(`.${l}`)))||await this.validateReferenceValue(a,l,y,e,n,t)}return t}async validateReferenceValue(e,o,t,n,r,i){if(t!=null){if(typeof t=="string")await r.resolveEntityAsync(t,n)||i.push(this.createUnresolvedReferenceError(e,o,t));else if(Array.isArray(t))for(let a=0;a<t.length;a++){let p=t[a];typeof p=="string"&&(await r.resolveEntityAsync(p,n)||i.push(this.createUnresolvedReferenceError(e,`${o}[${a}]`,p)))}}}createUnresolvedReferenceError(e,o,t){let n=`The entity '${t}' cannot be found in the current document or any imported namespaces.
|
|
4
|
+
Only embedded objects can infer type from their parent property's range. Subject Kanonaks (top-level entities) must explicitly declare their type.`,p.expectedValue="A valid class name (Scene, Character, Story, etc.)",o.push(p)}}return o}};var Y=class d{constructor(e,o,t,n){this.publisher=e;this.package_=o;this.name=t;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 o=e.split("/");if(o.length!==3)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let[t,n,r]=o;if(!t||!n||!r)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let i=n.indexOf("@");if(i===-1)return new d(t,n,r,void 0);let a=n.substring(0,i),p=n.substring(i+1);if(!a||!p)throw new Error(`Invalid Kanonak URI: ${e}. Expected format: publisher/package[@version]/name`);let s=p.split(".").map(Number),c=oe(s[0]||0,s[1]||0,s[2]||0);return new d(t,a,r,c)}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}`}};function oe(d,e,o){return{major:d,minor:e,patch:o,toString:()=>`${d}.${e}.${o}`,equals:t=>!t||typeof t!="object"?!1:t.major===d&&t.minor===e&&t.patch===o,getHashCode:()=>d<<20|e<<10|o,compareTo:t=>d!==t.major?d-t.major:e!==t.minor?e-t.minor:o-t.patch}}function k(d){if(Array.isArray(d))return d.map(o=>o?.toString()??"").filter(o=>o.length>0);let e=d?.toString();return e?[e]:[]}var A=class{cache=new Map;repository;logger;constructor(e,o){this.repository=e,this.logger=o}async resolveEntityAsync(e,o){let t=o.metadata?.namespace_?.toString()??"unknown",n=this.cache.get(t);if(n){let i=n.get(e);if(i)return i}let r=await this.buildEntityIndexAsyncInternal(o,new Set,"");return this.cache.set(t,r),r.get(e)??null}async resolveAllEntitiesAsync(e,o){let t=await this.buildAllEntitiesIndexAsync(o,new Set,"");if(e.includes(".")){let n=e.split("."),r=n[0],i=n[1],a=await this.findDocumentForAlias(o,r);return a?await this.resolveAllEntitiesAsync(i,a):[]}return t.filter(n=>n.entityName===e)}async buildAllEntitiesIndexAsync(e,o,t){let n=[],r=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building ALL entities index for namespace: ${r}`),o.has(r))return this.logger?.debug?.(`Skipping ${r} - already visited (circular import prevention)`),n;o.add(r);let i=t.length===0?r:`${t} \u2192 ${r}`;for(let[a,p]of Object.entries(e.body))if(!a.includes(".")&&p&&typeof p=="object"&&!Array.isArray(p)){let s=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 Y(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,a,s),entity:p,definedInNamespace:r,isImported:t.length>0,importPath:i})}if(this.logger?.debug?.(`Collected ${n.length} entities from ${r}`),e.metadata?.imports){let a=Object.values(e.metadata.imports).reduce((p,s)=>p+s.length,0);this.logger?.debug?.(`Processing ${a} import(s) for ${r}`);for(let[p,s]of Object.entries(e.metadata.imports))for(let c of s)try{this.logger?.debug?.(`Resolving import: ${p}/${c.packageName}`);let l=await this.repository.getHighestCompatibleVersionAsync(p,c);if(l){this.logger?.debug?.(`Successfully loaded import: ${l.metadata?.namespace_?.toString()}`);let y=await this.buildAllEntitiesIndexAsync(l,o,i);n.push(...y),this.logger?.debug?.(`Added ${y.length} entities from import ${l.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${p}/${c.packageName}`)}catch(l){let y=l;throw this.logger?.error?.(`Failed to process import ${p}/${c.packageName} for namespace ${r}. Error: ${y.message}`,y),new Error(`Failed to process import ${p}/${c.packageName} for namespace ${r}. See inner exception for details.`,{cause:l})}}return n}async buildEntityIndexAsync(e){return await this.buildEntityIndexAsyncInternal(e,new Set,"")}async buildEntityIndexAsyncInternal(e,o,t){let n=new Map,r=e.metadata?.namespace_?.toString()??"unknown";if(this.logger?.debug?.(`Building entity index for namespace: ${r}`),o.has(r))return this.logger?.debug?.(`Skipping ${r} - already visited (circular import prevention)`),n;o.add(r);let i=t.length===0?r:`${t} \u2192 ${r}`,a=0;for(let[p,s]of Object.entries(e.body))if(!p.includes(".")&&s&&typeof s=="object"&&!Array.isArray(s)&&!n.has(p)){let c=e.metadata.namespace_?.version??{major:1,minor:0,patch:0,toString:()=>"1.0.0",equals:()=>!1,getHashCode:()=>0,compareTo:()=>0};n.set(p,{entityName:p,uri:new Y(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,p,c),entity:s,definedInNamespace:r,isImported:t.length>0,importPath:i}),a++}if(this.logger?.debug?.(`Indexed ${a} entities from ${r}`),e.metadata?.imports){let p=Object.values(e.metadata.imports).reduce((s,c)=>s+c.length,0);this.logger?.debug?.(`Processing ${p} import(s) for ${r}`);for(let[s,c]of Object.entries(e.metadata.imports))for(let l of c)try{this.logger?.debug?.(`Resolving import: ${s}/${l.packageName}`);let y=await this.repository.getHighestCompatibleVersionAsync(s,l);if(y){this.logger?.debug?.(`Successfully loaded import: ${y.metadata?.namespace_?.toString()}`);let u=await this.buildEntityIndexAsyncInternal(y,o,i),m=0;for(let[f,g]of u.entries())if(n.has(f)||(n.set(f,g),m++),l.alias&&!f.includes(".")){let R=`${l.alias}.${f}`;n.has(R)||(n.set(R,g),m++)}this.logger?.debug?.(`Merged ${m} entities from import ${y.metadata?.namespace_?.toString()}`)}else this.logger?.warn?.(`Failed to load import: ${s}/${l.packageName}`)}catch(y){let u=y;throw this.logger?.error?.(`Failed to process import ${s}/${l.packageName} for namespace ${r}. Error: ${u.message}`,u),new Error(`Failed to process import ${s}/${l.packageName} for namespace ${r}. See inner exception for details.`,{cause:y})}}return n}async findDocumentForAlias(e,o){if(!e.metadata?.imports)return null;for(let[t,n]of Object.entries(e.metadata.imports))for(let r of n){if(r.alias===o)return await this.repository.getHighestCompatibleVersionAsync(t,r);if(!r.alias&&r.packageName===o)return await this.repository.getHighestCompatibleVersionAsync(t,r)}return null}clearCache(){this.cache.clear()}clearCacheForDocument(e){this.cache.delete(e)}async isSubclassOfAsync(e,o,t){if(e===o)return!0;let n=new Set;return await this.isSubclassOfRecursiveAsync(e,o,t,n)}async isSubclassOfRecursiveAsync(e,o,t,n){if(n.has(e))return!1;n.add(e);let r=await this.resolveEntityAsync(e,t);if(!r?.entity)return!1;let i=r.entity.subClassOf;if(i){let a=k(i);for(let p of a)if(p===o||await this.isSubclassOfRecursiveAsync(p,o,t,n))return!0}return!1}async isSubpropertyOfAsync(e,o,t){if(e===o)return!0;let n=new Set;return await this.isSubpropertyOfRecursiveAsync(e,o,t,n)}async isSubpropertyOfRecursiveAsync(e,o,t,n){if(n.has(e))return!1;n.add(e);let r=await this.resolveEntityAsync(e,t);if(!r?.entity)return!1;let i=r.entity.subPropertyOf;if(i){let a=k(i);for(let p of a)if(p===o||await this.isSubpropertyOfRecursiveAsync(p,o,t,n))return!0}return!1}};var w=class{get ruleName(){return"EmbeddedKanonakType"}async validateAsync(e,o){let t=[],n=new A(o),r=await this.buildPropertyRangeMap(e,n);for(let[i,a]of Object.entries(e.body))typeof a=="object"&&a!==null&&!Array.isArray(a)&&await this.checkEmbeddedTypes(i,a,void 0,r,n,e,t,0);return t}async checkEmbeddedTypes(e,o,t,n,r,i,a,p){if(p>0){let s=o.type;if(s!=null){let c=await this.validateEmbeddedType(e,String(s),t,r,i);c&&a.push(c)}}for(let[s,c]of Object.entries(o)){let l=this.localName(s),y=n.has(l)?n.get(l):t;if(typeof c=="object"&&c!==null)if(Array.isArray(c))for(let u=0;u<c.length;u++){let m=c[u];typeof m=="object"&&m!==null&&!Array.isArray(m)&&await this.checkEmbeddedTypes(`${e}.${s}[${u}]`,m,y,n,r,i,a,p+1)}else await this.checkEmbeddedTypes(`${e}.${s}`,c,y,n,r,i,a,p+1)}}async validateEmbeddedType(e,o,t,n,r){if(o.length===0||!t)return null;let i=this.localName(o),a=this.localName(t);if(a==="Resource"||a==="Class")return null;let p=e.split(".")[0];if(i===a){let c=new h;return c.ruleType=this.ruleName,c.severity="Warning",c.entityName=p,c.propertyName=e,c.actualValue=o,c.expectedValue=t,c.message=`Embedded object at '${e}' declares 'type: ${o}', which equals the parent property's range '${t}'. The declaration is redundant \u2014 the type is already inferred from the property's range.`,c.suggestion=`Remove the 'type: ${o}' line, or keep it if explicitness is preferred over concision.`,c}if(await n.isSubclassOfAsync(o,t,r)||(i!==o||a!==t)&&await n.isSubclassOfAsync(i,a,r))return null;let s=new h;return s.ruleType=this.ruleName,s.severity="Error",s.entityName=p,s.propertyName=e,s.actualValue=o,s.expectedValue=t,s.message=`Embedded object at '${e}' has 'type: ${o}', which is not a subclass of the parent property's range '${t}'.`,s.suggestion=`Either remove the 'type: ${o}' line (so the type is inferred from the property's range '${t}'), or add 'subClassOf: ${t}' to the '${o}' class definition so the relationship holds.`,s}localName(e){let o=e.lastIndexOf(".");return o<0||o===e.length-1?e:e.substring(o+1)}async buildPropertyRangeMap(e,o){let t=new Map,n=await o.buildEntityIndexAsync(e);for(let[r,i]of n){let a=i.entity.type;if(a==null)continue;let p=String(a),s=this.localName(p);if(!(s==="Property"||s==="DatatypeProperty"||s==="ObjectProperty"||s==="AnnotationProperty"))continue;let l=i.entity.range;if(l==null)continue;let y=String(l);y.length!==0&&t.set(this.localName(r),y)}return t}};var E=class{ruleName="ImportExistence";async validateAsync(e,o){let t=[];if(!e.metadata?.imports)return t;let n=await o.getAllDocumentsAsync();for(let[r,i]of Object.entries(e.metadata.imports))for(let a of i)if(!await o.getHighestCompatibleVersionAsync(r,a)){let s=await this.determineImportErrorAsync(o,r,a,n),c=new h;c.ruleType=this.ruleName,c.severity="Error",c.message=s.message,c.suggestion=s.suggestion,c.entityName=`Import: ${r}/${a.packageName}`,c.actualValue=a.toString(),c.expectedValue=s.expectedValue,t.push(c)}return t}async determineImportErrorAsync(e,o,t,n){let r=await e.getDocumentsByNamespaceAsync(o,t.packageName);if(r.length===0){let s=n.filter(u=>u.metadata.namespace_?.publisher===o).map(u=>u.metadata.namespace_.package_).filter((u,m,f)=>f.indexOf(u)===m),c=this.findSimilarPackages(t.packageName,s),l=`Import '${o}/${t.package_}' not found - package does not exist`,y=c.length>0?`Did you mean: ${c.slice(0,3).join(", ")}?`:s.length>0?`Available packages in ${o}: ${s.slice(0,5).join(", ")}`:`No packages found for publisher '${o}'. Verify the publisher name is correct.`;return{message:l,suggestion:y,expectedValue:"Existing package"}}let a=r.filter(s=>s.metadata.namespace_?.version).map(s=>s.metadata.namespace_.version.toString()).sort().join(", "),p=this.getAcceptableVersionRange(t);return{message:`Import '${o}/${t.toString()}' version mismatch - no compatible version found`,suggestion:`Available versions: ${a}. Required: ${p}`,expectedValue:p}}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,o){if(o.length===0)return[];let t=o.filter(i=>i.toLowerCase().includes(e.toLowerCase())||e.toLowerCase().includes(i.toLowerCase()));if(t.length>0)return t.sort((i,a)=>i.length-a.length);let n=o.map(i=>({package:i,distance:this.levenshteinDistance(e.toLowerCase(),i.toLowerCase())})).sort((i,a)=>i.distance-a.distance),r=Math.max(3,Math.floor(e.length*.4));return n.filter(i=>i.distance<=r).map(i=>i.package)}levenshteinDistance(e,o){if(!e||e.length===0)return o?.length??0;if(!o||o.length===0)return e.length;let t=e.length,n=o.length,r=Array(t+1).fill(null).map(()=>Array(n+1).fill(0));for(let i=0;i<=t;i++)r[i][0]=i;for(let i=0;i<=n;i++)r[0][i]=i;for(let i=1;i<=t;i++)for(let a=1;a<=n;a++){let p=e[i-1]===o[a-1]?0:1;r[i][a]=Math.min(Math.min(r[i-1][a]+1,r[i][a-1]+1),r[i-1][a-1]+p)}return r[t][n]}};var S=class{ruleName="UnresolvedReference";async validateAsync(e,o){let t=[],n=new A(o),r=await n.buildEntityIndexAsync(e),i=new Set;for(let[a,p]of r.entries()){let s=p.entity.type;if(s){let c=s.toString();(c==="ObjectProperty"||c.endsWith(".ObjectProperty"))&&i.add(a)}}for(let[a,p]of Object.entries(e.body)){if(!p||typeof p!="object"||Array.isArray(p))continue;let s=p,c=this.getPropertyValue(s,"type");if(!(!c||c==="Class"||c.endsWith("Property")||c==="AnnotationProperty"))for(let[l,y]of Object.entries(s))l==="type"||l==="label"||l==="comment"||!(i.has(l)||Array.from(i).some(m=>m.endsWith(`.${l}`)))||await this.validateReferenceValue(a,l,y,e,n,t)}return t}async validateReferenceValue(e,o,t,n,r,i){if(t!=null){if(typeof t=="string")await r.resolveEntityAsync(t,n)||i.push(this.createUnresolvedReferenceError(e,o,t));else if(Array.isArray(t))for(let a=0;a<t.length;a++){let p=t[a];typeof p=="string"&&(await r.resolveEntityAsync(p,n)||i.push(this.createUnresolvedReferenceError(e,`${o}[${a}]`,p)))}}}createUnresolvedReferenceError(e,o,t){let n=`The entity '${t}' cannot be found in the current document or any imported namespaces.
|
|
5
5
|
|
|
6
6
|
Possible solutions:
|
|
7
7
|
\u2022 Add import if the entity is defined in another namespace:
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kanonak-protocol/sdk",
|
|
3
|
-
"version": "3.
|
|
3
|
+
"version": "3.9.0",
|
|
4
4
|
"description": "Kanonak Protocol SDK - Document repository and parsing implementations for TypeScript",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "./dist/index.js",
|
|
@@ -105,7 +105,7 @@
|
|
|
105
105
|
"yaml-parser"
|
|
106
106
|
],
|
|
107
107
|
"dependencies": {
|
|
108
|
-
"@kanonak-protocol/types": "^3.
|
|
108
|
+
"@kanonak-protocol/types": "^3.9.0",
|
|
109
109
|
"ignore": "^7.0.5",
|
|
110
110
|
"js-yaml": "^4.1.0",
|
|
111
111
|
"yaml": "^2.7.0"
|