@kanonak-protocol/sdk 2.1.0 → 2.3.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/index.js CHANGED
@@ -1,60 +1,60 @@
1
- var Cr=Object.defineProperty;var Dr=(p,e)=>()=>(p&&(e=p(p=0)),e);var $r=(p,e)=>{for(var t in e)Cr(p,t,{get:e[t],enumerable:!0})};var Zt={};$r(Zt,{KanonakUri:()=>V});var V,Te=Dr(()=>{"use strict";V=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!==2)throw new Error(`Invalid kanonak URI format: ${e}. Expected format: publisher/package/name@version`);let r=t[0],n=t[1],o=r.split("/");if(o.length!==3)throw new Error(`Invalid kanonak URI path format: ${r}. Expected format: publisher/package/name`);let s=n.split(".").map(Number),a={major:s[0]||0,minor:s[1]||0,patch:s[2]||0,toString:()=>`${s[0]||0}.${s[1]||0}.${s[2]||0}`,equals:i=>!i||typeof i!="object"?!1:i.major===(s[0]||0)&&i.minor===(s[1]||0)&&i.patch===(s[2]||0),getHashCode:()=>(s[0]||0)<<20|(s[1]||0)<<10|(s[2]||0),compareTo:i=>(s[0]||0)!==i.major?(s[0]||0)-i.major:(s[1]||0)!==i.minor?(s[1]||0)-i.minor:(s[2]||0)-i.patch};return new p(o[0],o[1],o[2],a)}toString(){return`${this.publisher}/${this.package_}/${this.name}@${this.version.major}.${this.version.minor}.${this.version.patch}`}}});var nt=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 this.versionsEqual(s,t.version);case 1:return this.isCompatibleVersion(s,t.version);case 2:return this.isMajorCompatible(s,t.version);case 3:return this.compareVersions(s,t.minVersion)>=0;default:return!1}});return n.length===0?null:(n.sort((o,s)=>{let a=o.metadata.namespace_.version,i=s.metadata.namespace_.version;return!a&&!i?0:a?i?this.compareVersions(i,a):-1:1}),n[0])}async saveDocumentAsync(e,t){this.documents.set(t,e);let r=this.parser.save(e);this.documentContents.set(t,r)}async deleteDocumentAsync(e){this.documents.delete(e),this.documentContents.delete(e)}async clearNamespaceAsync(e,t){let r=[];for(let[n,o]of this.documents.entries())o.metadata?.namespace_?.publisher===e&&o.metadata?.namespace_?.package_===t&&r.push(n);for(let n of r)this.documents.delete(n),this.documentContents.delete(n)}async getAllDocumentReferencesAsync(){let e=[];for(let t of this.documents.values())t.metadata?.namespace_&&e.push({identifier:t.metadata.namespace_.toString(),uri:`kanonak://${t.metadata.namespace_}`,hasParseError:!1});return e}async getDocumentContentAsync(e){let t=this.documentContents.get(e);if(t!==void 0)return t;let r=this.documents.get(e);return r!==void 0?this.parser.save(r):null}async getDocumentUriAsync(e){let t=this.documents.get(e);return t?t.metadata?.namespace_?`kanonak://${t.metadata.namespace_}`:`kanonak://${e}`:null}versionsEqual(e,t){return e.major===t.major&&e.minor===t.minor&&e.patch===t.patch}compareVersions(e,t){return e.major!==t.major?e.major-t.major:e.minor!==t.minor?e.minor-t.minor:e.patch-t.patch}isCompatibleVersion(e,t){return this.compareVersions(e,t)>=0&&e.major===t.major&&e.minor===t.minor}isMajorCompatible(e,t){return t.major===0?this.compareVersions(e,t)>=0&&e.major===0&&e.minor===t.minor:this.compareVersions(e,t)>=0&&e.major===t.major}};import*as D from"fs/promises";import*as C from"path";import*as ot from"js-yaml";var O=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=ot.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),ot.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 oe=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=C.resolve(e),this.recursive=t,this.parser=r??new O,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=C.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=C.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 this.versionsEqual(a,t.version);case 1:return this.isCompatibleVersion(a,t.version);case 2:return this.isMajorCompatible(a,t.version);case 3:return this.compareVersions(a,t.minVersion)>=0;default:return!1}});return o.length===0?null:(o.sort((s,a)=>{let i=s.metadata.namespace_.version,c=a.metadata.namespace_.version;return this.compareVersions(c,i)}),o[0])}async saveDocumentAsync(e,t){let r,n=e.metadata.namespace_?.toString();if(n&&n.includes("@")&&n.includes("/")){let i=n.split("/"),c=i[0],u=i[1].replace("@","@")+".kan.yml";r=C.join(this.rootPath,c,u)}else r=C.join(this.rootPath,t),!r.endsWith(".yml")&&!r.endsWith(".yaml")&&!r.endsWith(".kan.yml")&&(r+=".kan.yml");let o=C.dirname(r);await D.mkdir(o,{recursive:!0});let s=this.parser.save(e);await D.writeFile(r,s,"utf8"),n&&this.documentCache.set(n,e),this.documentCache.set(r,e);let a=C.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 D.unlink(r)}catch{}let n=t.metadata.namespace_?.toString();n&&this.documentCache.delete(n),this.documentCache.delete(e),this.documentCache.delete(r);let o=C.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=C.join(this.rootPath,e);try{let o=await D.readdir(n);for(let s of o)s.includes(t)&&s.endsWith(".kan.yml")&&await D.unlink(C.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=`file://${r}`,o;for(let[i,c]of this.documentCache.entries())if(this.filePathsByIdentifier.get(i)===r&&c.metadata.namespace_){o=c.metadata.namespace_.toString();break}let s=o??C.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 D.access(e),t=e}catch{let r=C.join(this.rootPath,e);try{await D.access(r),t=r}catch{return null}}try{return await D.readFile(t,"utf8")}catch{return null}}async getDocumentUriAsync(e){await this.ensureCacheInitialized();let t=this.filePathsByIdentifier.get(e);if(!t)try{await D.access(e),t=e}catch{let r=C.join(this.rootPath,e);try{await D.access(r),t=r}catch{return null}}return`file://${t}`}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 D.mkdir(this.rootPath,{recursive:!0})}catch{}let t=(await this.findYamlFiles(this.rootPath,this.recursive)).map(async n=>{try{let o=await D.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=C.relative(this.rootPath,n);if(o&&o.metadata.namespace_){let i=o.metadata.namespace_.toString();this.documentCache.set(i,o),this.documentCache.set(n,o),this.documentCache.set(a,o),this.filePathsByIdentifier.set(i,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)}}versionsEqual(e,t){return e.major===t.major&&e.minor===t.minor&&e.patch===t.patch}compareVersions(e,t){return e.major!==t.major?e.major-t.major:e.minor!==t.minor?e.minor-t.minor:e.patch-t.patch}isCompatibleVersion(e,t){return this.compareVersions(e,t)>=0&&e.major===t.major&&e.minor===t.minor}isMajorCompatible(e,t){return t.major===0?this.compareVersions(e,t)>=0&&e.major===0&&e.minor===t.minor:this.compareVersions(e,t)>=0&&e.major===t.major}async findYamlFiles(e,t){let r=[];try{let n=await D.readdir(e,{withFileTypes:!0});for(let o of n){let s=C.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 Oe from"fs";var Vt=(r=>(r.NotFound="NotFound",r.Workspace="Workspace",r.Cache="Cache",r))(Vt||{}),Ee=class{cache;workspace;constructor(e,t,r){let n=r??new O;Oe.existsSync(e)||Oe.mkdirSync(e,{recursive:!0}),Oe.existsSync(t)||Oe.mkdirSync(t,{recursive:!0}),this.cache=new oe(e,!0,n),this.workspace=new oe(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 Kr}from"os";import{join as jr}from"path";function We(){let p=process.env.KANONAK_PACKAGE_CACHE;return p||jr(Kr(),".kanonak","packages")}var st=class p{static createComposite(e,t,r){let n=e??We(),o=t??".";return new Ee(n,o,r)}static createFromEnvironment(e){let t=We(),r=process.env.KANONAK_WORKSPACE_PATH??".";return p.createComposite(t,r,e)}};import{VersionOperator as at}from"@kanonak-protocol/types/document/models/enums";var xr="https://{publisher}/index.txt",Or="https://{publisher}/{package}/{version}.kan.yml",Yt={version:1},Ve=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 Yt}if(r.status===404)return Yt;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??xr;return Jt(r,{publisher:e})}resolvePackageUrl(e,t,r,n){let o=n.package??Or;return Jt(o,{publisher:e,package:t,version:r})}};function Jt(p,e){let t=p;for(let[n,o]of Object.entries(e))t=t.replaceAll(`{${n}}`,o);let r=t.match(/\{[a-z]+\}/);if(r)throw new Error(`Unresolved variable ${r[0]} in URL template: ${p}`);return t}var se=class p{indexCache=new Map;configResolver;fetchFn;constructor(e){this.configResolver=e?.configResolver??new Ve,this.fetchFn=e?.fetchFn}async resolveVersion(e,t){let r=await this.getPackageVersions(e,t.packageName);if(r.length===0)return null;let n=r.filter(o=>this.isVersionCompatible(o,t.version,t.versionOperator));return n.length===0?null:(n.sort((o,s)=>this.compareVersionStrings(s,o)),n[0])}async getHighestVersion(e,t){let r=await this.getPackageVersions(e,t);return r.length===0?null:[...r].sort((o,s)=>this.compareVersionStrings(s,o))[0]}async listLatestPackages(e){let t=this.indexCache.get(e);t||(t=await this.fetchIndex(e),this.indexCache.set(e,t));let r=[];for(let[n,o]of t){if(o.length===0)continue;let s=[...o].sort((a,i)=>this.compareVersionStrings(i,a));r.push({packageName:n,version:s[0]})}return r.sort((n,o)=>n.packageName.localeCompare(o.packageName)),r}async getPackageUrl(e,t,r){let n=await this.configResolver.getConfig(e);return this.configResolver.resolvePackageUrl(e,t,r,n)}async getPackageVersions(e,t){let r=this.indexCache.get(e);return r||(r=await this.fetchIndex(e),this.indexCache.set(e,r)),r.get(t)??[]}async fetchIndex(e){let t=await this.configResolver.getConfig(e),r=this.configResolver.resolveIndexUrl(e,t),n=this.fetchFn?await this.fetchFn(r,e):await fetch(r);if(!n.ok)throw new Error(`Failed to fetch publisher index: ${r} (${n.status} ${n.statusText})`);let o=await n.text();return p.parseIndex(o)}static parseIndex(e){let t=new Map;for(let r of e.split(`
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 i=t.get(s);i?i.push(a):t.set(s,[a])}return t}isVersionCompatible(e,t,r){let n=p.parseVersion(e);if(!n)return!1;switch(r){case at.Any:return!0;case at.Exact:return n.major===t.major&&n.minor===t.minor&&n.patch===t.patch;case at.Compatible:return n.major===t.major&&n.minor===t.minor&&n.patch>=t.patch;case at.Major:return n.major!==t.major?!1:n.minor>t.minor?!0:n.minor===t.minor?n.patch>=t.patch:!1;default:return!1}}static parseVersion(e){let t=e.split(".");if(t.length<2)return null;let r=parseInt(t[0],10),n=parseInt(t[1],10),o=t.length>=3?parseInt(t[2],10):0;return isNaN(r)||isNaN(n)||isNaN(o)?null:{major:r,minor:n,patch:o}}compareVersionStrings(e,t){let r=p.parseVersion(e),n=p.parseVersion(t);return!r&&!n?0:r?n?r.major!==n.major?r.major-n.major:r.minor!==n.minor?r.minor-n.minor:r.patch-n.patch:1:-1}};var it=class{parser=new O;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 se({fetchFn:e.fetchFn}):new se}async getHighestCompatibleVersionAsync(e,t){let r=await this.publisherIndex.resolveVersion(e,t);if(!r)return null;let n=`${e}/${t.packageName}@${r}`,o=this.documents.get(n);if(o)return o;if(this.getFromCache){let l=this.getFromCache(e,t.packageName,r);if(l){let u=this.parser.parse(l);return this.documents.set(n,u),this.contentCache.set(n,l),u}}let s=await this.publisherIndex.getPackageUrl(e,t.packageName,r),a=this.fetchFn?await this.fetchFn(s,e):await fetch(s);if(!a.ok)throw new Error(`Failed to fetch Kanonak package: ${s} (${a.status} ${a.statusText})`);let i=await a.text();this.onFetch&&this.onFetch(e,t.packageName,r,i);let c=this.parser.parse(i);return this.documents.set(n,c),this.contentCache.set(n,i),c}async getAllDocumentsAsync(){return Array.from(this.documents.values())}async getDocumentAsync(e){return this.documents.get(e)??null}async getDocumentsByNamespaceAsync(e,t){return Array.from(this.documents.values()).filter(r=>{let n=r.metadata.namespace_;return n&&n.publisher===e&&n.package_===t})}async saveDocumentAsync(e,t){throw new Error("HttpKanonakDocumentRepository is read-only")}async deleteDocumentAsync(e){throw new Error("HttpKanonakDocumentRepository is read-only")}async clearNamespaceAsync(e,t){throw new Error("HttpKanonakDocumentRepository is read-only")}async getAllDocumentReferencesAsync(){return[]}async getDocumentContentAsync(e){return this.contentCache.get(e)??null}async getDocumentUriAsync(e){let t=e.match(/^(.+?)\/(.+?)@(.+)$/);if(!t)return null;let[,r,n,o]=t;return this.publisherIndex.getPackageUrl(r,n,o)}};var U=class{};var Z=class extends U{statement=[]};var L=class extends Z{namespace;name;icon};var _=class extends Z{};Te();var I=class p extends U{subject;static parse(e){let t=new p;return t.subject=V.parse(e),t}};var q=class extends U{value};var T=class{predicate;object};var M=class extends T{};var F=class p extends M{static parse(e,t){let r=new p;return r.predicate=I.parse(e),r.object=t,r}};var z=class p extends M{static parse(e,t){let r=new p;return r.predicate=I.parse(e),r.object=t,r}};var X=class extends M{};var Y=class p extends T{static parse(e,t){let r=new p;return r.predicate=I.parse(e),r.object=I.parse(t),r}};var B=class extends T{};var W=class extends T{};Te();function j(p){if(Array.isArray(p))return p.map(t=>t?.toString()??"").filter(t=>t.length>0);let e=p?.toString();return e?[e]:[]}var E=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 V(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 V(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=j(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=j(s);for(let i of a)if(i===t||await this.isSubpropertyOfRecursiveAsync(i,t,r,n))return!0}return!1}};var Q=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 E(e),o=new Q(n);for(let s of r)for(let[a,i]of Object.entries(s.body)){let c=new L;c.namespace=s.metadata.namespace_?.toString()??"",c.name=a,c.statement=[];let l=await this.parseStatements(i,s,n,o,e);c.statement.push(...l),t.push(c)}return t}async parseStatements(e,t,r,n,o){let s=[];if(typeof e!="object"||e===null||Array.isArray(e))return s;for(let[a,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 z.parse(e,t);if(typeof t=="boolean"){let n=new X;return n.predicate=I.parse(e),n.object=t,n}}async parseObjectValue(e,t,r,n,o,s){if(typeof t=="string"){let a=await this.resolveReference(t,n,o);if(!a)return;let i=new Y;return i.predicate=I.parse(e),i.object=a,i}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 B;return l.predicate=I.parse(e),l.object=a,l}let i=[];for(let[,l]of Object.entries(t))if(typeof l=="object"&&l!==null&&!Array.isArray(l)){let u=new _;u.statement=await this.parseStatements(l,n,o,s,{}),i.push(u)}else if(typeof l=="string"){let u=await this.resolveReference(l,n,o);u&&i.push(u)}if(i.length>0){let l=new W;return l.predicate=I.parse(e),l.object=i,l}let c=new B;return c.predicate=I.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 q;u.value=l,a.push(u);continue}if(i&&l instanceof Date){let u=new q;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 c=new W;return c.predicate=I.parse(e),c.object=a,c}async resolveReference(e,t,r){let n=await r.resolveEntityAsync(e,t);if(n){let s=new I;return s.subject=n.uri,s}let o=t.metadata?.namespace_;if(o){let{KanonakUri:s}=await Promise.resolve().then(()=>(Te(),Zt)),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 I;return g.subject=new s(m,f.packageName,u,f.version),g}}}let i=new I;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 L&&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 L&&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 O().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 z)return[e.predicate.subject.name,e.object];if(e instanceof X)return[e.predicate.subject.name,e.object];if(e instanceof Y)return[e.predicate.subject.name,e.object.subject.name];if(e instanceof W){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 I?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 Er=new Set(["kanonak.org/core-rdf","kanonak.org/core-rdfs","kanonak.org/core-owl","kanonak.org/core-xsd","kanonak.org/core-kanonak"]),Qt={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 H(p){let e=p;if(e.entity&&typeof e.entity=="object"){let t=e.entity.type;if(typeof t=="string"){let r=Qt[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=Qt[r.name];if(n)return{publisher:n.publisher,package_:n.package_,name:r.name}}return r}}return null}function J(p,e){return Er.has(`${p}/${e}`)}var w=class p{static getTypeUri(e){return H(e)}static isCoreOntologyType(e){return J(e.publisher,e.package_)}static isClassType(e){let t=H(e);return t?J(t.publisher,t.package_)&&t.name==="Class":!1}static isDatatypeType(e){let t=H(e);return t?J(t.publisher,t.package_)&&t.name==="Datatype":!1}static isDatatypePropertyType(e){let t=H(e);return t?J(t.publisher,t.package_)&&t.name==="DatatypeProperty":!1}static isObjectPropertyType(e){let t=H(e);return t?J(t.publisher,t.package_)&&t.name==="ObjectProperty":!1}static isAnnotationPropertyType(e){let t=H(e);return t?J(t.publisher,t.package_)&&t.name==="AnnotationProperty":!1}static isGenericPropertyType(e){let t=H(e);return t?J(t.publisher,t.package_)&&t.name==="Property":!1}static isAnyPropertyType(e){let t=H(e);return!t||!J(t.publisher,t.package_)?!1:t.name==="Property"||t.name==="DatatypeProperty"||t.name==="ObjectProperty"||t.name==="AnnotationProperty"}static isSchemaDefinitionType(e){let t=H(e);return!t||!J(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=H(e);return r?t.has(r.name):!1}};var Nt=(a=>(a.Class="Class",a.DatatypeProperty="DatatypeProperty",a.ObjectProperty="ObjectProperty",a.AnnotationProperty="AnnotationProperty",a.Instance="Instance",a.Datatype="Datatype",a.Unknown="Unknown",a))(Nt||{}),_t=(a=>(a.InstanceOf="instanceOf",a.SubClassOf="subClassOf",a.Domain="domain",a.Range="range",a.ObjectRelationship="objectRelationship",a.SubPropertyOf="subPropertyOf",a.PropertyValue="propertyValue",a))(_t||{}),ct=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&&(w.isClassType(m)&&a.add(m.name),(w.isObjectPropertyType(m)||w.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=er(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 x=b;w.isClassType(x)?R="Class":w.isObjectPropertyType(x)?R="ObjectProperty":w.isDatatypePropertyType(x)?R="DatatypeProperty":w.isAnnotationPropertyType(x)?R="AnnotationProperty":w.isDatatypeType(x)?R="Datatype":w.isGenericPropertyType(x)?R="ObjectProperty":w.isInstanceOfKnownClass(x,a)&&(R="Instance")}let v=y&&f?`${y}/${g}@${f}`:g,K={};for(let[x,Et]of Object.entries(h))x!=="type"&&(typeof Et!="object"||Et===null)&&(K[x]=Et);o.push({id:v,label:h.label??g,type:R,namespace:y,properties:K}),tr(v,h,R,a,i,s,y,f,d),Tt(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=er(e);for(let[y,f]of Object.entries(e.body)){let d=f?.type;d&&(Tr(d,l)&&a.add(y),Nr(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=_r(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}),tr(h,f,g,a,i,r,s,o,l),Tt(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 er(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 rr={"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"},Vr=new Set(["kanonak.org/core-owl/ObjectProperty","kanonak.org/core-owl/DatatypeProperty","kanonak.org/core-owl/AnnotationProperty","kanonak.org/core-rdf/Property"]);function Ut(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 Tr(p,e){let t=Ut(p,e);return t?rr[t]==="Class":!1}function Nr(p,e){let t=Ut(p,e);return t?Vr.has(t):!1}function _r(p,e,t,r){if(!p||p==="Package")return"Unknown";let n=Ut(p,r);if(n){let s=rr[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 nr=new Set(["type","label","comment","version","publisher","imports","license","match","alias","package"]);function tr(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:te(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:te(d,s,a,i),type:"subPropertyOf",label:"subPropertyOf"})}if(t==="Instance"&&c){let f=c.split(".").pop()??c;o.push({source:p,target:te(f,s,a,i),type:"instanceOf",label:"type"})}if(t==="Instance")for(let[f,d]of Object.entries(e)){if(nr.has(f)||!n.has(f))continue;let g=Array.isArray(d)?d:[d];for(let h of g)typeof h=="string"&&Ur(h)&&o.push({source:p,target:te(h,s,a,i),type:"propertyValue",label:f,propertyId:te(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:te(f,s,a,i),target:te(d,s,a,i),type:"objectRelationship",label:e.label??p.split("/").pop()??"",propertyId:p})}}function Tt(p,e,t,r,n,o,s,a,i){for(let[c,l]of Object.entries(e)){if(nr.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:te(f,s,a,i),type:"instanceOf",label:"type (inferred)"}),Tt(m,u,t,r,n,o,s,a,i)}}function Ur(p){return!(!p||p.includes(" ")||p.includes(`
3
- `)||p.startsWith("http://")||p.startsWith("https://")||/^\d{4}-\d{2}/.test(p)||/^\d+(\.\d+)?$/.test(p))}function te(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}function Ne(p){return`${p.publisher}/${p.package_}/${p.name}`}function $(p,e,t){return`${p}/${e}/${t}`}function He(p){return`${p.s}|${p.p}|${Lt(p.o)}`}function Lt(p){switch(p.kind){case"uri":return`u:${p.key}`;case"literal":return`l:${p.datatype}:${p.lexical}`;case"blank":return`b:${p.id}`}}function S(p,e,t){return{s:p,p:e,o:{kind:"uri",key:t}}}var _e=class{all=new Set;byPIdx=new Map;bySPIdx=new Map;byPOIdx=new Map;tripleList=[];add(e){let t=He(e);return this.all.has(t)?!1:(this.all.add(t),this.tripleList.push(e),Mt(this.byPIdx,e.p,e),Mt(this.bySPIdx,`${e.s}|${e.p}`,e),e.o.kind==="uri"&&Mt(this.byPOIdx,`${e.p}|${e.o.key}`,e),!0)}has(e){return this.all.has(He(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}|${Lt(r)}`)}};function Mt(p,e,t){let r=p.get(e);r?r.push(t):p.set(e,[t])}var Ue=class{type=$("kanonak.org","core-rdf","type");subClassOf=$("kanonak.org","core-rdf","subClassOf");subPropertyOf=$("kanonak.org","core-rdf","subPropertyOf");domain=$("kanonak.org","core-rdf","domain");range=$("kanonak.org","core-rdf","range");equivalentClass=$("kanonak.org","core-owl","equivalentClass");equivalentProperty=$("kanonak.org","core-owl","equivalentProperty");inverseOf=$("kanonak.org","core-owl","inverseOf");sameAs=$("kanonak.org","core-owl","sameAs");transitiveProperty=$("kanonak.org","core-owl","TransitiveProperty");symmetricProperty=$("kanonak.org","core-owl","SymmetricProperty")};var Lr={name:"rdfs2",apply(p,e){let t=!1;for(let r of p.byPredicate(e.domain)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of p.byPredicate(n))p.add(S(s.s,e.type,o))&&(t=!0)}return t}},Mr={name:"rdfs3",apply(p,e){let t=!1;for(let r of p.byPredicate(e.range)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of p.byPredicate(n))s.o.kind==="uri"&&p.add(S(s.o.key,e.type,o))&&(t=!0)}return t}},Fr={name:"rdfs5",apply(p,e){let t=!1;for(let r of p.byPredicate(e.subPropertyOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of p.bySubjectPredicate(o,e.subPropertyOf))s.o.kind==="uri"&&p.add(S(n,e.subPropertyOf,s.o.key))&&(t=!0)}return t}},Br={name:"rdfs7",apply(p,e){let t=!1;for(let r of p.byPredicate(e.subPropertyOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of p.byPredicate(n)){let a={s:s.s,p:o,o:s.o};p.add(a)&&(t=!0)}}return t}},Wr={name:"rdfs9",apply(p,e){let t=!1;for(let r of p.byPredicate(e.subClassOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of p.byPredicateObject(e.type,n))p.add(S(s.s,e.type,o))&&(t=!0)}return t}},Hr={name:"rdfs11",apply(p,e){let t=!1;for(let r of p.byPredicate(e.subClassOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of p.bySubjectPredicate(o,e.subClassOf))s.o.kind==="uri"&&p.add(S(n,e.subClassOf,s.o.key))&&(t=!0)}return t}},Ge=[Lr,Mr,Fr,Br,Wr,Hr];var Gr={name:"prp-trp",apply(p,e){let t=!1,r=p.subjectsWithPredicateObject(e.type,e.transitiveProperty);for(let n of r){let o=p.byPredicate(n);for(let s of o){if(s.o.kind!=="uri")continue;let a=s.o.key;for(let i of p.bySubjectPredicate(a,n))i.o.kind==="uri"&&s.s!==i.o.key&&p.add(S(s.s,n,i.o.key))&&(t=!0)}}return t}},qr={name:"prp-symp",apply(p,e){let t=!1,r=p.subjectsWithPredicateObject(e.type,e.symmetricProperty);for(let n of r)for(let o of p.byPredicate(n))o.o.kind==="uri"&&p.add(S(o.o.key,n,o.s))&&(t=!0);return t}},zr={name:"prp-inv1",apply(p,e){let t=!1;for(let r of p.byPredicate(e.inverseOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of p.byPredicate(n))s.o.kind==="uri"&&p.add(S(s.o.key,o,s.s))&&(t=!0)}return t}},Xr={name:"prp-inv2",apply(p,e){let t=!1;for(let r of p.byPredicate(e.inverseOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of p.byPredicate(o))s.o.kind==="uri"&&p.add(S(s.o.key,n,s.s))&&(t=!0)}return t}},Yr={name:"prp-eqp1",apply(p,e){let t=!1;for(let r of p.byPredicate(e.equivalentProperty)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of p.byPredicate(n))p.add({s:s.s,p:o,o:s.o})&&(t=!0)}return t}},Jr={name:"prp-eqp2",apply(p,e){let t=!1;for(let r of p.byPredicate(e.equivalentProperty)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of p.byPredicate(o))p.add({s:s.s,p:n,o:s.o})&&(t=!0)}return t}},Zr={name:"cax-eqc1",apply(p,e){let t=!1;for(let r of p.byPredicate(e.equivalentClass)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of p.byPredicateObject(e.type,n))p.add(S(s.s,e.type,o))&&(t=!0)}return t}},Qr={name:"cax-eqc2",apply(p,e){let t=!1;for(let r of p.byPredicate(e.equivalentClass)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of p.byPredicateObject(e.type,o))p.add(S(s.s,e.type,n))&&(t=!0)}return t}},en={name:"eq-rep-s",apply(p,e){let t=!1;for(let r of p.byPredicate(e.sameAs)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o){for(let s of p.snapshot())s.s===n&&p.add({s:o,p:s.p,o:s.o})&&(t=!0);for(let s of p.snapshot())s.s===o&&p.add({s:n,p:s.p,o:s.o})&&(t=!0)}}return t}},tn={name:"eq-rep-o",apply(p,e){let t=!1;for(let r of p.byPredicate(e.sameAs)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of p.snapshot())s.o.kind==="uri"&&(s.o.key===n?p.add(S(s.s,s.p,o))&&(t=!0):s.o.key===o&&p.add(S(s.s,s.p,n))&&(t=!0))}return t}},qe=[Gr,qr,zr,Xr,Yr,Jr,Zr,Qr,en,tn];var Me=class{constructor(e,t){this.store=e;this.vocabulary=t}store;vocabulary;getInstancesOfClass(e){let t=Le(e);return this.store.subjectsWithPredicateObject(this.vocabulary.type,t)}getSubclasses(e){let t=Le(e);return this.store.subjectsWithPredicateObject(this.vocabulary.subClassOf,t).filter(n=>n!==t)}getSuperclasses(e){let t=Le(e);return this.store.uriObjectsOf(t,this.vocabulary.subClassOf).filter(r=>r!==t)}getTypesOfIndividual(e){return this.store.uriObjectsOf(Le(e),this.vocabulary.type)}isInstanceOf(e,t){return this.store.hasUri(Le(e),this.vocabulary.type,Le(t))}triples(){return this.store.snapshot()}size(){return this.store.size()}};function Le(p){return typeof p=="string"?p:$(p.publisher,p.package_,p.name)}var pt=class{vocabulary;profile;maxIterations;constructor(e={}){this.vocabulary=e.vocabulary??new Ue,this.profile=e.profile??"owl-rl-classification",this.maxIterations=e.maxIterations??100}async reason(e){let t=new _e,n=await new ee().parseKanonaks(e),o=new Ft;for(let i of n)if(i instanceof L){let c=rn(i);if(!c)continue;for(let l of i.statement)this.emitStatement(c,l,t,o)}let s=[...Ge];this.profile==="owl-rl-classification"&&s.push(...qe);let a=0;for(;a<this.maxIterations;){let i=!1;for(let c of s)c.apply(t,this.vocabulary)&&(i=!0);if(!i)break;a++}return new Me(t,this.vocabulary)}emitStatement(e,t,r,n){let o=nn(t);if(o){if(t instanceof F){r.add({s:e,p:o,o:{kind:"literal",lexical:t.object,datatype:"string"}});return}if(t instanceof z){r.add({s:e,p:o,o:{kind:"literal",lexical:String(t.object),datatype:"number"}});return}if(t instanceof X){r.add({s:e,p:o,o:{kind:"literal",lexical:String(t.object),datatype:"boolean"}});return}if(t instanceof Y){let s=Ne(t.object.subject);r.add(S(e,o,s));return}if(t instanceof B){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 W){for(let s of t.object??[])this.emitListItem(e,o,s,r,n);return}}}emitListItem(e,t,r,n,o){if(r instanceof I)n.add(S(e,t,Ne(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 q){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)}},Ft=class{counter=0;next(){return`b${this.counter++}`}};function rn(p){let e=p.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||!p.name?null:$(o,s,p.name)}function nn(p){let e=p.predicate;return e?.subject?Ne(e.subject):null}import on from"ignore";import*as ut from"fs";import*as Fe from"path";var lt=class{ignoreInstance;basePath;constructor(e){this.basePath=e;let t=Fe.join(e,".gitignore");if(ut.existsSync(t))try{let r=ut.readFileSync(t,"utf8");this.ignoreInstance=on(),this.ignoreInstance.add(r)}catch{this.ignoreInstance=null}else this.ignoreInstance=null}shouldIgnore(e){if(!this.ignoreInstance)return!1;let r=Fe.relative(this.basePath,e).split(Fe.sep).join("/");return this.ignoreInstance.ignores(r)}};var mt=class{propertyUri;propertyType;range;isImported;definedInNamespace};Te();Te();var yt=class{resourceResolver;constructor(e){this.resourceResolver=e}async buildFromNameAsync(e,t){return(await this.resourceResolver.resolveEntityAsync(e,t))?.uri??null}buildFromName(e,t,r){if(e.includes(".")){let o=e.split("."),s=o[0],a=o[1],i=this.findPackageNameForAlias(r,s);if(i){for(let c of t.values())if(c.entityName===a&&c.uri.package_===i)return c.uri}return null}let n=t.get(e);return n?n.uri:null}create(e,t,r,n){return new V(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}};async function sr(p,e){let t=[],r=await p.getAllDocumentsAsync();for(let n of r){let o=n.metadata.namespace_;if(!o)continue;let s=o.publisher,a=o.package_,i=o.version?`${o.version.major}.${o.version.minor}.${o.version.patch}`:"0.0.0";for(let[c,l]of Object.entries(n.body)){if(!l||typeof l!="object")continue;let u=l.type;!u||typeof u!="string"||u!=="Package"&&sn(u,e)&&t.push({entityName:c,entity:l,documentNamespace:`${s}/${a}@${i}`,publisher:s,package_:a,version:i})}}return t}function sn(p,e){let t=or(p),r=or(e);return t===r}function or(p){let e=p.lastIndexOf(".");if(e!==-1)return p.substring(e+1);let t=p.lastIndexOf("/");return t!==-1?p.substring(t+1):p}var ae=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 ft=class p{resolvedDocuments=[];currentEntityPath;withPath(e){let t=new p;return t.resolvedDocuments=this.resolvedDocuments,t.currentEntityPath=e,t}};var ie=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 ce=class p{static RESERVED_WORDS=new Set(["kanonak","imports","namespace","type","label","comment","subclassof","domain","range","required","functional"]);static VALID_PROPERTIES=new Set(["type","label","comment","subClassOf","subPropertyOf","domain","range","required","functional","inverseOf","transitive","symmetric","inverseFunctional"]);static VALID_NAME_PATTERN=/^[a-zA-Z][a-zA-Z0-9_-]*$/;static VALID_PROPERTY_NAME_PATTERN=/^[a-zA-Z][a-zA-Z0-9_.]*$/;ruleName="ResourceNaming";validate(e){let t=[],r=e.metadata?.namespace_?.publisher==="kanonak.org"&&e.metadata?.namespace_?.package_?.startsWith("core-");for(let[n,o]of Object.entries(e.body)){if(!r&&p.RESERVED_WORDS.has(n.toLowerCase())){let s=new k;s.ruleType=this.ruleName,s.severity="Error",s.entityName=n,s.message=`Entity name '${n}' is a reserved word and cannot be used.`,s.suggestion="Choose a different name that doesn't conflict with Kanonak reserved words.",t.push(s);continue}if(!p.VALID_NAME_PATTERN.test(n)){let s;/^\d/.test(n)?s="Entity names must start with a letter, not a number.":n.includes(" ")?s="Entity names cannot contain spaces. Use camelCase or underscores instead.":s="Entity names must start with a letter and contain only letters, numbers, and underscores.";let a=new k;a.ruleType=this.ruleName,a.severity="Error",a.entityName=n,a.message=`Invalid entity name '${n}'. ${s}`,a.suggestion=s,t.push(a)}o&&typeof o=="object"&&!Array.isArray(o)&&this.validatePropertyNames(n,o,t)}return t}validatePropertyNames(e,t,r){for(let n of Object.keys(t))if(!p.VALID_PROPERTIES.has(n)&&!p.VALID_PROPERTY_NAME_PATTERN.test(n)){let o=new k;o.ruleType=this.ruleName,o.severity="Warning",o.entityName=e,o.propertyName=n,o.message=`Property name '${n}' in entity '${e}' doesn't follow naming conventions.`,o.suggestion="Property names should start with a letter and contain only letters, numbers, and underscores.",r.push(o)}}};var pe=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 le=class{get ruleName(){return"SubjectKanonakTypeRequired"}validate(e){let t=[];for(let[r,n]of Object.entries(e.body)){if(typeof n!="object"||n===null||Array.isArray(n))continue;let o=n,s="type"in o,a=o.type?.toString().trim();if(!s||!a){let i=new k;i.ruleType=this.ruleName,i.severity="Error",i.entityName=r,i.propertyName="type",i.message=`Subject Kanonak '${r}' must have a 'type' property.`,i.suggestion=`Add a type statement like:
1
+ var Zr=Object.defineProperty;var Qr=(c,e)=>()=>(c&&(e=c(c=0)),e);var en=(c,e)=>{for(var t in e)Zr(c,t,{get:e[t],enumerable:!0})};var dr={};en(dr,{KanonakUri:()=>_});function sn(c,e,t){return{major:c,minor:e,patch:t,toString:()=>`${c}.${e}.${t}`,equals:r=>!r||typeof r!="object"?!1:r.major===c&&r.minor===e&&r.patch===t,getHashCode:()=>c<<20|e<<10|t,compareTo:r=>c!==r.major?c-r.major:e!==r.minor?e-r.minor:t-r.patch}}var _,Be=Qr(()=>{"use strict";_=class c{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 c(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 p=i.split(".").map(Number),l=sn(p[0]||0,p[1]||0,p[2]||0);return new c(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 N(c,e){return c.major!==e.major?c.major-e.major:c.minor!==e.minor?c.minor-e.minor:c.patch-e.patch}function Ne(c,e){return c.major===e.major&&c.minor===e.minor&&c.patch===e.patch}function Ht(c){return`${c.major}.${c.minor}.${c.patch}`}function qt(c,e,t){let r=`${c}.${e}.${t}`;return{major:c,minor:e,patch:t,toString:()=>r,equals:n=>n?.major===c&&n?.minor===e&&n?.patch===t,getHashCode:()=>c<<20|e<<10|t,compareTo:n=>c!==n.major?c-n.major:e!==n.minor?e-n.minor:t-n.patch}}function lr(c){let e=/^(\d+)\.(\d+)\.(\d+)$/.exec(c);return e?qt(Number(e[1]),Number(e[2]),Number(e[3])):null}function _e(c,e){return N(c,e)>=0&&c.major===e.major&&c.minor===e.minor}function Ue(c,e){return e.major===0?N(c,e)>=0&&c.major===0&&c.minor===e.minor:N(c,e)>=0&&c.major===e.major}function ur(c,e={}){let{requestedVersion:t}=e;if(c.length===0)return{chosen:null,alternatives:[],multipleVersionsPresent:!1,exactRequestedVersionMissing:!!t};if(t){let n=c.find(o=>{let s=o.metadata.namespace_?.version;return!!s&&Ht(s)===t});return n?{chosen:n,alternatives:c.filter(o=>o!==n),multipleVersionsPresent:c.length>1,exactRequestedVersionMissing:!1}:{chosen:null,alternatives:c,multipleVersionsPresent:c.length>1,exactRequestedVersionMissing:!0}}if(c.length===1)return{chosen:c[0],alternatives:[],multipleVersionsPresent:!1,exactRequestedVersionMissing:!1};let r=[...c].sort((n,o)=>{let s=n.metadata.namespace_?.version,a=o.metadata.namespace_?.version;return!s&&!a?0:s?a?N(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 Ne(s,t.version);case 1:return _e(s,t.version);case 2:return Ue(s,t.version);case 3:return N(s,t.minVersion)>=0;default:return!1}});return n.length===0?null:(n.sort((o,s)=>{let a=o.metadata.namespace_.version,i=s.metadata.namespace_.version;return!a&&!i?0:a?i?N(i,a):-1:1}),n[0])}async saveDocumentAsync(e,t){this.documents.set(t,e);let r=this.parser.save(e);this.documentContents.set(t,r)}async deleteDocumentAsync(e){this.documents.delete(e),this.documentContents.delete(e)}async clearNamespaceAsync(e,t){let r=[];for(let[n,o]of this.documents.entries())o.metadata?.namespace_?.publisher===e&&o.metadata?.namespace_?.package_===t&&r.push(n);for(let n of r)this.documents.delete(n),this.documentContents.delete(n)}async getAllDocumentReferencesAsync(){let e=[];for(let t of this.documents.values())t.metadata?.namespace_&&e.push({identifier:t.metadata.namespace_.toString(),uri:`kanonak://${t.metadata.namespace_}`,hasParseError:!1});return e}async getDocumentContentAsync(e){let t=this.documentContents.get(e);if(t!==void 0)return t;let r=this.documents.get(e);return r!==void 0?this.parser.save(r):null}async getDocumentUriAsync(e){let t=this.documents.get(e);return t?t.metadata?.namespace_?`kanonak://${t.metadata.namespace_}`:`kanonak://${e}`:null}};import*as C from"fs/promises";import*as D from"path";import{pathToFileURL as mr}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: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 p=0;p<s.length;p++)i=(i<<5)-i+s.charCodeAt(p);for(let p=0;p<o.length;p++)i=(i<<5)-i+o.charCodeAt(p);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),p=e.alias;return{package_:`${r} ${n} ${s.toString()}`,publisher:t,packageName:r,versionOperator:a,version:s,alias:p,minVersion:s,maxVersion:i,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 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 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 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 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 Ne(a,t.version);case 1:return _e(a,t.version);case 2:return Ue(a,t.version);case 3:return N(a,t.minVersion)>=0;default:return!1}});return o.length===0?null:(o.sort((s,a)=>{let i=s.metadata.namespace_.version,p=a.metadata.namespace_.version;return N(p,i)}),o[0])}async saveDocumentAsync(e,t){let r,n=e.metadata.namespace_?.toString();if(n&&n.includes("@")&&n.includes("/")){let i=n.split("/"),p=i[0],u=i[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 C.mkdir(o,{recursive:!0});let s=this.parser.save(e);await C.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 C.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 C.readdir(n);for(let s of o)s.includes(t)&&s.endsWith(".kan.yml")&&await C.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=mr(r).toString(),o;for(let[i,p]of this.documentCache.entries())if(this.filePathsByIdentifier.get(i)===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 C.access(e),t=e}catch{let r=D.join(this.rootPath,e);try{await C.access(r),t=r}catch{return null}}try{return await C.readFile(t,"utf8")}catch{return null}}async getDocumentUriAsync(e){await this.ensureCacheInitialized();let t=this.filePathsByIdentifier.get(e);if(!t)try{await C.access(e),t=e}catch{let r=D.join(this.rootPath,e);try{await C.access(r),t=r}catch{return null}}return mr(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 C.mkdir(this.rootPath,{recursive:!0})}catch{}let t=(await this.findYamlFiles(this.rootPath,this.recursive)).map(async n=>{try{let o=await C.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 i=o.metadata.namespace_.toString();this.documentCache.set(i,o),this.documentCache.set(n,o),this.documentCache.set(a,o),this.filePathsByIdentifier.set(i,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 C.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 Le from"fs";var Gt=(r=>(r.NotFound="NotFound",r.Workspace="Workspace",r.Cache="Cache",r))(Gt||{}),Me=class{cache;workspace;constructor(e,t,r){let n=r??new $;Le.existsSync(e)||Le.mkdirSync(e,{recursive:!0}),Le.existsSync(t)||Le.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 tn}from"os";import{join as rn}from"path";function Qe(){let c=process.env.KANONAK_PACKAGE_CACHE;return c||rn(tn(),".kanonak","packages")}var ft=class c{static createComposite(e,t,r){let n=e??Qe(),o=t??".";return new Me(n,o,r)}static createFromEnvironment(e){let t=Qe(),r=process.env.KANONAK_WORKSPACE_PATH??".";return c.createComposite(t,r,e)}};import{VersionOperator as dt}from"@kanonak-protocol/types/document/models/enums";var nn="https://{publisher}/index.txt",on="https://{publisher}/{package}/{version}.kan.yml",yr={version:1},Fe=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 yr}if(r.status===404)return yr;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??nn;return fr(r,{publisher:e})}resolvePackageUrl(e,t,r,n){let o=n.package??on;return fr(o,{publisher:e,package:t,version:r})}};function fr(c,e){let t=c;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: ${c}`);return t}var pe=class c{indexCache=new Map;configResolver;fetchFn;constructor(e){this.configResolver=e?.configResolver??new Fe,this.fetchFn=e?.fetchFn}async resolveVersion(e,t){let r=await this.getPackageVersions(e,t.packageName);if(r.length===0)return null;let n=r.filter(o=>this.isVersionCompatible(o,t.version,t.versionOperator));return n.length===0?null:(n.sort((o,s)=>this.compareVersionStrings(s,o)),n[0])}async getHighestVersion(e,t){let r=await this.getPackageVersions(e,t);return r.length===0?null:[...r].sort((o,s)=>this.compareVersionStrings(s,o))[0]}async listLatestPackages(e){let t=this.indexCache.get(e);t||(t=await this.fetchIndex(e),this.indexCache.set(e,t));let r=[];for(let[n,o]of t){if(o.length===0)continue;let s=[...o].sort((a,i)=>this.compareVersionStrings(i,a));r.push({packageName:n,version:s[0]})}return r.sort((n,o)=>n.packageName.localeCompare(o.packageName)),r}async getPackageUrl(e,t,r){let n=await this.configResolver.getConfig(e);return this.configResolver.resolvePackageUrl(e,t,r,n)}async getPackageVersions(e,t){let r=this.indexCache.get(e);return r||(r=await this.fetchIndex(e),this.indexCache.set(e,r)),r.get(t)??[]}async fetchIndex(e){let t=await this.configResolver.getConfig(e),r=this.configResolver.resolveIndexUrl(e,t),n=this.fetchFn?await this.fetchFn(r,e):await fetch(r);if(!n.ok)throw new Error(`Failed to fetch publisher index: ${r} (${n.status} ${n.statusText})`);let o=await n.text();return c.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 i=t.get(s);i?i.push(a):t.set(s,[a])}return t}isVersionCompatible(e,t,r){let n=c.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=c.parseVersion(e),n=c.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 i=await a.text();this.onFetch&&this.onFetch(e,t.packageName,r,i);let p=this.parser.parse(i);return this.documents.set(n,p),this.contentCache.set(n,i),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 B=class{};var re=class extends B{statement=[]};var W=class extends re{namespace;name;icon};var M=class extends re{name};Be();var I=class c extends B{subject;static parse(e){let t=new c;return t.subject=_.parse(e),t}};var J=class extends B{value};var U=class{predicate;object};var H=class extends U{};var q=class c extends H{static parse(e,t){let r=new c;return r.predicate=I.parse(e),r.object=t,r}};var Z=class c extends H{static parse(e,t){let r=new c;return r.predicate=I.parse(e),r.object=t,r}};var Q=class extends H{};var ee=class c extends U{static parse(e,t){let r=new c;return r.predicate=I.parse(e),r.object=I.parse(t),r}};var G=class extends U{};var z=class extends U{};Be();function j(c){if(Array.isArray(c))return c.map(t=>t?.toString()??"").filter(t=>t.length>0);let e=c?.toString();return e?[e]:[]}var E=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 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 _(e.metadata.namespace_.publisher,e.metadata.namespace_.package_,a,p),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,p)=>i+p.length,0);this.logger?.debug?.(`Processing ${a} import(s) for ${o}`);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 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,p]of Object.entries(e.body))if(p&&typeof p=="object"&&!Array.isArray(p)&&!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:p,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((p,l)=>p+l.length,0);this.logger?.debug?.(`Processing ${i} 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=j(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=j(s);for(let i of a)if(i===t||await this.isSubpropertyOfRecursiveAsync(i,t,r,n))return!0}return!1}};var ne=class c{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"&&c.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 c.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 E(e),o=new ne(n);for(let s of r)for(let[a,i]of Object.entries(s.body)){let p=new W;p.namespace=s.metadata.namespace_?.toString()??"",p.name=a,p.statement=[];let l=await this.parseStatements(i,s,n,o,e);p.statement.push(...l),t.push(p)}return t}async parseStatements(e,t,r,n,o){let s=[];if(typeof e!="object"||e===null||Array.isArray(e))return s;for(let[a,i]of Object.entries(e))try{let p=await this.getPropertyMetadata(a,t,r,o,n);if(!p)continue;let l=await this.parsePropertyValue(a,i,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,i=a.type?.toString()??"",p=i.includes(".")?i.substring(i.lastIndexOf(".")+1):i;if(!new Set(["Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]).has(p))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 q.parse(e,t.toISOString());if(typeof t=="string")return q.parse(e,t);if(typeof t=="number")return Z.parse(e,t);if(typeof t=="boolean"){let n=new Q;return n.predicate=I.parse(e),n.object=t,n}}async parseObjectValue(e,t,r,n,o,s){if(typeof t=="string"){let a=await this.resolveReference(t,n,o);if(!a)return;let i=new ee;return i.predicate=I.parse(e),i.object=a,i}if(typeof t=="object"&&!Array.isArray(t)){let a=new M;if(a.statement=await this.parseStatements(t,n,o,s,{}),a.statement.length>0){let l=new G;return l.predicate=I.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 M;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 z;return l.predicate=I.parse(e),l.object=i,l}let p=new G;return p.predicate=I.parse(e),p.object=a,p}}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 J;u.value=l,a.push(u);continue}if(i&&l instanceof Date){let u=new J;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 M;u.statement=await this.parseStatements(l,n,o,s,{}),a.push(u)}}let p=new z;return p.predicate=I.parse(e),p.object=a,p}async resolveReference(e,t,r){let n=await r.resolveEntityAsync(e,t);if(n){let s=new I;return s.subject=n.uri,s}let o=t.metadata?.namespace_;if(o){let{KanonakUri:s}=await Promise.resolve().then(()=>(Be(),dr)),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 I;return g.subject=new s(m,f.packageName,u,f.version),g}}}let i=new I;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 W&&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 W&&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 i of s.statement){let[p,l]=this.convertStatementToProperty(i);p&&l!==null&&l!==void 0&&(a[p]=l),this.collectImportsFromStatement(i,e,o)}n.body[s.name]=a}return n}convertStatementToProperty(e){if(e instanceof q)return[e.predicate.subject.name,e.object];if(e instanceof Z)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.subject.name];if(e instanceof z){let t=this.convertKanonakListToValue(e.object);return[e.predicate.subject.name,t]}else if(e instanceof G){let t=this.convertEmbeddedKanonakToValue(e.object);return[e.predicate.subject.name,t]}return[null,null]}convertKanonakListToValue(e){let t=[];for(let r of e)r instanceof I?t.push(r.subject.name):r instanceof M&&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 an=new Set(["kanonak.org/core-rdf","kanonak.org/core-rdfs","kanonak.org/core-owl","kanonak.org/core-xsd","kanonak.org/core-kanonak"]),gr={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 X(c){let e=c;if(e.entity&&typeof e.entity=="object"){let t=e.entity.type;if(typeof t=="string"){let r=gr[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=gr[r.name];if(n)return{publisher:n.publisher,package_:n.package_,name:r.name}}return r}}return null}function te(c,e){return an.has(`${c}/${e}`)}var w=class c{static getTypeUri(e){return X(e)}static isCoreOntologyType(e){return te(e.publisher,e.package_)}static isClassType(e){let t=X(e);return t?te(t.publisher,t.package_)&&t.name==="Class":!1}static isDatatypeType(e){let t=X(e);return t?te(t.publisher,t.package_)&&t.name==="Datatype":!1}static isDatatypePropertyType(e){let t=X(e);return t?te(t.publisher,t.package_)&&t.name==="DatatypeProperty":!1}static isObjectPropertyType(e){let t=X(e);return t?te(t.publisher,t.package_)&&t.name==="ObjectProperty":!1}static isAnnotationPropertyType(e){let t=X(e);return t?te(t.publisher,t.package_)&&t.name==="AnnotationProperty":!1}static isGenericPropertyType(e){let t=X(e);return t?te(t.publisher,t.package_)&&t.name==="Property":!1}static isAnyPropertyType(e){let t=X(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=X(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(c.isSchemaDefinitionType(e))return!1;let r=X(e);return r?t.has(r.name):!1}};var Xt=(a=>(a.Class="Class",a.DatatypeProperty="DatatypeProperty",a.ObjectProperty="ObjectProperty",a.AnnotationProperty="AnnotationProperty",a.Instance="Instance",a.Datatype="Datatype",a.Unknown="Unknown",a))(Xt||{}),Yt=(a=>(a.InstanceOf="instanceOf",a.SubClassOf="subClassOf",a.Domain="domain",a.Range="range",a.ObjectRelationship="objectRelationship",a.SubPropertyOf="subPropertyOf",a.PropertyValue="propertyValue",a))(Yt||{}),ht=class{static async buildFromRepository(e){let r=await new oe().parseKanonaks(e),n=await e.getAllDocumentsAsync(),o=[],s=[],a=new Set,i=new Set,p=new Map;for(let u of r){let m=u;m.name&&(w.isClassType(m)&&a.add(m.name),(w.isObjectPropertyType(m)||w.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"&&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=hr(u);for(let[g,h]of Object.entries(u.body)){if(!h||typeof h!="object")continue;let k=l.get(g),R="Unknown";if(k){let V=k;w.isClassType(V)?R="Class":w.isObjectPropertyType(V)?R="ObjectProperty":w.isDatatypePropertyType(V)?R="DatatypeProperty":w.isAnnotationPropertyType(V)?R="AnnotationProperty":w.isDatatypeType(V)?R="Datatype":w.isGenericPropertyType(V)?R="ObjectProperty":w.isInstanceOfKnownClass(V,a)&&(R="Instance")}let P=y&&f?`${y}/${g}@${f}`:g,x={};for(let[V,Wt]of Object.entries(h))V!=="type"&&(typeof Wt!="object"||Wt===null)&&(x[V]=Wt);o.push({id:P,label:h.label??g,type:R,namespace:y,properties:x}),kr(P,h,R,a,i,s,y,f,d),zt(P,h,i,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,i=new Set,p=new Map,l=hr(e);for(let[y,f]of Object.entries(e.body)){let d=f?.type;d&&(pn(d,l)&&a.add(y),ln(d,l)&&(i.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=un(d,y,a,l),h=s&&o?`${s}/${y}@${o}`:y,k={};for(let[R,P]of Object.entries(f))R!=="type"&&(typeof P!="object"||P===null)&&(k[R]=P);t.push({id:h,label:f.label??y,type:g,namespace:s,properties:k}),kr(h,f,g,a,i,r,s,o,l),zt(h,f,i,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 hr(c,e){let t=new Map;if(c.metadata?.imports)for(let[r,n]of Object.entries(c.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 br={"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"},cn=new Set(["kanonak.org/core-owl/ObjectProperty","kanonak.org/core-owl/DatatypeProperty","kanonak.org/core-owl/AnnotationProperty","kanonak.org/core-rdf/Property"]);function Jt(c,e){if(c.includes(".")){let t=c.indexOf("."),r=c.substring(0,t),n=c.substring(t+1),o=e.get(r);if(o)return`${o.publisher}/${o.package_}/${n}`}return null}function pn(c,e){let t=Jt(c,e);return t?br[t]==="Class":!1}function ln(c,e){let t=Jt(c,e);return t?cn.has(t):!1}function un(c,e,t,r){if(!c||c==="Package")return"Unknown";let n=Jt(c,r);if(n){let s=br[n];if(s)return s;let a=n.split("/").pop()?.split("@")[0]??"";return t.has(a)?"Instance":"Unknown"}let o=c.split(".").pop()??c;return t.has(o)?"Instance":"Unknown"}var Rr=new Set(["type","label","comment","version","publisher","imports","license","match","alias","package"]);function kr(c,e,t,r,n,o,s,a,i){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:c,target:se(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:c,target:se(d,s,a,i),type:"subPropertyOf",label:"subPropertyOf"})}if(t==="Instance"&&p){let f=p.split(".").pop()??p;o.push({source:c,target:se(f,s,a,i),type:"instanceOf",label:"type"})}if(t==="Instance")for(let[f,d]of Object.entries(e)){if(Rr.has(f)||!n.has(f))continue;let g=Array.isArray(d)?d:[d];for(let h of g)typeof h=="string"&&mn(h)&&o.push({source:c,target:se(h,s,a,i),type:"propertyValue",label:f,propertyId:se(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:se(f,s,a,i),target:se(d,s,a,i),type:"objectRelationship",label:e.label??c.split("/").pop()??"",propertyId:c})}}function zt(c,e,t,r,n,o,s,a,i){for(let[p,l]of Object.entries(e)){if(Rr.has(p)||typeof l!="object"||l===null||Array.isArray(l))continue;let u=l,m=`${c}/${p}`,y=r.get(p),f=y?y.split(".").pop()??y:"Unknown",d={};for(let[h,k]of Object.entries(u))(typeof k!="object"||k===null)&&(d[h]=k);n.push({id:m,label:`${f} (embedded)`,type:"Instance",namespace:s,properties:d});let g=s&&a?`${s}/${p}@${a}`:p;o.push({source:c,target:m,type:"propertyValue",label:p,propertyId:t.has(p)?g:void 0}),y&&o.push({source:m,target:se(f,s,a,i),type:"instanceOf",label:"type (inferred)"}),zt(m,u,t,r,n,o,s,a,i)}}function mn(c){return!(!c||c.includes(" ")||c.includes(`
3
+ `)||c.startsWith("http://")||c.startsWith("https://")||/^\d{4}-\d{2}/.test(c)||/^\d+(\.\d+)?$/.test(c))}function se(c,e,t,r){if(c.includes("@")&&c.includes("/"))return c;if(c.includes(".")){let n=c.indexOf("."),o=c.substring(0,n),s=c.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}/${c}@${t}`:c}function We(c){return`${c.publisher}/${c.package_}/${c.name}`}function K(c,e,t){return`${c}/${e}/${t}`}function et(c){return`${c.s}|${c.p}|${Zt(c.o)}`}function Zt(c){switch(c.kind){case"uri":return`u:${c.key}`;case"literal":return`l:${c.datatype}:${c.lexical}`;case"blank":return`b:${c.id}`}}function A(c,e,t){return{s:c,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),Qt(this.byPIdx,e.p,e),Qt(this.bySPIdx,`${e.s}|${e.p}`,e),e.o.kind==="uri"&&Qt(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}|${Zt(r)}`)}};function Qt(c,e,t){let r=c.get(e);r?r.push(t):c.set(e,[t])}var qe=class{type=K("kanonak.org","core-rdf","type");subClassOf=K("kanonak.org","core-rdf","subClassOf");subPropertyOf=K("kanonak.org","core-rdf","subPropertyOf");domain=K("kanonak.org","core-rdf","domain");range=K("kanonak.org","core-rdf","range");equivalentClass=K("kanonak.org","core-owl","equivalentClass");equivalentProperty=K("kanonak.org","core-owl","equivalentProperty");inverseOf=K("kanonak.org","core-owl","inverseOf");sameAs=K("kanonak.org","core-owl","sameAs");transitiveProperty=K("kanonak.org","core-owl","TransitiveProperty");symmetricProperty=K("kanonak.org","core-owl","SymmetricProperty")};var yn={name:"rdfs2",apply(c,e){let t=!1;for(let r of c.byPredicate(e.domain)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of c.byPredicate(n))c.add(A(s.s,e.type,o))&&(t=!0)}return t}},fn={name:"rdfs3",apply(c,e){let t=!1;for(let r of c.byPredicate(e.range)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of c.byPredicate(n))s.o.kind==="uri"&&c.add(A(s.o.key,e.type,o))&&(t=!0)}return t}},dn={name:"rdfs5",apply(c,e){let t=!1;for(let r of c.byPredicate(e.subPropertyOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of c.bySubjectPredicate(o,e.subPropertyOf))s.o.kind==="uri"&&c.add(A(n,e.subPropertyOf,s.o.key))&&(t=!0)}return t}},gn={name:"rdfs7",apply(c,e){let t=!1;for(let r of c.byPredicate(e.subPropertyOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of c.byPredicate(n)){let a={s:s.s,p:o,o:s.o};c.add(a)&&(t=!0)}}return t}},hn={name:"rdfs9",apply(c,e){let t=!1;for(let r of c.byPredicate(e.subClassOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of c.byPredicateObject(e.type,n))c.add(A(s.s,e.type,o))&&(t=!0)}return t}},kn={name:"rdfs11",apply(c,e){let t=!1;for(let r of c.byPredicate(e.subClassOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of c.bySubjectPredicate(o,e.subClassOf))s.o.kind==="uri"&&c.add(A(n,e.subClassOf,s.o.key))&&(t=!0)}return t}},tt=[yn,fn,dn,gn,hn,kn];var bn={name:"prp-trp",apply(c,e){let t=!1,r=c.subjectsWithPredicateObject(e.type,e.transitiveProperty);for(let n of r){let o=c.byPredicate(n);for(let s of o){if(s.o.kind!=="uri")continue;let a=s.o.key;for(let i of c.bySubjectPredicate(a,n))i.o.kind==="uri"&&s.s!==i.o.key&&c.add(A(s.s,n,i.o.key))&&(t=!0)}}return t}},Rn={name:"prp-symp",apply(c,e){let t=!1,r=c.subjectsWithPredicateObject(e.type,e.symmetricProperty);for(let n of r)for(let o of c.byPredicate(n))o.o.kind==="uri"&&c.add(A(o.o.key,n,o.s))&&(t=!0);return t}},Pn={name:"prp-inv1",apply(c,e){let t=!1;for(let r of c.byPredicate(e.inverseOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of c.byPredicate(n))s.o.kind==="uri"&&c.add(A(s.o.key,o,s.s))&&(t=!0)}return t}},vn={name:"prp-inv2",apply(c,e){let t=!1;for(let r of c.byPredicate(e.inverseOf)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;for(let s of c.byPredicate(o))s.o.kind==="uri"&&c.add(A(s.o.key,n,s.s))&&(t=!0)}return t}},wn={name:"prp-eqp1",apply(c,e){let t=!1;for(let r of c.byPredicate(e.equivalentProperty)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of c.byPredicate(n))c.add({s:s.s,p:o,o:s.o})&&(t=!0)}return t}},In={name:"prp-eqp2",apply(c,e){let t=!1;for(let r of c.byPredicate(e.equivalentProperty)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of c.byPredicate(o))c.add({s:s.s,p:n,o:s.o})&&(t=!0)}return t}},Sn={name:"cax-eqc1",apply(c,e){let t=!1;for(let r of c.byPredicate(e.equivalentClass)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of c.byPredicateObject(e.type,n))c.add(A(s.s,e.type,o))&&(t=!0)}return t}},An={name:"cax-eqc2",apply(c,e){let t=!1;for(let r of c.byPredicate(e.equivalentClass)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of c.byPredicateObject(e.type,o))c.add(A(s.s,e.type,n))&&(t=!0)}return t}},Dn={name:"eq-rep-s",apply(c,e){let t=!1;for(let r of c.byPredicate(e.sameAs)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o){for(let s of c.snapshot())s.s===n&&c.add({s:o,p:s.p,o:s.o})&&(t=!0);for(let s of c.snapshot())s.s===o&&c.add({s:n,p:s.p,o:s.o})&&(t=!0)}}return t}},Cn={name:"eq-rep-o",apply(c,e){let t=!1;for(let r of c.byPredicate(e.sameAs)){if(r.o.kind!=="uri")continue;let n=r.s,o=r.o.key;if(n!==o)for(let s of c.snapshot())s.o.kind==="uri"&&(s.o.key===n?c.add(A(s.s,s.p,o))&&(t=!0):s.o.key===o&&c.add(A(s.s,s.p,n))&&(t=!0))}return t}},rt=[bn,Rn,Pn,vn,wn,In,Sn,An,Dn,Cn];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(c){return typeof c=="string"?c:K(c.publisher,c.package_,c.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 er;for(let i of n)if(i instanceof W){let p=Kn(i);if(!p)continue;for(let l of i.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 i=!1;for(let p of s)p.apply(t,this.vocabulary)&&(i=!0);if(!i)break;a++}return new ze(t,this.vocabulary)}emitStatement(e,t,r,n){let o=$n(t);if(o){if(t instanceof q){r.add({s:e,p:o,o:{kind:"literal",lexical:t.object,datatype:"string"}});return}if(t instanceof Z){r.add({s:e,p:o,o:{kind:"literal",lexical:String(t.object),datatype:"number"}});return}if(t instanceof Q){r.add({s:e,p:o,o:{kind:"literal",lexical:String(t.object),datatype:"boolean"}});return}if(t instanceof ee){let s=We(t.object.subject);r.add(A(e,o,s));return}if(t instanceof G){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 z){for(let s of t.object??[])this.emitListItem(e,o,s,r,n);return}}}emitListItem(e,t,r,n,o){if(r instanceof I)n.add(A(e,t,We(r.subject)));else if(r instanceof M){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 J){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)}},er=class{counter=0;next(){return`b${this.counter++}`}};function Kn(c){let e=c.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||!c.name?null:K(o,s,c.name)}function $n(c){let e=c.predicate;return e?.subject?We(e.subject):null}import xn 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=xn(),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 Pt=class{propertyUri;propertyType;range;isImported;definedInNamespace};import{parseDocument as jn,LineCounter as On,isMap as Ye,isPair as O,isScalar as T,isSeq as vt}from"yaml";var Je=class c{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 c,r=new On,n=jn(e,{lineCounter:r});if(n.errors.length>0||!Ye(n.contents))return t;rr(n.contents,[],r,t);for(let o of n.contents.items){if(!O(o)||!T(o.key))continue;let s=String(o.key.value),a=o.key.range;if(!a)continue;t.entities.set(s,F(a,r));let i=o.value,p=i&&typeof i=="object"&&"range"in i?i.range:void 0;if(p?t.entityBlocks.set(s,F([a[0],a[1],p[2]],r)):t.entityBlocks.set(s,F(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)||!T(f.key))continue;let d=String(f.key.value),g=f.key.range;g&&l.set(d,F(g,r));let h=f.value;if(h&&typeof h=="object"&&"range"in h&&Array.isArray(h.range)){let k=h.range;u.set(d,F(k,r))}if(vt(h)){let k=[];for(let R of h.items)R&&typeof R=="object"&&"range"in R&&Array.isArray(R.range)&&k.push(F(R.range,r));k.length>0&&m.set(d,k)}}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=Vn(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(tr(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,p]of o)tr(p,e,t)&&(!a||Pr(p,a))&&(s=i,a=p);if(n)for(let[i,p]of n)tr(p,e,t)&&(!a||Pr(p,a))&&(s=i,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 Vn(c,e){let t=[];if(!Ye(c))return t;let r=c.items.find(n=>O(n)&&T(n.key)&&String(n.key.value)==="imports");if(!r||!O(r)||!vt(r.value))return t;for(let n of r.value.items){if(!Ye(n))continue;let o=n.items.find(i=>O(i)&&T(i.key)&&String(i.key.value)==="publisher");if(!o||!O(o)||!T(o.value))continue;let s=String(o.value.value),a=n.items.find(i=>O(i)&&T(i.key)&&String(i.key.value)==="packages");if(!(!a||!O(a)||!vt(a.value)))for(let i of a.value.items){if(!Ye(i))continue;let p=i.items.find(g=>O(g)&&T(g.key)&&String(g.key.value)==="package");if(!p||!O(p)||!T(p.value)||!p.value.range)continue;let l=String(p.value.value),u=i.items.find(g=>O(g)&&T(g.key)&&String(g.key.value)==="version"),m=u&&O(u)&&T(u.value)?String(u.value.value):"",y=i.items.find(g=>O(g)&&T(g.key)&&String(g.key.value)==="alias"),f=y&&O(y)&&T(y.value)?String(y.value.value):void 0,d=f!==void 0?{publisher:s,package_:l,version:m,alias:f,position:F(p.value.range,e)}:{publisher:s,package_:l,version:m,position:F(p.value.range,e)};t.push(d)}}return t}function tr(c,e,t){return!(e<c.line||e>c.endLine||e===c.line&&t<c.column||e===c.endLine&&t>c.endColumn)}function Pr(c,e){let t=c.endLine-c.line,r=e.endLine-e.line;if(t!==r)return t<r;let n=c.endLine===c.line?c.endColumn-c.column:Number.MAX_SAFE_INTEGER,o=e.endLine===e.line?e.endColumn-e.column:Number.MAX_SAFE_INTEGER;return n<o}function rr(c,e,t,r){if(Ye(c)){for(let n of c.items){if(!O(n)||!T(n.key))continue;let o=String(n.key.value),s=[...e,o],a=JSON.stringify(s);n.key.range&&r.setNestedKeyPosition(a,F(n.key.range,t));let i=n.value,p=vr(i);p&&r.setNestedValuePosition(a,F(p,t)),rr(i,s,t,r)}return}if(vt(c)){for(let n=0;n<c.items.length;n++){let o=c.items[n],s=[...e,n],a=JSON.stringify(s),i=vr(o);i&&r.setNestedValuePosition(a,F(i,t)),rr(o,s,t,r)}return}}function vr(c){if(!c||typeof c!="object"||!("range"in c))return;let e=c.range;return Array.isArray(e)&&e.length>=3?e:void 0}function F(c,e){let t=e.linePos(c[0]),r=e.linePos(c[2]);return{line:t.line-1,column:t.col-1,endLine:r.line-1,endColumn:r.col-1}}function wr(c,e){let r=(e??new $).parse(c),n=Je.fromContent(c);return{document:r,positions:n}}Be();Be();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],i=this.findPackageNameForAlias(r,s);if(i){for(let p of t.values())if(p.entityName===a&&p.uri.package_===i)return p.uri}return null}let n=t.get(e);return n?n.uri:null}create(e,t,r,n){return new _(e,t,r,n)}findPackageNameForAlias(e,t){if(!e.metadata.imports)return null;for(let[r,n]of Object.entries(e.metadata.imports))for(let o of n)if(o.alias===t||!o.alias&&o.packageName===t)return o.packageName;return null}};async function Sr(c,e){let t=[],r=await c.getAllDocumentsAsync();for(let n of r){let o=n.metadata.namespace_;if(!o)continue;let s=o.publisher,a=o.package_,i=o.version?`${o.version.major}.${o.version.minor}.${o.version.patch}`:"0.0.0";for(let[p,l]of Object.entries(n.body)){if(!l||typeof l!="object")continue;let u=l.type;!u||typeof u!="string"||u!=="Package"&&En(u,e)&&t.push({entityName:p,entity:l,documentNamespace:`${s}/${a}@${i}`,publisher:s,package_:a,version:i})}}return t}function En(c,e){let t=Ir(c),r=Ir(e);return t===r}function Ir(c){let e=c.lastIndexOf(".");if(e!==-1)return c.substring(e+1);let t=c.lastIndexOf("/");return t!==-1?c.substring(t+1):c}var le=class{isValid=!1;errors=[];warnings=[];get totalIssues(){return this.errors.length+this.warnings.length}};var v=(t=>(t.Warning="Warning",t.Error="Error",t))(v||{});var b=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 c{resolvedDocuments=[];currentEntityPath;withPath(e){let t=new c;return t.resolvedDocuments=this.resolvedDocuments,t.currentEntityPath=e,t}};var ue=class c{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&&c.NAMESPACE_PREFIX_PATTERN.test(s)){let a=this.getSuggestionForPrefixedValue(s),i=e.split(".")[0],p=new b;p.ruleType=this.ruleName,p.severity="Error",p.entityName=i,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 me=class c{static RESERVED_WORDS=new Set(["kanonak","imports","namespace","type","label","comment","subclassof","domain","range","required","functional"]);static VALID_PROPERTIES=new Set(["type","label","comment","subClassOf","subPropertyOf","domain","range","required","functional","inverseOf","transitive","symmetric","inverseFunctional"]);static VALID_NAME_PATTERN=/^[a-zA-Z][a-zA-Z0-9_-]*$/;static VALID_PROPERTY_NAME_PATTERN=/^[a-zA-Z][a-zA-Z0-9_.]*$/;ruleName="ResourceNaming";validate(e){let t=[],r=e.metadata?.namespace_?.publisher==="kanonak.org"&&e.metadata?.namespace_?.package_?.startsWith("core-");for(let[n,o]of Object.entries(e.body)){if(!r&&c.RESERVED_WORDS.has(n.toLowerCase())){let s=new b;s.ruleType=this.ruleName,s.severity="Error",s.entityName=n,s.message=`Entity name '${n}' is a reserved word and cannot be used.`,s.suggestion="Choose a different name that doesn't conflict with Kanonak reserved words.",t.push(s);continue}if(!c.VALID_NAME_PATTERN.test(n)){let s;/^\d/.test(n)?s="Entity names must start with a letter, not a number.":n.includes(" ")?s="Entity names cannot contain spaces. Use camelCase or underscores instead.":s="Entity names must start with a letter and contain only letters, numbers, and underscores.";let a=new b;a.ruleType=this.ruleName,a.severity="Error",a.entityName=n,a.message=`Invalid entity name '${n}'. ${s}`,a.suggestion=s,t.push(a)}o&&typeof o=="object"&&!Array.isArray(o)&&this.validatePropertyNames(n,o,t)}return t}validatePropertyNames(e,t,r){for(let n of Object.keys(t))if(!c.VALID_PROPERTIES.has(n)&&!c.VALID_PROPERTY_NAME_PATTERN.test(n)){let o=new b;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 ye=class c{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 p of a){let l=p?.toString();l&&l==="Property"&&!r&&i.push(l)}else{let p=a?.toString();p&&p==="Property"&&!r&&i.push(p)}for(let p of i){let l=this.getPropertyValue(s,"range"),u=this.determinePropertyType(l),m=new b;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":c.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 fe=class{get ruleName(){return"SubjectKanonakTypeRequired"}validate(e){let t=[];for(let[r,n]of Object.entries(e.body)){if(typeof n!="object"||n===null||Array.isArray(n))continue;let o=n,s="type"in o,a=o.type?.toString().trim();if(!s||!a){let i=new b;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:
4
4
  type: Scene
5
5
 
6
- Only embedded objects can infer type from their parent property's range. Subject Kanonaks (top-level entities) must explicitly declare their type.`,i.expectedValue="A valid class name (Scene, Character, Story, etc.)",t.push(i)}}return t}};var ue=class{get ruleName(){return"EmbeddedKanonakNoExplicitType"}validate(e){let t=[];for(let[r,n]of Object.entries(e.body))typeof n=="object"&&n!==null&&!Array.isArray(n)&&this.checkForEmbeddedTypeViolations(r,n,t,0);return t}checkForEmbeddedTypeViolations(e,t,r,n){for(let[o,s]of Object.entries(t)){let a=o;if(n>0&&a.toLowerCase()==="type"){let i=s?.toString(),c=e.split(".")[0],l=new k;l.ruleType=this.ruleName,l.severity="Error",l.entityName=c,l.propertyName=e,l.actualValue="type",l.message=`Embedded object at '${e}' cannot have explicit 'type' property.`,l.suggestion=`Remove the 'type: ${i}' line.
6
+ Only embedded objects can infer type from their parent property's range. Subject Kanonaks (top-level entities) must explicitly declare their type.`,i.expectedValue="A valid class name (Scene, Character, Story, etc.)",t.push(i)}}return t}};var de=class{get ruleName(){return"EmbeddedKanonakNoExplicitType"}validate(e){let t=[];for(let[r,n]of Object.entries(e.body))typeof n=="object"&&n!==null&&!Array.isArray(n)&&this.checkForEmbeddedTypeViolations(r,n,t,0);return t}checkForEmbeddedTypeViolations(e,t,r,n){for(let[o,s]of Object.entries(t)){let a=o;if(n>0&&a.toLowerCase()==="type"){let i=s?.toString(),p=e.split(".")[0],l=new b;l.ruleType=this.ruleName,l.severity="Error",l.entityName=p,l.propertyName=e,l.actualValue="type",l.message=`Embedded object at '${e}' cannot have explicit 'type' property.`,l.suggestion=`Remove the 'type: ${i}' line.
7
7
 
8
8
  Type is automatically inferred from the containing property's range.
9
9
  If you need a different type, modify the 'range' of the parent property and version it appropriately.
10
10
 
11
- Example: If the parent property is 'hasCharacter' with range 'Character', all embedded objects in that property will be typed as 'Character' automatically.`,l.expectedValue="No explicit type (inferred from parent property's range)",r.push(l)}if(typeof s=="object"&&s!==null)if(Array.isArray(s))for(let i=0;i<s.length;i++){let c=s[i];typeof c=="object"&&c!==null&&!Array.isArray(c)&&this.checkForEmbeddedTypeViolations(`${e}.${a}[${i}]`,c,r,n+1)}else this.checkForEmbeddedTypeViolations(`${e}.${a}`,s,r,n+1)}}};var me=class{ruleName="ImportExistence";async validateAsync(e,t){let r=[];if(!e.metadata?.imports)return r;let n=await t.getAllDocumentsAsync();for(let[o,s]of Object.entries(e.metadata.imports))for(let a of s)if(!await t.getHighestCompatibleVersionAsync(o,a)){let c=await this.determineImportErrorAsync(t,o,a,n),l=new k;l.ruleType=this.ruleName,l.severity="Error",l.message=c.message,l.suggestion=c.suggestion,l.entityName=`Import: ${o}/${a.packageName}`,l.actualValue=a.toString(),l.expectedValue=c.expectedValue,r.push(l)}return r}async determineImportErrorAsync(e,t,r,n){let o=await e.getDocumentsByNamespaceAsync(t,r.packageName);if(o.length===0){let c=n.filter(y=>y.metadata.namespace_?.publisher===t).map(y=>y.metadata.namespace_.package_).filter((y,f,d)=>d.indexOf(y)===f),l=this.findSimilarPackages(r.packageName,c),u=`Import '${t}/${r.package_}' not found - package does not exist`,m=l.length>0?`Did you mean: ${l.slice(0,3).join(", ")}?`:c.length>0?`Available packages in ${t}: ${c.slice(0,5).join(", ")}`:`No packages found for publisher '${t}'. Verify the publisher name is correct.`;return{message:u,suggestion:m,expectedValue:"Existing package"}}let a=o.filter(c=>c.metadata.namespace_?.version).map(c=>c.metadata.namespace_.version.toString()).sort().join(", "),i=this.getAcceptableVersionRange(r);return{message:`Import '${t}/${r.toString()}' version mismatch - no compatible version found`,suggestion:`Available versions: ${a}. Required: ${i}`,expectedValue:i}}getAcceptableVersionRange(e){switch(e.versionOperator){case 0:return`exactly ${e.version.major}.${e.version.minor}.${e.version.patch}`;case 1:return`${e.version.major}.${e.version.minor}.${e.version.patch} to ${e.version.major}.${e.version.minor}.x`;case 2:return e.version.major===0?`0.${e.version.minor}.x`:`${e.version.major}.x.x`;case 3:return`any version >= ${e.version.major}.${e.version.minor}.${e.version.patch}`;default:return e.toString()}}findSimilarPackages(e,t){if(t.length===0)return[];let r=t.filter(s=>s.toLowerCase().includes(e.toLowerCase())||e.toLowerCase().includes(s.toLowerCase()));if(r.length>0)return r.sort((s,a)=>s.length-a.length);let n=t.map(s=>({package:s,distance:this.levenshteinDistance(e.toLowerCase(),s.toLowerCase())})).sort((s,a)=>s.distance-a.distance),o=Math.max(3,Math.floor(e.length*.4));return n.filter(s=>s.distance<=o).map(s=>s.package)}levenshteinDistance(e,t){if(!e||e.length===0)return t?.length??0;if(!t||t.length===0)return e.length;let r=e.length,n=t.length,o=Array(r+1).fill(null).map(()=>Array(n+1).fill(0));for(let s=0;s<=r;s++)o[s][0]=s;for(let s=0;s<=n;s++)o[0][s]=s;for(let s=1;s<=r;s++)for(let a=1;a<=n;a++){let i=e[s-1]===t[a-1]?0:1;o[s][a]=Math.min(Math.min(o[s-1][a]+1,o[s][a-1]+1),o[s-1][a-1]+i)}return o[r][n]}};var ye=class{ruleName="UnresolvedReference";async validateAsync(e,t){let r=[],n=new E(t),o=await n.buildEntityIndexAsync(e),s=new Set;for(let[a,i]of o.entries()){let c=i.entity.type;if(c){let l=c.toString();(l==="ObjectProperty"||l.endsWith(".ObjectProperty"))&&s.add(a)}}for(let[a,i]of Object.entries(e.body)){if(!i||typeof i!="object"||Array.isArray(i))continue;let c=i,l=this.getPropertyValue(c,"type");if(!(!l||l==="Class"||l.endsWith("Property")||l==="AnnotationProperty"))for(let[u,m]of Object.entries(c))u==="type"||u==="label"||u==="comment"||!(s.has(u)||Array.from(s).some(f=>f.endsWith(`.${u}`)))||await this.validateReferenceValue(a,u,m,e,n,r)}return r}async validateReferenceValue(e,t,r,n,o,s){if(r!=null){if(typeof r=="string")await o.resolveEntityAsync(r,n)||s.push(this.createUnresolvedReferenceError(e,t,r));else if(Array.isArray(r))for(let a=0;a<r.length;a++){let i=r[a];typeof i=="string"&&(await o.resolveEntityAsync(i,n)||s.push(this.createUnresolvedReferenceError(e,`${t}[${a}]`,i)))}}}createUnresolvedReferenceError(e,t,r){let n=`The entity '${r}' cannot be found in the current document or any imported namespaces.
11
+ Example: If the parent property is 'hasCharacter' with range 'Character', all embedded objects in that property will be typed as 'Character' automatically.`,l.expectedValue="No explicit type (inferred from parent property's range)",r.push(l)}if(typeof s=="object"&&s!==null)if(Array.isArray(s))for(let i=0;i<s.length;i++){let p=s[i];typeof p=="object"&&p!==null&&!Array.isArray(p)&&this.checkForEmbeddedTypeViolations(`${e}.${a}[${i}]`,p,r,n+1)}else this.checkForEmbeddedTypeViolations(`${e}.${a}`,s,r,n+1)}}};var ge=class{ruleName="ImportExistence";async validateAsync(e,t){let r=[];if(!e.metadata?.imports)return r;let n=await t.getAllDocumentsAsync();for(let[o,s]of Object.entries(e.metadata.imports))for(let a of s)if(!await t.getHighestCompatibleVersionAsync(o,a)){let p=await this.determineImportErrorAsync(t,o,a,n),l=new b;l.ruleType=this.ruleName,l.severity="Error",l.message=p.message,l.suggestion=p.suggestion,l.entityName=`Import: ${o}/${a.packageName}`,l.actualValue=a.toString(),l.expectedValue=p.expectedValue,r.push(l)}return r}async determineImportErrorAsync(e,t,r,n){let o=await e.getDocumentsByNamespaceAsync(t,r.packageName);if(o.length===0){let p=n.filter(y=>y.metadata.namespace_?.publisher===t).map(y=>y.metadata.namespace_.package_).filter((y,f,d)=>d.indexOf(y)===f),l=this.findSimilarPackages(r.packageName,p),u=`Import '${t}/${r.package_}' not found - package does not exist`,m=l.length>0?`Did you mean: ${l.slice(0,3).join(", ")}?`:p.length>0?`Available packages in ${t}: ${p.slice(0,5).join(", ")}`:`No packages found for publisher '${t}'. Verify the publisher name is correct.`;return{message:u,suggestion:m,expectedValue:"Existing package"}}let a=o.filter(p=>p.metadata.namespace_?.version).map(p=>p.metadata.namespace_.version.toString()).sort().join(", "),i=this.getAcceptableVersionRange(r);return{message:`Import '${t}/${r.toString()}' version mismatch - no compatible version found`,suggestion:`Available versions: ${a}. Required: ${i}`,expectedValue:i}}getAcceptableVersionRange(e){switch(e.versionOperator){case 0:return`exactly ${e.version.major}.${e.version.minor}.${e.version.patch}`;case 1:return`${e.version.major}.${e.version.minor}.${e.version.patch} to ${e.version.major}.${e.version.minor}.x`;case 2:return e.version.major===0?`0.${e.version.minor}.x`:`${e.version.major}.x.x`;case 3:return`any version >= ${e.version.major}.${e.version.minor}.${e.version.patch}`;default:return e.toString()}}findSimilarPackages(e,t){if(t.length===0)return[];let r=t.filter(s=>s.toLowerCase().includes(e.toLowerCase())||e.toLowerCase().includes(s.toLowerCase()));if(r.length>0)return r.sort((s,a)=>s.length-a.length);let n=t.map(s=>({package:s,distance:this.levenshteinDistance(e.toLowerCase(),s.toLowerCase())})).sort((s,a)=>s.distance-a.distance),o=Math.max(3,Math.floor(e.length*.4));return n.filter(s=>s.distance<=o).map(s=>s.package)}levenshteinDistance(e,t){if(!e||e.length===0)return t?.length??0;if(!t||t.length===0)return e.length;let r=e.length,n=t.length,o=Array(r+1).fill(null).map(()=>Array(n+1).fill(0));for(let s=0;s<=r;s++)o[s][0]=s;for(let s=0;s<=n;s++)o[0][s]=s;for(let s=1;s<=r;s++)for(let a=1;a<=n;a++){let i=e[s-1]===t[a-1]?0:1;o[s][a]=Math.min(Math.min(o[s-1][a]+1,o[s][a-1]+1),o[s-1][a-1]+i)}return o[r][n]}};var he=class{ruleName="UnresolvedReference";async validateAsync(e,t){let r=[],n=new E(t),o=await n.buildEntityIndexAsync(e),s=new Set;for(let[a,i]of o.entries()){let p=i.entity.type;if(p){let l=p.toString();(l==="ObjectProperty"||l.endsWith(".ObjectProperty"))&&s.add(a)}}for(let[a,i]of Object.entries(e.body)){if(!i||typeof i!="object"||Array.isArray(i))continue;let p=i,l=this.getPropertyValue(p,"type");if(!(!l||l==="Class"||l.endsWith("Property")||l==="AnnotationProperty"))for(let[u,m]of Object.entries(p))u==="type"||u==="label"||u==="comment"||!(s.has(u)||Array.from(s).some(f=>f.endsWith(`.${u}`)))||await this.validateReferenceValue(a,u,m,e,n,r)}return r}async validateReferenceValue(e,t,r,n,o,s){if(r!=null){if(typeof r=="string")await o.resolveEntityAsync(r,n)||s.push(this.createUnresolvedReferenceError(e,t,r));else if(Array.isArray(r))for(let a=0;a<r.length;a++){let i=r[a];typeof i=="string"&&(await o.resolveEntityAsync(i,n)||s.push(this.createUnresolvedReferenceError(e,`${t}[${a}]`,i)))}}}createUnresolvedReferenceError(e,t,r){let n=`The entity '${r}' cannot be found in the current document or any imported namespaces.
12
12
 
13
13
  Possible solutions:
14
14
  \u2022 Add import if the entity is defined in another namespace:
15
15
  kanonak namespace add-import <publisher>/<package>@<version>
16
16
  \u2022 Check for typos in the reference name '${r}'
17
17
  \u2022 Define '${r}' in the current namespace or an appropriate namespace
18
- \u2022 Use 'kanonak search type ${r} --include-imports' to locate the entity`,o=new k;return o.ruleType=this.ruleName,o.severity="Warning",o.entityName=e,o.propertyName=t,o.actualValue=r,o.message=`Reference to '${r}' could not be resolved`,o.suggestion=n,o.expectedValue="A valid entity reference that exists in the current document or imported namespaces",o}getPropertyValue(e,t){let r=e[t];return r?r.toString():null}};var fe=class{ruleName="TypeAmbiguity";async validateAsync(e,t){let r=[],n=new Map,o=[];if(e.metadata?.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){o.push({doc:c,import:i,publisher:s});let l=await this.getTransitiveImportsAsync(t,c,new Set);o.push(...l.map(u=>({doc:u,import:null,publisher:s})))}}for(let{doc:s,import:a}of o){let i=s.metadata?.namespace_?.toString()??"unknown";for(let c of Object.keys(s.body))n.has(c)||n.set(c,[]),n.get(c).push({namespace:i,import:a})}for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let i=a;this.checkAmbiguousReference(i,"type",n,s,r),this.checkAmbiguousReference(i,"subClassOf",n,s,r),this.checkAmbiguousReference(i,"subPropertyOf",n,s,r),this.checkAmbiguousReference(i,"domain",n,s,r),this.checkAmbiguousReference(i,"range",n,s,r)}return r}checkAmbiguousReference(e,t,r,n,o){let s=e[t];if(!s)return;let a=j(s);for(let i of a){if(i.includes("."))continue;let c=r.get(i);if(c&&c.length>1){let l=c.map(f=>f.namespace).join(", "),u=[];for(let{namespace:f,import:d}of c)if(d?.alias)u.push(`${d.alias}.${i}`);else{let g=f.split("/"),b=g[g.length-1]?.split("@")[0]??"alias";u.push(`${b}.${i}`)}let m=u.length>0?`Use one of: ${u.join(", ")}`:"Consider adding namespace aliases to your imports",y=new k;y.ruleType=this.ruleName,y.severity="Warning",y.entityName=n,y.propertyName=t,y.actualValue=i,y.message=`Type '${i}' is ambiguous. It's defined in: ${l}`,y.suggestion=m,o.push(y)}}}async getTransitiveImportsAsync(e,t,r){let n=[],o=t.metadata?.namespace_?.toString()??"";if(r.has(o))return n;if(r.add(o),t.metadata?.imports)for(let[s,a]of Object.entries(t.metadata.imports))for(let i of a){let c=await e.getHighestCompatibleVersionAsync(s,i);if(c){n.push(c);let l=await this.getTransitiveImportsAsync(e,c,r);n.push(...l)}}return n}};var de=class{ruleName="ClassHierarchyCycle";async validateAsync(e,t){let r=[],n=new Map,o=new Set;await this.buildClassHierarchy(e,t,n,o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let i=a,c=i.type,l=i.subClassOf;if(c?.toString()==="Class"&&l){let u=s,m=this.detectCycle(u,n);if(m){let y=m.join(" \u2192 "),f=new k;f.ruleType=this.ruleName,f.severity="Error",f.message=`Circular class hierarchy detected: ${y}`,f.suggestion="Remove the circular dependency by breaking one of the subClassOf relationships",f.entityName=u,f.propertyName="subClassOf",f.actualValue=y,r.push(f);break}}}return r}async buildClassHierarchy(e,t,r,n){let o=e.metadata?.namespace_?.toString()??"";if(!(o&&n.has(o))){o&&n.add(o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let i=a,c=i.type,l=i.subClassOf;if(c?.toString()==="Class"&&l){let u=j(l);u.length>0&&r.set(s,u)}}if(e.metadata?.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);c&&await this.buildClassHierarchy(c,t,r,n)}}}detectCycle(e,t){let r=[],n=new Set;return this.detectCycleRecursive(e,t,r,n)}detectCycleRecursive(e,t,r,n){if(r.includes(e)){let s=r.indexOf(e),a=r.slice(s);return a.push(e),a}if(n.has(e))return null;r.push(e),n.add(e);let o=t.get(e);if(o)for(let s of o){let a=this.detectCycleRecursive(s,t,r,n);if(a)return a}return r.pop(),null}};var ge=class{ruleName="PropertyHierarchyCycle";async validateAsync(e,t){let r=[],n=new Map,o=new Set;await this.buildPropertyHierarchy(e,t,n,o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)&&a.subPropertyOf){let l=s,u=this.detectCycle(l,n);if(u){let m=u.join(" \u2192 "),y=new k;y.ruleType=this.ruleName,y.severity="Error",y.message=`Circular property hierarchy detected: ${m}`,y.suggestion="Remove the circular dependency by breaking one of the subPropertyOf relationships",y.entityName=l,y.propertyName="subPropertyOf",y.actualValue=m,r.push(y);break}}return r}async buildPropertyHierarchy(e,t,r,n){let o=e.metadata?.namespace_?.toString()??"";if(!(o&&n.has(o))){o&&n.add(o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let i=a,c=i.type;if(c){let l=c.toString();if(l==="DatatypeProperty"||l==="ObjectProperty"||l==="AnnotationProperty"){let u=i.subPropertyOf;if(u){let m=j(u);m.length>0&&r.set(s,m)}}}}if(e.metadata?.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);c&&await this.buildPropertyHierarchy(c,t,r,n)}}}detectCycle(e,t){let r=[],n=new Set;return this.detectCycleRecursive(e,t,r,n)}detectCycleRecursive(e,t,r,n){if(r.includes(e)){let s=r.indexOf(e),a=r.slice(s);return a.push(e),a}if(n.has(e))return null;r.push(e),n.add(e);let o=t.get(e);if(o)for(let s of o){let a=this.detectCycleRecursive(s,t,r,n);if(a)return a}return r.pop(),null}};var he=class{get ruleName(){return"PropertyRangeRequired"}async validateAsync(e,t){let r=[];for(let[n,o]of Object.entries(e.body)){if(typeof o!="object"||o===null||Array.isArray(o))continue;let s=o,a=s.type?.toString();if(a==="DatatypeProperty"||a==="ObjectProperty"||a?.endsWith(".DatatypeProperty")||a?.endsWith(".ObjectProperty")){let i="range"in s,c=s.range?.toString().trim();if(!i||!c){let l=new k;l.ruleType=this.ruleName,l.severity="Error",l.entityName=n,l.propertyName="range",l.message=`Property '${n}' must have a 'range' defined.`,l.suggestion=a==="DatatypeProperty"?"Add a range like: range: string (or integer, boolean, etc.)":"Add a range like: range: ClassName (the class this property expects)",l.expectedValue=a==="DatatypeProperty"?"A datatype (string, integer, boolean, decimal, etc.)":"A class name (Character, Scene, Story, etc.)",r.push(l)}}}return r}};var ke=class{builtInClasses=new Set(["Resource","Class","Literal","Thing","Nothing","Property","DatatypeProperty","ObjectProperty","AnnotationProperty","FunctionalProperty","InverseFunctionalProperty","TransitiveProperty","SymmetricProperty"]);get ruleName(){return"SubClassOfReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();(i==="Class"||i&&i.endsWith(".Class"))&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=j(s.subClassOf);for(let c=0;c<i.length;c++){let l=i[c];if(this.builtInClasses.has(l)||n.has(l))continue;if(!await this.isClassAvailableInImports(e,t,l)){let m=i.length>1?`[${c}]`:"",y=new k;y.ruleType=this.ruleName,y.severity="Error",y.message=`Class '${l}' referenced in subClassOf${m} is not defined or imported`,y.suggestion=`Define '${l}' as a Class, or import a namespace that contains it`,y.entityName=o,y.propertyName="subClassOf",y.actualValue=l,y.expectedValue="Defined or imported class",r.push(y)}}}return r}async isClassAvailableInImports(e,t,r){if(!e.metadata.imports)return!1;let n=null,o=r;if(r.includes(".")){let s=r.split(".",2);n=s[0],o=s[1]}for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){if(n!==null&&i.alias!==n)continue;let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=n!==null?o:r,u=c.body[l];if(u&&typeof u=="object"&&!Array.isArray(u)){let f=u.type?.toString();if(f==="Class"||f&&f.endsWith(".Class"))return!0}let m=new Set;if(await this.isClassAvailableInImportsRecursive(c,t,l,m))return!0}}return!1}async isClassAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=c.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(m==="Class"||m&&m.endsWith(".Class"))return!0}if(await this.isClassAvailableInImportsRecursive(c,t,r,n))return!0}}return!1}};var be=class{builtInProperties=new Set(["type","label","comment","domain","range","subPropertyOf","subClassOf","inverseOf","sameAs","seeAlso","isDefinedBy","functional","required"]);get ruleName(){return"SubPropertyOfReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();(i==="DatatypeProperty"||i==="ObjectProperty"||i==="AnnotationProperty")&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=j(s.subPropertyOf);for(let c=0;c<i.length;c++){let l=i[c];if(this.builtInProperties.has(l)||n.has(l))continue;if(!await this.isPropertyAvailableInImports(e,t,l)){let m=i.length>1?`[${c}]`:"",y=new k;y.ruleType=this.ruleName,y.severity="Error",y.message=`Property '${l}' referenced in subPropertyOf${m} is not defined or imported`,y.suggestion=`Define '${l}' as a DatatypeProperty or ObjectProperty, or import a namespace that contains it`,y.entityName=o,y.propertyName="subPropertyOf",y.actualValue=l,y.expectedValue="Defined or imported property",r.push(y)}}}return r}async isPropertyAvailableInImports(e,t,r){if(!e.metadata.imports)return!1;let n=null,o=r;if(r.includes(".")){let s=r.split(".",2);n=s[0],o=s[1]}for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){if(n!==null&&i.alias!==n)continue;let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=n!==null?o:r,u=c.body[l];if(u&&typeof u=="object"&&!Array.isArray(u)){let f=u.type?.toString();if(f==="DatatypeProperty"||f==="ObjectProperty"||f==="AnnotationProperty")return!0}let m=new Set;if(await this.isPropertyAvailableInImportsRecursive(c,t,l,m))return!0}}return!1}async isPropertyAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=c.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(m==="DatatypeProperty"||m==="ObjectProperty"||m==="AnnotationProperty")return!0}if(await this.isPropertyAvailableInImportsRecursive(c,t,r,n))return!0}}return!1}};var Re=class{get ruleName(){return"NamespaceImportCycle"}async validateAsync(e,t){let r=[],n=e.metadata.namespace_?.toString();if(!n)return r;let o=new Map,s=new Set;await this.buildImportGraph(e,t,o,s);let a=this.detectCycle(n,o);if(a){let i=a.join(" \u2192 "),c=new k;c.ruleType=this.ruleName,c.severity="Error",c.message=`Circular namespace import detected: ${i}`,c.suggestion="Remove one of the imports to break the circular dependency. Circular dependencies prevent proper package resolution.",c.entityName="imports",c.propertyName="imports",c.actualValue=i,r.push(c)}return r}async buildImportGraph(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(!(!o||n.has(o))&&(n.add(o),e.metadata.imports)){let s=[];for(let[a,i]of Object.entries(e.metadata.imports))for(let c of i){let l=`${a}/${c.packageName}@${c.version}`;s.push(l);let u=await t.getHighestCompatibleVersionAsync(a,c);u&&await this.buildImportGraph(u,t,r,n)}s.length>0&&r.set(o,s)}}detectCycle(e,t){let r=[],n=new Set;return this.detectCycleRecursive(e,t,r,n)}detectCycleRecursive(e,t,r,n){let o=r.indexOf(e);if(o>=0){let a=r.slice(o);return a.push(e),a}if(n.has(e))return null;r.push(e),n.add(e);let s=t.get(e);if(s)for(let a of s){let i=this.detectCycleRecursive(a,t,r,n);if(i)return i}return r.pop(),null}};var ve=class{metadataKeys=new Set(["type","label","comment","subClassOf","subPropertyOf","domain","range","inverseOf","transitive","symmetric","functional","inverseFunctional"]);get ruleName(){return"InstancePropertyReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();this.isPropertyType(i)&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let a=s,i=a.type?.toString();if(this.isPropertyType(i)||this.isClassType(i))continue;for(let[c,l]of Object.entries(a)){if(!c||this.metadataKeys.has(c))continue;let u=c,m=null;if(c.includes(".")){let f=c.lastIndexOf(".");m=c.substring(0,f),u=c.substring(f+1)}if(n.has(u))continue;if(!await this.isPropertyAvailableInImports(e,t,u,m)){let f=new k;f.ruleType=this.ruleName,f.severity="Error",f.message=`Property '${c}' is not defined or imported`,f.suggestion=m?`The property '${u}' is not found in the imported namespace with alias '${m}'.
18
+ \u2022 Use 'kanonak search type ${r} --include-imports' to locate the entity`,o=new b;return o.ruleType=this.ruleName,o.severity="Warning",o.entityName=e,o.propertyName=t,o.actualValue=r,o.message=`Reference to '${r}' could not be resolved`,o.suggestion=n,o.expectedValue="A valid entity reference that exists in the current document or imported namespaces",o}getPropertyValue(e,t){let r=e[t];return r?r.toString():null}};var ke=class{ruleName="TypeAmbiguity";async validateAsync(e,t){let r=[],n=new Map,o=[];if(e.metadata?.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let p=await t.getHighestCompatibleVersionAsync(s,i);if(p){o.push({doc:p,import:i,publisher:s});let l=await this.getTransitiveImportsAsync(t,p,new Set);o.push(...l.map(u=>({doc:u,import:null,publisher:s})))}}for(let{doc:s,import:a}of o){let i=s.metadata?.namespace_?.toString()??"unknown";for(let p of Object.keys(s.body))n.has(p)||n.set(p,[]),n.get(p).push({namespace:i,import:a})}for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let i=a;this.checkAmbiguousReference(i,"type",n,s,r),this.checkAmbiguousReference(i,"subClassOf",n,s,r),this.checkAmbiguousReference(i,"subPropertyOf",n,s,r),this.checkAmbiguousReference(i,"domain",n,s,r),this.checkAmbiguousReference(i,"range",n,s,r)}return r}checkAmbiguousReference(e,t,r,n,o){let s=e[t];if(!s)return;let a=j(s);for(let i of a){if(i.includes("."))continue;let p=r.get(i);if(p&&p.length>1){let l=p.map(f=>f.namespace).join(", "),u=[];for(let{namespace:f,import:d}of p)if(d?.alias)u.push(`${d.alias}.${i}`);else{let g=f.split("/"),k=g[g.length-1]?.split("@")[0]??"alias";u.push(`${k}.${i}`)}let m=u.length>0?`Use one of: ${u.join(", ")}`:"Consider adding namespace aliases to your imports",y=new b;y.ruleType=this.ruleName,y.severity="Warning",y.entityName=n,y.propertyName=t,y.actualValue=i,y.message=`Type '${i}' is ambiguous. It's defined in: ${l}`,y.suggestion=m,o.push(y)}}}async getTransitiveImportsAsync(e,t,r){let n=[],o=t.metadata?.namespace_?.toString()??"";if(r.has(o))return n;if(r.add(o),t.metadata?.imports)for(let[s,a]of Object.entries(t.metadata.imports))for(let i of a){let p=await e.getHighestCompatibleVersionAsync(s,i);if(p){n.push(p);let l=await this.getTransitiveImportsAsync(e,p,r);n.push(...l)}}return n}};var be=class{ruleName="ClassHierarchyCycle";async validateAsync(e,t){let r=[],n=new Map,o=new Set;await this.buildClassHierarchy(e,t,n,o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let i=a,p=i.type,l=i.subClassOf;if(p?.toString()==="Class"&&l){let u=s,m=this.detectCycle(u,n);if(m){let y=m.join(" \u2192 "),f=new b;f.ruleType=this.ruleName,f.severity="Error",f.message=`Circular class hierarchy detected: ${y}`,f.suggestion="Remove the circular dependency by breaking one of the subClassOf relationships",f.entityName=u,f.propertyName="subClassOf",f.actualValue=y,r.push(f);break}}}return r}async buildClassHierarchy(e,t,r,n){let o=e.metadata?.namespace_?.toString()??"";if(!(o&&n.has(o))){o&&n.add(o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let i=a,p=i.type,l=i.subClassOf;if(p?.toString()==="Class"&&l){let u=j(l);u.length>0&&r.set(s,u)}}if(e.metadata?.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let p=await t.getHighestCompatibleVersionAsync(s,i);p&&await this.buildClassHierarchy(p,t,r,n)}}}detectCycle(e,t){let r=[],n=new Set;return this.detectCycleRecursive(e,t,r,n)}detectCycleRecursive(e,t,r,n){if(r.includes(e)){let s=r.indexOf(e),a=r.slice(s);return a.push(e),a}if(n.has(e))return null;r.push(e),n.add(e);let o=t.get(e);if(o)for(let s of o){let a=this.detectCycleRecursive(s,t,r,n);if(a)return a}return r.pop(),null}};var Re=class{ruleName="PropertyHierarchyCycle";async validateAsync(e,t){let r=[],n=new Map,o=new Set;await this.buildPropertyHierarchy(e,t,n,o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)&&a.subPropertyOf){let l=s,u=this.detectCycle(l,n);if(u){let m=u.join(" \u2192 "),y=new b;y.ruleType=this.ruleName,y.severity="Error",y.message=`Circular property hierarchy detected: ${m}`,y.suggestion="Remove the circular dependency by breaking one of the subPropertyOf relationships",y.entityName=l,y.propertyName="subPropertyOf",y.actualValue=m,r.push(y);break}}return r}async buildPropertyHierarchy(e,t,r,n){let o=e.metadata?.namespace_?.toString()??"";if(!(o&&n.has(o))){o&&n.add(o);for(let[s,a]of Object.entries(e.body))if(a&&typeof a=="object"&&!Array.isArray(a)){let i=a,p=i.type;if(p){let l=p.toString();if(l==="DatatypeProperty"||l==="ObjectProperty"||l==="AnnotationProperty"){let u=i.subPropertyOf;if(u){let m=j(u);m.length>0&&r.set(s,m)}}}}if(e.metadata?.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let p=await t.getHighestCompatibleVersionAsync(s,i);p&&await this.buildPropertyHierarchy(p,t,r,n)}}}detectCycle(e,t){let r=[],n=new Set;return this.detectCycleRecursive(e,t,r,n)}detectCycleRecursive(e,t,r,n){if(r.includes(e)){let s=r.indexOf(e),a=r.slice(s);return a.push(e),a}if(n.has(e))return null;r.push(e),n.add(e);let o=t.get(e);if(o)for(let s of o){let a=this.detectCycleRecursive(s,t,r,n);if(a)return a}return r.pop(),null}};var Pe=class{get ruleName(){return"PropertyRangeRequired"}async validateAsync(e,t){let r=[];for(let[n,o]of Object.entries(e.body)){if(typeof o!="object"||o===null||Array.isArray(o))continue;let s=o,a=s.type?.toString();if(a==="DatatypeProperty"||a==="ObjectProperty"||a?.endsWith(".DatatypeProperty")||a?.endsWith(".ObjectProperty")){let i="range"in s,p=s.range?.toString().trim();if(!i||!p){let l=new b;l.ruleType=this.ruleName,l.severity="Error",l.entityName=n,l.propertyName="range",l.message=`Property '${n}' must have a 'range' defined.`,l.suggestion=a==="DatatypeProperty"?"Add a range like: range: string (or integer, boolean, etc.)":"Add a range like: range: ClassName (the class this property expects)",l.expectedValue=a==="DatatypeProperty"?"A datatype (string, integer, boolean, decimal, etc.)":"A class name (Character, Scene, Story, etc.)",r.push(l)}}}return r}};var ve=class{builtInClasses=new Set(["Resource","Class","Literal","Thing","Nothing","Property","DatatypeProperty","ObjectProperty","AnnotationProperty","FunctionalProperty","InverseFunctionalProperty","TransitiveProperty","SymmetricProperty"]);get ruleName(){return"SubClassOfReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();(i==="Class"||i&&i.endsWith(".Class"))&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=j(s.subClassOf);for(let p=0;p<i.length;p++){let l=i[p];if(this.builtInClasses.has(l)||n.has(l))continue;if(!await this.isClassAvailableInImports(e,t,l)){let m=i.length>1?`[${p}]`:"",y=new b;y.ruleType=this.ruleName,y.severity="Error",y.message=`Class '${l}' referenced in subClassOf${m} is not defined or imported`,y.suggestion=`Define '${l}' as a Class, or import a namespace that contains it`,y.entityName=o,y.propertyName="subClassOf",y.actualValue=l,y.expectedValue="Defined or imported class",r.push(y)}}}return r}async isClassAvailableInImports(e,t,r){if(!e.metadata.imports)return!1;let n=null,o=r;if(r.includes(".")){let s=r.split(".",2);n=s[0],o=s[1]}for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){if(n!==null&&i.alias!==n)continue;let p=await t.getHighestCompatibleVersionAsync(s,i);if(p){let l=n!==null?o:r,u=p.body[l];if(u&&typeof u=="object"&&!Array.isArray(u)){let f=u.type?.toString();if(f==="Class"||f&&f.endsWith(".Class"))return!0}let m=new Set;if(await this.isClassAvailableInImportsRecursive(p,t,l,m))return!0}}return!1}async isClassAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let p=await t.getHighestCompatibleVersionAsync(s,i);if(p){let l=p.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(m==="Class"||m&&m.endsWith(".Class"))return!0}if(await this.isClassAvailableInImportsRecursive(p,t,r,n))return!0}}return!1}};var we=class{builtInProperties=new Set(["type","label","comment","domain","range","subPropertyOf","subClassOf","inverseOf","sameAs","seeAlso","isDefinedBy","functional","required"]);get ruleName(){return"SubPropertyOfReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();(i==="DatatypeProperty"||i==="ObjectProperty"||i==="AnnotationProperty")&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=j(s.subPropertyOf);for(let p=0;p<i.length;p++){let l=i[p];if(this.builtInProperties.has(l)||n.has(l))continue;if(!await this.isPropertyAvailableInImports(e,t,l)){let m=i.length>1?`[${p}]`:"",y=new b;y.ruleType=this.ruleName,y.severity="Error",y.message=`Property '${l}' referenced in subPropertyOf${m} is not defined or imported`,y.suggestion=`Define '${l}' as a DatatypeProperty or ObjectProperty, or import a namespace that contains it`,y.entityName=o,y.propertyName="subPropertyOf",y.actualValue=l,y.expectedValue="Defined or imported property",r.push(y)}}}return r}async isPropertyAvailableInImports(e,t,r){if(!e.metadata.imports)return!1;let n=null,o=r;if(r.includes(".")){let s=r.split(".",2);n=s[0],o=s[1]}for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){if(n!==null&&i.alias!==n)continue;let p=await t.getHighestCompatibleVersionAsync(s,i);if(p){let l=n!==null?o:r,u=p.body[l];if(u&&typeof u=="object"&&!Array.isArray(u)){let f=u.type?.toString();if(f==="DatatypeProperty"||f==="ObjectProperty"||f==="AnnotationProperty")return!0}let m=new Set;if(await this.isPropertyAvailableInImportsRecursive(p,t,l,m))return!0}}return!1}async isPropertyAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let p=await t.getHighestCompatibleVersionAsync(s,i);if(p){let l=p.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(m==="DatatypeProperty"||m==="ObjectProperty"||m==="AnnotationProperty")return!0}if(await this.isPropertyAvailableInImportsRecursive(p,t,r,n))return!0}}return!1}};var Ie=class{get ruleName(){return"NamespaceImportCycle"}async validateAsync(e,t){let r=[],n=e.metadata.namespace_?.toString();if(!n)return r;let o=new Map,s=new Set;await this.buildImportGraph(e,t,o,s);let a=this.detectCycle(n,o);if(a){let i=a.join(" \u2192 "),p=new b;p.ruleType=this.ruleName,p.severity="Error",p.message=`Circular namespace import detected: ${i}`,p.suggestion="Remove one of the imports to break the circular dependency. Circular dependencies prevent proper package resolution.",p.entityName="imports",p.propertyName="imports",p.actualValue=i,r.push(p)}return r}async buildImportGraph(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(!(!o||n.has(o))&&(n.add(o),e.metadata.imports)){let s=[];for(let[a,i]of Object.entries(e.metadata.imports))for(let p of i){let l=`${a}/${p.packageName}@${p.version}`;s.push(l);let u=await t.getHighestCompatibleVersionAsync(a,p);u&&await this.buildImportGraph(u,t,r,n)}s.length>0&&r.set(o,s)}}detectCycle(e,t){let r=[],n=new Set;return this.detectCycleRecursive(e,t,r,n)}detectCycleRecursive(e,t,r,n){let o=r.indexOf(e);if(o>=0){let a=r.slice(o);return a.push(e),a}if(n.has(e))return null;r.push(e),n.add(e);let s=t.get(e);if(s)for(let a of s){let i=this.detectCycleRecursive(a,t,r,n);if(i)return i}return r.pop(),null}};var Se=class{metadataKeys=new Set(["type","label","comment","subClassOf","subPropertyOf","domain","range","inverseOf","transitive","symmetric","functional","inverseFunctional"]);get ruleName(){return"InstancePropertyReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();this.isPropertyType(i)&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let a=s,i=a.type?.toString();if(this.isPropertyType(i)||this.isClassType(i))continue;for(let[p,l]of Object.entries(a)){if(!p||this.metadataKeys.has(p))continue;let u=p,m=null;if(p.includes(".")){let f=p.lastIndexOf(".");m=p.substring(0,f),u=p.substring(f+1)}if(n.has(u))continue;if(!await this.isPropertyAvailableInImports(e,t,u,m)){let f=new b;f.ruleType=this.ruleName,f.severity="Error",f.message=`Property '${p}' is not defined or imported`,f.suggestion=m?`The property '${u}' is not found in the imported namespace with alias '${m}'.
19
19
  1. Verify the namespace is imported with the correct alias
20
20
  2. Check if the property name is spelled correctly
21
- 3. Ensure the imported namespace version contains this property`:`The property '${c}' is not defined in this namespace or any imported namespace.
22
- 1. Define '${c}' as an ObjectProperty or DatatypeProperty in this namespace, OR
23
- 2. Import the namespace that contains '${c}', OR
24
- 3. Use a qualified reference like 'alias.${c}' if already imported with an alias`,f.entityName=o,f.propertyName=c,f.actualValue=l?.toString(),f.expectedValue="A defined or imported property",r.push(f)}}}return r}isPropertyType(e){return e?e==="ObjectProperty"||e==="DatatypeProperty"||e==="AnnotationProperty"||e==="Property"||e.endsWith(".ObjectProperty")||e.endsWith(".DatatypeProperty")||e.endsWith(".AnnotationProperty")||e.endsWith(".Property"):!1}isClassType(e){return e?e==="Class"||e.endsWith(".Class"):!1}async isPropertyAvailableInImports(e,t,r,n){if(!e.metadata.imports)return!1;for(let[o,s]of Object.entries(e.metadata.imports))for(let a of s){if(n!==null&&a.alias!==n)continue;let i=await t.getHighestCompatibleVersionAsync(o,a);if(i){let c=i.body[r];if(c&&typeof c=="object"&&!Array.isArray(c)){let m=c.type?.toString();if(this.isPropertyType(m))return!0}let l=new Set;if(await this.isPropertyAvailableInImportsRecursive(i,t,r,l))return!0}}return!1}async isPropertyAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=c.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(this.isPropertyType(m))return!0}if(await this.isPropertyAvailableInImportsRecursive(c,t,r,n))return!0}}return!1}};var Pe=class{metadataKeys=new Set(["type","label","comment","subClassOf","subPropertyOf","domain","range","inverseOf","transitive","symmetric","functional","inverseFunctional"]);get ruleName(){return"DefinitionPropertyReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();this.isPropertyType(i)&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let a=s,i=a.type?.toString();if(!this.isPropertyType(i)&&!this.isClassType(i))continue;for(let[c,l]of Object.entries(a)){if(!c||this.metadataKeys.has(c))continue;let u=c,m=null;if(c.includes(".")){let f=c.lastIndexOf(".");m=c.substring(0,f),u=c.substring(f+1)}if(n.has(u))continue;if(!await this.isPropertyAvailableInImports(e,t,u,m)){let f=this.isClassType(i)?"class":"property",d=new k;d.ruleType=this.ruleName,d.severity="Error",d.message=`Property '${c}' used on ${f} '${o}' is not defined or imported`,d.suggestion=m?`The property '${u}' is not found in the imported namespace with alias '${m}'.
21
+ 3. Ensure the imported namespace version contains this property`:`The property '${p}' is not defined in this namespace or any imported namespace.
22
+ 1. Define '${p}' as an ObjectProperty or DatatypeProperty in this namespace, OR
23
+ 2. Import the namespace that contains '${p}', OR
24
+ 3. Use a qualified reference like 'alias.${p}' if already imported with an alias`,f.entityName=o,f.propertyName=p,f.actualValue=l?.toString(),f.expectedValue="A defined or imported property",r.push(f)}}}return r}isPropertyType(e){return e?e==="ObjectProperty"||e==="DatatypeProperty"||e==="AnnotationProperty"||e==="Property"||e.endsWith(".ObjectProperty")||e.endsWith(".DatatypeProperty")||e.endsWith(".AnnotationProperty")||e.endsWith(".Property"):!1}isClassType(e){return e?e==="Class"||e.endsWith(".Class"):!1}async isPropertyAvailableInImports(e,t,r,n){if(!e.metadata.imports)return!1;for(let[o,s]of Object.entries(e.metadata.imports))for(let a of s){if(n!==null&&a.alias!==n)continue;let i=await t.getHighestCompatibleVersionAsync(o,a);if(i){let p=i.body[r];if(p&&typeof p=="object"&&!Array.isArray(p)){let m=p.type?.toString();if(this.isPropertyType(m))return!0}let l=new Set;if(await this.isPropertyAvailableInImportsRecursive(i,t,r,l))return!0}}return!1}async isPropertyAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let p=await t.getHighestCompatibleVersionAsync(s,i);if(p){let l=p.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(this.isPropertyType(m))return!0}if(await this.isPropertyAvailableInImportsRecursive(p,t,r,n))return!0}}return!1}};var Ae=class{metadataKeys=new Set(["type","label","comment","subClassOf","subPropertyOf","domain","range","inverseOf","transitive","symmetric","functional","inverseFunctional"]);get ruleName(){return"DefinitionPropertyReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();this.isPropertyType(i)&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let a=s,i=a.type?.toString();if(!this.isPropertyType(i)&&!this.isClassType(i))continue;for(let[p,l]of Object.entries(a)){if(!p||this.metadataKeys.has(p))continue;let u=p,m=null;if(p.includes(".")){let f=p.lastIndexOf(".");m=p.substring(0,f),u=p.substring(f+1)}if(n.has(u))continue;if(!await this.isPropertyAvailableInImports(e,t,u,m)){let f=this.isClassType(i)?"class":"property",d=new b;d.ruleType=this.ruleName,d.severity="Error",d.message=`Property '${p}' used on ${f} '${o}' is not defined or imported`,d.suggestion=m?`The property '${u}' is not found in the imported namespace with alias '${m}'.
25
25
  1. Verify the namespace is imported with the correct alias
26
26
  2. Check if the property name is spelled correctly
27
- 3. Ensure the imported namespace version contains this property`:`The property '${c}' is not defined in this namespace or any imported namespace.
28
- 1. Define '${c}' as an ObjectProperty or DatatypeProperty in this namespace, OR
29
- 2. Import the namespace that contains '${c}', OR
30
- 3. Use a qualified reference like 'alias.${c}' if already imported with an alias`,d.entityName=o,d.propertyName=c,d.actualValue=l?.toString(),d.expectedValue="A defined or imported property",r.push(d)}}}return r}isPropertyType(e){return e?e==="ObjectProperty"||e==="DatatypeProperty"||e==="AnnotationProperty"||e==="Property"||e.endsWith(".ObjectProperty")||e.endsWith(".DatatypeProperty")||e.endsWith(".AnnotationProperty")||e.endsWith(".Property"):!1}isClassType(e){return e?e==="Class"||e.endsWith(".Class"):!1}async isPropertyAvailableInImports(e,t,r,n){if(!e.metadata.imports)return!1;for(let[o,s]of Object.entries(e.metadata.imports))for(let a of s){if(n!==null&&a.alias!==n)continue;let i=await t.getHighestCompatibleVersionAsync(o,a);if(i){let c=i.body[r];if(c&&typeof c=="object"&&!Array.isArray(c)){let m=c.type?.toString();if(this.isPropertyType(m))return!0}let l=new Set;if(await this.isPropertyAvailableInImportsRecursive(i,t,r,l))return!0}}return!1}async isPropertyAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=c.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(this.isPropertyType(m))return!0}if(await this.isPropertyAvailableInImportsRecursive(c,t,r,n))return!0}}return!1}};var we=class{xsdTypes=new Set(["string","integer","boolean","decimal","float","double","date","dateTime","time","duration","anyURI","base64Binary","hexBinary","long","int","short","byte","unsignedLong","unsignedInt","unsignedShort","unsignedByte","positiveInteger","nonPositiveInteger","negativeInteger","nonNegativeInteger","normalizedString","token","language","Name","NCName","ENTITY","ENTITIES","IDREF","IDREFS","NMTOKEN","NMTOKENS"]);get ruleName(){return"XsdImport"}async validateAsync(e,t){let r=[],n=new Set,o=[];for(let[s,a]of Object.entries(e.body))if(typeof a=="object"&&a!==null&&!Array.isArray(a)){let i=a,c=!1,l=i.type;if(Array.isArray(l)){for(let u of l)if(u?.toString()==="DatatypeProperty"){c=!0;break}}else l?.toString()==="DatatypeProperty"&&(c=!0);if(c){o.push(s);let u=this.getPropertyValue(i,"range");u&&this.xsdTypes.has(u)&&n.add(u)}}if(n.size>0&&!await this.checkXsdImportAsync(e.metadata,t)){let a=Array.from(n).sort().join(", "),i=o.sort().join(", "),c=new k;c.ruleType=this.ruleName,c.severity="Error",c.message=`XSD namespace not imported but XSD types are used: ${a}`,c.suggestion=`Add an XSD import to the imports section. The core XSD types package is 'core-xsd' from publisher 'kanonak.org'. Used by properties: ${i}`,c.entityName="imports",r.push(c)}return r}async checkXsdImportAsync(e,t,r=new Set){if(!e?.imports)return!1;let n=e.namespace_?.toString()??"";if(n&&r.has(n))return!1;n&&r.add(n);for(let[,o]of Object.entries(e.imports))for(let s of o)if(s.packageName==="xsd"||s.packageName.toLowerCase().endsWith("-xsd"))return!0;for(let[o,s]of Object.entries(e.imports))for(let a of s){let i=await t.getHighestCompatibleVersionAsync(o,a);if(i?.metadata&&await this.checkXsdImportAsync(i.metadata,t,r))return!0}return!1}getPropertyValue(e,t){return e[t]?.toString()}};var Ie=class{get ruleName(){return"AmbiguousReference"}async validateAsync(e,t){let r=[],n=await this.buildEntitySourceMapAsync(e,t);for(let[o,s]of Object.entries(e.body))typeof s=="object"&&s!==null&&!Array.isArray(s)&&this.validateEntityReferences(o,s,n,e,r);return r}async buildEntitySourceMapAsync(e,t){let r=new Map,n=new Set;for(let o of Object.keys(e.body)){let s=e.metadata.namespace_?.toString()??"";r.has(o)||r.set(o,[]),r.get(o).push(`(local:${s})`)}if(e.metadata.imports)for(let[o,s]of Object.entries(e.metadata.imports))for(let a of s){let i=await t.getHighestCompatibleVersionAsync(o,a);i&&await this.collectEntitiesRecursivelyAsync(i,r,n,t)}return r}async collectEntitiesRecursivelyAsync(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(!r.has(o)){r.add(o);for(let s of Object.keys(e.body)){t.has(s)||t.set(s,[]);let a=t.get(s);a.includes(o)||a.push(o)}if(e.metadata.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await n.getHighestCompatibleVersionAsync(s,i);c&&await this.collectEntitiesRecursivelyAsync(c,t,r,n)}}}validateEntityReferences(e,t,r,n,o){for(let[s,a]of Object.entries(t)){let i=s;if(i&&!i.includes(".")){let c=r.get(i);if(c&&c.length>1&&!c.some(u=>u.startsWith("(local:"))){let u=c.filter(m=>!m.startsWith("(local:"));u.length>1&&o.push(this.createAmbiguityError(e,i,`Property '${i}'`,u,n,!0,i))}}this.validatePropertyValue(e,i,a,r,n,o)}}validatePropertyValue(e,t,r,n,o,s){if(r!=null){if(typeof r=="string"&&!r.includes(".")){let a=n.get(r);if(a&&a.length>1&&!a.some(c=>c.startsWith("(local:"))){let c=a.filter(l=>!l.startsWith("(local:"));c.length>1&&s.push(this.createAmbiguityError(e,t,`Reference '${r}'`,c,o,!1,r))}}else if(Array.isArray(r))for(let a=0;a<r.length;a++){let i=`${e}.${t}[${a}]`;this.validatePropertyValue(i,null,r[a],n,o,s)}else if(typeof r=="object"&&!Array.isArray(r)){let a=t?`${e}.${t}`:e;this.validateEntityReferences(a,r,n,o,s)}}}createAmbiguityError(e,t,r,n,o,s,a){let i=[];for(let d of n){let g=this.findAliasForNamespace(o,d);if(g){let h=t?.split(".").pop()??t;i.push(`${g}.${h}`)}}let c=i.length>0?`Use one of: ${i.map(d=>`'${d}'`).join(", ")}`:`Add aliases to imports and use qualified names (e.g., 'alias.${t}')`,l=n.map(d=>` \u2022 ${d}`).join(`
31
- `),u=e.split(".")[0],m=e.includes(".")?e:t,y=new k;y.ruleType=this.ruleName,y.severity="Error",y.entityName=u,m&&(y.propertyName=m);let f=a??t;return f&&(y.actualValue=f),y.message=`${r} is ambiguous - defined in multiple imported namespaces`,y.suggestion=`${c}
27
+ 3. Ensure the imported namespace version contains this property`:`The property '${p}' is not defined in this namespace or any imported namespace.
28
+ 1. Define '${p}' as an ObjectProperty or DatatypeProperty in this namespace, OR
29
+ 2. Import the namespace that contains '${p}', OR
30
+ 3. Use a qualified reference like 'alias.${p}' if already imported with an alias`,d.entityName=o,d.propertyName=p,d.actualValue=l?.toString(),d.expectedValue="A defined or imported property",r.push(d)}}}return r}isPropertyType(e){return e?e==="ObjectProperty"||e==="DatatypeProperty"||e==="AnnotationProperty"||e==="Property"||e.endsWith(".ObjectProperty")||e.endsWith(".DatatypeProperty")||e.endsWith(".AnnotationProperty")||e.endsWith(".Property"):!1}isClassType(e){return e?e==="Class"||e.endsWith(".Class"):!1}async isPropertyAvailableInImports(e,t,r,n){if(!e.metadata.imports)return!1;for(let[o,s]of Object.entries(e.metadata.imports))for(let a of s){if(n!==null&&a.alias!==n)continue;let i=await t.getHighestCompatibleVersionAsync(o,a);if(i){let p=i.body[r];if(p&&typeof p=="object"&&!Array.isArray(p)){let m=p.type?.toString();if(this.isPropertyType(m))return!0}let l=new Set;if(await this.isPropertyAvailableInImportsRecursive(i,t,r,l))return!0}}return!1}async isPropertyAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let p=await t.getHighestCompatibleVersionAsync(s,i);if(p){let l=p.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(this.isPropertyType(m))return!0}if(await this.isPropertyAvailableInImportsRecursive(p,t,r,n))return!0}}return!1}};var De=class{xsdTypes=new Set(["string","integer","boolean","decimal","float","double","date","dateTime","time","duration","anyURI","base64Binary","hexBinary","long","int","short","byte","unsignedLong","unsignedInt","unsignedShort","unsignedByte","positiveInteger","nonPositiveInteger","negativeInteger","nonNegativeInteger","normalizedString","token","language","Name","NCName","ENTITY","ENTITIES","IDREF","IDREFS","NMTOKEN","NMTOKENS"]);get ruleName(){return"XsdImport"}async validateAsync(e,t){let r=[],n=new Set,o=[];for(let[s,a]of Object.entries(e.body))if(typeof a=="object"&&a!==null&&!Array.isArray(a)){let i=a,p=!1,l=i.type;if(Array.isArray(l)){for(let u of l)if(u?.toString()==="DatatypeProperty"){p=!0;break}}else l?.toString()==="DatatypeProperty"&&(p=!0);if(p){o.push(s);let u=this.getPropertyValue(i,"range");u&&this.xsdTypes.has(u)&&n.add(u)}}if(n.size>0&&!await this.checkXsdImportAsync(e.metadata,t)){let a=Array.from(n).sort().join(", "),i=o.sort().join(", "),p=new b;p.ruleType=this.ruleName,p.severity="Error",p.message=`XSD namespace not imported but XSD types are used: ${a}`,p.suggestion=`Add an XSD import to the imports section. The core XSD types package is 'core-xsd' from publisher 'kanonak.org'. Used by properties: ${i}`,p.entityName="imports",r.push(p)}return r}async checkXsdImportAsync(e,t,r=new Set){if(!e?.imports)return!1;let n=e.namespace_?.toString()??"";if(n&&r.has(n))return!1;n&&r.add(n);for(let[,o]of Object.entries(e.imports))for(let s of o)if(s.packageName==="xsd"||s.packageName.toLowerCase().endsWith("-xsd"))return!0;for(let[o,s]of Object.entries(e.imports))for(let a of s){let i=await t.getHighestCompatibleVersionAsync(o,a);if(i?.metadata&&await this.checkXsdImportAsync(i.metadata,t,r))return!0}return!1}getPropertyValue(e,t){return e[t]?.toString()}};var Ce=class{get ruleName(){return"AmbiguousReference"}async validateAsync(e,t){let r=[],n=await this.buildEntitySourceMapAsync(e,t),o=await this.buildDatatypePropertyNamesAsync(e,t);for(let[s,a]of Object.entries(e.body))typeof a=="object"&&a!==null&&!Array.isArray(a)&&this.validateEntityReferences(s,a,n,o,e,r);return r}async buildEntitySourceMapAsync(e,t){let r=new Map,n=new Set;for(let o of Object.keys(e.body)){let s=e.metadata.namespace_?.toString()??"";r.has(o)||r.set(o,[]),r.get(o).push(`(local:${s})`)}if(e.metadata.imports)for(let[o,s]of Object.entries(e.metadata.imports))for(let a of s){let i=await t.getHighestCompatibleVersionAsync(o,a);i&&await this.collectEntitiesRecursivelyAsync(i,r,n,t)}return r}async collectEntitiesRecursivelyAsync(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(!r.has(o)){r.add(o);for(let s of Object.keys(e.body)){t.has(s)||t.set(s,[]);let a=t.get(s);a.includes(o)||a.push(o)}if(e.metadata.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let p=await n.getHighestCompatibleVersionAsync(s,i);p&&await this.collectEntitiesRecursivelyAsync(p,t,r,n)}}}async buildDatatypePropertyNamesAsync(e,t){let r=new Set,n=new Set;if(await this.collectDatatypePropertiesAsync(e,r,n,t),e.metadata.imports)for(let[o,s]of Object.entries(e.metadata.imports))for(let a of s){let i=await t.getHighestCompatibleVersionAsync(o,a);i&&await this.collectDatatypePropertiesAsync(i,r,n,t)}return r}async collectDatatypePropertiesAsync(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(!r.has(o)){r.add(o);for(let[s,a]of Object.entries(e.body)){if(typeof a!="object"||a===null||Array.isArray(a))continue;let i=a.type;if(typeof i!="string")continue;(i.includes(".")?i.substring(i.lastIndexOf(".")+1):i)==="DatatypeProperty"&&t.add(s)}if(e.metadata.imports)for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let p=await n.getHighestCompatibleVersionAsync(s,i);p&&await this.collectDatatypePropertiesAsync(p,t,r,n)}}}validateEntityReferences(e,t,r,n,o,s){for(let[a,i]of Object.entries(t)){let p=a;if(p&&!p.includes(".")){let l=r.get(p);if(l&&l.length>1&&!l.some(m=>m.startsWith("(local:"))){let m=l.filter(y=>!y.startsWith("(local:"));m.length>1&&s.push(this.createAmbiguityError(e,p,`Property '${p}'`,m,o,!0,p))}}this.validatePropertyValue(e,p,i,r,n,o,s)}}validatePropertyValue(e,t,r,n,o,s,a){if(r==null)return;let i=t&&t.includes(".")?t.substring(t.lastIndexOf(".")+1):t,p=!!i&&o.has(i);if(typeof r=="string"&&!r.includes(".")&&!p){let l=n.get(r);if(l&&l.length>1&&!l.some(m=>m.startsWith("(local:"))){let m=l.filter(y=>!y.startsWith("(local:"));m.length>1&&a.push(this.createAmbiguityError(e,t,`Reference '${r}'`,m,s,!1,r))}}else if(Array.isArray(r))for(let l=0;l<r.length;l++){let u=`${e}.${t}[${l}]`;this.validatePropertyValue(u,t,r[l],n,o,s,a)}else if(typeof r=="object"&&!Array.isArray(r)){let l=t?`${e}.${t}`:e;this.validateEntityReferences(l,r,n,o,s,a)}}createAmbiguityError(e,t,r,n,o,s,a){let i=[];for(let d of n){let g=this.findAliasForNamespace(o,d);if(g){let h=t?.split(".").pop()??t;i.push(`${g}.${h}`)}}let p=i.length>0?`Use one of: ${i.map(d=>`'${d}'`).join(", ")}`:`Add aliases to imports and use qualified names (e.g., 'alias.${t}')`,l=n.map(d=>` \u2022 ${d}`).join(`
31
+ `),u=e.split(".")[0],m=e.includes(".")?e:t,y=new b;y.ruleType=this.ruleName,y.severity="Error",y.entityName=u,m&&(y.propertyName=m);let f=a??t;return f&&(y.actualValue=f),y.message=`${r} is ambiguous - defined in multiple imported namespaces`,y.suggestion=`${p}
32
32
 
33
33
  Defined in:
34
- ${l}`,y.expectedValue="Unambiguous reference (use namespace alias to disambiguate)",y}findAliasForNamespace(e,t){if(!e.metadata.imports)return null;for(let[r,n]of Object.entries(e.metadata.imports))for(let o of n)if(`${r}/${o.packageName}@${o.version}`===t&&o.alias)return o.alias;return null}};var Ae=class{builtInClasses=new Set(["Resource","Class","Literal","Thing","Nothing","Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]);primitiveTypes=new Set(["string","integer","int","long","short","byte","decimal","float","double","boolean","bool","dateTime","date","time","duration","anyURI","anySimpleType","nonNegativeInteger","positiveInteger","negativeInteger","nonPositiveInteger","unsignedInt","unsignedLong","unsignedShort","unsignedByte","base64Binary","hexBinary","Literal","Resource"]);get ruleName(){return"PropertyRangeReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();this.isValidRangeTargetType(i)&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let a=s,i=a.type?.toString();if(i!=="DatatypeProperty"&&i!=="ObjectProperty"&&!i?.endsWith(".DatatypeProperty")&&!i?.endsWith(".ObjectProperty"))continue;let c=a.range;if(!c)continue;let l=[];if(Array.isArray(c))for(let u of c){let m=u?.toString();m&&l.push(m)}else{let u=c?.toString();u&&l.push(u)}if(l.length===0)continue;for(let u of l){if(this.primitiveTypes.has(u)||this.builtInClasses.has(u)||n.has(u))continue;if(!await this.isTypeAvailableInImports(e,t,u)){let y=i?.includes("ObjectProperty")?"ObjectProperty":"DatatypeProperty",f=new k;f.ruleType=this.ruleName,f.severity="Error",f.message=`Property '${o}' has range '${u}' which is not defined or imported`,f.suggestion=y==="ObjectProperty"?`For ObjectProperty:
34
+ ${l}`,y.expectedValue="Unambiguous reference (use namespace alias to disambiguate)",y}findAliasForNamespace(e,t){if(!e.metadata.imports)return null;for(let[r,n]of Object.entries(e.metadata.imports))for(let o of n)if(`${r}/${o.packageName}@${o.version}`===t&&o.alias)return o.alias;return null}};var Ke=class{builtInClasses=new Set(["Resource","Class","Literal","Thing","Nothing","Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]);primitiveTypes=new Set(["string","integer","int","long","short","byte","decimal","float","double","boolean","bool","dateTime","date","time","duration","anyURI","anySimpleType","nonNegativeInteger","positiveInteger","negativeInteger","nonPositiveInteger","unsignedInt","unsignedLong","unsignedShort","unsignedByte","base64Binary","hexBinary","Literal","Resource"]);get ruleName(){return"PropertyRangeReference"}async validateAsync(e,t){let r=[],n=new Set;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let i=s.type?.toString();this.isValidRangeTargetType(i)&&n.add(o)}for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let a=s,i=a.type?.toString();if(i!=="DatatypeProperty"&&i!=="ObjectProperty"&&!i?.endsWith(".DatatypeProperty")&&!i?.endsWith(".ObjectProperty"))continue;let p=a.range;if(!p)continue;let l=[];if(Array.isArray(p))for(let u of p){let m=u?.toString();m&&l.push(m)}else{let u=p?.toString();u&&l.push(u)}if(l.length===0)continue;for(let u of l){if(this.primitiveTypes.has(u)||this.builtInClasses.has(u)||n.has(u))continue;if(!await this.isTypeAvailableInImports(e,t,u)){let y=i?.includes("ObjectProperty")?"ObjectProperty":"DatatypeProperty",f=new b;f.ruleType=this.ruleName,f.severity="Error",f.message=`Property '${o}' has range '${u}' which is not defined or imported`,f.suggestion=y==="ObjectProperty"?`For ObjectProperty:
35
35
  1. Define '${u}' as a Class in this namespace, OR
36
36
  2. Import the namespace that contains '${u}', OR
37
37
  3. Use a qualified reference like 'alias.${u}' if already imported with an alias`:`For DatatypeProperty:
38
38
  1. Use a primitive type (string, integer, boolean, dateTime, etc.), OR
39
- 2. If '${u}' should be a class, change property type to ObjectProperty`,f.entityName=o,f.propertyName="range",f.actualValue=u,f.expectedValue=y==="ObjectProperty"?"A defined or imported class name":"A primitive type or defined class",r.push(f)}}}return r}async isTypeAvailableInImports(e,t,r){if(!e.metadata.imports)return!1;let n=null,o=r;if(r.includes(".")){let s=r.split(".",2);n=s[0],o=s[1]}for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){if(n!==null&&i.alias!==n)continue;let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=n!==null?o:r,u=c.body[l];if(u&&typeof u=="object"&&!Array.isArray(u)){let f=u.type?.toString();if(this.isValidRangeTargetType(f))return!0}let m=new Set;if(await this.isTypeAvailableInImportsRecursive(c,t,l,m))return!0}}return!1}async isTypeAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let c=await t.getHighestCompatibleVersionAsync(s,i);if(c){let l=c.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(this.isValidRangeTargetType(m))return!0}if(await this.isTypeAvailableInImportsRecursive(c,t,r,n))return!0}}return!1}isValidRangeTargetType(e){return e?e==="Class"||e.endsWith(".Class")||e==="Datatype"||e.endsWith(".Datatype"):!1}};var Se=class{xsdTypes=new Set(["string","integer","boolean","decimal","float","double","date","dateTime","time","duration","anyURI","base64Binary","hexBinary","long","int","short","byte","unsignedLong","unsignedInt","unsignedShort","unsignedByte","positiveInteger","nonPositiveInteger","negativeInteger","nonNegativeInteger","normalizedString","token","language","Name","NCName","ENTITY","ENTITIES","IDREF","IDREFS","NMTOKEN","NMTOKENS"]);get ruleName(){return"ObjectPropertyImport"}async validateAsync(e,t){let r=[],n=new Map,o=new E(t);await o.buildEntityIndexAsync(e);for(let[s,a]of Object.entries(e.body))if(typeof a=="object"&&a!==null&&!Array.isArray(a)){let i=a,c=!1,l=i.type;if(Array.isArray(l)){for(let u of l)if(u?.toString()==="ObjectProperty"){c=!0;break}}else l?.toString()==="ObjectProperty"&&(c=!0);if(c){let u=i.range,m=[];if(Array.isArray(u))for(let y of u){let f=y?.toString();f&&m.push(f)}else{let y=u?.toString();y&&m.push(y)}for(let y of m)this.xsdTypes.has(y)||(n.has(y)||n.set(y,[]),n.get(y).push(s))}}for(let[s,a]of n)if(!await o.resolveEntityAsync(s,e))for(let c of a){let l=new k;l.ruleType=this.ruleName,l.severity="Warning",l.message=`ObjectProperty references class '${s}' which may not be imported`,l.suggestion=`Ensure the namespace containing '${s}' is imported, or define '${s}' in this document`,l.entityName=c,l.propertyName="range",l.actualValue=s,r.push(l)}return r}};var Ce=class{standardProperties=new Set(["type","label","comment","subClassOf","domain","range","subPropertyOf","inverseOf","sameAs","seeAlso","isDefinedBy"]);get ruleName(){return"ObjectPropertyValue"}async validateAsync(e,t){let r=[],n=new E(t),o=new Q(n),s=await n.buildEntityIndexAsync(e),a=await this.buildPropertyMetadataAsync(e,t,n,s);for(let[i,c]of Object.entries(e.body))typeof c=="object"&&c!==null&&!Array.isArray(c)&&await this.scanEntityForObjectProperties(c,i,"",a,n,o,e,r);return r}async scanEntityForObjectProperties(e,t,r,n,o,s,a,i){for(let[c,l]of Object.entries(e)){if(this.standardProperties.has(c))continue;let u=c,m=c.lastIndexOf(".");m>0&&m<c.length-1&&(u=c.substring(m+1));let y=n.get(u);if(y&&s.isEffectiveObjectProperty(y.propertyType,y.rangeUri)){let d=r?`${r}.${c}`:c;if(typeof l=="string"&&l.trim().length>0){let g=l.trim();if(g.includes(",")){let b=g.split(",").map(R=>R.trim()).filter(R=>R.length>0);i.push({ruleType:this.ruleName,severity:"Error",message:`Property '${c}' has a comma-separated string value, but ObjectProperty expects a list of references`,suggestion:`Use YAML list format:
40
- ${c}:
41
- - ${b[0]}
42
- ${b.slice(1).map(R=>` - ${R}`).join(`
43
- `)}`,entityName:t,propertyName:c,propertyPath:d,actualValue:g,expectedValue:`A single reference to ${y.range??"an entity"} OR a YAML list`});continue}let h=await o.resolveEntityAsync(g,a);if(h)y.range&&(await this.validateRangeType(h,y.range,o,a)||i.push({ruleType:this.ruleName,severity:"Warning",message:`Property '${c}' expects a ${y.range}, but '${g}' may not be a ${y.range}`,suggestion:`Ensure '${g}' is defined with appropriate type`,entityName:t,propertyName:c,propertyPath:d,actualValue:g,expectedValue:y.range}));else{let b=y.range??"entity";i.push({ruleType:this.ruleName,severity:"Error",message:`Property '${c}' references '${g}' which is not defined or imported`,suggestion:`Define '${g}' or import a namespace that contains it. Expected range: ${b}`,entityName:t,propertyName:c,propertyPath:d,actualValue:g,expectedValue:"Defined or imported entity"})}}else if(typeof l=="object"&&l!==null&&!Array.isArray(l)){let g=r?`${r}.${c}`:c;await this.scanEntityForObjectProperties(l,t,g,n,o,s,a,i)}else if(Array.isArray(l))for(let g=0;g<l.length;g++){let h=l[g];if(typeof h=="string"&&h.trim().length>0){let b=h.trim(),R=await o.resolveEntityAsync(b,a);if(R){if(y.range&&!await this.validateRangeType(R,y.range,o,a)){let K=r?`${r}.${c}[${g}]`:`${c}[${g}]`;i.push({ruleType:this.ruleName,severity:"Warning",message:`Property '${c}' expects a ${y.range}, but '${b}' may not be a ${y.range}`,suggestion:`Ensure '${b}' is defined with appropriate type`,entityName:t,propertyName:`${c}[${g}]`,propertyPath:K,actualValue:b,expectedValue:y.range})}}else{let v=y.range??"entity",K=r?`${r}.${c}[${g}]`:`${c}[${g}]`;i.push({ruleType:this.ruleName,severity:"Error",message:`Property '${c}' references '${b}' which is not defined or imported`,suggestion:`Define '${b}' or import a namespace that contains it. Expected range: ${v}`,entityName:t,propertyName:`${c}[${g}]`,propertyPath:K,actualValue:b,expectedValue:"Defined or imported entity"})}}else if(typeof h=="object"&&h!==null&&!Array.isArray(h)){let b=r?`${r}.${c}[${g}]`:`${c}[${g}]`;await this.scanEntityForObjectProperties(h,t,b,n,o,s,a,i)}}}if(typeof l=="object"&&l!==null&&!Array.isArray(l)&&!n.has(c)){let f=r?`${r}.${c}`:c;await this.scanEntityForObjectProperties(l,t,f,n,o,s,a,i)}else if(Array.isArray(l))for(let f=0;f<l.length;f++){let d=l[f];if(typeof d=="object"&&d!==null&&!Array.isArray(d)){let g=r?`${r}.${c}[${f}]`:`${c}[${f}]`;await this.scanEntityForObjectProperties(d,t,g,n,o,s,a,i)}}}}async validateRangeType(e,t,r,n){if(!new Set(["Property","DatatypeProperty","ObjectProperty","AnnotationProperty","Class","Resource"]).has(t))return!0;let s=e.entity.type;if(s){let a=[];if(Array.isArray(s))for(let i of s){let c=i?.toString();c&&c.trim().length>0&&a.push(c)}else{let i=s?.toString();i&&i.trim().length>0&&a.push(i)}for(let i of a){let c=i.includes(".")?i.split(".")[1]:i;if(c===t||t==="Property"&&(c==="DatatypeProperty"||c==="ObjectProperty"||c==="AnnotationProperty")||t==="Class"&&c==="Class"||await r.isSubclassOfAsync(i,t,n))return!0}}return!1}async buildPropertyMetadataAsync(e,t,r,n){let o=new Map;for(let[s,a]of n){let i=a.entity.type;if(i){let c=[];if(Array.isArray(i))for(let m of i){let y=m?.toString();y&&y.trim().length>0&&c.push(y)}else{let m=i?.toString();m&&m.trim().length>0&&c.push(m)}let l=!1,u="Property";for(let m of c){let y=m.includes(".")?m.split(".")[1]:m;if(y==="Property"||y==="DatatypeProperty"||y==="ObjectProperty"||y==="AnnotationProperty"){l=!0,u=m;break}}if(l){let m={propertyType:u},y=a.entity.range;if(y){let f=y?.toString();if(f&&f.trim().length>0){m.range=f;let d=await r.resolveEntityAsync(f,e);d&&(m.rangeUri=d.uri)}}o.set(s,m)}}}return o}};var De=class{standardProperties=new Set(["type","label","comment","subClassOf","domain","range","subPropertyOf","inverseOf","sameAs","seeAlso","isDefinedBy"]);get ruleName(){return"PropertyDomain"}async validateAsync(e,t){let r=[],n=new Map;for(let[s,a]of Object.entries(e.body))if(typeof a=="object"&&a!==null&&!Array.isArray(a)){let i=a,c=this.getPropertyValue(i,"type");(c==="DatatypeProperty"||c?.endsWith(".DatatypeProperty")||c==="ObjectProperty"||c?.endsWith(".ObjectProperty")||c==="AnnotationProperty"||c?.endsWith(".AnnotationProperty"))&&n.set(s,i)}let o=await this.buildCompleteClassHierarchyAsync(e,t);for(let[s,a]of Object.entries(e.body))if(typeof a=="object"&&a!==null&&!Array.isArray(a)){let i=a,c=this.getPropertyValue(i,"type");if(!c||c==="Class"||c.endsWith(".Class")||c.endsWith("Property")||c==="AnnotationProperty")continue;this.validateEntityProperties(i,s,c,n,o,r)}return r}async buildCompleteClassHierarchyAsync(e,t){let r=new Map,n=new Set,o=async(a,i)=>{if(!n.has(i)){n.add(i);for(let[c,l]of Object.entries(a.body))if(typeof l=="object"&&l!==null&&!Array.isArray(l)){let u=l,m=this.getPropertyValue(u,"type");if(m==="Class"||m?.endsWith(".Class")){let y=u.subClassOf;if(y===void 0){for(let d of Object.keys(u))if(d.endsWith(".subClassOf")){y=u[d];break}}let f=j(y);f.length>0&&r.set(c,f)}}if(a.metadata.imports)for(let[c,l]of Object.entries(a.metadata.imports))for(let u of l)try{let m=await t.getHighestCompatibleVersionAsync(c,u);if(m){let y=`${c}/${u.packageName}@${u.version}`;await o(m,y)}}catch{}}},s=e.metadata.namespace_?.toString()??"unknown";return await o(e,s),r}validateEntityProperties(e,t,r,n,o,s){for(let[a,i]of Object.entries(e)){if(this.standardProperties.has(a))continue;let c=a,l=a.lastIndexOf(".");l>0&&l<a.length-1&&(c=a.substring(l+1));let u=n.get(c);if(!u)continue;let m=this.getPropertyValue(u,"domain");if(m){if(!this.isTypeCompatibleWithDomain(r,m,o)){let y=t.split(".")[0];s.push({ruleType:this.ruleName,severity:"Error",entityName:y,propertyName:t,actualValue:a,message:`Property '${a}' has domain '${m}' but is used on '${r}' at '${t}'`,suggestion:`Either:
39
+ 2. If '${u}' should be a class, change property type to ObjectProperty`,f.entityName=o,f.propertyName="range",f.actualValue=u,f.expectedValue=y==="ObjectProperty"?"A defined or imported class name":"A primitive type or defined class",r.push(f)}}}return r}async isTypeAvailableInImports(e,t,r){if(!e.metadata.imports)return!1;let n=null,o=r;if(r.includes(".")){let s=r.split(".",2);n=s[0],o=s[1]}for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){if(n!==null&&i.alias!==n)continue;let p=await t.getHighestCompatibleVersionAsync(s,i);if(p){let l=n!==null?o:r,u=p.body[l];if(u&&typeof u=="object"&&!Array.isArray(u)){let f=u.type?.toString();if(this.isValidRangeTargetType(f))return!0}let m=new Set;if(await this.isTypeAvailableInImportsRecursive(p,t,l,m))return!0}}return!1}async isTypeAvailableInImportsRecursive(e,t,r,n){let o=e.metadata.namespace_?.toString()??"";if(o&&n.has(o)||(o&&n.add(o),!e.metadata.imports))return!1;for(let[s,a]of Object.entries(e.metadata.imports))for(let i of a){let p=await t.getHighestCompatibleVersionAsync(s,i);if(p){let l=p.body[r];if(l&&typeof l=="object"&&!Array.isArray(l)){let m=l.type?.toString();if(this.isValidRangeTargetType(m))return!0}if(await this.isTypeAvailableInImportsRecursive(p,t,r,n))return!0}}return!1}isValidRangeTargetType(e){return e?e==="Class"||e.endsWith(".Class")||e==="Datatype"||e.endsWith(".Datatype"):!1}};var $e=class{xsdTypes=new Set(["string","integer","boolean","decimal","float","double","date","dateTime","time","duration","anyURI","base64Binary","hexBinary","long","int","short","byte","unsignedLong","unsignedInt","unsignedShort","unsignedByte","positiveInteger","nonPositiveInteger","negativeInteger","nonNegativeInteger","normalizedString","token","language","Name","NCName","ENTITY","ENTITIES","IDREF","IDREFS","NMTOKEN","NMTOKENS"]);get ruleName(){return"ObjectPropertyImport"}async validateAsync(e,t){let r=[],n=new Map,o=new E(t);await o.buildEntityIndexAsync(e);for(let[s,a]of Object.entries(e.body))if(typeof a=="object"&&a!==null&&!Array.isArray(a)){let i=a,p=!1,l=i.type;if(Array.isArray(l)){for(let u of l)if(u?.toString()==="ObjectProperty"){p=!0;break}}else l?.toString()==="ObjectProperty"&&(p=!0);if(p){let u=i.range,m=[];if(Array.isArray(u))for(let y of u){let f=y?.toString();f&&m.push(f)}else{let y=u?.toString();y&&m.push(y)}for(let y of m)this.xsdTypes.has(y)||(n.has(y)||n.set(y,[]),n.get(y).push(s))}}for(let[s,a]of n)if(!await o.resolveEntityAsync(s,e))for(let p of a){let l=new b;l.ruleType=this.ruleName,l.severity="Warning",l.message=`ObjectProperty references class '${s}' which may not be imported`,l.suggestion=`Ensure the namespace containing '${s}' is imported, or define '${s}' in this document`,l.entityName=p,l.propertyName="range",l.actualValue=s,r.push(l)}return r}};var xe=class{standardProperties=new Set(["type","label","comment","subClassOf","domain","range","subPropertyOf","inverseOf","sameAs","seeAlso","isDefinedBy"]);get ruleName(){return"ObjectPropertyValue"}async validateAsync(e,t){let r=[],n=new E(t),o=new ne(n),s=await n.buildEntityIndexAsync(e),a=await this.buildPropertyMetadataAsync(e,t,n,s);for(let[i,p]of Object.entries(e.body))typeof p=="object"&&p!==null&&!Array.isArray(p)&&await this.scanEntityForObjectProperties(p,i,"",a,n,o,e,r);return r}async scanEntityForObjectProperties(e,t,r,n,o,s,a,i){for(let[p,l]of Object.entries(e)){if(this.standardProperties.has(p))continue;let u=p,m=p.lastIndexOf(".");m>0&&m<p.length-1&&(u=p.substring(m+1));let y=n.get(u);if(y&&s.isEffectiveObjectProperty(y.propertyType,y.rangeUri)){let d=r?`${r}.${p}`:p;if(typeof l=="string"&&l.trim().length>0){let g=l.trim();if(g.includes(",")){let k=g.split(",").map(R=>R.trim()).filter(R=>R.length>0);i.push({ruleType:this.ruleName,severity:"Error",message:`Property '${p}' has a comma-separated string value, but ObjectProperty expects a list of references`,suggestion:`Use YAML list format:
40
+ ${p}:
41
+ - ${k[0]}
42
+ ${k.slice(1).map(R=>` - ${R}`).join(`
43
+ `)}`,entityName:t,propertyName:p,propertyPath:d,actualValue:g,expectedValue:`A single reference to ${y.range??"an entity"} OR a YAML list`});continue}let h=await o.resolveEntityAsync(g,a);if(h)y.range&&(await this.validateRangeType(h,y.range,o,a)||i.push({ruleType:this.ruleName,severity:"Warning",message:`Property '${p}' expects a ${y.range}, but '${g}' may not be a ${y.range}`,suggestion:`Ensure '${g}' is defined with appropriate type`,entityName:t,propertyName:p,propertyPath:d,actualValue:g,expectedValue:y.range}));else{let k=y.range??"entity";i.push({ruleType:this.ruleName,severity:"Error",message:`Property '${p}' references '${g}' which is not defined or imported`,suggestion:`Define '${g}' or import a namespace that contains it. Expected range: ${k}`,entityName:t,propertyName:p,propertyPath:d,actualValue:g,expectedValue:"Defined or imported entity"})}}else if(typeof l=="object"&&l!==null&&!Array.isArray(l)){let g=r?`${r}.${p}`:p;await this.scanEntityForObjectProperties(l,t,g,n,o,s,a,i)}else if(Array.isArray(l))for(let g=0;g<l.length;g++){let h=l[g];if(typeof h=="string"&&h.trim().length>0){let k=h.trim(),R=await o.resolveEntityAsync(k,a);if(R){if(y.range&&!await this.validateRangeType(R,y.range,o,a)){let x=r?`${r}.${p}[${g}]`:`${p}[${g}]`;i.push({ruleType:this.ruleName,severity:"Warning",message:`Property '${p}' expects a ${y.range}, but '${k}' may not be a ${y.range}`,suggestion:`Ensure '${k}' is defined with appropriate type`,entityName:t,propertyName:`${p}[${g}]`,propertyPath:x,actualValue:k,expectedValue:y.range})}}else{let P=y.range??"entity",x=r?`${r}.${p}[${g}]`:`${p}[${g}]`;i.push({ruleType:this.ruleName,severity:"Error",message:`Property '${p}' references '${k}' which is not defined or imported`,suggestion:`Define '${k}' or import a namespace that contains it. Expected range: ${P}`,entityName:t,propertyName:`${p}[${g}]`,propertyPath:x,actualValue:k,expectedValue:"Defined or imported entity"})}}else if(typeof h=="object"&&h!==null&&!Array.isArray(h)){let k=r?`${r}.${p}[${g}]`:`${p}[${g}]`;await this.scanEntityForObjectProperties(h,t,k,n,o,s,a,i)}}}if(typeof l=="object"&&l!==null&&!Array.isArray(l)&&!n.has(p)){let f=r?`${r}.${p}`:p;await this.scanEntityForObjectProperties(l,t,f,n,o,s,a,i)}else if(Array.isArray(l))for(let f=0;f<l.length;f++){let d=l[f];if(typeof d=="object"&&d!==null&&!Array.isArray(d)){let g=r?`${r}.${p}[${f}]`:`${p}[${f}]`;await this.scanEntityForObjectProperties(d,t,g,n,o,s,a,i)}}}}async validateRangeType(e,t,r,n){if(!new Set(["Property","DatatypeProperty","ObjectProperty","AnnotationProperty","Class","Resource"]).has(t))return!0;let s=e.entity.type;if(s){let a=[];if(Array.isArray(s))for(let i of s){let p=i?.toString();p&&p.trim().length>0&&a.push(p)}else{let i=s?.toString();i&&i.trim().length>0&&a.push(i)}for(let i of a){let p=i.includes(".")?i.split(".")[1]:i;if(p===t||t==="Property"&&(p==="DatatypeProperty"||p==="ObjectProperty"||p==="AnnotationProperty")||t==="Class"&&p==="Class"||await r.isSubclassOfAsync(i,t,n))return!0}}return!1}async buildPropertyMetadataAsync(e,t,r,n){let o=new Map;for(let[s,a]of n){let i=a.entity.type;if(i){let p=[];if(Array.isArray(i))for(let m of i){let y=m?.toString();y&&y.trim().length>0&&p.push(y)}else{let m=i?.toString();m&&m.trim().length>0&&p.push(m)}let l=!1,u="Property";for(let m of p){let y=m.includes(".")?m.split(".")[1]:m;if(y==="Property"||y==="DatatypeProperty"||y==="ObjectProperty"||y==="AnnotationProperty"){l=!0,u=m;break}}if(l){let m={propertyType:u},y=a.entity.range;if(y){let f=y?.toString();if(f&&f.trim().length>0){m.range=f;let d=await r.resolveEntityAsync(f,e);d&&(m.rangeUri=d.uri)}}o.set(s,m)}}}return o}};var je=class{standardProperties=new Set(["type","label","comment","subClassOf","domain","range","subPropertyOf","inverseOf","sameAs","seeAlso","isDefinedBy"]);get ruleName(){return"PropertyDomain"}async validateAsync(e,t){let r=[],n=new Map;for(let[s,a]of Object.entries(e.body))if(typeof a=="object"&&a!==null&&!Array.isArray(a)){let i=a,p=this.getPropertyValue(i,"type");(p==="DatatypeProperty"||p?.endsWith(".DatatypeProperty")||p==="ObjectProperty"||p?.endsWith(".ObjectProperty")||p==="AnnotationProperty"||p?.endsWith(".AnnotationProperty"))&&n.set(s,i)}let o=await this.buildCompleteClassHierarchyAsync(e,t);for(let[s,a]of Object.entries(e.body))if(typeof a=="object"&&a!==null&&!Array.isArray(a)){let i=a,p=this.getPropertyValue(i,"type");if(!p||p==="Class"||p.endsWith(".Class")||p.endsWith("Property")||p==="AnnotationProperty")continue;this.validateEntityProperties(i,s,p,n,o,r)}return r}async buildCompleteClassHierarchyAsync(e,t){let r=new Map,n=new Set,o=async(a,i)=>{if(!n.has(i)){n.add(i);for(let[p,l]of Object.entries(a.body))if(typeof l=="object"&&l!==null&&!Array.isArray(l)){let u=l,m=this.getPropertyValue(u,"type");if(m==="Class"||m?.endsWith(".Class")){let y=u.subClassOf;if(y===void 0){for(let d of Object.keys(u))if(d.endsWith(".subClassOf")){y=u[d];break}}let f=j(y);f.length>0&&r.set(p,f)}}if(a.metadata.imports)for(let[p,l]of Object.entries(a.metadata.imports))for(let u of l)try{let m=await t.getHighestCompatibleVersionAsync(p,u);if(m){let y=`${p}/${u.packageName}@${u.version}`;await o(m,y)}}catch{}}},s=e.metadata.namespace_?.toString()??"unknown";return await o(e,s),r}validateEntityProperties(e,t,r,n,o,s){for(let[a,i]of Object.entries(e)){if(this.standardProperties.has(a))continue;let p=a,l=a.lastIndexOf(".");l>0&&l<a.length-1&&(p=a.substring(l+1));let u=n.get(p);if(!u)continue;let m=this.getPropertyValue(u,"domain");if(m){if(!this.isTypeCompatibleWithDomain(r,m,o)){let y=t.split(".")[0];s.push({ruleType:this.ruleName,severity:"Error",entityName:y,propertyName:t,actualValue:a,message:`Property '${a}' has domain '${m}' but is used on '${r}' at '${t}'`,suggestion:`Either:
44
44
  1. Use this property only on '${m}' instances
45
45
  2. Change the property domain to include '${r}'
46
- 3. Create a different property for '${r}'`,expectedValue:`Property used on ${m} or its subclasses`})}if(typeof i=="object"&&i!==null&&!Array.isArray(i)){let y=i,f=this.getPropertyValue(y,"type");if(f){let d=`${t}.${a}`;this.validateEntityProperties(y,d,f,n,o,s)}else{let d=this.getPropertyValue(u,"range");if(d){let g=`${t}.${a}`;this.validateEntityProperties(y,g,d,n,o,s)}}}else if(Array.isArray(i))for(let y=0;y<i.length;y++){let f=i[y];if(typeof f=="object"&&f!==null&&!Array.isArray(f)){let d=f,g=this.getPropertyValue(d,"type");if(g){let h=`${t}.${a}[${y}]`;this.validateEntityProperties(d,h,g,n,o,s)}else{let h=this.getPropertyValue(u,"range");if(h){let b=`${t}.${a}[${y}]`;this.validateEntityProperties(d,b,h,n,o,s)}}}}}}}isTypeCompatibleWithDomain(e,t,r){if(e===t)return!0;let n=new Set,o=[e];for(;o.length>0;){let s=o.shift();if(n.has(s))continue;n.add(s);let a=r.get(s);if(a)for(let i of a){if(i===t)return!0;o.push(i)}}return!1}getPropertyValue(e,t){if(t in e){let r=e[t];return this.extractFirstValue(r)}for(let r of Object.keys(e))if(r.endsWith(`.${t}`)){let n=e[r];return this.extractFirstValue(n)}}extractFirstValue(e){if(Array.isArray(e)){let t=[];for(let r of e)t.push(r?.toString()??"");return t.length>0?t[0]:void 0}return e?.toString()}};var $e=class{get ruleName(){return"PropertyValueType"}async validateAsync(e,t){let r=[],n=new Map;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let a=s,i=this.getPropertyValue(a,"type");(i==="DatatypeProperty"||i==="ObjectProperty")&&n.set(o,a)}for(let[o,s]of Object.entries(e.body)){if(typeof s!="object"||s===null||Array.isArray(s))continue;let a=s,i=this.getPropertyValue(a,"type");if(!(!i||i==="Class"||i.endsWith("Property")||i==="AnnotationProperty"))for(let[c,l]of Object.entries(a)){if(c==="type"||c==="label"||c==="comment")continue;let u=c,m=c.lastIndexOf(".");m>0&&m<c.length-1&&(u=c.substring(m+1));let y=n.get(u);if(!y)continue;let f=this.getPropertyValue(y,"type"),d=this.getPropertyValue(y,"range");if(f==="DatatypeProperty"){if(typeof l=="object"&&l!==null&&!Array.isArray(l)||Array.isArray(l))r.push({ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:c,message:`Property '${c}' is a DatatypeProperty with range '${d}' but instance '${o}' has a complex object value`,suggestion:`Either:
47
- 1. Create a class for this data and change '${c}' to an ObjectProperty
46
+ 3. Create a different property for '${r}'`,expectedValue:`Property used on ${m} or its subclasses`})}if(typeof i=="object"&&i!==null&&!Array.isArray(i)){let y=i,f=this.getPropertyValue(y,"type");if(f){let d=`${t}.${a}`;this.validateEntityProperties(y,d,f,n,o,s)}else{let d=this.getPropertyValue(u,"range");if(d){let g=`${t}.${a}`;this.validateEntityProperties(y,g,d,n,o,s)}}}else if(Array.isArray(i))for(let y=0;y<i.length;y++){let f=i[y];if(typeof f=="object"&&f!==null&&!Array.isArray(f)){let d=f,g=this.getPropertyValue(d,"type");if(g){let h=`${t}.${a}[${y}]`;this.validateEntityProperties(d,h,g,n,o,s)}else{let h=this.getPropertyValue(u,"range");if(h){let k=`${t}.${a}[${y}]`;this.validateEntityProperties(d,k,h,n,o,s)}}}}}}}isTypeCompatibleWithDomain(e,t,r){if(e===t)return!0;let n=new Set,o=[e];for(;o.length>0;){let s=o.shift();if(n.has(s))continue;n.add(s);let a=r.get(s);if(a)for(let i of a){if(i===t)return!0;o.push(i)}}return!1}getPropertyValue(e,t){if(t in e){let r=e[t];return this.extractFirstValue(r)}for(let r of Object.keys(e))if(r.endsWith(`.${t}`)){let n=e[r];return this.extractFirstValue(n)}}extractFirstValue(e){if(Array.isArray(e)){let t=[];for(let r of e)t.push(r?.toString()??"");return t.length>0?t[0]:void 0}return e?.toString()}};var Oe=class{get ruleName(){return"PropertyValueType"}async validateAsync(e,t){let r=[],n=new Map;for(let[o,s]of Object.entries(e.body))if(typeof s=="object"&&s!==null&&!Array.isArray(s)){let a=s,i=this.getPropertyValue(a,"type");(i==="DatatypeProperty"||i==="ObjectProperty")&&n.set(o,a)}for(let[o,s]of Object.entries(e.body)){if(typeof s!="object"||s===null||Array.isArray(s))continue;let a=s,i=this.getPropertyValue(a,"type");if(!(!i||i==="Class"||i.endsWith("Property")||i==="AnnotationProperty"))for(let[p,l]of Object.entries(a)){if(p==="type"||p==="label"||p==="comment")continue;let u=p,m=p.lastIndexOf(".");m>0&&m<p.length-1&&(u=p.substring(m+1));let y=n.get(u);if(!y)continue;let f=this.getPropertyValue(y,"type"),d=this.getPropertyValue(y,"range");if(f==="DatatypeProperty"){if(typeof l=="object"&&l!==null&&!Array.isArray(l)||Array.isArray(l))r.push({ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:p,message:`Property '${p}' is a DatatypeProperty with range '${d}' but instance '${o}' has a complex object value`,suggestion:`Either:
47
+ 1. Create a class for this data and change '${p}' to an ObjectProperty
48
48
  2. Store as a JSON string to keep it as DatatypeProperty
49
- 3. Use separate properties instead of nesting`,expectedValue:`A simple value of type '${d}'`});else if(!this.validateDatatypeValue(d,l)){let g={ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:c,message:`Property '${c}' expects type '${d}' but instance '${o}' has value of type '${this.getValueTypeName(l)}'`,suggestion:`Provide a value of type '${d}'`,toString:()=>""};d&&(g.expectedValue=d),r.push(g)}}else if(f==="ObjectProperty")if(Array.isArray(l))for(let g=0;g<l.length;g++){let h=l[g];typeof h!="string"&&(typeof h!="object"||h===null||Array.isArray(h))&&r.push({ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:`${c}[${g}]`,message:`ObjectProperty '${c}' array item ${g} in instance '${o}' has invalid type '${this.getValueTypeName(h)}'`,suggestion:"Array items must be references (strings) or embedded objects (dictionaries)",expectedValue:"string or object"})}else typeof l!="string"&&(typeof l!="object"||l===null||Array.isArray(l))&&r.push({ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:c,message:`ObjectProperty '${c}' in instance '${o}' has invalid value type '${this.getValueTypeName(l)}'`,suggestion:"Value must be a reference (string), embedded object (dictionary), or array of these",expectedValue:`Reference to ${d} or embedded ${d} object`})}}return r}validateDatatypeValue(e,t){switch(e?.toLowerCase()){case"string":return typeof t=="string";case"integer":case"int":return typeof t=="number"&&Number.isInteger(t);case"decimal":return typeof t=="number";case"boolean":return typeof t=="boolean";case"float":case"double":return typeof t=="number";default:return!0}}getValueTypeName(e){return typeof e=="string"?"string":typeof e=="number"?Number.isInteger(e)?"integer":"decimal":typeof e=="boolean"?"boolean":Array.isArray(e)?"array":typeof e=="object"&&e!==null?"object":e===null?"null":e===void 0?"undefined":typeof e}getPropertyValue(e,t){if(t in e){let r=e[t];if(Array.isArray(r)){let n=[];for(let o of r)n.push(o?.toString()??"");return n.length>0?n[0]:void 0}return r?.toString()}}};var Ke=class{builtInClasses=new Set(["Resource","Class","Literal","Thing","Nothing","Property","DatatypeProperty","ObjectProperty","AnnotationProperty","FunctionalProperty","InverseFunctionalProperty","TransitiveProperty","SymmetricProperty"]);get ruleName(){return"ClassDefinition"}async validateAsync(e,t){let r=[],n=new Map,o=new Set;for(let[a,i]of Object.entries(e.body))if(typeof i=="object"&&i!==null&&!Array.isArray(i)){let l=i.type;if(l)if(Array.isArray(l))for(let u of l){let m=u?.toString();if(m==="Class"||m&&m.endsWith(".Class")){o.add(a);break}}else{let u=l?.toString();(u==="Class"||u&&u.endsWith(".Class"))&&o.add(a)}}for(let[a,i]of Object.entries(e.body))if(typeof i=="object"&&i!==null&&!Array.isArray(i)){let c=i,l=c.type;if(l)if(Array.isArray(l)){let u=!1;for(let m of l){let y=m?.toString();if(y&&this.isDefinitionType(y)){u=!0;break}}if(!u)for(let m of l){let y=m?.toString();y&&y.trim().length>0&&(n.has(y)||n.set(y,[]),n.get(y).push(a))}}else{let u=l?.toString();u&&u.trim().length>0&&(this.isDefinitionType(u)||(n.has(u)||n.set(u,[]),n.get(u).push(a)))}this.checkNestedTypes(c,a,n,a)}let s=new E(t);for(let[a,i]of n){if(this.builtInClasses.has(a)||o.has(a))continue;let c=await s.resolveEntityAsync(a,e);if(!(c&&this.isClassEntity(c.entity))){let u=Array.from(new Set(i)).sort();for(let m of u)r.push({ruleType:this.ruleName,severity:"Error",message:`Class '${a}' is not defined or imported`,suggestion:`Define '${a}' as a Class in this document, or import a namespace that contains it`,entityName:m,propertyName:"type",actualValue:a,expectedValue:"Defined or imported class"})}}return r}checkNestedTypes(e,t,r,n){if(typeof e=="object"&&e!==null&&!Array.isArray(e)){let o=e,s=o.type;if(s){let a=new Set(["Class","DatatypeProperty","ObjectProperty","AnnotationProperty"]);if(Array.isArray(s))for(let i of s){let c=i?.toString();c&&c.trim().length>0&&!a.has(c)&&(r.has(c)||r.set(c,[]),r.get(c).push(n))}else{let i=s?.toString();i&&i.trim().length>0&&!a.has(i)&&(r.has(i)||r.set(i,[]),r.get(i).push(n))}}for(let[a,i]of Object.entries(o))if(a!=="type"){let c=`${n}.${a}`;this.checkNestedTypes(i,t,r,c)}}else if(Array.isArray(e))for(let o=0;o<e.length;o++){let s=`${n}[${o}]`;this.checkNestedTypes(e[o],t,r,s)}}isClassEntity(e){if(!e)return!1;let t=e.type;if(!t)return!1;if(Array.isArray(t))for(let r of t){let n=r?.toString();if(n==="Class"||n&&n.endsWith(".Class"))return!0}else{let r=t?.toString();if(r==="Class"||r&&r.endsWith(".Class"))return!0}return!1}isDefinitionType(e){return!e||e.trim().length===0?!1:new Set(["Class","Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]).has(e)?!0:e.endsWith(".Class")||e.endsWith(".Property")||e.endsWith(".DatatypeProperty")||e.endsWith(".ObjectProperty")||e.endsWith(".AnnotationProperty")}};var dt=class{parser;documentRules;repositoryRules;includeWarnings=!0;constructor(e){this.parser=e??new O,this.documentRules=[new ie,new ce,new pe,new le,new ue],this.repositoryRules=[new me,new ye,new fe,new de,new ge,new he,new ke,new be,new Re,new ve,new Pe,new we,new Ie,new Ae,new Se,new Ce,new De,new $e,new Ke]}async validateAsync(e,t){let r=new ae;for(let n of this.documentRules)try{let o=n.validate(e);this.addErrorsToResult(r,o)}catch(o){let s=new k;s.ruleType=n.ruleName,s.severity="Error",s.message=`Validation rule '${n.ruleName}' failed: ${o instanceof Error?o.message:String(o)}`,r.errors.push(s)}if(t){let n=[];for(let o of this.repositoryRules)try{let s=await o.validateAsync(e,t);this.addErrorsToResult(r,s)}catch(s){let a=s instanceof Error?s.message:String(s);n.push({ruleName:o.ruleName,cause:a})}if(n.length>0){let o=new Map;for(let{ruleName:s,cause:a}of n){let i=o.get(a);i?i.push(s):o.set(a,[s])}for(let[s,a]of o){let i=new k;i.ruleType=a[0],i.severity="Error",a.length===1?i.message=`Validation rule '${a[0]}' failed: ${s}`:i.message=`${s} (affects ${a.length} rules: ${a.join(", ")})`,r.errors.push(i)}}}return r.isValid=r.errors.length===0,r}async validateYamlAsync(e,t){let r=this.parser.parseWithErrors(e);if(!r.isValid){let n=new ae;n.isValid=!1;for(let o of r.errors){let s=new k;s.ruleType="ParseError",s.severity="Error",s.lineNumber=o.line,s.column=o.column,s.message=o.message,o.keyName&&(s.entityName=o.keyName),o.errorType==="DuplicateKey"&&(s.suggestion="All property names must be unique across the entire document. Rename one of the duplicate properties to make them unique."),n.errors.push(s)}return n}return await this.validateAsync(r.document,t)}addDocumentRule(e){this.documentRules.push(e)}addRepositoryRule(e){this.repositoryRules.push(e)}removeDocumentRule(e){let t=this.documentRules.findIndex(r=>r instanceof e);t>=0&&this.documentRules.splice(t,1)}removeRepositoryRule(e){let t=this.repositoryRules.findIndex(r=>r instanceof e);t>=0&&this.repositoryRules.splice(t,1)}addErrorsToResult(e,t){for(let r of t)r.severity==="Error"?e.errors.push(r):this.includeWarnings&&e.warnings.push(r)}};function ze(p){if(!p.expiresAt)return!1;let e=new Date(p.expiresAt),t=300*1e3;return e.getTime()<=Date.now()+t}function gt(p){return!!p.accessToken&&!ze(p)}function A(p){let e=p.replace(/^https?:\/\//,"").replace(/^git:\/\//,"").replace(/\/+$/,"").trim();if(!e)throw new Error("Publisher host cannot be empty");return e}import{existsSync as In,readFileSync as An}from"fs";import{homedir as Sn}from"os";import{join as Cn}from"path";import{execFile as an}from"child_process";import{promisify as cn}from"util";var ht=cn(an),kt="kanonak",bt="/usr/bin/security",Xe=class{async get(e){let t=A(e);try{let{stdout:r}=await ht(bt,["find-generic-password","-s",kt,"-a",t,"-w"],{timeout:1e4});try{return JSON.parse(r.trim())}catch{throw new Error(`Stored credential for '${t}' is corrupted (not valid JSON).
50
- Run 'kanonak logout ${t}' then 'kanonak login ${t}' to fix.`)}}catch(r){if(ar(r,44))return null;throw new Error(`macOS Keychain read failed for '${t}': ${Rt(r)}
49
+ 3. Use separate properties instead of nesting`,expectedValue:`A simple value of type '${d}'`});else if(!this.validateDatatypeValue(d,l)){let g={ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:p,message:`Property '${p}' expects type '${d}' but instance '${o}' has value of type '${this.getValueTypeName(l)}'`,suggestion:`Provide a value of type '${d}'`,toString:()=>""};d&&(g.expectedValue=d),r.push(g)}}else if(f==="ObjectProperty")if(Array.isArray(l))for(let g=0;g<l.length;g++){let h=l[g];typeof h!="string"&&(typeof h!="object"||h===null||Array.isArray(h))&&r.push({ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:`${p}[${g}]`,message:`ObjectProperty '${p}' array item ${g} in instance '${o}' has invalid type '${this.getValueTypeName(h)}'`,suggestion:"Array items must be references (strings) or embedded objects (dictionaries)",expectedValue:"string or object"})}else typeof l!="string"&&(typeof l!="object"||l===null||Array.isArray(l))&&r.push({ruleType:this.ruleName,severity:"Error",entityName:o,propertyName:p,message:`ObjectProperty '${p}' in instance '${o}' has invalid value type '${this.getValueTypeName(l)}'`,suggestion:"Value must be a reference (string), embedded object (dictionary), or array of these",expectedValue:`Reference to ${d} or embedded ${d} object`})}}return r}validateDatatypeValue(e,t){switch(e?.toLowerCase()){case"string":return typeof t=="string";case"integer":case"int":return typeof t=="number"&&Number.isInteger(t);case"decimal":return typeof t=="number";case"boolean":return typeof t=="boolean";case"float":case"double":return typeof t=="number";default:return!0}}getValueTypeName(e){return typeof e=="string"?"string":typeof e=="number"?Number.isInteger(e)?"integer":"decimal":typeof e=="boolean"?"boolean":Array.isArray(e)?"array":typeof e=="object"&&e!==null?"object":e===null?"null":e===void 0?"undefined":typeof e}getPropertyValue(e,t){if(t in e){let r=e[t];if(Array.isArray(r)){let n=[];for(let o of r)n.push(o?.toString()??"");return n.length>0?n[0]:void 0}return r?.toString()}}};var Ve=class{builtInClasses=new Set(["Resource","Class","Literal","Thing","Nothing","Property","DatatypeProperty","ObjectProperty","AnnotationProperty","FunctionalProperty","InverseFunctionalProperty","TransitiveProperty","SymmetricProperty"]);get ruleName(){return"ClassDefinition"}async validateAsync(e,t){let r=[],n=new Map,o=new Set;for(let[a,i]of Object.entries(e.body))if(typeof i=="object"&&i!==null&&!Array.isArray(i)){let l=i.type;if(l)if(Array.isArray(l))for(let u of l){let m=u?.toString();if(m==="Class"||m&&m.endsWith(".Class")){o.add(a);break}}else{let u=l?.toString();(u==="Class"||u&&u.endsWith(".Class"))&&o.add(a)}}for(let[a,i]of Object.entries(e.body))if(typeof i=="object"&&i!==null&&!Array.isArray(i)){let p=i,l=p.type;if(l)if(Array.isArray(l)){let u=!1;for(let m of l){let y=m?.toString();if(y&&this.isDefinitionType(y)){u=!0;break}}if(!u)for(let m of l){let y=m?.toString();y&&y.trim().length>0&&(n.has(y)||n.set(y,[]),n.get(y).push(a))}}else{let u=l?.toString();u&&u.trim().length>0&&(this.isDefinitionType(u)||(n.has(u)||n.set(u,[]),n.get(u).push(a)))}this.checkNestedTypes(p,a,n,a)}let s=new E(t);for(let[a,i]of n){if(this.builtInClasses.has(a)||o.has(a))continue;let p=await s.resolveEntityAsync(a,e);if(!(p&&this.isClassEntity(p.entity))){let u=Array.from(new Set(i)).sort();for(let m of u)r.push({ruleType:this.ruleName,severity:"Error",message:`Class '${a}' is not defined or imported`,suggestion:`Define '${a}' as a Class in this document, or import a namespace that contains it`,entityName:m,propertyName:"type",actualValue:a,expectedValue:"Defined or imported class"})}}return r}checkNestedTypes(e,t,r,n){if(typeof e=="object"&&e!==null&&!Array.isArray(e)){let o=e,s=o.type;if(s){let a=new Set(["Class","DatatypeProperty","ObjectProperty","AnnotationProperty"]);if(Array.isArray(s))for(let i of s){let p=i?.toString();p&&p.trim().length>0&&!a.has(p)&&(r.has(p)||r.set(p,[]),r.get(p).push(n))}else{let i=s?.toString();i&&i.trim().length>0&&!a.has(i)&&(r.has(i)||r.set(i,[]),r.get(i).push(n))}}for(let[a,i]of Object.entries(o))if(a!=="type"){let p=`${n}.${a}`;this.checkNestedTypes(i,t,r,p)}}else if(Array.isArray(e))for(let o=0;o<e.length;o++){let s=`${n}[${o}]`;this.checkNestedTypes(e[o],t,r,s)}}isClassEntity(e){if(!e)return!1;let t=e.type;if(!t)return!1;if(Array.isArray(t))for(let r of t){let n=r?.toString();if(n==="Class"||n&&n.endsWith(".Class"))return!0}else{let r=t?.toString();if(r==="Class"||r&&r.endsWith(".Class"))return!0}return!1}isDefinitionType(e){return!e||e.trim().length===0?!1:new Set(["Class","Property","DatatypeProperty","ObjectProperty","AnnotationProperty"]).has(e)?!0:e.endsWith(".Class")||e.endsWith(".Property")||e.endsWith(".DatatypeProperty")||e.endsWith(".ObjectProperty")||e.endsWith(".AnnotationProperty")}};var St=class{parser;documentRules;repositoryRules;includeWarnings=!0;constructor(e){this.parser=e??new $,this.documentRules=[new ue,new me,new ye,new fe,new de],this.repositoryRules=[new ge,new he,new ke,new be,new Re,new Pe,new ve,new we,new Ie,new Se,new Ae,new De,new Ce,new Ke,new $e,new xe,new je,new Oe,new Ve]}async validateAsync(e,t){let r=new le;for(let n of this.documentRules)try{let o=n.validate(e);this.addErrorsToResult(r,o)}catch(o){let s=new b;s.ruleType=n.ruleName,s.severity="Error",s.message=`Validation rule '${n.ruleName}' failed: ${o instanceof Error?o.message:String(o)}`,r.errors.push(s)}if(t){let n=[];for(let o of this.repositoryRules)try{let s=await o.validateAsync(e,t);this.addErrorsToResult(r,s)}catch(s){let a=s instanceof Error?s.message:String(s);n.push({ruleName:o.ruleName,cause:a})}if(n.length>0){let o=new Map;for(let{ruleName:s,cause:a}of n){let i=o.get(a);i?i.push(s):o.set(a,[s])}for(let[s,a]of o){let i=new b;i.ruleType=a[0],i.severity="Error",a.length===1?i.message=`Validation rule '${a[0]}' failed: ${s}`:i.message=`${s} (affects ${a.length} rules: ${a.join(", ")})`,r.errors.push(i)}}}return r.isValid=r.errors.length===0,r}async validateYamlAsync(e,t){let r=this.parser.parseWithErrors(e);if(!r.isValid){let n=new le;n.isValid=!1;for(let o of r.errors){let s=new b;s.ruleType="ParseError",s.severity="Error",s.lineNumber=o.line,s.column=o.column,s.message=o.message,o.keyName&&(s.entityName=o.keyName),o.errorType==="DuplicateKey"&&(s.suggestion="All property names must be unique across the entire document. Rename one of the duplicate properties to make them unique."),n.errors.push(s)}return n}return await this.validateAsync(r.document,t)}addDocumentRule(e){this.documentRules.push(e)}addRepositoryRule(e){this.repositoryRules.push(e)}removeDocumentRule(e){let t=this.documentRules.findIndex(r=>r instanceof e);t>=0&&this.documentRules.splice(t,1)}removeRepositoryRule(e){let t=this.repositoryRules.findIndex(r=>r instanceof e);t>=0&&this.repositoryRules.splice(t,1)}addErrorsToResult(e,t){for(let r of t)r.severity==="Error"?e.errors.push(r):this.includeWarnings&&e.warnings.push(r)}};import{VersionOperator as Rm}from"@kanonak-protocol/types/document/models/enums";function nt(c){if(!c.expiresAt)return!1;let e=new Date(c.expiresAt),t=300*1e3;return e.getTime()<=Date.now()+t}function At(c){return!!c.accessToken&&!nt(c)}function S(c){let e=c.replace(/^https?:\/\//,"").replace(/^git:\/\//,"").replace(/\/+$/,"").trim();if(!e)throw new Error("Publisher host cannot be empty");return e}import{existsSync as Qn,readFileSync as eo}from"fs";import{homedir as to}from"os";import{join as ro}from"path";import{execFile as Tn}from"child_process";import{promisify as Nn}from"util";var Dt=Nn(Tn),Ct="kanonak",Kt="/usr/bin/security",ot=class{async get(e){let t=S(e);try{let{stdout:r}=await Dt(Kt,["find-generic-password","-s",Ct,"-a",t,"-w"],{timeout:1e4});try{return JSON.parse(r.trim())}catch{throw new Error(`Stored credential for '${t}' is corrupted (not valid JSON).
50
+ Run 'kanonak logout ${t}' then 'kanonak login ${t}' to fix.`)}}catch(r){if(Ar(r,44))return null;throw new Error(`macOS Keychain read failed for '${t}': ${$t(r)}
51
51
  The Keychain may be locked or inaccessible.
52
- Try unlocking it via Keychain Access.app or running 'security unlock-keychain'.`)}}async store(e,t){let r=A(e),n=JSON.stringify(t);try{await ht(bt,["add-generic-password","-s",kt,"-a",r,"-U","-w",n],{timeout:1e4})}catch(o){throw new Error(`macOS Keychain write failed for '${r}': ${Rt(o)}
52
+ Try unlocking it via Keychain Access.app or running 'security unlock-keychain'.`)}}async store(e,t){let r=S(e),n=JSON.stringify(t);try{await Dt(Kt,["add-generic-password","-s",Ct,"-a",r,"-U","-w",n],{timeout:1e4})}catch(o){throw new Error(`macOS Keychain write failed for '${r}': ${$t(o)}
53
53
  Ensure the Keychain is unlocked and the CLI has write permission.
54
- On managed devices, your IT policy may block credential storage.`)}}async remove(e){let t=A(e);try{await ht(bt,["delete-generic-password","-s",kt,"-a",t],{timeout:1e4})}catch(r){if(ar(r,44))return;console.warn(` Warning: macOS Keychain delete failed for '${t}': ${Rt(r)}
55
- The credential may not have been fully removed.`)}}async list(){try{let{stdout:e}=await ht(bt,["dump-keychain"],{timeout:1e4}),t=[],r=!1;for(let n of e.split(`
56
- `))if(n.includes(`"svce"<blob>="${kt}"`)&&(r=!0),r&&n.includes('"acct"<blob>=')){let o=n.match(/"acct"<blob>="([^"]+)"/);o&&t.push(o[1]),r=!1}return t}catch(e){return console.warn(` Warning: Could not enumerate Keychain entries: ${Rt(e)}`),[]}}};function ar(p,e){return typeof p=="object"&&p!==null&&"code"in p&&p.code===e}function Rt(p){return p instanceof Error?p.message:String(p)}import{execFile as pn}from"child_process";import{promisify as ln}from"util";var un=ln(pn),vt="kanonak:",Ye=class{async get(e){let t=vt+A(e),r=`
57
- ${wt}
54
+ On managed devices, your IT policy may block credential storage.`)}}async remove(e){let t=S(e);try{await Dt(Kt,["delete-generic-password","-s",Ct,"-a",t],{timeout:1e4})}catch(r){if(Ar(r,44))return;console.warn(` Warning: macOS Keychain delete failed for '${t}': ${$t(r)}
55
+ The credential may not have been fully removed.`)}}async list(){try{let{stdout:e}=await Dt(Kt,["dump-keychain"],{timeout:1e4}),t=[],r=!1;for(let n of e.split(`
56
+ `))if(n.includes(`"svce"<blob>="${Ct}"`)&&(r=!0),r&&n.includes('"acct"<blob>=')){let o=n.match(/"acct"<blob>="([^"]+)"/);o&&t.push(o[1]),r=!1}return t}catch(e){return console.warn(` Warning: Could not enumerate Keychain entries: ${$t(e)}`),[]}}};function Ar(c,e){return typeof c=="object"&&c!==null&&"code"in c&&c.code===e}function $t(c){return c instanceof Error?c.message:String(c)}import{execFile as _n}from"child_process";import{promisify as Un}from"util";var Ln=Un(_n),xt="kanonak:",st=class{async get(e){let t=xt+S(e),r=`
57
+ ${Ot}
58
58
  $target = [Console]::In.ReadLine()
59
59
  $ptr = [IntPtr]::Zero
60
60
  $result = [CredMan]::CredRead($target, 1, 0, [ref]$ptr)
@@ -66,8 +66,8 @@ try {
66
66
  [System.Text.Encoding]::Unicode.GetString($bytes)
67
67
  } finally {
68
68
  [CredMan]::CredFree($ptr)
69
- }`;try{let{stdout:n}=await Pt(r,t),o=n.trim();return o?JSON.parse(o):null}catch{return null}}async store(e,t){let r=vt+A(e),n=JSON.stringify(t),o=`
70
- ${wt}
69
+ }`;try{let{stdout:n}=await jt(r,t),o=n.trim();return o?JSON.parse(o):null}catch{return null}}async store(e,t){let r=xt+S(e),n=JSON.stringify(t),o=`
70
+ ${Ot}
71
71
  $target = [Console]::In.ReadLine()
72
72
  $json = [Console]::In.ReadLine()
73
73
  $bytes = [System.Text.Encoding]::Unicode.GetBytes($json)
@@ -83,13 +83,13 @@ try {
83
83
  if (-not $result) { throw "CredWrite failed" }
84
84
  } finally {
85
85
  [System.Runtime.InteropServices.Marshal]::FreeHGlobal($cred.CredentialBlob)
86
- }`;try{await Pt(o,`${r}
87
- ${n}`)}catch(s){throw new Error(`Windows Credential Manager write failed: ${String(s)}`)}}async remove(e){let t=vt+A(e),r=`
88
- ${wt}
86
+ }`;try{await jt(o,`${r}
87
+ ${n}`)}catch(s){throw new Error(`Windows Credential Manager write failed: ${String(s)}`)}}async remove(e){let t=xt+S(e),r=`
88
+ ${Ot}
89
89
  $target = [Console]::In.ReadLine()
90
- [CredMan]::CredDelete($target, 1, 0) | Out-Null`;try{await Pt(r,t)}catch{}}async list(){let e=`
91
- ${wt}
92
- ${mn}
90
+ [CredMan]::CredDelete($target, 1, 0) | Out-Null`;try{await jt(r,t)}catch{}}async list(){let e=`
91
+ ${Ot}
92
+ ${Mn}
93
93
  $prefix = [Console]::In.ReadLine()
94
94
  $count = 0
95
95
  $pCreds = [IntPtr]::Zero
@@ -103,8 +103,8 @@ if ([CredMan]::CredEnumerate($null, 0, [ref]$count, [ref]$pCreds)) {
103
103
  }
104
104
  }
105
105
  [CredMan]::CredFree($pCreds)
106
- }`;try{let{stdout:t}=await Pt(e,vt);return t.trim().split(`
107
- `).map(r=>r.trim()).filter(Boolean)}catch{return[]}}};async function Pt(p,e){for(let t of["pwsh","powershell"])try{return await un(t,["-NoProfile","-NonInteractive","-Command",p],{timeout:15e3,...e!==void 0&&{input:e}})}catch(r){if(t==="powershell")throw r}throw new Error("Neither pwsh nor powershell found")}var wt=`
106
+ }`;try{let{stdout:t}=await jt(e,xt);return t.trim().split(`
107
+ `).map(r=>r.trim()).filter(Boolean)}catch{return[]}}};async function jt(c,e){for(let t of["pwsh","powershell"])try{return await Ln(t,["-NoProfile","-NonInteractive","-Command",c],{timeout:15e3,...e!==void 0&&{input:e}})}catch(r){if(t==="powershell")throw r}throw new Error("Neither pwsh nor powershell found")}var Ot=`
108
108
  Add-Type -TypeDefinition @"
109
109
  using System;
110
110
  using System.Runtime.InteropServices;
@@ -135,15 +135,16 @@ public class CredMan {
135
135
  [DllImport("Advapi32.dll", SetLastError = true, CharSet = CharSet.Unicode)]
136
136
  public static extern bool CredEnumerate(string filter, int flags, out int count, out IntPtr credentials);
137
137
  }
138
- "@`,mn="";import{execFile as yn,spawn as fn}from"child_process";import{promisify as dn}from"util";var At=dn(yn),It="kanonak",Je=class{async get(e){let t=A(e);try{let{stdout:r}=await At("secret-tool",["lookup","service",It,"publisher",t],{timeout:1e4}),n=r.trim();return n?JSON.parse(n):null}catch{return null}}async store(e,t){let r=A(e),n=JSON.stringify(t);await new Promise((o,s)=>{let a=fn("secret-tool",["store","--label",`Kanonak: ${r}`,"service",It,"publisher",r],{stdio:["pipe","ignore","ignore"],timeout:1e4});a.stdin.write(n),a.stdin.end(),a.on("close",i=>{i===0?o():s(new Error(`secret-tool store exited with code ${i}`))}),a.on("error",s)})}async remove(e){let t=A(e);try{await At("secret-tool",["clear","service",It,"publisher",t],{timeout:1e4})}catch{}}async list(){try{let{stdout:e}=await At("secret-tool",["search","service",It],{timeout:1e4}),t=[];for(let r of e.split(`
139
- `)){let n=r.match(/attribute\.publisher\s*=\s*(.+)/);n&&t.push(n[1].trim())}return t}catch{return[]}}};async function Bt(){try{return await At("sh",["-c","command -v secret-tool"],{timeout:5e3}),!0}catch{return!1}}import{existsSync as ir,mkdirSync as cr,readFileSync as pr,writeFileSync as lr}from"fs";import{createCipheriv as gn,createDecipheriv as hn,randomBytes as ur}from"crypto";import{homedir as kn}from"os";import{join as Gt,dirname as mr}from"path";var fr=Gt(kn(),".config","kanonak"),Ze=Gt(fr,"keyring.key"),St=Gt(fr,"credentials.enc"),yr="aes-256-gcm",Wt=32,Be=12,Ht=16,Qe=class{async get(e){let t=this.loadStore(),r=A(e);return t[r]??null}async store(e,t){let r=this.loadStore(),n=A(e);r[n]=t,this.saveStore(r)}async remove(e){let t=this.loadStore(),r=A(e);delete t[r],this.saveStore(t)}async list(){let e=this.loadStore();return Object.keys(e)}loadStore(){if(!ir(St))return{};try{let e=this.getOrCreateKey(),t=pr(St);if(t.length<Be+Ht)return{};let r=t.subarray(0,Be),n=t.subarray(Be,Be+Ht),o=t.subarray(Be+Ht),s=hn(yr,e,r);s.setAuthTag(n);let a=Buffer.concat([s.update(o),s.final()]);return JSON.parse(a.toString("utf-8"))}catch{return{}}}saveStore(e){let t=this.getOrCreateKey(),r=ur(Be),n=gn(yr,t,r),o=Buffer.from(JSON.stringify(e),"utf-8"),s=Buffer.concat([n.update(o),n.final()]),a=n.getAuthTag(),i=Buffer.concat([r,a,s]);cr(mr(St),{recursive:!0}),lr(St,i,{mode:384})}getOrCreateKey(){if(ir(Ze)){let t=pr(Ze);if(t.length!==Wt)throw new Error(`Credential keyring key is corrupted (expected ${Wt} bytes, got ${t.length}). Delete ${Ze} and re-authenticate.`);return t}let e=ur(Wt);return cr(mr(Ze),{recursive:!0}),lr(Ze,e,{mode:384}),e}};import{execFile as bn}from"child_process";import{promisify as Rn}from"util";var vn=Rn(bn),dr=3e4,et=class{constructor(e){this.helperPath=e}helperPath;async get(e){let t=A(e);try{let n=(await this.runHelper("get",{publisher:t})).trim();return n?JSON.parse(n):null}catch(r){throw new Error(`Credential helper '${this.helperPath}' failed to read credential for '${t}': ${Ct(r)}
138
+ "@`,Mn="";import{execFile as Fn,spawn as Bn}from"child_process";import{promisify as Wn}from"util";var Et=Wn(Fn),Vt="kanonak",at=class{async get(e){let t=S(e);try{let{stdout:r}=await Et("secret-tool",["lookup","service",Vt,"publisher",t],{timeout:1e4}),n=r.trim();return n?JSON.parse(n):null}catch{return null}}async store(e,t){let r=S(e),n=JSON.stringify(t);await new Promise((o,s)=>{let a=Bn("secret-tool",["store","--label",`Kanonak: ${r}`,"service",Vt,"publisher",r],{stdio:["pipe","ignore","ignore"],timeout:1e4});a.stdin.write(n),a.stdin.end(),a.on("close",i=>{i===0?o():s(new Error(`secret-tool store exited with code ${i}`))}),a.on("error",s)})}async remove(e){let t=S(e);try{await Et("secret-tool",["clear","service",Vt,"publisher",t],{timeout:1e4})}catch{}}async list(){try{let{stdout:e}=await Et("secret-tool",["search","service",Vt],{timeout:1e4}),t=[];for(let r of e.split(`
139
+ `)){let n=r.match(/attribute\.publisher\s*=\s*(.+)/);n&&t.push(n[1].trim())}return t}catch{return[]}}};async function nr(){try{return await Et("sh",["-c","command -v secret-tool"],{timeout:5e3}),!0}catch{return!1}}import{existsSync as Dr,mkdirSync as Cr,readFileSync as Kr,writeFileSync as $r}from"fs";import{createCipheriv as Hn,createDecipheriv as qn,randomBytes as xr}from"crypto";import{homedir as Gn}from"os";import{join as ar,dirname as jr}from"path";var Vr=ar(Gn(),".config","kanonak"),it=ar(Vr,"keyring.key"),Tt=ar(Vr,"credentials.enc"),Or="aes-256-gcm",or=32,Ze=12,sr=16,ct=class{async get(e){let t=this.loadStore(),r=S(e);return t[r]??null}async store(e,t){let r=this.loadStore(),n=S(e);r[n]=t,this.saveStore(r)}async remove(e){let t=this.loadStore(),r=S(e);delete t[r],this.saveStore(t)}async list(){let e=this.loadStore();return Object.keys(e)}loadStore(){if(!Dr(Tt))return{};try{let e=this.getOrCreateKey(),t=Kr(Tt);if(t.length<Ze+sr)return{};let r=t.subarray(0,Ze),n=t.subarray(Ze,Ze+sr),o=t.subarray(Ze+sr),s=qn(Or,e,r);s.setAuthTag(n);let a=Buffer.concat([s.update(o),s.final()]);return JSON.parse(a.toString("utf-8"))}catch{return{}}}saveStore(e){let t=this.getOrCreateKey(),r=xr(Ze),n=Hn(Or,t,r),o=Buffer.from(JSON.stringify(e),"utf-8"),s=Buffer.concat([n.update(o),n.final()]),a=n.getAuthTag(),i=Buffer.concat([r,a,s]);Cr(jr(Tt),{recursive:!0}),$r(Tt,i,{mode:384})}getOrCreateKey(){if(Dr(it)){let t=Kr(it);if(t.length!==or)throw new Error(`Credential keyring key is corrupted (expected ${or} bytes, got ${t.length}). Delete ${it} and re-authenticate.`);return t}let e=xr(or);return Cr(jr(it),{recursive:!0}),$r(it,e,{mode:384}),e}};import{execFile as zn}from"child_process";import{promisify as Xn}from"util";var Yn=Xn(zn),Er=3e4,pt=class{constructor(e){this.helperPath=e}helperPath;async get(e){let t=S(e);try{let n=(await this.runHelper("get",{publisher:t})).trim();return n?JSON.parse(n):null}catch(r){throw new Error(`Credential helper '${this.helperPath}' failed to read credential for '${t}': ${Nt(r)}
140
140
  Verify the helper binary exists, is executable, and implements the Kanonak credential helper protocol.
141
- Check the 'credentialHelper' path in ~/.kanonak/config.json.`)}}async store(e,t){let r=A(e);try{await this.runHelper("store",{publisher:r,credential:t})}catch(n){throw new Error(`Credential helper '${this.helperPath}' failed to store credential for '${r}': ${Ct(n)}
142
- Verify the helper binary supports the 'store' action.`)}}async remove(e){let t=A(e);try{await this.runHelper("erase",{publisher:t})}catch(r){console.warn(` Warning: Credential helper '${this.helperPath}' failed to erase credential for '${t}': ${Ct(r)}`)}}async list(){try{let e=await this.runHelper("list",void 0);return JSON.parse(e.trim())}catch(e){return console.warn(` Warning: Credential helper '${this.helperPath}' failed to list credentials: ${Ct(e)}`),[]}}async runHelper(e,t){try{let{stdout:r}=await vn(this.helperPath,[e],{...t&&{input:JSON.stringify(t)},timeout:dr});return r}catch(r){throw Pn(r)?new Error(`Credential helper not found at '${this.helperPath}'.
143
- Check the 'credentialHelper' path in ~/.kanonak/config.json.`):wn(r)?new Error(`Credential helper '${this.helperPath}' timed out after ${dr/1e3}s on '${e}'.
144
- The helper may be waiting for authentication to an external vault.`):r}}};function Ct(p){return p instanceof Error?p.message:String(p)}function Pn(p){return p instanceof Error&&"code"in p&&p.code==="ENOENT"}function wn(p){return p instanceof Error&&"killed"in p&&p.killed}var qt=Cn(Sn(),".kanonak","config.json"),Dt=class{backend=null;backendReady=null;async getBackend(){if(this.backend)return this.backend;if(this.backendReady)return this.backendReady;this.backendReady=this.resolveBackend();try{return this.backend=await this.backendReady,this.backend}catch(e){throw this.backendReady=null,e}}async getToken(e){let t=Dn(e);if(t)return t;let n=await(await this.getBackend()).get(e);return!n||!gt(n)?null:n.accessToken??null}async getCredential(e){return(await this.getBackend()).get(e)}async store(e,t){return(await this.getBackend()).store(e,t)}async remove(e){return(await this.getBackend()).remove(e)}async list(){return(await this.getBackend()).list()}async resolveBackend(){let e=$n();return e.credentialHelper?new et(e.credentialHelper):process.platform==="darwin"?new Xe:process.platform==="win32"?new Ye:await Bt()?new Je:new Qe}};function Dn(p){let t="KANONAK_TOKEN_"+A(p).replace(/[.\-]/g,"_").toUpperCase();return process.env[t]??null}function $n(){if(!In(qt))return{};try{return JSON.parse(An(qt,"utf-8"))}catch(p){let e=p instanceof Error?p.message:String(p);return console.warn(` Warning: Failed to parse ${qt}: ${e}
145
- Using default credential backend. Fix the JSON syntax or delete the file.`),{}}}import{createHash as Kn,createPrivateKey as jn,generateKeyPairSync as xn,randomUUID as On,sign as En}from"crypto";function hr(){let{publicKey:p,privateKey:e}=xn("ec",{namedCurve:"P-256"});return{publicKey:p.export({format:"jwk"}),privateKey:e.export({format:"jwk"})}}function tt(p,e,t,r,n,o){let s={alg:"ES256",typ:"dpop+jwt",jwk:{kty:e.kty,crv:e.crv,x:e.x,y:e.y}},a={jti:On(),htm:t.toUpperCase(),htu:r,iat:Math.floor(Date.now()/1e3)};return n&&(a.ath=Kn("sha256").update(n).digest("base64url")),o&&(a.nonce=o),Vn(s,a,p)}function kr(p){return!p||p.length===0?!1:p.some(e=>e.toUpperCase()==="ES256")}function Vn(p,e,t){let r=gr(JSON.stringify(p)),n=gr(JSON.stringify(e)),o=`${r}.${n}`,s=jn({key:t,format:"jwk"}),i=En("SHA256",Buffer.from(o),{key:s,dsaEncoding:"ieee-p1363"}).toString("base64url");return`${o}.${i}`}function gr(p){return Buffer.from(p,"utf-8").toString("base64url")}function br(p){let e=new Map;return async(t,r,n="GET")=>{if(!p)return fetch(t,{method:n});let o=await p.getCredential(r);if(!o?.accessToken)return fetch(t,{method:n});ze(o)&&console.warn(` Warning: Access token for '${r}' is expired. Run 'kanonak login ${r}' to re-authenticate.`);let s={};if(o.dpopKeyPair){let i=e.get(r);try{let c=tt(o.dpopKeyPair.privateKey,o.dpopKeyPair.publicKey,n,t,o.accessToken,i);s.Authorization=`DPoP ${o.accessToken}`,s.DPoP=c}catch(c){let l=c instanceof Error?c.message:String(c);console.error(` Error: Failed to create DPoP proof for '${r}': ${l}
146
- The stored key pair may be corrupted. Run 'kanonak login ${r}' to re-authenticate.`),s.Authorization=`Bearer ${o.accessToken}`}}else s.Authorization=`Bearer ${o.accessToken}`;let a=await fetch(t,{method:n,headers:s});if(a.status===401&&o.dpopKeyPair){let i=a.headers.get("DPoP-Nonce");if(i){e.set(r,i);try{let c=tt(o.dpopKeyPair.privateKey,o.dpopKeyPair.publicKey,n,t,o.accessToken,i);s.DPoP=c,a=await fetch(t,{method:n,headers:s})}catch{}}}return a}}import{CtlKanonakUriType as rt,PathSegmentType as zt}from"@kanonak-protocol/types/ctl/parsing/enums";var Tn=/\.?([a-zA-Z_][a-zA-Z0-9_-]*|\[\d+\])/g;function Nn(p){let e=p.split(".").map(Number),t=e[0]||0,r=e[1]||0,n=e[2]||0;return{major:t,minor:r,patch:n,toString:()=>`${t}.${r}.${n}`,equals:o=>o&&typeof o=="object"&&o.major===t&&o.minor===r&&o.patch===n,getHashCode:()=>t<<20|r<<10|n,compareTo:o=>t!==o.major?t-o.major:r!==o.minor?r-o.minor:n-o.patch}}var je=class p{scheme="kanonak";publisher;package_;version;resourceName;path;rawUri;constructor(e){this.publisher=e.publisher,this.package_=e.package_,this.version=e.version,this.resourceName=e.resourceName,this.path=e.path??[],this.rawUri=e.rawUri}get uriType(){return this.path.length>0?rt.DeepLink:this.resourceName!=null?rt.Resource:this.version!=null?rt.VersionedPackage:this.package_!=null?rt.Package:rt.Publisher}get namespace_(){return this.package_==null?null:this.version==null?`${this.publisher}/${this.package_}`:`${this.publisher}/${this.package_}@${this.version}`}static parse(e){if(!e||e.trim().length===0)throw new Error("Kanonak URI string cannot be null or empty");if(!e.toLowerCase().startsWith("kanonak://"))throw new Error(`Invalid Kanonak URI: '${e}'. Must start with 'kanonak://'`);let t=e.substring(8);if(!t||t.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Publisher is required after 'kanonak://'`);let r=t.indexOf("#"),n=null,o;if(r>=0){if(o=t.substring(0,r),n=t.substring(r+1),!n||n.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Deep link path required after '#'`)}else o=t;let s,a=null,i=null,c=null,l=o.indexOf("@");if(l>=0){let m=o.substring(0,l),y=o.substring(l+1),f=m.indexOf("/");if(f<0)throw new Error(`Invalid Kanonak URI: '${e}'. Expected format: publisher/package@version/resource`);if(s=m.substring(0,f),a=m.substring(f+1),!s||s.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Publisher cannot be empty`);if(!a||a.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Package cannot be empty`);let d=y.indexOf("/");if(d<0)throw new Error(`Invalid Kanonak URI: '${e}'. CTL requires resource references (kanonak://publisher/package@version/resource)`);let g=y.substring(0,d);if(c=y.substring(d+1),!g||g.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Version required after '@'`);if(i=Nn(g),!c||c.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Resource name cannot be empty`)}else{let m=o.split("/");if(m.length<3)throw new Error(`Invalid Kanonak URI: '${e}'. CTL requires resource references (kanonak://publisher/package/resource)`);if(m.length>3)throw new Error(`Invalid Kanonak URI: '${e}'. Too many path segments. Expected: publisher/package/resource`);if(s=m[0],a=m[1],c=m[2],!s||s.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Publisher cannot be empty`);if(!a||a.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Package cannot be empty`);if(!c||c.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Resource name cannot be empty`)}let u=[];return n!=null&&(u=_n(n,e)),new p({publisher:s,package_:a,version:i,resourceName:c,path:u,rawUri:e})}static tryParse(e){try{return p.parse(e)}catch{return null}}static isKanonakUri(e){return!!e&&e.trim().length>0&&e.toLowerCase().startsWith("kanonak://")}toString(){let e=`kanonak://${this.publisher}`;if(this.package_!=null&&(e+=`/${this.package_}`,this.version!=null&&(e+=`@${this.version}`),this.resourceName!=null&&(e+=`/${this.resourceName}`,this.path.length>0))){e+="#";let t=!0;for(let r of this.path)r.type_===zt.Index?e+=`[${r.index}]`:(t||(e+="."),e+=r.name),t=!1}return e}equals(e){return e instanceof p?this.rawUri.toLowerCase()===e.rawUri.toLowerCase():!1}getHashCode(){let e=0,t=this.rawUri.toLowerCase();for(let r=0;r<t.length;r++)e=(e<<5)-e+t.charCodeAt(r),e|=0;return e}};function _n(p,e){let t=[],r=new RegExp(Tn.source,"g"),n=0,o;for(;(o=r.exec(p))!==null;){let s=o[1];if(s.startsWith("[")&&s.endsWith("]")){let a=s.substring(1,s.length-1),i=parseInt(a,10);if(isNaN(i))throw new Error(`Invalid Kanonak URI: '${e}'. Invalid array index: ${s}`);t.push({type_:zt.Index,index:i,toString:()=>`[${i}]`})}else t.push({type_:zt.Property,name:s,toString:()=>s});n+=o[0].length}if(n!==p.length)throw new Error(`Invalid Kanonak URI: '${e}'. Invalid path syntax in: ${p}`);return t}import{VersionOperator as re}from"@kanonak-protocol/types/document/models/enums";import*as Pr from"js-yaml";var Un=/\[([^\]]+)\]\((kanonak:\/\/[^)]+)\)/gi,Ln=/\[([^\]]+)\]\(kan:\/\/([^)]+)\)/gi,Mn=/```[\s\S]*?```|`[^`]+`/g,Fn=/^---\s*\n([\s\S]*?)\n---\s*\n/;function Bn(p,e,t){let r=`${p}.${e}.${t}`;return{major:p,minor:e,patch:t,toString:()=>r,equals:n=>n?.major===p&&n?.minor===e&&n?.patch===t,getHashCode:()=>p<<20|e<<10|t,compareTo:n=>p!==n.major?p-n.major:e!==n.minor?e-n.minor:t-n.patch}}function Wn(p,e,t,r,n){let o=r===re.Compatible?"~":r===re.Major?"^":r===re.Exact?"=":"*",s=`${e} ${o} ${t}`;return{package_:s,publisher:p,packageName:e,versionOperator:r,version:t,alias:n,get minVersion(){return t},get maxVersion(){return t},toEmbeddedObject(){let a={package:e,version:t.toString()};return n&&(a.alias=n),r!==re.Exact&&(a.match=o),a},toString(){return s}}}var $t=class{parse(e,t){if(e==null)throw new Error("Content cannot be null");e.charCodeAt(0)===65279&&(e=e.substring(1));let r=Fn.exec(e);return r?this.parseWithFrontmatter(e,r,t??null):this.parseInline(e,t??null)}async parseFileAsync(e){if(!e||e.trim().length===0)throw new Error("File path cannot be null or empty");let r=(await import("fs")).readFileSync(e,"utf-8");return this.parse(r,e)}parseWithFrontmatter(e,t,r){let n=t[1],o=e.substring(t[0].length),s=null,a=new Map;try{let c=Pr.load(n);if(!c)throw new Error("Frontmatter YAML is empty");if(!c.imports||!Array.isArray(c.imports))throw new Error("Frontmatter must contain an 'imports' sequence");let l={};for(let m of c.imports){if(!m||typeof m!="object")throw new Error("Each import entry must be a mapping with 'publisher' and 'packages'");let y=m.publisher?.toString();if(!y)throw new Error("Each import entry requires a 'publisher' property");if(!m.packages||!Array.isArray(m.packages))throw new Error(`Import entry for publisher '${y}' requires a 'packages' sequence`);l[y]||(l[y]=[]);for(let f of m.packages){if(!f||typeof f!="object")throw new Error(`Each package in publisher '${y}' must be a mapping`);let g=(f.version?.toString()??"1.0.0").split(".").map(Number),h=Bn(g[0]||0,g[1]||0,g[2]||0),b=f.match?.toString(),R=b==="^"?re.Major:b==="~"?re.Compatible:b==="*"?re.Any:re.Exact,v=Wn(y,f.package?.toString()??"",h,R,f.alias?.toString()??null);l[y].push(v)}}let u=[];for(let m of Object.values(l))u.push(...m);s={namespace_:void 0,imports:l,get allImports(){return u}},a=this.buildAliasMap(l)}catch(c){let l={displayText:"(frontmatter)",rawUri:"",startOffset:0,endOffset:t[0].length,line:1,column:1,isResolved:!1,error:`Failed to parse frontmatter: ${c.message}`,get fullMarkdownLink(){return`[${this.displayText}](${this.rawUri})`}};return Xt({metadata:null,rawMarkdown:o,frontmatterLength:t[0].length,filePath:r,references:[l]})}let i=this.parseMarkdownBody(o,a,t[0].length);return Xt({metadata:s,rawMarkdown:o,frontmatterLength:t[0].length,filePath:r,references:i})}parseInline(e,t){let r=this.parseMarkdownBody(e,new Map,0);return Xt({metadata:null,rawMarkdown:e,frontmatterLength:0,filePath:t,references:r})}parseMarkdownBody(e,t,r){let n=[],o=Hn(e),s=new RegExp(Un.source,"gi"),a;for(;(a=s.exec(e))!==null;){if(Rr(a.index,o))continue;let c=a[1],l=a[2],{line:u,column:m}=vr(e,a.index),y={displayText:c,rawUri:l,startOffset:a.index+r,endOffset:a.index+a[0].length+r,line:u,column:m,isResolved:!1,get fullMarkdownLink(){return`[${this.displayText}](${this.rawUri})`}};try{y.parsedUri=je.parse(l)}catch(f){y.error=f.message}n.push(y)}let i=new RegExp(Ln.source,"gi");for(;(a=i.exec(e))!==null;){if(Rr(a.index,o))continue;let c=a[1],l=a[2],{line:u,column:m}=vr(e,a.index),y=null,f=null;try{y=Gn(l,t)}catch(g){f=g.message}let d={displayText:c,rawUri:y??`kan://${l}`,startOffset:a.index+r,endOffset:a.index+a[0].length+r,line:u,column:m,isResolved:!1,error:f,get fullMarkdownLink(){return`[${this.displayText}](${this.rawUri})`}};if(y!=null&&f==null)try{d.parsedUri=je.parse(y)}catch(g){d.error=g.message}n.push(d)}return n.sort((c,l)=>c.startOffset-l.startOffset),n}buildAliasMap(e){let t=new Map;for(let[r,n]of Object.entries(e))for(let o of n){let s=o.alias??o.packageName;t.set(s.toLowerCase(),{publisher:r,package_:o.packageName,version:o.version})}return t}};function Xt(p){return{metadata:p.metadata,get hasFrontmatter(){return p.metadata!=null},rawMarkdown:p.rawMarkdown,frontmatterLength:p.frontmatterLength,filePath:p.filePath,references:p.references,get referenceCount(){return p.references.length},get allReferencesResolved(){return p.references.every(e=>e.isResolved)},get unresolvedReferences(){return p.references.filter(e=>!e.isResolved)},get errorReferences(){return p.references.filter(e=>e.error!=null)}}}function Hn(p){let e=[],t=new RegExp(Mn.source,"g"),r;for(;(r=t.exec(p))!==null;)e.push([r.index,r.index+r[0].length]);return e}function Rr(p,e){for(let[t,r]of e)if(p>=t&&p<r)return!0;return!1}function vr(p,e){let t=1,r=1;for(let n=0;n<e&&n<p.length;n++)p[n]===`
147
- `?(t++,r=1):r++;return{line:t,column:r}}function Gn(p,e){if(!p||p.trim().length===0)throw new Error("kan:// link cannot be empty");if(e.size===0)throw new Error("kan:// links require frontmatter with imports");let t=null,r=p,n=p.indexOf(".");if(n>0&&(t=p.substring(0,n),r=p.substring(n+1),!r||r.trim().length===0))throw new Error(`Resource name required after alias '${t}.'`);if(t!=null){let o=e.get(t.toLowerCase());if(!o){let s=Array.from(e.keys()).join(", ");throw new Error(`Unknown alias: '${t}'. Available: ${s}`)}return`kanonak://${o.publisher}/${o.package_}@${o.version}/${r}`}else{let o=e.values().next().value;if(!o)throw new Error(`Cannot resolve '${r}': no imports defined`);return`kanonak://${o.publisher}/${o.package_}@${o.version}/${r}`}}import{CtlValidationErrorType as G,CtlValidationSeverity as ne}from"@kanonak-protocol/types/ctl/models/enums";import{CtlKanonakUriType as wr,PathSegmentType as Ir}from"@kanonak-protocol/types/ctl/parsing/enums";var Kt=class{repository;constructor(e){if(!e)throw new Error("Repository is required for CTL validation");this.repository=e}async validateAsync(e){if(!e)throw new Error("Document cannot be null");let t=[],r=[];for(let o of e.references){if(!o.parsedUri){t.push({errorType:G.InvalidUri,severity:ne.Error,message:o.error??"Failed to parse Kanonak URI",reference:o,line:o.line,column:o.column,toString(){let s=this.line!=null?`(${this.line}:${this.column})`:"";return`${ne[this.severity]}: ${this.message} ${s}`.trim()}});continue}try{await this.resolveReference(o,t,r)}catch(s){t.push({errorType:G.ParseError,severity:ne.Error,message:`Error resolving reference: ${s.message}`,reference:o,line:o.line,column:o.column,toString(){let a=this.line!=null?`(${this.line}:${this.column})`:"";return`${ne[this.severity]}: ${this.message} ${a}`.trim()}})}}return{isValid:t.length===0,document:e,errors:t,warnings:r,get totalReferences(){return e.referenceCount},get resolvedReferences(){return e.references.filter(o=>o.isResolved).length},get summary(){if(t.length===0)return`All ${e.referenceCount} references validated`;let o=e.references.filter(s=>s.isResolved).length;return`${t.length} error(s), ${o}/${e.referenceCount} references resolved`}}}async resolveReference(e,t,r){let n=e.parsedUri;switch(n.uriType){case wr.Resource:await this.resolveResource(e,t);break;case wr.DeepLink:await this.resolveDeepLink(e,t);break;default:t.push({errorType:G.InvalidUri,severity:ne.Error,message:`Unsupported URI type: ${n.uriType}. CTL only supports resource references.`,reference:e,line:e.line,column:e.column,suggestion:"Use resource URIs: kanonak://publisher/package@version/resource",toString(){let o=this.line!=null?`(${this.line}:${this.column})`:"";return`${ne[this.severity]}: ${this.message} ${o}`.trim()}});break}}async resolveResource(e,t){let r=e.parsedUri,n=r.namespace_,o=await this.repository.getDocumentAsync(n);if(!o){t.push(this.createError(G.PackageNotFound,`Package not found: ${n}`,e));return}if(o.body&&o.body[r.resourceName])e.isResolved=!0;else{let s=o.body?Object.keys(o.body).slice(0,5):[];t.push(this.createError(G.EntityNotFound,`Resource not found: ${r.resourceName} in ${n}`,e,s.length>0?`Available resources: ${s.join(", ")}`:void 0))}}async resolveDeepLink(e,t){let r=e.parsedUri,n=r.namespace_,o=await this.repository.getDocumentAsync(n);if(!o){t.push(this.createError(G.PackageNotFound,`Package not found: ${n}`,e));return}if(!o.body||!o.body[r.resourceName]){t.push(this.createError(G.EntityNotFound,`Resource not found: ${r.resourceName} in ${n}`,e));return}let s=o.body[r.resourceName],a=r.resourceName;for(let i of r.path){if(s==null){t.push(this.createError(G.PathNotFound,`Path not found: ${a}`,e));return}if(i.type_===Ir.Property){let c=i.name;a+=`.${c}`;let l=qn(s,c);if(l===void 0){let u=Xn(s);t.push(this.createError(G.PathNotFound,`Path not found: ${a}`,e,u));return}s=l}else if(i.type_===Ir.Index){let c=i.index;a+=`[${c}]`;let l=zn(s,c);if(l===void 0){let u=Yn(s);t.push(this.createError(G.IndexOutOfBounds,`Index out of bounds: ${a}`,e,u));return}s=l}}e.isResolved=!0,e.resolvedValue=s}createError(e,t,r,n){return{errorType:e,severity:ne.Error,message:t,reference:r,line:r.line,column:r.column,suggestion:n,toString(){let o=this.line!=null?`(${this.line}:${this.column})`:"";return`${ne[this.severity]}: ${this.message} ${o}`.trim()}}}};function qn(p,e){if(p&&typeof p=="object"&&!Array.isArray(p)){if(e in p)return p[e];let t=Object.keys(p).find(r=>r.toLowerCase()===e.toLowerCase());if(t)return p[t]}}function zn(p,e){if(Array.isArray(p)&&e>=0&&e<p.length)return p[e]}function Xn(p){if(p&&typeof p=="object"&&!Array.isArray(p)){let e=Object.keys(p).slice(0,5);if(e.length>0)return`Available properties: ${e.join(", ")}`}}function Yn(p){if(Array.isArray(p))return p.length>0?`Collection has ${p.length} items (valid indices: 0-${p.length-1})`:"Collection is empty"}import{ResolvedResourceType as xe}from"@kanonak-protocol/types/ctl/resolution/enums";var Jn=new Set(["kanonak.org/core-rdf","kanonak.org/core-rdfs","kanonak.org/core-owl","kanonak.org/core-xsd","kanonak.org/core-kanonak"]);var jt=class{repository;constructor(e){if(!e)throw new Error("Repository is required for CTL graph resolution");this.repository=e}async resolveAsync(e,t=1e3){if(!e)throw new Error("Document cannot be null");let r=new Set,n=[],o=[],s=[],a=[],i=new Set;for(let d of e.references)d.parsedUri&&i.add(d.parsedUri.toString());let c=new Map,l=new Map,u=await this.repository.getAllDocumentsAsync();for(let d of u){let g=d.metadata?.namespace_?.toString();if(!g||!d.body)continue;let h=[];for(let[b,R]of Object.entries(d.body))if(R&&typeof R=="object"&&!Array.isArray(R)){let v=this.createMockSubjectKanonak(b,R,g),K=`kanonak://${g}/${b}`;c.has(K)||c.set(K,{entity:v,namespace:g}),h.push(v)}l.set(g,h)}let m=0,y=!1;for(let d of e.references){if(!d.parsedUri){a.push({reference:d.rawUri,reason:d.error??"Failed to parse URI"});continue}let g=d.parsedUri.toString();if(r.has(g))continue;let h=await this.resolveEntityRecursive(g,null,null,0,t,r,i,n,o,s,a,c,l);m=Math.max(m,h),h>=t&&(y=!0)}let f=ro(e.rawMarkdown);return{sourceFile:e.filePath??null,originalContent:e.rawMarkdown,title:f,directReferences:n,inheritedReferences:o,foundationTypes:s,get totalResourceCount(){return n.length+o.length+s.length},get allResources(){return[...n,...o,...s]},maxDepthReached:m,wasTruncated:y,unresolvedResources:a}}async resolveEntityRecursive(e,t,r,n,o,s,a,i,c,l,u,m,y){if(s.has(e)||(s.add(e),n>=o))return n;if(!t){let R=m.get(e);if(!R)return u.push({reference:e,reason:"Resource not found in workspace"}),n;t=R.entity}let f=t,d=f.namespace??f.namespace_??"";!r&&d&&(r=await this.repository.getDocumentAsync(d));let g=this.createResolvedResource(t,e,n,y);switch(this.classifyTier(e,d,a)){case 0:i.push(g);break;case 2:l.push(g);break;default:c.push(g);break}let b=n;for(let R of g.parentClasses){let v=this.resolveReferenceToUri(R,d,r);if(v&&!s.has(v)){let K=m.get(v),x=await this.resolveEntityRecursive(v,K?.entity??null,null,n+1,o,s,a,i,c,l,u,m,y);b=Math.max(b,x)}}for(let R of g.properties.filter(v=>v.isObjectProperty)){let v=this.resolveReferenceToUri(R.rangeType,d,r);if(v&&!s.has(v)){let K=m.get(v),x=await this.resolveEntityRecursive(v,K?.entity??null,null,n+1,o,s,a,i,c,l,u,m,y);b=Math.max(b,x)}}if(g.instanceOf_){let R=this.resolveReferenceToUri(g.instanceOf_,d,r);if(R&&!s.has(R)){let v=m.get(R),K=await this.resolveEntityRecursive(R,v?.entity??null,null,n+1,o,s,a,i,c,l,u,m,y);b=Math.max(b,K)}}return b}createResolvedResource(e,t,r,n){let o=e,s=o.name??"",a=o.namespace??o.namespace_??"",i=this.classifyEntityType(e),c=Ar(e),l=Qn(e),u=eo(e),m=[];if(i===xe.Class){let y=n.get(a);y&&(m=to(s,y))}return{name:s,kanonakUri:t,resource:e,resourceType:i,parentClass:l.length>0?l[0]:null,parentClasses:l,comment:c,properties:m,namespace_:a,resolutionDepth:r,instanceOf_:u}}classifyEntityType(e){if(w.isClassType(e))return xe.Class;if(w.isAnnotationPropertyType(e))return xe.AnnotationProperty;if(w.isDatatypePropertyType(e))return xe.DatatypeProperty;if(w.isObjectPropertyType(e))return xe.ObjectProperty;let t=w.getTypeUri(e);return t&&!w.isCoreOntologyType(t)?xe.Instance:xe.Other}classifyTier(e,t,r){return r.has(e)?0:Zn(t)?2:1}resolveReferenceToUri(e,t,r){if(e.toLowerCase().startsWith("kanonak://"))return e;if(e.includes(".")&&r?.metadata){let n=e.indexOf("."),o=e.substring(0,n),s=e.substring(n+1);if(s){let a=r.metadata.allImports;if(a){for(let i of a)if((i.alias??i.packageName).toLowerCase()===o.toLowerCase())return`kanonak://${i.version?`${i.publisher}/${i.packageName}@${i.version}`:`${i.publisher}/${i.packageName}`}/${s}`}}}return!e.includes(".")&&t?`kanonak://${t}/${e}`:null}createMockSubjectKanonak(e,t,r){let n=[];for(let[o,s]of Object.entries(t))typeof s=="string"?o==="type"||o==="subClassOf"||o==="domain"||o==="range"||o==="subPropertyOf"?n.push({predicate:{subject:{name:o,publisher:"",package_:""}},object:{subject:{name:s,publisher:"",package_:""}}}):n.push({predicate:{subject:{name:o,publisher:"",package_:""}},object:s}):Array.isArray(s)&&n.push({predicate:{subject:{name:o,publisher:"",package_:""}},object:s.map(a=>typeof a=="string"?{subject:{name:a,publisher:"",package_:""}}:a)});return{name:e,namespace_:r,statement:n,entity:t}}};function Zn(p){if(!p)return!1;let e=p.split("/");if(e.length<2)return!1;let t=e[0],r=e[1],n=r.includes("@")?r.split("@")[0]:r;return Jn.has(`${t}/${n}`)}function Ar(p){let e=p;if(e.entity&&typeof e.entity=="object")return e.entity.comment??null;if(e.statement&&Array.isArray(e.statement)){for(let t of e.statement)if(t.predicate?.subject?.name==="comment"&&typeof t.object=="string")return t.object}return null}function Qn(p){let e=[],t=p,r=t.name??"";if(t.entity&&typeof t.entity=="object"){let n=t.entity.subClassOf;if(typeof n=="string")n.toLowerCase()!==r.toLowerCase()&&e.push(n);else if(Array.isArray(n))for(let o of n){let s=typeof o=="string"?o:o?.subject?.name??o?.name;s&&s.toLowerCase()!==r.toLowerCase()&&e.push(s)}return e}if(t.statement&&Array.isArray(t.statement)){for(let n of t.statement)if(n.predicate?.subject?.name==="subClassOf"){if(n.object?.subject?.name){let o=n.object.subject.name;o.toLowerCase()!==r.toLowerCase()&&e.push(o)}else if(Array.isArray(n.object))for(let o of n.object){let s=o?.subject?.name??o?.name;s&&s.toLowerCase()!==r.toLowerCase()&&e.push(s)}}}return e}function eo(p){let e=w.getTypeUri(p);return e?w.isCoreOntologyType(e)?null:e.name:null}function to(p,e){let t=[];for(let r of e){if(!w.isAnyPropertyType(r))continue;let n=r,o=[],s=[];if(n.entity&&typeof n.entity=="object"){let l=n.entity.domain;if(typeof l=="string")o.push(l);else if(Array.isArray(l))for(let m of l)o.push(typeof m=="string"?m:m?.name??String(m));let u=n.entity.range;if(typeof u=="string")s.push(u);else if(Array.isArray(u))for(let m of u)s.push(typeof m=="string"?m:m?.name??String(m))}if(!o.some(l=>l.toLowerCase()===p.toLowerCase()))continue;s.length===0&&s.push("unknown");let a=w.isObjectPropertyType(r),i=n.entity?.collection!=null,c=Ar(r);t.push({name:n.name??"",rangeTypes:s,domains:o,get rangeType(){return s.length>0?s.join(", "):"unknown"},isObjectProperty:a,isCollection:i,comment:c})}return t}function ro(p){let e=p.split(`
148
- `);for(let t of e){let r=t.trim();if(r.startsWith("# ")&&!r.startsWith("## "))return r.substring(2).trim()}return null}import{ResolvedResourceType as N}from"@kanonak-protocol/types/ctl/resolution/enums";var Ot=class{resolvedResourceNames=new Set;render(e){if(!e)throw new Error("Graph cannot be null");this.resolvedResourceNames=new Set(e.allResources.map(r=>r.name.toLowerCase()));let t=[];return t.push(this.transformTemplateLinks(e.originalContent)),t.push(""),t.push("---"),t.push(""),t.push("# Kanonak Resource Reference"),t.push(""),this.renderSummary(t,e),this.renderHierarchyDiagram(t,e),this.renderQuickReference(t,e),this.renderTier(t,"Direct References",e.directReferences,"Resources explicitly referenced in this template."),this.renderTier(t,"Inherited References",e.inheritedReferences,"Parent classes, property types, and other dependencies of directly referenced entities."),this.renderTier(t,"Foundation Types",e.foundationTypes,"Core ontology types that form the base of the type hierarchy."),e.unresolvedResources.length>0&&this.renderUnresolved(t,e.unresolvedResources),t.join(`
149
- `)}generateAnchor(e){return e.toLowerCase()}renderInternalLink(e){return this.resolvedResourceNames.has(e.toLowerCase())?`[${e}](#${this.generateAnchor(e)})`:e}renderInternalLinks(e){return e.map(t=>this.renderInternalLink(t)).join(", ")}transformTemplateLinks(e){let t=/\[([^\]]+)\]\(can:\/\/([^)]+)\)/g;return e.replace(t,(r,n,o)=>{let s;if(o.includes("#"))s=o.substring(o.indexOf("#")+1);else{let a=o.lastIndexOf(".");s=a>=0?o.substring(a+1):o}return this.resolvedResourceNames.has(s.toLowerCase())?`[${n}](#${this.generateAnchor(s)})`:r})}renderSummary(e,t){e.push(`**Total Resources**: ${t.totalResourceCount}`),e.push(`- Direct: ${t.directReferences.length}`),e.push(`- Inherited: ${t.inheritedReferences.length}`),e.push(`- Foundation: ${t.foundationTypes.length}`),t.wasTruncated&&(e.push(""),e.push(`**Resolution was truncated at depth ${t.maxDepthReached}** - some resources may be missing.`),e.push("To include more resources, re-run with a higher depth limit: `kanonak ctl resolve <file> --depth 2000`")),e.push("")}renderQuickReference(e,t){let r=t.allResources;if(r.length===0)return;e.push("## Quick Reference"),e.push("");let n=r.filter(l=>l.resourceType===N.Class),o=r.filter(l=>l.resourceType===N.AnnotationProperty),s=r.filter(l=>l.resourceType===N.DatatypeProperty),a=r.filter(l=>l.resourceType===N.ObjectProperty),i=r.filter(l=>l.resourceType===N.Instance);if(n.length>0){e.push(`### Classes (${n.length})`),e.push(""),e.push("| Class | Extends | Properties |"),e.push("|-------|---------|------------|");for(let l of[...n].sort((u,m)=>u.name.localeCompare(m.name))){let u=this.renderInternalLink(l.name),m=l.parentClasses.length>0?this.renderInternalLinks(l.parentClasses):"-";e.push(`| ${u} | ${m} | ${l.properties.length} |`)}e.push("")}let c=[...o,...s,...a];if(c.length>0){e.push(`### Properties (${c.length})`),e.push(""),e.push("| Property | Type | Description |"),e.push("|----------|------|-------------|");for(let l of[...c].sort((u,m)=>u.name.localeCompare(m.name))){let u=this.renderInternalLink(l.name),m=Sr(l.resourceType),y=no(l.comment??"");e.push(`| ${u} | ${m} | ${y} |`)}e.push("")}if(i.length>0){let l=new Map;for(let u of i){let m=u.instanceOf_??"Unknown";l.has(m)||l.set(m,[]),l.get(m).push(u)}e.push("### Resources by Type"),e.push(""),e.push("| Type | Resources |"),e.push("|------|-----------|");for(let[u,m]of[...l.entries()].sort((y,f)=>y[0].localeCompare(f[0]))){let y=this.renderInternalLink(u),f=this.renderInternalLinks(m.map(d=>d.name));e.push(`| ${y} | ${f} |`)}e.push("")}}renderHierarchyDiagram(e,t){let r=t.allResources.filter(a=>a.resourceType===N.Class);if(r.length===0)return;let n=r.filter(a=>a.parentClasses.length>0);if(n.length===0)return;let o=new Set;for(let a of n)for(let i of a.parentClasses)o.add(i.toLowerCase());let s=new Set(r.map(a=>a.name.toLowerCase()));e.push("## Type Hierarchy"),e.push(""),e.push("```mermaid"),e.push("flowchart TB");for(let a of[...r].sort((i,c)=>i.name.localeCompare(c.name))){let i=xt(a.name);e.push(` ${i}["${a.name}"]`)}for(let a of[...o])if(!s.has(a)){let i=a;for(let l of n)for(let u of l.parentClasses)u.toLowerCase()===a&&(i=u);let c=xt(i);e.push(` ${c}["${i}"]:::external`)}e.push("");for(let a of n){let i=xt(a.name);for(let c of a.parentClasses){let l=xt(c);e.push(` ${l} --> ${i}`)}}e.push(""),e.push(" classDef external fill:#f9f9f9,stroke:#999,stroke-dasharray: 5 5"),e.push("```"),e.push("")}renderTier(e,t,r,n){if(r.length!==0){e.push(`## ${t} (${r.length})`),e.push(""),e.push(`*${n}*`),e.push("");for(let o of[...r].sort((s,a)=>s.name.localeCompare(a.name)))this.renderEntity(e,o)}}renderEntity(e,t){let r=this.generateAnchor(t.name);if(e.push(`### ${t.name}`),e.push(`<a id="${r}"></a>`),e.push(""),e.push("| Attribute | Value |"),e.push("|-----------|-------|"),e.push(`| **URI** | \`${t.kanonakUri}\` |`),e.push(`| **Type** | ${Sr(t.resourceType)} |`),t.parentClasses.length>0){let n=this.renderInternalLinks(t.parentClasses);e.push(`| **Extends** | ${n} |`)}if(t.instanceOf_){let n=this.renderInternalLink(t.instanceOf_);e.push(`| **Instance of** | ${n} |`)}e.push(""),t.comment&&(e.push(t.comment),e.push("")),t.resourceType===N.Class&&t.properties.length>0&&this.renderPropertiesTable(e,t.properties),e.push("---"),e.push("")}renderPropertiesTable(e,t){e.push("| Property | Type | Description |"),e.push("|----------|------|-------------|");for(let r of[...t].sort((n,o)=>n.name.localeCompare(o.name))){let o=r.rangeTypes.map(a=>{let i=this.renderInternalLink(a);return r.isObjectProperty?`-> ${i}`:i}).join(", ");r.isCollection&&(o=`${o}[]`);let s=(r.comment??"").replace(/\|/g,"\\|").replace(/\n/g," ").replace(/\r/g,"");e.push(`| ${r.name} | ${o} | ${s} |`)}e.push("")}renderUnresolved(e,t){e.push(`## Unresolved References (${t.length})`),e.push(""),e.push("*The following references could not be resolved:*"),e.push("");for(let r of t)e.push(`- \`${r.reference}\`: ${r.reason}`);e.push("")}};function Sr(p){switch(p){case N.Class:return"Class";case N.AnnotationProperty:return"Annotation Property";case N.DatatypeProperty:return"Datatype Property";case N.ObjectProperty:return"Object Property";case N.Instance:return"Instance";default:return"Other"}}function no(p){return p?(p=p.replace(/\|/g,"\\|").replace(/\n/g," ").replace(/\r/g,""),p.length<=50?p:p.substring(0,47)+"..."):""}function xt(p){return p.replace(/[^a-zA-Z0-9]/g,"_")}import{CtlValidationErrorType as oo,CtlValidationSeverity as so}from"@kanonak-protocol/types/ctl/models/enums";import{CtlKanonakUriType as ao,PathSegmentType as io}from"@kanonak-protocol/types/ctl/parsing/enums";import{ResolvedResourceType as co}from"@kanonak-protocol/types/ctl/resolution/enums";export{Ie as AmbiguousReferenceRule,X as BooleanStatement,Ke as ClassDefinitionRule,de as ClassHierarchyCycleRule,Ee as CompositeKanonakDocumentRepository,Dt as CredentialStore,jt as CtlGraphResolver,je as CtlKanonakUri,ao as CtlKanonakUriType,Ot as CtlMarkdownRenderer,$t as CtlParser,oo as CtlValidationErrorType,so as CtlValidationSeverity,Kt as CtlValidator,Z as DefinedKanonak,Pe as DefinitionPropertyReferenceRule,Vt as DocumentLocation,_t as EdgeType,_ as EmbeddedKanonak,ue as EmbeddedKanonakNoExplicitTypeRule,B as EmbeddedStatement,oe as FileSystemKanonakDocumentRepository,lt as GitIgnoreFilter,ct as GraphBuilder,it as HttpKanonakDocumentRepository,me as ImportExistenceRule,nt as InMemoryKanonakDocumentRepository,ve as InstancePropertyReferenceRule,U as Kanonak,ee as KanonakObjectParser,dt as KanonakObjectValidator,O as KanonakParser,V as KanonakUri,yt as KanonakUriBuilder,Ue as KanonakVocabulary,W as ListStatement,q as LiteralKanonak,Re as NamespaceImportCycleRule,ie as NamespacePrefixRule,Nt as NodeType,z as NumberStatement,qe as OWL_RL_CLASSIFICATION_RULES,Se as ObjectPropertyImportRule,Ce as ObjectPropertyValueValidationRule,k as OntologyValidationError,ae as OntologyValidationResult,io as PathSegmentType,De as PropertyDomainRule,ge as PropertyHierarchyCycleRule,mt as PropertyMetadata,Ae as PropertyRangeReferenceRule,he as PropertyRangeRequiredRule,pe as PropertyTypeSpecificityRule,$e as PropertyValueTypeRule,Ve as PublisherConfigResolver,se as PublisherIndex,Ge as RDFS_RULES,pt as Reasoner,Me as ReasoningResult,I as ReferenceKanonak,Y as ReferenceStatement,st as RepositoryFactory,co as ResolvedResourceType,ce as ResourceNamingRule,E as ResourceResolver,w as ResourceTypeClassifier,M as ScalarStatement,T as Statement,F as StringStatement,ke as SubClassOfReferenceRule,be as SubPropertyOfReferenceRule,L as SubjectKanonak,le as SubjectKanonakTypeRequiredRule,_e as TripleStore,fe as TypeAmbiguityRule,Q as TypeResolver,ye as UnresolvedReferenceRule,ft as ValidationContext,P as ValidationSeverity,we as XsdImportRule,br as createAuthenticatedFetch,tt as createDPoPProof,sr as findInstancesByType,hr as generateDPoPKeyPair,We as getGlobalCachePath,gt as hasValidToken,ze as isExpired,$ as makeUriKey,A as normalizeHost,kr as serverSupportsDPoP,He as tripleKey,Ne as uriKey,S as uriTriple};
141
+ Check the 'credentialHelper' path in ~/.kanonak/config.json.`)}}async store(e,t){let r=S(e);try{await this.runHelper("store",{publisher:r,credential:t})}catch(n){throw new Error(`Credential helper '${this.helperPath}' failed to store credential for '${r}': ${Nt(n)}
142
+ Verify the helper binary supports the 'store' action.`)}}async remove(e){let t=S(e);try{await this.runHelper("erase",{publisher:t})}catch(r){console.warn(` Warning: Credential helper '${this.helperPath}' failed to erase credential for '${t}': ${Nt(r)}`)}}async list(){try{let e=await this.runHelper("list",void 0);return JSON.parse(e.trim())}catch(e){return console.warn(` Warning: Credential helper '${this.helperPath}' failed to list credentials: ${Nt(e)}`),[]}}async runHelper(e,t){try{let{stdout:r}=await Yn(this.helperPath,[e],{...t&&{input:JSON.stringify(t)},timeout:Er});return r}catch(r){throw Jn(r)?new Error(`Credential helper not found at '${this.helperPath}'.
143
+ Check the 'credentialHelper' path in ~/.kanonak/config.json.`):Zn(r)?new Error(`Credential helper '${this.helperPath}' timed out after ${Er/1e3}s on '${e}'.
144
+ The helper may be waiting for authentication to an external vault.`):r}}};function Nt(c){return c instanceof Error?c.message:String(c)}function Jn(c){return c instanceof Error&&"code"in c&&c.code==="ENOENT"}function Zn(c){return c instanceof Error&&"killed"in c&&c.killed}var ir=ro(to(),".kanonak","config.json"),_t=class{backend=null;backendReady=null;async getBackend(){if(this.backend)return this.backend;if(this.backendReady)return this.backendReady;this.backendReady=this.resolveBackend();try{return this.backend=await this.backendReady,this.backend}catch(e){throw this.backendReady=null,e}}async getToken(e){let t=no(e);if(t)return t;let n=await(await this.getBackend()).get(e);return!n||!At(n)?null:n.accessToken??null}async getCredential(e){return(await this.getBackend()).get(e)}async store(e,t){return(await this.getBackend()).store(e,t)}async remove(e){return(await this.getBackend()).remove(e)}async list(){return(await this.getBackend()).list()}async resolveBackend(){let e=oo();return e.credentialHelper?new pt(e.credentialHelper):process.platform==="darwin"?new ot:process.platform==="win32"?new st:await nr()?new at:new ct}};function no(c){let t="KANONAK_TOKEN_"+S(c).replace(/[.\-]/g,"_").toUpperCase();return process.env[t]??null}function oo(){if(!Qn(ir))return{};try{return JSON.parse(eo(ir,"utf-8"))}catch(c){let e=c instanceof Error?c.message:String(c);return console.warn(` Warning: Failed to parse ${ir}: ${e}
145
+ Using default credential backend. Fix the JSON syntax or delete the file.`),{}}}import{createHash as so,createPrivateKey as ao,generateKeyPairSync as io,randomUUID as co,sign as po}from"crypto";function Nr(){let{publicKey:c,privateKey:e}=io("ec",{namedCurve:"P-256"});return{publicKey:c.export({format:"jwk"}),privateKey:e.export({format:"jwk"})}}function lt(c,e,t,r,n,o){let s={alg:"ES256",typ:"dpop+jwt",jwk:{kty:e.kty,crv:e.crv,x:e.x,y:e.y}},a={jti:co(),htm:t.toUpperCase(),htu:r,iat:Math.floor(Date.now()/1e3)};return n&&(a.ath=so("sha256").update(n).digest("base64url")),o&&(a.nonce=o),lo(s,a,c)}function _r(c){return!c||c.length===0?!1:c.some(e=>e.toUpperCase()==="ES256")}function lo(c,e,t){let r=Tr(JSON.stringify(c)),n=Tr(JSON.stringify(e)),o=`${r}.${n}`,s=ao({key:t,format:"jwk"}),i=po("SHA256",Buffer.from(o),{key:s,dsaEncoding:"ieee-p1363"}).toString("base64url");return`${o}.${i}`}function Tr(c){return Buffer.from(c,"utf-8").toString("base64url")}function Ur(c){let e=new Map;return async(t,r,n="GET")=>{if(!c)return fetch(t,{method:n});let o=await c.getCredential(r);if(!o?.accessToken)return fetch(t,{method:n});nt(o)&&console.warn(` Warning: Access token for '${r}' is expired. Run 'kanonak login ${r}' to re-authenticate.`);let s={};if(o.dpopKeyPair){let i=e.get(r);try{let p=lt(o.dpopKeyPair.privateKey,o.dpopKeyPair.publicKey,n,t,o.accessToken,i);s.Authorization=`DPoP ${o.accessToken}`,s.DPoP=p}catch(p){let l=p instanceof Error?p.message:String(p);console.error(` Error: Failed to create DPoP proof for '${r}': ${l}
146
+ The stored key pair may be corrupted. Run 'kanonak login ${r}' to re-authenticate.`),s.Authorization=`Bearer ${o.accessToken}`}}else s.Authorization=`Bearer ${o.accessToken}`;let a=await fetch(t,{method:n,headers:s});if(a.status===401&&o.dpopKeyPair){let i=a.headers.get("DPoP-Nonce");if(i){e.set(r,i);try{let p=lt(o.dpopKeyPair.privateKey,o.dpopKeyPair.publicKey,n,t,o.accessToken,i);s.DPoP=p,a=await fetch(t,{method:n,headers:s})}catch{}}}return a}}import{readFileSync as uo,writeFileSync as mo,existsSync as yo}from"fs";import{createHash as fo}from"crypto";import Lr from"js-yaml";var Mr="kanonak.lock",go=`# This file is generated by Kanonak CLI. Do not edit manually.
147
+ `;function Fr(c=Mr){if(!yo(c))return null;let e=uo(c,"utf-8"),t=Lr.load(e);return!t||typeof t!="object"||t.version!=="1"?null:{version:"1",lastUpdated:t.lastUpdated??new Date().toISOString(),packages:t.packages??{}}}function Br(c,e=Mr){c.lastUpdated=new Date().toISOString();let t={};for(let n of Object.keys(c.packages).sort())t[n]=c.packages[n];c.packages=t;let r=Lr.dump(c,{lineWidth:-1,sortKeys:!1,quotingType:'"'});mo(e,go+r,"utf-8")}function Wr(c){return`sha256:${fo("sha256").update(c).digest("hex")}`}import{CtlKanonakUriType as ut,PathSegmentType as cr}from"@kanonak-protocol/types/ctl/parsing/enums";var ho=/\.?([a-zA-Z_][a-zA-Z0-9_-]*|\[\d+\])/g;function ko(c){let e=c.split(".").map(Number),t=e[0]||0,r=e[1]||0,n=e[2]||0;return{major:t,minor:r,patch:n,toString:()=>`${t}.${r}.${n}`,equals:o=>o&&typeof o=="object"&&o.major===t&&o.minor===r&&o.patch===n,getHashCode:()=>t<<20|r<<10|n,compareTo:o=>t!==o.major?t-o.major:r!==o.minor?r-o.minor:n-o.patch}}var Ee=class c{scheme="kanonak";publisher;package_;version;resourceName;path;rawUri;constructor(e){this.publisher=e.publisher,this.package_=e.package_,this.version=e.version,this.resourceName=e.resourceName,this.path=e.path??[],this.rawUri=e.rawUri}get uriType(){return this.path.length>0?ut.DeepLink:this.resourceName!=null?ut.Resource:this.version!=null?ut.VersionedPackage:this.package_!=null?ut.Package:ut.Publisher}get namespace_(){return this.package_==null?null:this.version==null?`${this.publisher}/${this.package_}`:`${this.publisher}/${this.package_}@${this.version}`}static parse(e){if(!e||e.trim().length===0)throw new Error("Kanonak URI string cannot be null or empty");if(!e.toLowerCase().startsWith("kanonak://"))throw new Error(`Invalid Kanonak URI: '${e}'. Must start with 'kanonak://'`);let t=e.substring(8);if(!t||t.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Publisher is required after 'kanonak://'`);let r=t.indexOf("#"),n=null,o;if(r>=0){if(o=t.substring(0,r),n=t.substring(r+1),!n||n.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Deep link path required after '#'`)}else o=t;let s,a=null,i=null,p=null,l=o.indexOf("@");if(l>=0){let m=o.substring(0,l),y=o.substring(l+1),f=m.indexOf("/");if(f<0)throw new Error(`Invalid Kanonak URI: '${e}'. Expected format: publisher/package@version/resource`);if(s=m.substring(0,f),a=m.substring(f+1),!s||s.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Publisher cannot be empty`);if(!a||a.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Package cannot be empty`);let d=y.indexOf("/");if(d<0)throw new Error(`Invalid Kanonak URI: '${e}'. CTL requires resource references (kanonak://publisher/package@version/resource)`);let g=y.substring(0,d);if(p=y.substring(d+1),!g||g.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Version required after '@'`);if(i=ko(g),!p||p.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Resource name cannot be empty`)}else{let m=o.split("/");if(m.length<3)throw new Error(`Invalid Kanonak URI: '${e}'. CTL requires resource references (kanonak://publisher/package/resource)`);if(m.length>3)throw new Error(`Invalid Kanonak URI: '${e}'. Too many path segments. Expected: publisher/package/resource`);if(s=m[0],a=m[1],p=m[2],!s||s.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Publisher cannot be empty`);if(!a||a.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Package cannot be empty`);if(!p||p.trim().length===0)throw new Error(`Invalid Kanonak URI: '${e}'. Resource name cannot be empty`)}let u=[];return n!=null&&(u=bo(n,e)),new c({publisher:s,package_:a,version:i,resourceName:p,path:u,rawUri:e})}static tryParse(e){try{return c.parse(e)}catch{return null}}static isKanonakUri(e){return!!e&&e.trim().length>0&&e.toLowerCase().startsWith("kanonak://")}toString(){let e=`kanonak://${this.publisher}`;if(this.package_!=null&&(e+=`/${this.package_}`,this.version!=null&&(e+=`@${this.version}`),this.resourceName!=null&&(e+=`/${this.resourceName}`,this.path.length>0))){e+="#";let t=!0;for(let r of this.path)r.type_===cr.Index?e+=`[${r.index}]`:(t||(e+="."),e+=r.name),t=!1}return e}equals(e){return e instanceof c?this.rawUri.toLowerCase()===e.rawUri.toLowerCase():!1}getHashCode(){let e=0,t=this.rawUri.toLowerCase();for(let r=0;r<t.length;r++)e=(e<<5)-e+t.charCodeAt(r),e|=0;return e}};function bo(c,e){let t=[],r=new RegExp(ho.source,"g"),n=0,o;for(;(o=r.exec(c))!==null;){let s=o[1];if(s.startsWith("[")&&s.endsWith("]")){let a=s.substring(1,s.length-1),i=parseInt(a,10);if(isNaN(i))throw new Error(`Invalid Kanonak URI: '${e}'. Invalid array index: ${s}`);t.push({type_:cr.Index,index:i,toString:()=>`[${i}]`})}else t.push({type_:cr.Property,name:s,toString:()=>s});n+=o[0].length}if(n!==c.length)throw new Error(`Invalid Kanonak URI: '${e}'. Invalid path syntax in: ${c}`);return t}import{VersionOperator as ae}from"@kanonak-protocol/types/document/models/enums";import*as Gr from"js-yaml";var Ro=/\[([^\]]+)\]\((kanonak:\/\/[^)]+)\)/gi,Po=/\[([^\]]+)\]\(kan:\/\/([^)]+)\)/gi,vo=/```[\s\S]*?```|`[^`]+`/g,wo=/^---\s*\n([\s\S]*?)\n---\s*\n/;function Io(c,e,t){let r=`${c}.${e}.${t}`;return{major:c,minor:e,patch:t,toString:()=>r,equals:n=>n?.major===c&&n?.minor===e&&n?.patch===t,getHashCode:()=>c<<20|e<<10|t,compareTo:n=>c!==n.major?c-n.major:e!==n.minor?e-n.minor:t-n.patch}}function So(c,e,t,r,n){let o=r===ae.Compatible?"~":r===ae.Major?"^":r===ae.Exact?"=":"*",s=`${e} ${o} ${t}`;return{package_:s,publisher:c,packageName:e,versionOperator:r,version:t,alias:n,get minVersion(){return t},get maxVersion(){return t},toEmbeddedObject(){let a={package:e,version:t.toString()};return n&&(a.alias=n),r!==ae.Exact&&(a.match=o),a},toString(){return s}}}var Ut=class{parse(e,t){if(e==null)throw new Error("Content cannot be null");e.charCodeAt(0)===65279&&(e=e.substring(1));let r=wo.exec(e);return r?this.parseWithFrontmatter(e,r,t??null):this.parseInline(e,t??null)}async parseFileAsync(e){if(!e||e.trim().length===0)throw new Error("File path cannot be null or empty");let r=(await import("fs")).readFileSync(e,"utf-8");return this.parse(r,e)}parseWithFrontmatter(e,t,r){let n=t[1],o=e.substring(t[0].length),s=null,a=new Map;try{let p=Gr.load(n);if(!p)throw new Error("Frontmatter YAML is empty");if(!p.imports||!Array.isArray(p.imports))throw new Error("Frontmatter must contain an 'imports' sequence");let l={};for(let m of p.imports){if(!m||typeof m!="object")throw new Error("Each import entry must be a mapping with 'publisher' and 'packages'");let y=m.publisher?.toString();if(!y)throw new Error("Each import entry requires a 'publisher' property");if(!m.packages||!Array.isArray(m.packages))throw new Error(`Import entry for publisher '${y}' requires a 'packages' sequence`);l[y]||(l[y]=[]);for(let f of m.packages){if(!f||typeof f!="object")throw new Error(`Each package in publisher '${y}' must be a mapping`);let g=(f.version?.toString()??"1.0.0").split(".").map(Number),h=Io(g[0]||0,g[1]||0,g[2]||0),k=f.match?.toString(),R=k==="^"?ae.Major:k==="~"?ae.Compatible:k==="*"?ae.Any:ae.Exact,P=So(y,f.package?.toString()??"",h,R,f.alias?.toString()??null);l[y].push(P)}}let u=[];for(let m of Object.values(l))u.push(...m);s={namespace_:void 0,imports:l,get allImports(){return u}},a=this.buildAliasMap(l)}catch(p){let l={displayText:"(frontmatter)",rawUri:"",startOffset:0,endOffset:t[0].length,line:1,column:1,isResolved:!1,error:`Failed to parse frontmatter: ${p.message}`,get fullMarkdownLink(){return`[${this.displayText}](${this.rawUri})`}};return pr({metadata:null,rawMarkdown:o,frontmatterLength:t[0].length,filePath:r,references:[l]})}let i=this.parseMarkdownBody(o,a,t[0].length);return pr({metadata:s,rawMarkdown:o,frontmatterLength:t[0].length,filePath:r,references:i})}parseInline(e,t){let r=this.parseMarkdownBody(e,new Map,0);return pr({metadata:null,rawMarkdown:e,frontmatterLength:0,filePath:t,references:r})}parseMarkdownBody(e,t,r){let n=[],o=Ao(e),s=new RegExp(Ro.source,"gi"),a;for(;(a=s.exec(e))!==null;){if(Hr(a.index,o))continue;let p=a[1],l=a[2],{line:u,column:m}=qr(e,a.index),y={displayText:p,rawUri:l,startOffset:a.index+r,endOffset:a.index+a[0].length+r,line:u,column:m,isResolved:!1,get fullMarkdownLink(){return`[${this.displayText}](${this.rawUri})`}};try{y.parsedUri=Ee.parse(l)}catch(f){y.error=f.message}n.push(y)}let i=new RegExp(Po.source,"gi");for(;(a=i.exec(e))!==null;){if(Hr(a.index,o))continue;let p=a[1],l=a[2],{line:u,column:m}=qr(e,a.index),y=null,f=null;try{y=Do(l,t)}catch(g){f=g.message}let d={displayText:p,rawUri:y??`kan://${l}`,startOffset:a.index+r,endOffset:a.index+a[0].length+r,line:u,column:m,isResolved:!1,error:f,get fullMarkdownLink(){return`[${this.displayText}](${this.rawUri})`}};if(y!=null&&f==null)try{d.parsedUri=Ee.parse(y)}catch(g){d.error=g.message}n.push(d)}return n.sort((p,l)=>p.startOffset-l.startOffset),n}buildAliasMap(e){let t=new Map;for(let[r,n]of Object.entries(e))for(let o of n){let s=o.alias??o.packageName;t.set(s.toLowerCase(),{publisher:r,package_:o.packageName,version:o.version})}return t}};function pr(c){return{metadata:c.metadata,get hasFrontmatter(){return c.metadata!=null},rawMarkdown:c.rawMarkdown,frontmatterLength:c.frontmatterLength,filePath:c.filePath,references:c.references,get referenceCount(){return c.references.length},get allReferencesResolved(){return c.references.every(e=>e.isResolved)},get unresolvedReferences(){return c.references.filter(e=>!e.isResolved)},get errorReferences(){return c.references.filter(e=>e.error!=null)}}}function Ao(c){let e=[],t=new RegExp(vo.source,"g"),r;for(;(r=t.exec(c))!==null;)e.push([r.index,r.index+r[0].length]);return e}function Hr(c,e){for(let[t,r]of e)if(c>=t&&c<r)return!0;return!1}function qr(c,e){let t=1,r=1;for(let n=0;n<e&&n<c.length;n++)c[n]===`
148
+ `?(t++,r=1):r++;return{line:t,column:r}}function Do(c,e){if(!c||c.trim().length===0)throw new Error("kan:// link cannot be empty");if(e.size===0)throw new Error("kan:// links require frontmatter with imports");let t=null,r=c,n=c.indexOf(".");if(n>0&&(t=c.substring(0,n),r=c.substring(n+1),!r||r.trim().length===0))throw new Error(`Resource name required after alias '${t}.'`);if(t!=null){let o=e.get(t.toLowerCase());if(!o){let s=Array.from(e.keys()).join(", ");throw new Error(`Unknown alias: '${t}'. Available: ${s}`)}return`kanonak://${o.publisher}/${o.package_}@${o.version}/${r}`}else{let o=e.values().next().value;if(!o)throw new Error(`Cannot resolve '${r}': no imports defined`);return`kanonak://${o.publisher}/${o.package_}@${o.version}/${r}`}}import{CtlValidationErrorType as Y,CtlValidationSeverity as ie}from"@kanonak-protocol/types/ctl/models/enums";import{CtlKanonakUriType as zr,PathSegmentType as Xr}from"@kanonak-protocol/types/ctl/parsing/enums";var Lt=class{repository;constructor(e){if(!e)throw new Error("Repository is required for CTL validation");this.repository=e}async validateAsync(e){if(!e)throw new Error("Document cannot be null");let t=[],r=[];for(let o of e.references){if(!o.parsedUri){t.push({errorType:Y.InvalidUri,severity:ie.Error,message:o.error??"Failed to parse Kanonak URI",reference:o,line:o.line,column:o.column,toString(){let s=this.line!=null?`(${this.line}:${this.column})`:"";return`${ie[this.severity]}: ${this.message} ${s}`.trim()}});continue}try{await this.resolveReference(o,t,r)}catch(s){t.push({errorType:Y.ParseError,severity:ie.Error,message:`Error resolving reference: ${s.message}`,reference:o,line:o.line,column:o.column,toString(){let a=this.line!=null?`(${this.line}:${this.column})`:"";return`${ie[this.severity]}: ${this.message} ${a}`.trim()}})}}return{isValid:t.length===0,document:e,errors:t,warnings:r,get totalReferences(){return e.referenceCount},get resolvedReferences(){return e.references.filter(o=>o.isResolved).length},get summary(){if(t.length===0)return`All ${e.referenceCount} references validated`;let o=e.references.filter(s=>s.isResolved).length;return`${t.length} error(s), ${o}/${e.referenceCount} references resolved`}}}async resolveReference(e,t,r){let n=e.parsedUri;switch(n.uriType){case zr.Resource:await this.resolveResource(e,t);break;case zr.DeepLink:await this.resolveDeepLink(e,t);break;default:t.push({errorType:Y.InvalidUri,severity:ie.Error,message:`Unsupported URI type: ${n.uriType}. CTL only supports resource references.`,reference:e,line:e.line,column:e.column,suggestion:"Use resource URIs: kanonak://publisher/package@version/resource",toString(){let o=this.line!=null?`(${this.line}:${this.column})`:"";return`${ie[this.severity]}: ${this.message} ${o}`.trim()}});break}}async resolveResource(e,t){let r=e.parsedUri,n=r.namespace_,o=await this.repository.getDocumentAsync(n);if(!o){t.push(this.createError(Y.PackageNotFound,`Package not found: ${n}`,e));return}if(o.body&&o.body[r.resourceName])e.isResolved=!0;else{let s=o.body?Object.keys(o.body).slice(0,5):[];t.push(this.createError(Y.EntityNotFound,`Resource not found: ${r.resourceName} in ${n}`,e,s.length>0?`Available resources: ${s.join(", ")}`:void 0))}}async resolveDeepLink(e,t){let r=e.parsedUri,n=r.namespace_,o=await this.repository.getDocumentAsync(n);if(!o){t.push(this.createError(Y.PackageNotFound,`Package not found: ${n}`,e));return}if(!o.body||!o.body[r.resourceName]){t.push(this.createError(Y.EntityNotFound,`Resource not found: ${r.resourceName} in ${n}`,e));return}let s=o.body[r.resourceName],a=r.resourceName;for(let i of r.path){if(s==null){t.push(this.createError(Y.PathNotFound,`Path not found: ${a}`,e));return}if(i.type_===Xr.Property){let p=i.name;a+=`.${p}`;let l=Co(s,p);if(l===void 0){let u=$o(s);t.push(this.createError(Y.PathNotFound,`Path not found: ${a}`,e,u));return}s=l}else if(i.type_===Xr.Index){let p=i.index;a+=`[${p}]`;let l=Ko(s,p);if(l===void 0){let u=xo(s);t.push(this.createError(Y.IndexOutOfBounds,`Index out of bounds: ${a}`,e,u));return}s=l}}e.isResolved=!0,e.resolvedValue=s}createError(e,t,r,n){return{errorType:e,severity:ie.Error,message:t,reference:r,line:r.line,column:r.column,suggestion:n,toString(){let o=this.line!=null?`(${this.line}:${this.column})`:"";return`${ie[this.severity]}: ${this.message} ${o}`.trim()}}}};function Co(c,e){if(c&&typeof c=="object"&&!Array.isArray(c)){if(e in c)return c[e];let t=Object.keys(c).find(r=>r.toLowerCase()===e.toLowerCase());if(t)return c[t]}}function Ko(c,e){if(Array.isArray(c)&&e>=0&&e<c.length)return c[e]}function $o(c){if(c&&typeof c=="object"&&!Array.isArray(c)){let e=Object.keys(c).slice(0,5);if(e.length>0)return`Available properties: ${e.join(", ")}`}}function xo(c){if(Array.isArray(c))return c.length>0?`Collection has ${c.length} items (valid indices: 0-${c.length-1})`:"Collection is empty"}import{ResolvedResourceType as Te}from"@kanonak-protocol/types/ctl/resolution/enums";var jo=new Set(["kanonak.org/core-rdf","kanonak.org/core-rdfs","kanonak.org/core-owl","kanonak.org/core-xsd","kanonak.org/core-kanonak"]);var Mt=class{repository;constructor(e){if(!e)throw new Error("Repository is required for CTL graph resolution");this.repository=e}async resolveAsync(e,t=1e3){if(!e)throw new Error("Document cannot be null");let r=new Set,n=[],o=[],s=[],a=[],i=new Set;for(let d of e.references)d.parsedUri&&i.add(d.parsedUri.toString());let p=new Map,l=new Map,u=await this.repository.getAllDocumentsAsync();for(let d of u){let g=d.metadata?.namespace_?.toString();if(!g||!d.body)continue;let h=[];for(let[k,R]of Object.entries(d.body))if(R&&typeof R=="object"&&!Array.isArray(R)){let P=this.createMockSubjectKanonak(k,R,g),x=`kanonak://${g}/${k}`;p.has(x)||p.set(x,{entity:P,namespace:g}),h.push(P)}l.set(g,h)}let m=0,y=!1;for(let d of e.references){if(!d.parsedUri){a.push({reference:d.rawUri,reason:d.error??"Failed to parse URI"});continue}let g=d.parsedUri.toString();if(r.has(g))continue;let h=await this.resolveEntityRecursive(g,null,null,0,t,r,i,n,o,s,a,p,l);m=Math.max(m,h),h>=t&&(y=!0)}let f=No(e.rawMarkdown);return{sourceFile:e.filePath??null,originalContent:e.rawMarkdown,title:f,directReferences:n,inheritedReferences:o,foundationTypes:s,get totalResourceCount(){return n.length+o.length+s.length},get allResources(){return[...n,...o,...s]},maxDepthReached:m,wasTruncated:y,unresolvedResources:a}}async resolveEntityRecursive(e,t,r,n,o,s,a,i,p,l,u,m,y){if(s.has(e)||(s.add(e),n>=o))return n;if(!t){let R=m.get(e);if(!R)return u.push({reference:e,reason:"Resource not found in workspace"}),n;t=R.entity}let f=t,d=f.namespace??f.namespace_??"";!r&&d&&(r=await this.repository.getDocumentAsync(d));let g=this.createResolvedResource(t,e,n,y);switch(this.classifyTier(e,d,a)){case 0:i.push(g);break;case 2:l.push(g);break;default:p.push(g);break}let k=n;for(let R of g.parentClasses){let P=this.resolveReferenceToUri(R,d,r);if(P&&!s.has(P)){let x=m.get(P),V=await this.resolveEntityRecursive(P,x?.entity??null,null,n+1,o,s,a,i,p,l,u,m,y);k=Math.max(k,V)}}for(let R of g.properties.filter(P=>P.isObjectProperty)){let P=this.resolveReferenceToUri(R.rangeType,d,r);if(P&&!s.has(P)){let x=m.get(P),V=await this.resolveEntityRecursive(P,x?.entity??null,null,n+1,o,s,a,i,p,l,u,m,y);k=Math.max(k,V)}}if(g.instanceOf_){let R=this.resolveReferenceToUri(g.instanceOf_,d,r);if(R&&!s.has(R)){let P=m.get(R),x=await this.resolveEntityRecursive(R,P?.entity??null,null,n+1,o,s,a,i,p,l,u,m,y);k=Math.max(k,x)}}return k}createResolvedResource(e,t,r,n){let o=e,s=o.name??"",a=o.namespace??o.namespace_??"",i=this.classifyEntityType(e),p=Yr(e),l=Vo(e),u=Eo(e),m=[];if(i===Te.Class){let y=n.get(a);y&&(m=To(s,y))}return{name:s,kanonakUri:t,resource:e,resourceType:i,parentClass:l.length>0?l[0]:null,parentClasses:l,comment:p,properties:m,namespace_:a,resolutionDepth:r,instanceOf_:u}}classifyEntityType(e){if(w.isClassType(e))return Te.Class;if(w.isAnnotationPropertyType(e))return Te.AnnotationProperty;if(w.isDatatypePropertyType(e))return Te.DatatypeProperty;if(w.isObjectPropertyType(e))return Te.ObjectProperty;let t=w.getTypeUri(e);return t&&!w.isCoreOntologyType(t)?Te.Instance:Te.Other}classifyTier(e,t,r){return r.has(e)?0:Oo(t)?2:1}resolveReferenceToUri(e,t,r){if(e.toLowerCase().startsWith("kanonak://"))return e;if(e.includes(".")&&r?.metadata){let n=e.indexOf("."),o=e.substring(0,n),s=e.substring(n+1);if(s){let a=r.metadata.allImports;if(a){for(let i of a)if((i.alias??i.packageName).toLowerCase()===o.toLowerCase())return`kanonak://${i.version?`${i.publisher}/${i.packageName}@${i.version}`:`${i.publisher}/${i.packageName}`}/${s}`}}}return!e.includes(".")&&t?`kanonak://${t}/${e}`:null}createMockSubjectKanonak(e,t,r){let n=[];for(let[o,s]of Object.entries(t))typeof s=="string"?o==="type"||o==="subClassOf"||o==="domain"||o==="range"||o==="subPropertyOf"?n.push({predicate:{subject:{name:o,publisher:"",package_:""}},object:{subject:{name:s,publisher:"",package_:""}}}):n.push({predicate:{subject:{name:o,publisher:"",package_:""}},object:s}):Array.isArray(s)&&n.push({predicate:{subject:{name:o,publisher:"",package_:""}},object:s.map(a=>typeof a=="string"?{subject:{name:a,publisher:"",package_:""}}:a)});return{name:e,namespace_:r,statement:n,entity:t}}};function Oo(c){if(!c)return!1;let e=c.split("/");if(e.length<2)return!1;let t=e[0],r=e[1],n=r.includes("@")?r.split("@")[0]:r;return jo.has(`${t}/${n}`)}function Yr(c){let e=c;if(e.entity&&typeof e.entity=="object")return e.entity.comment??null;if(e.statement&&Array.isArray(e.statement)){for(let t of e.statement)if(t.predicate?.subject?.name==="comment"&&typeof t.object=="string")return t.object}return null}function Vo(c){let e=[],t=c,r=t.name??"";if(t.entity&&typeof t.entity=="object"){let n=t.entity.subClassOf;if(typeof n=="string")n.toLowerCase()!==r.toLowerCase()&&e.push(n);else if(Array.isArray(n))for(let o of n){let s=typeof o=="string"?o:o?.subject?.name??o?.name;s&&s.toLowerCase()!==r.toLowerCase()&&e.push(s)}return e}if(t.statement&&Array.isArray(t.statement)){for(let n of t.statement)if(n.predicate?.subject?.name==="subClassOf"){if(n.object?.subject?.name){let o=n.object.subject.name;o.toLowerCase()!==r.toLowerCase()&&e.push(o)}else if(Array.isArray(n.object))for(let o of n.object){let s=o?.subject?.name??o?.name;s&&s.toLowerCase()!==r.toLowerCase()&&e.push(s)}}}return e}function Eo(c){let e=w.getTypeUri(c);return e?w.isCoreOntologyType(e)?null:e.name:null}function To(c,e){let t=[];for(let r of e){if(!w.isAnyPropertyType(r))continue;let n=r,o=[],s=[];if(n.entity&&typeof n.entity=="object"){let l=n.entity.domain;if(typeof l=="string")o.push(l);else if(Array.isArray(l))for(let m of l)o.push(typeof m=="string"?m:m?.name??String(m));let u=n.entity.range;if(typeof u=="string")s.push(u);else if(Array.isArray(u))for(let m of u)s.push(typeof m=="string"?m:m?.name??String(m))}if(!o.some(l=>l.toLowerCase()===c.toLowerCase()))continue;s.length===0&&s.push("unknown");let a=w.isObjectPropertyType(r),i=n.entity?.collection!=null,p=Yr(r);t.push({name:n.name??"",rangeTypes:s,domains:o,get rangeType(){return s.length>0?s.join(", "):"unknown"},isObjectProperty:a,isCollection:i,comment:p})}return t}function No(c){let e=c.split(`
149
+ `);for(let t of e){let r=t.trim();if(r.startsWith("# ")&&!r.startsWith("## "))return r.substring(2).trim()}return null}import{ResolvedResourceType as L}from"@kanonak-protocol/types/ctl/resolution/enums";var Bt=class{resolvedResourceNames=new Set;render(e){if(!e)throw new Error("Graph cannot be null");this.resolvedResourceNames=new Set(e.allResources.map(r=>r.name.toLowerCase()));let t=[];return t.push(this.transformTemplateLinks(e.originalContent)),t.push(""),t.push("---"),t.push(""),t.push("# Kanonak Resource Reference"),t.push(""),this.renderSummary(t,e),this.renderHierarchyDiagram(t,e),this.renderQuickReference(t,e),this.renderTier(t,"Direct References",e.directReferences,"Resources explicitly referenced in this template."),this.renderTier(t,"Inherited References",e.inheritedReferences,"Parent classes, property types, and other dependencies of directly referenced entities."),this.renderTier(t,"Foundation Types",e.foundationTypes,"Core ontology types that form the base of the type hierarchy."),e.unresolvedResources.length>0&&this.renderUnresolved(t,e.unresolvedResources),t.join(`
150
+ `)}generateAnchor(e){return e.toLowerCase()}renderInternalLink(e){return this.resolvedResourceNames.has(e.toLowerCase())?`[${e}](#${this.generateAnchor(e)})`:e}renderInternalLinks(e){return e.map(t=>this.renderInternalLink(t)).join(", ")}transformTemplateLinks(e){let t=/\[([^\]]+)\]\(can:\/\/([^)]+)\)/g;return e.replace(t,(r,n,o)=>{let s;if(o.includes("#"))s=o.substring(o.indexOf("#")+1);else{let a=o.lastIndexOf(".");s=a>=0?o.substring(a+1):o}return this.resolvedResourceNames.has(s.toLowerCase())?`[${n}](#${this.generateAnchor(s)})`:r})}renderSummary(e,t){e.push(`**Total Resources**: ${t.totalResourceCount}`),e.push(`- Direct: ${t.directReferences.length}`),e.push(`- Inherited: ${t.inheritedReferences.length}`),e.push(`- Foundation: ${t.foundationTypes.length}`),t.wasTruncated&&(e.push(""),e.push(`**Resolution was truncated at depth ${t.maxDepthReached}** - some resources may be missing.`),e.push("To include more resources, re-run with a higher depth limit: `kanonak ctl resolve <file> --depth 2000`")),e.push("")}renderQuickReference(e,t){let r=t.allResources;if(r.length===0)return;e.push("## Quick Reference"),e.push("");let n=r.filter(l=>l.resourceType===L.Class),o=r.filter(l=>l.resourceType===L.AnnotationProperty),s=r.filter(l=>l.resourceType===L.DatatypeProperty),a=r.filter(l=>l.resourceType===L.ObjectProperty),i=r.filter(l=>l.resourceType===L.Instance);if(n.length>0){e.push(`### Classes (${n.length})`),e.push(""),e.push("| Class | Extends | Properties |"),e.push("|-------|---------|------------|");for(let l of[...n].sort((u,m)=>u.name.localeCompare(m.name))){let u=this.renderInternalLink(l.name),m=l.parentClasses.length>0?this.renderInternalLinks(l.parentClasses):"-";e.push(`| ${u} | ${m} | ${l.properties.length} |`)}e.push("")}let p=[...o,...s,...a];if(p.length>0){e.push(`### Properties (${p.length})`),e.push(""),e.push("| Property | Type | Description |"),e.push("|----------|------|-------------|");for(let l of[...p].sort((u,m)=>u.name.localeCompare(m.name))){let u=this.renderInternalLink(l.name),m=Jr(l.resourceType),y=_o(l.comment??"");e.push(`| ${u} | ${m} | ${y} |`)}e.push("")}if(i.length>0){let l=new Map;for(let u of i){let m=u.instanceOf_??"Unknown";l.has(m)||l.set(m,[]),l.get(m).push(u)}e.push("### Resources by Type"),e.push(""),e.push("| Type | Resources |"),e.push("|------|-----------|");for(let[u,m]of[...l.entries()].sort((y,f)=>y[0].localeCompare(f[0]))){let y=this.renderInternalLink(u),f=this.renderInternalLinks(m.map(d=>d.name));e.push(`| ${y} | ${f} |`)}e.push("")}}renderHierarchyDiagram(e,t){let r=t.allResources.filter(a=>a.resourceType===L.Class);if(r.length===0)return;let n=r.filter(a=>a.parentClasses.length>0);if(n.length===0)return;let o=new Set;for(let a of n)for(let i of a.parentClasses)o.add(i.toLowerCase());let s=new Set(r.map(a=>a.name.toLowerCase()));e.push("## Type Hierarchy"),e.push(""),e.push("```mermaid"),e.push("flowchart TB");for(let a of[...r].sort((i,p)=>i.name.localeCompare(p.name))){let i=Ft(a.name);e.push(` ${i}["${a.name}"]`)}for(let a of[...o])if(!s.has(a)){let i=a;for(let l of n)for(let u of l.parentClasses)u.toLowerCase()===a&&(i=u);let p=Ft(i);e.push(` ${p}["${i}"]:::external`)}e.push("");for(let a of n){let i=Ft(a.name);for(let p of a.parentClasses){let l=Ft(p);e.push(` ${l} --> ${i}`)}}e.push(""),e.push(" classDef external fill:#f9f9f9,stroke:#999,stroke-dasharray: 5 5"),e.push("```"),e.push("")}renderTier(e,t,r,n){if(r.length!==0){e.push(`## ${t} (${r.length})`),e.push(""),e.push(`*${n}*`),e.push("");for(let o of[...r].sort((s,a)=>s.name.localeCompare(a.name)))this.renderEntity(e,o)}}renderEntity(e,t){let r=this.generateAnchor(t.name);if(e.push(`### ${t.name}`),e.push(`<a id="${r}"></a>`),e.push(""),e.push("| Attribute | Value |"),e.push("|-----------|-------|"),e.push(`| **URI** | \`${t.kanonakUri}\` |`),e.push(`| **Type** | ${Jr(t.resourceType)} |`),t.parentClasses.length>0){let n=this.renderInternalLinks(t.parentClasses);e.push(`| **Extends** | ${n} |`)}if(t.instanceOf_){let n=this.renderInternalLink(t.instanceOf_);e.push(`| **Instance of** | ${n} |`)}e.push(""),t.comment&&(e.push(t.comment),e.push("")),t.resourceType===L.Class&&t.properties.length>0&&this.renderPropertiesTable(e,t.properties),e.push("---"),e.push("")}renderPropertiesTable(e,t){e.push("| Property | Type | Description |"),e.push("|----------|------|-------------|");for(let r of[...t].sort((n,o)=>n.name.localeCompare(o.name))){let o=r.rangeTypes.map(a=>{let i=this.renderInternalLink(a);return r.isObjectProperty?`-> ${i}`:i}).join(", ");r.isCollection&&(o=`${o}[]`);let s=(r.comment??"").replace(/\|/g,"\\|").replace(/\n/g," ").replace(/\r/g,"");e.push(`| ${r.name} | ${o} | ${s} |`)}e.push("")}renderUnresolved(e,t){e.push(`## Unresolved References (${t.length})`),e.push(""),e.push("*The following references could not be resolved:*"),e.push("");for(let r of t)e.push(`- \`${r.reference}\`: ${r.reason}`);e.push("")}};function Jr(c){switch(c){case L.Class:return"Class";case L.AnnotationProperty:return"Annotation Property";case L.DatatypeProperty:return"Datatype Property";case L.ObjectProperty:return"Object Property";case L.Instance:return"Instance";default:return"Other"}}function _o(c){return c?(c=c.replace(/\|/g,"\\|").replace(/\n/g," ").replace(/\r/g,""),c.length<=50?c:c.substring(0,47)+"..."):""}function Ft(c){return c.replace(/[^a-zA-Z0-9]/g,"_")}import{CtlValidationErrorType as Uo,CtlValidationSeverity as Lo}from"@kanonak-protocol/types/ctl/models/enums";import{CtlKanonakUriType as Mo,PathSegmentType as Fo}from"@kanonak-protocol/types/ctl/parsing/enums";import{ResolvedResourceType as Bo}from"@kanonak-protocol/types/ctl/resolution/enums";export{Ce as AmbiguousReferenceRule,Q as BooleanStatement,Ve as ClassDefinitionRule,be as ClassHierarchyCycleRule,Me as CompositeKanonakDocumentRepository,_t as CredentialStore,Mt as CtlGraphResolver,Ee as CtlKanonakUri,Mo as CtlKanonakUriType,Bt as CtlMarkdownRenderer,Ut as CtlParser,Uo as CtlValidationErrorType,Lo as CtlValidationSeverity,Lt as CtlValidator,re as DefinedKanonak,Ae as DefinitionPropertyReferenceRule,Gt as DocumentLocation,Yt as EdgeType,M as EmbeddedKanonak,de as EmbeddedKanonakNoExplicitTypeRule,G as EmbeddedStatement,ce as FileSystemKanonakDocumentRepository,bt as GitIgnoreFilter,ht as GraphBuilder,gt as HttpKanonakDocumentRepository,ge as ImportExistenceRule,mt as InMemoryKanonakDocumentRepository,Se as InstancePropertyReferenceRule,B as Kanonak,Je as KanonakDocumentPositions,oe as KanonakObjectParser,St as KanonakObjectValidator,$ as KanonakParser,_ as KanonakUri,wt as KanonakUriBuilder,qe as KanonakVocabulary,z as ListStatement,J as LiteralKanonak,Ie as NamespaceImportCycleRule,ue as NamespacePrefixRule,Xt as NodeType,Z as NumberStatement,rt as OWL_RL_CLASSIFICATION_RULES,$e as ObjectPropertyImportRule,xe as ObjectPropertyValueValidationRule,b as OntologyValidationError,le as OntologyValidationResult,Fo as PathSegmentType,je as PropertyDomainRule,Re as PropertyHierarchyCycleRule,Pt as PropertyMetadata,Ke as PropertyRangeReferenceRule,Pe as PropertyRangeRequiredRule,ye as PropertyTypeSpecificityRule,Oe as PropertyValueTypeRule,Fe as PublisherConfigResolver,pe as PublisherIndex,tt as RDFS_RULES,kt as Reasoner,ze as ReasoningResult,I as ReferenceKanonak,ee as ReferenceStatement,ft as RepositoryFactory,Bo as ResolvedResourceType,me as ResourceNamingRule,E as ResourceResolver,w as ResourceTypeClassifier,H as ScalarStatement,U as Statement,q as StringStatement,ve as SubClassOfReferenceRule,we as SubPropertyOfReferenceRule,W as SubjectKanonak,fe as SubjectKanonakTypeRequiredRule,He as TripleStore,ke as TypeAmbiguityRule,ne as TypeResolver,he as UnresolvedReferenceRule,It as ValidationContext,v as ValidationSeverity,Rm as VersionOperator,De as XsdImportRule,N as compareVersions,Wr as computeIntegrity,Ur as createAuthenticatedFetch,lt as createDPoPProof,qt as createVersion,Sr as findInstancesByType,Ht as formatVersion,Nr as generateDPoPKeyPair,Qe as getGlobalCachePath,At as hasValidToken,_e as isCompatibleVersion,nt as isExpired,Ue as isMajorCompatible,Fr as loadLockFile,K as makeUriKey,S as normalizeHost,lr as parseVersionString,wr as parseWithPositions,ur as pickHighestDocument,Br as saveLockFile,_r as serverSupportsDPoP,et as tripleKey,We as uriKey,A as uriTriple,Ne as versionsEqual};