@blocklet/pages-kit-inner-components 0.5.32 → 0.5.33

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.
@@ -1,9 +1,9 @@
1
- "use strict";var Dt=Object.defineProperty;var _t=(e,n,t)=>n in e?Dt(e,n,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[n]=t;var k=(e,n,t)=>_t(e,typeof n!="symbol"?n+"":n,t);const vt=require("@blocklet/pages-kit/builtin/utils"),ye=require("@blocklet/pages-kit/types"),de=require("@blocklet/pages-kit/utils/property"),ue=require("@blocklet/quickjs"),kt=require("@blocklet/sdk/lib/config"),He=require("lru-cache"),ot=require("node-fetch"),$=require("ufo"),Z=require("crypto"),Rt=require("@blocklet/logger"),E=require("fs"),y=require("path"),xt=require("lodash/isNil"),Nt=require("@blocklet/pages-kit/utils/builtin"),rt=require("@blocklet/pages-kit/utils/typescript/builtin-module-transformer"),Be=require("@blocklet/sdk/lib/component"),Lt=require("autoprefixer"),Mt=require("esbuild"),Ut=require("postcss"),Ft=require("tailwindcss"),$t=require("typescript"),ee=require("@syncedstore/core"),qt=require("yjs"),Ht=require("@blocklet/pages-kit/utils/data-source"),we=require("@blocklet/pages-kit/utils/route"),Bt=require("lodash"),Gt=require("@reactivedata/reactive"),Ne=require("glob"),Vt=require("lib0/decoding"),Jt=require("lib0/encoding"),zt=require("lodash/cloneDeep"),Kt=require("lodash/debounce"),Yt=require("lodash/get"),Wt=require("lodash/isEmpty"),Qt=require("lodash/pick"),Xt=require("lodash/set"),Zt=require("lodash/union"),es=require("nanoid"),ts=require("p-limit"),ss=require("stream/promises"),ns=require("tar"),os=require("wait-on"),ie=require("y-protocols/awareness"),ve=require("y-protocols/sync"),rs=require("yaml"),v=require("sequelize");require("sqlite3");require("@blocklet/pages-kit/types/state");const N=e=>e&&e.__esModule?e:{default:e};function fe(e){if(e&&e.__esModule)return e;const n=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const t in e)if(t!=="default"){const s=Object.getOwnPropertyDescriptor(e,t);Object.defineProperty(n,t,s.get?s:{enumerable:!0,get:()=>e[t]})}}return n.default=e,Object.freeze(n)}const O=N(kt),as=N(ot),is=N(Rt),at=N(y),cs=N(xt),ls=N(Lt),ds=fe(Mt),us=N(Ut),ps=N(Ft),F=N($t),V=fe(qt),ke=fe(Vt),x=fe(Jt),fs=N(zt),it=N(Kt),Ge=N(Yt),ct=N(Wt),ms=N(Qt),Qe=N(Xt),gs=N(Zt),hs=N(ts),ys=N(os),ne=fe(rs);O.default.env.mode;O.default.env.OPENAI_API_KEY||process.env.OPENAI_API_KEY;O.default.env.OPENAI_BASE_URL||process.env.OPENAI_BASE_URL;O.default.env.TRANSLATE_ADDITIONAL_PROMPT||process.env.TRANSLATE_ADDITIONAL_PROMPT;O.default.env.PAGE_CONTENT_ADDITIONAL_PROMPT||process.env.PAGE_CONTENT_ADDITIONAL_PROMPT;const Ss="image-bin";O.default.env.INIT_TEMPLATE_PATH;const Es=process.env.DATABASE_URL||at.default.join(O.default.env.dataDir,"db/pages-kit.db"),Xe=O.default,ws=()=>O.default.env.tenantMode==="multiple",bs=()=>{var e;return(cs.default(Xe.env.preferences.multiTenantAllProjectAccessPassports)?[]:(e=Xe.env.preferences.multiTenantAllProjectAccessPassports)==null?void 0:e.split(","))||[]},Is=at.default.join(O.default.env.dataDir,"fs-memoize-cache"),Os=O.default.env.FS_MEMOIZE_CACHE_VERSION||"v1.0.0",w=is.default("pages-kit"),As=v.DataTypes.sqlite.DATE.parse;v.DataTypes.sqlite.DATE.parse=(e,n)=>typeof e=="number"?new Date(e):As(e,n);const me=new v.Sequelize({dialect:"sqlite",storage:Es,benchmark:process.env.ENABLE_SEQUELIZE_BENCHMARK==="true",retry:{match:[/SQLITE_BUSY/],name:"query",max:10},logging:process.env.ENABLE_SEQUELIZE_LOGGING==="true"?console.log:!1});me.query("pragma journal_mode = WAL;");me.query("pragma synchronous = normal;");me.query("pragma journal_size_limit = 67108864;");class Ce extends v.Model{}Ce.init({id:{type:v.DataTypes.UUID,allowNull:!1,primaryKey:!0,defaultValue:v.DataTypes.UUIDV4},projectId:{type:v.DataTypes.UUID,allowNull:!1},componentId:{type:v.DataTypes.STRING,allowNull:!1}},{sequelize:me,tableName:"ProjectComponents",timestamps:!1});class K extends v.Model{static async getProjectByIdOrSlug(n){return K.findOne({where:{[v.Op.or]:[{id:n},{slug:n}]}})}}K.init({id:{type:v.DataTypes.UUID,defaultValue:v.DataTypes.UUIDV4,primaryKey:!0},name:{type:v.DataTypes.STRING,allowNull:!1},description:v.DataTypes.TEXT,createdAt:v.DataTypes.DATE,updatedAt:v.DataTypes.DATE,createdBy:{type:v.DataTypes.STRING,allowNull:!1},updatedBy:{type:v.DataTypes.STRING,allowNull:!1},slug:v.DataTypes.STRING,icon:v.DataTypes.STRING,pinnedAt:v.DataTypes.DATE,useAllResources:v.DataTypes.BOOLEAN,npmSecret:v.DataTypes.STRING,relatedBlocklets:{type:v.DataTypes.JSON,allowNull:!1,defaultValue:{},get(){return this.getDataValue("relatedBlocklets")||{}},set(e){this.setDataValue("relatedBlocklets",JSON.stringify(e||{}))}}},{sequelize:me,paranoid:!0});K.hasMany(Ce,{foreignKey:"projectId",as:"components"});const Cs=Is,Ts=Os,Le=7*24*60*60*1e3,Ps=24*60*60*1e3,lt=async(e="")=>{const n=y.join(Cs,e);try{if(!(await E.promises.stat(n)).isDirectory())throw new Error(`${n} is not a directory`)}catch{await E.promises.mkdir(n,{recursive:!0})}return n},js=(e,n)=>{const t=Z.createHash("md5").update(n).digest("hex");return y.join(e,`${Ts}-${t}.json`)},Ds=async(e="")=>{const n=await lt(e),t=Date.now();try{const s=await E.promises.readdir(n);await Promise.all(s.filter(o=>o.endsWith(".json")).map(async o=>{const r=y.join(n,o);try{const a=await E.promises.readFile(r,"utf-8"),i=JSON.parse(a);i.createdAt&&t-i.createdAt>Le&&await E.promises.unlink(r)}catch{try{const i=await E.promises.stat(r);t-i.mtimeMs>Le&&await E.promises.unlink(r)}catch{}}}))}catch(s){console.error(`Failed to cleanup cache in ${n}:`,s)}},_s=(()=>{const e=new Set;return setInterval(async()=>{await Promise.all(Array.from(e).map(s=>Ds(s)))},Ps).unref(),s=>{e.add(s)}})();function Ve(e,n){return n.subdir&&_s(n.subdir),ue.memoize(async(...s)=>{const o=await lt(n.subdir||""),r=n.keyGenerator?n.keyGenerator(...s):JSON.stringify(s),a=js(o,r);try{const i=await E.promises.readFile(a,"utf-8"),{value:d,createdAt:c}=JSON.parse(i);if(c&&Date.now()-c>Le)throw await E.promises.unlink(a).catch(()=>{}),new Error("Cache expired");return d}catch{const d=await e(...s),c=JSON.stringify({value:d,createdAt:Date.now()});return E.promises.writeFile(a,c,"utf-8").catch(p=>{console.error("Failed to write fs cache:",p)}),d}},{keyGenerator:n.keyGenerator,lruOptions:n.lruOptions})}const vs=async(e,{componentId:n})=>{const t=`@tailwind components;
1
+ "use strict";var Dt=Object.defineProperty;var _t=(e,n,t)=>n in e?Dt(e,n,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[n]=t;var k=(e,n,t)=>_t(e,typeof n!="symbol"?n+"":n,t);const vt=require("@blocklet/pages-kit/builtin/utils"),ye=require("@blocklet/pages-kit/types"),de=require("@blocklet/pages-kit/utils/property"),ue=require("@blocklet/quickjs"),kt=require("@blocklet/sdk/lib/config"),He=require("lru-cache"),ot=require("node-fetch"),$=require("ufo"),Z=require("crypto"),Rt=require("@blocklet/logger"),w=require("fs"),y=require("path"),xt=require("lodash/isNil"),Nt=require("@blocklet/pages-kit/utils/builtin"),rt=require("@blocklet/pages-kit/utils/typescript/builtin-module-transformer"),Be=require("@blocklet/sdk/lib/component"),Lt=require("autoprefixer"),Mt=require("esbuild"),Ut=require("postcss"),Ft=require("tailwindcss"),$t=require("typescript"),ee=require("@syncedstore/core"),qt=require("yjs"),Ht=require("@blocklet/pages-kit/utils/data-source"),Ee=require("@blocklet/pages-kit/utils/route"),Bt=require("lodash"),Gt=require("@reactivedata/reactive"),Ne=require("glob"),Vt=require("lib0/decoding"),Jt=require("lib0/encoding"),zt=require("lodash/cloneDeep"),Kt=require("lodash/debounce"),Yt=require("lodash/get"),Wt=require("lodash/isEmpty"),Qt=require("lodash/pick"),Xt=require("lodash/set"),Zt=require("lodash/union"),es=require("nanoid"),ts=require("p-limit"),ss=require("stream/promises"),ns=require("tar"),os=require("wait-on"),ie=require("y-protocols/awareness"),ve=require("y-protocols/sync"),rs=require("yaml"),v=require("sequelize");require("sqlite3");require("@blocklet/pages-kit/types/state");const N=e=>e&&e.__esModule?e:{default:e};function fe(e){if(e&&e.__esModule)return e;const n=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const t in e)if(t!=="default"){const s=Object.getOwnPropertyDescriptor(e,t);Object.defineProperty(n,t,s.get?s:{enumerable:!0,get:()=>e[t]})}}return n.default=e,Object.freeze(n)}const O=N(kt),as=N(ot),is=N(Rt),at=N(y),cs=N(xt),ls=N(Lt),ds=fe(Mt),us=N(Ut),ps=N(Ft),F=N($t),V=fe(qt),ke=fe(Vt),x=fe(Jt),fs=N(zt),it=N(Kt),Ge=N(Yt),ct=N(Wt),ms=N(Qt),Qe=N(Xt),gs=N(Zt),hs=N(ts),ys=N(os),ne=fe(rs);O.default.env.mode;O.default.env.OPENAI_API_KEY||process.env.OPENAI_API_KEY;O.default.env.OPENAI_BASE_URL||process.env.OPENAI_BASE_URL;O.default.env.TRANSLATE_ADDITIONAL_PROMPT||process.env.TRANSLATE_ADDITIONAL_PROMPT;O.default.env.PAGE_CONTENT_ADDITIONAL_PROMPT||process.env.PAGE_CONTENT_ADDITIONAL_PROMPT;const Ss="image-bin";O.default.env.INIT_TEMPLATE_PATH;const ws=process.env.DATABASE_URL||at.default.join(O.default.env.dataDir,"db/pages-kit.db"),Xe=O.default,Es=()=>O.default.env.tenantMode==="multiple",bs=()=>{var e;return(cs.default(Xe.env.preferences.multiTenantAllProjectAccessPassports)?[]:(e=Xe.env.preferences.multiTenantAllProjectAccessPassports)==null?void 0:e.split(","))||[]},Is=at.default.join(O.default.env.dataDir,"fs-memoize-cache"),Os=O.default.env.FS_MEMOIZE_CACHE_VERSION||"v1.0.0",E=is.default("pages-kit"),As=v.DataTypes.sqlite.DATE.parse;v.DataTypes.sqlite.DATE.parse=(e,n)=>typeof e=="number"?new Date(e):As(e,n);const me=new v.Sequelize({dialect:"sqlite",storage:ws,benchmark:process.env.ENABLE_SEQUELIZE_BENCHMARK==="true",retry:{match:[/SQLITE_BUSY/],name:"query",max:10},logging:process.env.ENABLE_SEQUELIZE_LOGGING==="true"?console.log:!1});me.query("pragma journal_mode = WAL;");me.query("pragma synchronous = normal;");me.query("pragma journal_size_limit = 67108864;");class Ce extends v.Model{}Ce.init({id:{type:v.DataTypes.UUID,allowNull:!1,primaryKey:!0,defaultValue:v.DataTypes.UUIDV4},projectId:{type:v.DataTypes.UUID,allowNull:!1},componentId:{type:v.DataTypes.STRING,allowNull:!1}},{sequelize:me,tableName:"ProjectComponents",timestamps:!1});class K extends v.Model{static async getProjectByIdOrSlug(n){return K.findOne({where:{[v.Op.or]:[{id:n},{slug:n}]}})}}K.init({id:{type:v.DataTypes.UUID,defaultValue:v.DataTypes.UUIDV4,primaryKey:!0},name:{type:v.DataTypes.STRING,allowNull:!1},description:v.DataTypes.TEXT,createdAt:v.DataTypes.DATE,updatedAt:v.DataTypes.DATE,createdBy:{type:v.DataTypes.STRING,allowNull:!1},updatedBy:{type:v.DataTypes.STRING,allowNull:!1},slug:v.DataTypes.STRING,icon:v.DataTypes.STRING,pinnedAt:v.DataTypes.DATE,useAllResources:v.DataTypes.BOOLEAN,npmSecret:v.DataTypes.STRING,relatedBlocklets:{type:v.DataTypes.JSON,allowNull:!1,defaultValue:{},get(){return this.getDataValue("relatedBlocklets")||{}},set(e){this.setDataValue("relatedBlocklets",JSON.stringify(e||{}))}}},{sequelize:me,paranoid:!0});K.hasMany(Ce,{foreignKey:"projectId",as:"components"});const Cs=Is,Ts=Os,Le=7*24*60*60*1e3,Ps=24*60*60*1e3,lt=async(e="")=>{const n=y.join(Cs,e);try{if(!(await w.promises.stat(n)).isDirectory())throw new Error(`${n} is not a directory`)}catch{await w.promises.mkdir(n,{recursive:!0})}return n},js=(e,n)=>{const t=Z.createHash("md5").update(n).digest("hex");return y.join(e,`${Ts}-${t}.json`)},Ds=async(e="")=>{const n=await lt(e),t=Date.now();try{const s=await w.promises.readdir(n);await Promise.all(s.filter(o=>o.endsWith(".json")).map(async o=>{const r=y.join(n,o);try{const i=await w.promises.readFile(r,"utf-8"),u=JSON.parse(i);u.createdAt&&t-u.createdAt>Le&&await w.promises.unlink(r)}catch{try{const u=await w.promises.stat(r);t-u.mtimeMs>Le&&await w.promises.unlink(r)}catch{}}}))}catch(s){console.error(`Failed to cleanup cache in ${n}:`,s)}},_s=(()=>{const e=new Set;return setInterval(async()=>{await Promise.all(Array.from(e).map(s=>Ds(s)))},Ps).unref(),s=>{e.add(s)}})();function Ve(e,n){return n.subdir&&_s(n.subdir),ue.memoize(async(...s)=>{const o=await lt(n.subdir||""),r=n.keyGenerator?n.keyGenerator(...s):JSON.stringify(s),i=js(o,r);try{const u=await w.promises.readFile(i,"utf-8"),{value:d,createdAt:a}=JSON.parse(u);if(a&&Date.now()-a>Le)throw await w.promises.unlink(i).catch(()=>{}),new Error("Cache expired");return d}catch{const d=await e(...s),a=JSON.stringify({value:d,createdAt:Date.now()});return w.promises.writeFile(i,a,"utf-8").catch(p=>{console.error("Failed to write fs cache:",p)}),d}},{keyGenerator:n.keyGenerator,lruOptions:n.lruOptions})}const vs=async(e,{componentId:n})=>{const t=`@tailwind components;
2
2
  @tailwind utilities;
3
- `,s=`.CustomComponent_${n}`;return(await us.default([ps.default({content:[{raw:e,extension:"tsx"}]}),ls.default({overrideBrowserslist:["> 1%","last 2 versions"],stats:{}}),r=>{r.walkRules(a=>{a.selectors=a.selectors.map(i=>i.replace(/\.(.+)/g,`${s}.$1,${s} .$1`))})}]).process(t)).css},ks=async(e,{componentId:n})=>{const t=await vs(e,{componentId:n});return`export const __PagesKit_CSS__ = ${JSON.stringify(t)};
3
+ `,s=`.CustomComponent_${n}`;return(await us.default([ps.default({content:[{raw:e,extension:"tsx"}]}),ls.default({overrideBrowserslist:["> 1%","last 2 versions"],stats:{}}),r=>{r.walkRules(i=>{i.selectors=i.selectors.map(u=>u.replace(/\.(.+)/g,`${s}.$1,${s} .$1`))})}]).process(t)).css},ks=async(e,{componentId:n})=>{const t=await vs(e,{componentId:n});return`export const __PagesKit_CSS__ = ${JSON.stringify(t)};
4
4
 
5
5
  ${e}
6
- `},Ze=Ve(async(e,n)=>{let t=F.default.transpileModule(e,{compilerOptions:{jsx:F.default.JsxEmit.React,target:F.default.ScriptTarget.ES2016,module:F.default.ModuleKind.ESNext},transformers:{before:[rt.createBuiltinModuleTransformer(F.default)]}}).outputText;if(n.tailwind&&(t=await ks(t,{componentId:n.componentId})),n.module===ye.PreloadComponentScriptModule.ESM)return t;const s=F.default.transpileModule(t,{compilerOptions:{jsx:F.default.JsxEmit.React,target:F.default.ScriptTarget.ES2016,module:F.default.ModuleKind.CommonJS,moduleResolution:F.default.ModuleResolutionKind.Node16}}).outputText;return n.module===ye.PreloadComponentScriptModule.CJS?s:xs(n.moduleName,s)},{keyGenerator:(e,n)=>{const t=Z.createHash("md5").update(e).digest("hex"),s={...n,componentId:n.componentId,module:n.module,...n.module!==ye.PreloadComponentScriptModule.ESM?{moduleName:n.moduleName}:{},tailwind:n.tailwind};return JSON.stringify(["transpileModule",t,s])},lruOptions:{max:100,ttl:1e3*60*60*24*7},subdir:"transpileModule"}),Rs=async(e,n)=>{var a,i;const s=(i=(a=(await ds.build({entryPoints:["index.tsx"],external:Object.keys(Nt.BuiltinModules),format:"esm",target:"esnext",bundle:!0,write:!1,plugins:[{name:"vfs",setup(d){let c=null;d.onResolve({filter:/.*/},p=>p.path==="index.tsx"?{path:"index.tsx",namespace:"vfs"}:p.path==="./component"?{path:"component.tsx",namespace:"vfs"}:null),d.onLoad({filter:/.*/,namespace:"vfs"},async p=>{var S;if(p.path==="index.tsx")return{contents:`export { ${n} } from './component'`,loader:"tsx"};if(p.path==="component.tsx")return{contents:e,loader:"tsx"};if(rt.isRelativeModule(p.path)){const m=p.path.split("/").pop();if(c||(c=await je({ensureLoaded:!1})),(S=c==null?void 0:c.chunks)!=null&&S[m])try{const u=E.readFileSync(c.chunks[m],"utf-8");return w.info("get chunk from local file system",m),{contents:u,loader:"tsx"}}catch{}}return null})}}]})).outputFiles)==null?void 0:a[0])==null?void 0:i.contents;if(!s)throw new Error("Failed to build server code");const o=Buffer.from(s).toString();return F.default.transpileModule(o,{compilerOptions:{module:F.default.ModuleKind.ESNext,target:F.default.ScriptTarget.ES2020}}).outputText},dt=Ve(async(e,n)=>{const t=await Rs(e,n);return new RegExp(`export\\s+\\{\\s+${n}\\s+\\}`,"m").test(t)?t:void 0},{keyGenerator:(e,n)=>{const t=Z.createHash("md5").update(e).digest("hex");return JSON.stringify(["extractExportValueSchema",t,n])},lruOptions:{max:100,ttl:1e3*60*60*24*7},subdir:"extractExportValueSchema"}),xs=(e,n)=>`// GENERATED FILE. DO NOT EDIT.
6
+ `},Ze=Ve(async(e,n)=>{let t=F.default.transpileModule(e,{compilerOptions:{jsx:F.default.JsxEmit.React,target:F.default.ScriptTarget.ES2016,module:F.default.ModuleKind.ESNext},transformers:{before:[rt.createBuiltinModuleTransformer(F.default)]}}).outputText;if(n.tailwind&&(t=await ks(t,{componentId:n.componentId})),n.module===ye.PreloadComponentScriptModule.ESM)return t;const s=F.default.transpileModule(t,{compilerOptions:{jsx:F.default.JsxEmit.React,target:F.default.ScriptTarget.ES2016,module:F.default.ModuleKind.CommonJS,moduleResolution:F.default.ModuleResolutionKind.Node16}}).outputText;return n.module===ye.PreloadComponentScriptModule.CJS?s:xs(n.moduleName,s)},{keyGenerator:(e,n)=>{const t=Z.createHash("md5").update(e).digest("hex"),s={...n,componentId:n.componentId,module:n.module,...n.module!==ye.PreloadComponentScriptModule.ESM?{moduleName:n.moduleName}:{},tailwind:n.tailwind};return JSON.stringify(["transpileModule",t,s])},lruOptions:{max:100,ttl:1e3*60*60*24*7},subdir:"transpileModule"}),Rs=async(e,n)=>{var i,u;const s=(u=(i=(await ds.build({entryPoints:["index.tsx"],external:Object.keys(Nt.BuiltinModules),format:"esm",target:"esnext",bundle:!0,write:!1,plugins:[{name:"vfs",setup(d){let a=null;d.onResolve({filter:/.*/},p=>p.path==="index.tsx"?{path:"index.tsx",namespace:"vfs"}:p.path==="./component"?{path:"component.tsx",namespace:"vfs"}:null),d.onLoad({filter:/.*/,namespace:"vfs"},async p=>{var S;if(p.path==="index.tsx")return{contents:`export { ${n} } from './component'`,loader:"tsx"};if(p.path==="component.tsx")return{contents:e,loader:"tsx"};if(rt.isRelativeModule(p.path)){const f=p.path.split("/").pop();if(a||(a=await je({ensureLoaded:!1})),(S=a==null?void 0:a.chunks)!=null&&S[f])try{const l=w.readFileSync(a.chunks[f],"utf-8");return E.info("get chunk from local file system",f),{contents:l,loader:"tsx"}}catch{}}return null})}}]})).outputFiles)==null?void 0:i[0])==null?void 0:u.contents;if(!s)throw new Error("Failed to build server code");const o=Buffer.from(s).toString();return F.default.transpileModule(o,{compilerOptions:{module:F.default.ModuleKind.ESNext,target:F.default.ScriptTarget.ES2020}}).outputText},dt=Ve(async(e,n)=>{const t=await Rs(e,n);return new RegExp(`export\\s+\\{[^}]*(?:\\w+\\s+as\\s+${n}\\b|\\b${n}\\b)[^}]*\\}`,"m").test(t)?t:void 0},{keyGenerator:(e,n)=>{const t=Z.createHash("md5").update(e).digest("hex");return JSON.stringify(["extractExportValueSchema",t,n])},lruOptions:{max:100,ttl:1e3*60*60*24*7},subdir:"extractExportValueSchema"}),xs=(e,n)=>`// GENERATED FILE. DO NOT EDIT.
7
7
  var ${e} = async function () {
8
8
 
9
9
  const exports = {};
@@ -29,7 +29,7 @@ var ${e} = async function () {
29
29
 
30
30
  return exports;
31
31
  };
32
- `,ce=new He.LRUCache({max:100}),ut=60*60,Me=60;function pt(e){w.info("clear preload components cache",{cacheKey:e}),ce.delete(e)}function ft(e){for(const n of ce.keys())n.includes(e)&&(w.info("clear preload components cache",{cacheKey:n}),pt(n))}function mt({mode:e,instanceId:n,componentId:t,locale:s}){return["getPreloadComponents",e,n,t,s].join("-")}async function Ns({mode:e,req:n,state:t,locale:s,instances:o,module:r}){const{supportedLocales:a,config:{defaultLocale:i}}=t;if(!i)return null;const d=(await Promise.all(o.map(async u=>{try{const l=mt({mode:e,instanceId:u.id,componentId:u.componentId,locale:s});if(e!=="draft"&&u.useCache&&ce.has(l))return w.info(`get preload component from cache: ${l}`),ce.get(l);const f=pe({state:t,componentId:u.componentId});if(!f)return null;const b=await gt({req:n,state:t,componentId:f.id,locale:s,defaultLocale:i,properties:u.properties});if(!b)return null;const _={instanceId:u.id,preload:b};if(e!=="draft"&&u.useCache){let T=ut;u.cacheDuration&&(T=u.cacheDuration),w.info(`set preload component to cache(${T}s): ${l}`),ce.set(l,_,{ttl:T*1e3})}return _}catch(l){return w.error("get preload component error",{instanceId:u.id,componentId:u.componentId},{error:l}),null}}))).filter(u=>!!u),c=Object.values(d.reduce((u,l)=>({...u,...l.preload.components}),{}));async function p(){const u=await Promise.all(c.map(async l=>{const f=de.componentUMDName({componentId:l.component.id}),b=r===ye.PreloadComponentScriptModule.ESM?{module:r,script:await Ze(l.script,{componentId:l.component.id,module:r,tailwind:e!=="draft"})}:{module:r,script:await Ze(l.script,{componentId:l.component.id,module:r,moduleName:f,tailwind:e!=="draft"}),moduleName:f};return[l.component.id,{component:l.component,script:b}]}));return Object.fromEntries(u)}const S=await p();return{config:{defaultLocale:i,supportedLocales:a},components:S,instances:d.map(u=>({id:u.instanceId,componentId:u.preload.component.id,locales:{[u.preload.locale]:{props:u.preload.props}}}))}}async function gt({req:e,state:n,componentId:t,locale:s,defaultLocale:o,properties:r}){const{supportedLocales:a}=n,i=pe({state:n,componentId:t});if(!i)return null;const d=a.some(p=>p.locale===s)?s:o;if(!d)return null;const c=await ht({req:e,state:n,componentId:t,locale:d,defaultLocale:o,properties:r});return c?{component:i,...c}:null}const Ls=20;async function ht({req:e,depth:n=0,state:t,componentId:s,locale:o,defaultLocale:r,properties:a}){if(n>Ls)throw new RangeError("max component depth exceeded");const i=Ms({state:t,componentId:s,properties:a,locale:o});if(!i)return null;const{props:d}=i,c={locale:o||r,components:{[i.component.id]:{component:i.component,script:i.script}},props:{...d}};try{const p=await Fs({...i,req:e});p!=null&&p.props&&Object.assign(c.props,p.props)}catch(p){w.error("preload data at server side error",{componentId:s,name:i.component.name},{error:p})}return await Promise.all(Object.entries(d).map(async([p,S])=>{if((S==null?void 0:S.type)===de.RenderNestedComponent){const m=await ht({req:e,depth:n+1,state:t,componentId:S.componentId,locale:o,defaultLocale:r,properties:S.properties});m&&(Object.assign(c.components,m.components),Object.assign(c.props,{[p]:{type:de.RenderNestedComponent,componentId:S.componentId,props:m.props}}))}})),c}function Ms({state:e,componentId:n,locale:t,properties:s}){const o=pe({state:e,componentId:n});if(!o)return null;const r=de.mergeComponent({componentId:n,getComponent:a=>pe({state:e,componentId:a}),locale:t,defaultLocale:e.config.defaultLocale,properties:s});return r?{component:o,script:r.script,props:{locale:t,...r.props}}:null}function pe({state:e,componentId:n}){var t,s,o;return((t=e.components[n])==null?void 0:t.data)??((o=(s=e.resources.components)==null?void 0:s[n])==null?void 0:o.component)}function Us({state:e,name:n}){var s,o;const t=n.toLowerCase();return((s=Object.values(e.components).find(r=>{var a;return((a=r.data.name)==null?void 0:a.toLowerCase())===t}))==null?void 0:s.data)??((o=e.resources.components&&Object.values(e.resources.components).find(r=>{var a;return((a=r.component.name)==null?void 0:a.toLowerCase())===t}))==null?void 0:o.component)}async function Fs({component:e,script:n,props:t,req:s}){if(!(n!=null&&n.includes("getServerSideProps")))return null;const o=await dt(n,"getServerSideProps");if(!o)return null;const r=new Promise(i=>{setTimeout(()=>{i({})},Me*1e3)});return await Promise.race([r,ue.Sandbox.callFunction({code:`${o}
32
+ `,ce=new He.LRUCache({max:100}),ut=60*60,Me=60;function pt(e){E.info("clear preload components cache",{cacheKey:e}),ce.delete(e)}function ft(e){for(const n of ce.keys())n.includes(e)&&(E.info("clear preload components cache",{cacheKey:n}),pt(n))}function mt({mode:e,instanceId:n,componentId:t,locale:s}){return["getPreloadComponents",e,n,t,s].join("-")}async function Ns({mode:e,req:n,state:t,locale:s,instances:o,module:r}){const{supportedLocales:i,config:{defaultLocale:u}}=t;if(!u)return null;const d=(await Promise.all(o.map(async l=>{try{const c=mt({mode:e,instanceId:l.id,componentId:l.componentId,locale:s});if(e!=="draft"&&l.useCache&&ce.has(c))return E.info(`get preload component from cache: ${c}`),ce.get(c);const m=pe({state:t,componentId:l.componentId});if(!m)return null;const b=await gt({req:n,state:t,componentId:m.id,locale:s,defaultLocale:u,properties:l.properties});if(!b)return null;const _={instanceId:l.id,preload:b};if(e!=="draft"&&l.useCache){let T=ut;l.cacheDuration&&(T=l.cacheDuration),E.info(`set preload component to cache(${T}s): ${c}`),ce.set(c,_,{ttl:T*1e3})}return _}catch(c){return E.error("get preload component error",{instanceId:l.id,componentId:l.componentId},{error:c}),null}}))).filter(l=>!!l),a=Object.values(d.reduce((l,c)=>({...l,...c.preload.components}),{}));async function p(){const l=await Promise.all(a.map(async c=>{const m=de.componentUMDName({componentId:c.component.id}),b=r===ye.PreloadComponentScriptModule.ESM?{module:r,script:await Ze(c.script,{componentId:c.component.id,module:r,tailwind:e!=="draft"})}:{module:r,script:await Ze(c.script,{componentId:c.component.id,module:r,moduleName:m,tailwind:e!=="draft"}),moduleName:m};return[c.component.id,{component:c.component,script:b}]}));return Object.fromEntries(l)}const S=await p();return{config:{defaultLocale:u,supportedLocales:i},components:S,instances:d.map(l=>({id:l.instanceId,componentId:l.preload.component.id,locales:{[l.preload.locale]:{props:l.preload.props}}}))}}async function gt({req:e,state:n,componentId:t,locale:s,defaultLocale:o,properties:r}){const{supportedLocales:i}=n,u=pe({state:n,componentId:t});if(!u)return null;const d=i.some(p=>p.locale===s)?s:o;if(!d)return null;const a=await ht({req:e,state:n,componentId:t,locale:d,defaultLocale:o,properties:r});return a?{component:u,...a}:null}const Ls=20;async function ht({req:e,depth:n=0,state:t,componentId:s,locale:o,defaultLocale:r,properties:i}){if(n>Ls)throw new RangeError("max component depth exceeded");const u=Ms({state:t,componentId:s,properties:i,locale:o});if(!u)return null;const{props:d}=u,a={locale:o||r,components:{[u.component.id]:{component:u.component,script:u.script}},props:{...d}};try{const p=await Fs({...u,req:e});p!=null&&p.props&&Object.assign(a.props,p.props)}catch(p){E.error("preload data at server side error",{componentId:s,name:u.component.name},{error:p})}return await Promise.all(Object.entries(d).map(async([p,S])=>{if((S==null?void 0:S.type)===de.RenderNestedComponent){const f=await ht({req:e,depth:n+1,state:t,componentId:S.componentId,locale:o,defaultLocale:r,properties:S.properties});f&&(Object.assign(a.components,f.components),Object.assign(a.props,{[p]:{type:de.RenderNestedComponent,componentId:S.componentId,props:f.props}}))}})),a}function Ms({state:e,componentId:n,locale:t,properties:s}){const o=pe({state:e,componentId:n});if(!o)return null;const r=de.mergeComponent({componentId:n,getComponent:i=>pe({state:e,componentId:i}),locale:t,defaultLocale:e.config.defaultLocale,properties:s});return r?{component:o,script:r.script,props:{locale:t,...r.props}}:null}function pe({state:e,componentId:n}){var t,s,o;return((t=e.components[n])==null?void 0:t.data)??((o=(s=e.resources.components)==null?void 0:s[n])==null?void 0:o.component)}function Us({state:e,name:n}){var s,o;const t=n.toLowerCase();return((s=Object.values(e.components).find(r=>{var i;return((i=r.data.name)==null?void 0:i.toLowerCase())===t}))==null?void 0:s.data)??((o=e.resources.components&&Object.values(e.resources.components).find(r=>{var i;return((i=r.component.name)==null?void 0:i.toLowerCase())===t}))==null?void 0:o.component)}async function Fs({component:e,script:n,props:t,req:s}){if(!(n!=null&&n.includes("getServerSideProps")))return null;const o=await dt(n,"getServerSideProps");if(!o)return null;const r=o.match(/export\s*{\s*(\w+)\s+as\s+getServerSideProps\s*}/)||o.match(/export\s*{\s*getServerSideProps\s*}/),i=(r==null?void 0:r[1])||"getServerSideProps",u=new Promise(a=>{setTimeout(()=>{a({})},Me*1e3)});return await Promise.race([u,ue.Sandbox.callFunction({code:`${o}
33
33
 
34
34
  export async function getServerSidePropsWrapper(props) {
35
35
  const { location, fetch, props: componentProps } = props;
@@ -40,18 +40,18 @@ export async function getServerSidePropsWrapper(props) {
40
40
  try {
41
41
  globalThis.location = location;
42
42
  globalThis.fetch = fetch;
43
- return await getServerSideProps(componentProps);
43
+ return await ${i}(componentProps);
44
44
  } finally {
45
45
  // 清理全局状态
46
46
  if (originalLocation) globalThis.location = originalLocation;
47
47
  if (originalFetch) globalThis.fetch = originalFetch;
48
48
  }
49
- }`,filename:`${e.name||e.id}.js`,moduleLoader:i=>{if(i==="@blocklet/pages-kit/builtin/utils")return`const { joinURL, withQuery, getQuery, getComponentMountPoint } = globalThis
49
+ }`,filename:`${e.name||e.id}.js`,moduleLoader:a=>{if(a==="@blocklet/pages-kit/builtin/utils")return`const { joinURL, withQuery, getQuery, getComponentMountPoint } = globalThis
50
50
  export { joinURL, withQuery, getQuery, getComponentMountPoint }
51
- `;if(i==="@blocklet/pages-kit/builtin/dayjs")return ue.BuiltinModules.dayjs},global:{console:{log:(...i)=>{w.info(...i)},warn:(...i)=>{w.warn(...i)},error:(...i)=>{w.error(...i)}},getComponentMountPoint:vt.getComponentMountPoint,joinURL:$.joinURL,withQuery:$.withQuery,getQuery:$.getQuery},functionName:"getServerSidePropsWrapper",args:[{location:{href:$.joinURL($.withHttps(s.hostname),s.originalUrl)},fetch:(i,{...d}={})=>{const c=typeof i=="string"&&i.startsWith("/")?$.joinURL(O.default.env.appUrl,i):i;if(typeof c=="string"&&$.parseURL(c).host===$.parseURL(O.default.env.appUrl).host){const p=s.get("cookie");if(p){const S=new ot.Headers(d.headers);S.set("cookie",p),d.headers=S}}return as.default(c,{...d,timeout:Me*1e3}).then(p=>({ok:p.ok,status:p.status,statusText:p.statusText,headers:Object.fromEntries(p.headers.entries()),json:()=>p.json()}))},props:t}]})])}const yt=ue.memoize(async(e,n,t)=>{if(!(e!=null&&e.includes(n)))return null;const s=await dt(e,n);if(s)try{return await ue.Sandbox.callFunction({code:`
51
+ `;if(a==="@blocklet/pages-kit/builtin/dayjs")return ue.BuiltinModules.dayjs},global:{console:{log:(...a)=>{E.info(...a)},warn:(...a)=>{E.warn(...a)},error:(...a)=>{E.error(...a)}},getComponentMountPoint:vt.getComponentMountPoint,joinURL:$.joinURL,withQuery:$.withQuery,getQuery:$.getQuery},functionName:"getServerSidePropsWrapper",args:[{location:{href:$.joinURL($.withHttps(s.hostname),s.originalUrl)},fetch:(a,{...p}={})=>{const S=typeof a=="string"&&a.startsWith("/")?$.joinURL(O.default.env.appUrl,a):a;if(typeof S=="string"&&$.parseURL(S).host===$.parseURL(O.default.env.appUrl).host){const f=s.get("cookie");if(f){const l=new ot.Headers(p.headers);l.set("cookie",f),p.headers=l}}return as.default(S,{...p,timeout:Me*1e3}).then(f=>({ok:f.ok,status:f.status,statusText:f.statusText,headers:Object.fromEntries(f.headers.entries()),json:()=>f.json()}))},props:t}]})])}const yt=ue.memoize(async(e,n,t)=>{if(!(e!=null&&e.includes(n)))return null;const s=await dt(e,n);if(s)try{return await ue.Sandbox.callFunction({code:`
52
52
  ${s}
53
53
 
54
54
  export function get${n}SchemaWrapper() {
55
55
  return ${n};
56
56
  }
57
- `,filename:`${t}.js`,functionName:`get${n}SchemaWrapper`})}catch(o){return w.error(`获取 ${n} 失败`,{componentId:t,error:o}),null}return null},{keyGenerator:(e,n,t)=>{const s=Z.createHash("md5").update(e).digest("hex");return JSON.stringify(["getExportSchemaValueFromCode",s,n,t])},lruOptions:{max:100,ttl:1e3*60*60}}),$s="z8iZiDFg3vkkrPwsiba1TLXy3H9XHzFERsP8o",Ue="page",Fe="trigger-reload-project-resource",Je=$s,qs="z2qa7BQdkEb3TwYyEYC1psK6uvmGnHSUHt5RM";function be(e){e.observeDeep(n=>{n.some(t=>t.changes.keys.has("updatedAt")||t.changes.keys.has("publishedAt"))||e.set("updatedAt",new Date().toISOString())})}function St(){return E.mkdtempSync(y.join(O.default.env.dataDir,"tmp-"))}function Ie(e,n,t=[]){return Array.isArray(e)?e.flatMap((s,o)=>Ie(s,n,[...t,o])):typeof e=="object"?e===null?[]:Object.entries(e).flatMap(([s,o])=>Ie(o,n,[...t,s])):n(e)?[t]:[]}function q(e){return e.filter(n=>n!=null)}function Hs(e){e.pages&&Object.keys(e.pages).forEach(t=>{const s=ee.getYjsValue(e.pages[t]);s&&s instanceof V.Map&&be(s)});const n=ee.getYjsValue(e.pages);n&&n instanceof V.Map&&n.observe(t=>{t.changes.keys.forEach((s,o)=>{if(s.action==="add"){const r=ee.getYjsValue(e.pages[o]);r&&r instanceof V.Map&&be(r)}})})}function Bs(e){e.routes&&Object.keys(e.routes).forEach(t=>{var o;const s=ee.getYjsValue((o=e.routes)==null?void 0:o[t]);s&&s instanceof V.Map&&be(s)});const n=ee.getYjsValue(e.routes);n&&n instanceof V.Map&&n.observe(t=>{t.changes.keys.forEach((s,o)=>{var r;if(s.action==="add"){const a=ee.getYjsValue((r=e.routes)==null?void 0:r[o]);a&&a instanceof V.Map&&be(a)}})})}function Gs(e,n){var t;for(const s of n||Object.keys(e.routes||{})){let o=s,r=[];if(s.includes("-")){const[a,...i]=s.split("-");o=a,r=i||[]}if(((t=e.routes)==null?void 0:t[o])!==void 0){e.routes[o].publishedAt=new Date().toISOString();const a=e.routes[o];if(!a||!a.params||a.params.length===0)continue;if(s.includes("-")&&r.length>0){const i=we.getRouteMetaDataByOptionIds(r,a);i&&(i.publishedAt=new Date().toISOString())}if(!n){const i=we.generateParamCombinations({basePath:a.path,params:a.params,routeId:a.id,paramsOptions:a.paramsOptions,currentIndex:0,currentParams:[],currentOptionIds:[],result:[]});for(const d of i)d.routeMetaData??(d.routeMetaData={}),d.routeMetaData.publishedAt=new Date().toISOString()}}}}function Re({page:e,route:n,state:t,routeId:s,routePathInfo:o}){var a,i,d,c,p,S,m,u,l;w.info(`Executing datasource data assembly, routeId: ${s}, routePathInfo: ${JSON.stringify(o)}`);const r={...Bt.cloneDeep(e),id:s,slug:(o==null?void 0:o.path)??n.path,createdAt:n.createdAt,updatedAt:((a=o==null?void 0:o.routeMetaData)==null?void 0:a.updatedAt)??n.updatedAt,publishedAt:((i=o==null?void 0:o.routeMetaData)==null?void 0:i.publishedAt)??n.publishedAt,isPublic:(((d=o==null?void 0:o.routeMetaData)==null?void 0:d.isPublic)??n.isPublic)&&n.isPublic};for(const f of t.supportedLocales){if(n.dataSource){let b=n.id;o&&(b=o.paramOptionIds.join("-"));const _=((S=(p=(c=n.dataSource.pathDataMappings)==null?void 0:c[b])==null?void 0:p.dataCache)==null?void 0:S[f.locale])??((l=(u=(m=n.dataSource.pathDataMappings)==null?void 0:m[b])==null?void 0:u.dataCache)==null?void 0:l[t.config.defaultLocale||"en"]);if(!_)continue;Ht.setPageDataSource(r,t,f.locale,_)}o&&o.routeMetaData&&(o.routeMetaData.publishedAt=new Date().toISOString())}return r}const{uploadToMediaKit:Vs}=require("@blocklet/uploader-server"),Se=es.customAlphabet("abcdefghijklmnopqrstuvwxyz0123456789",16),ze=/^\w+(\w|-|\.)+\w+\.(jpe?g|png|gif|svg|bmp|webp|mp4|m4v|webm)$/,le=/mediakit:\/\/([a-f0-9]{32}\.(jpe?g|png|gif|svg|bmp|webp|mp4|m4v|webm))/i,et=/mediakit:\/\/([a-f0-9]{32}\.(jpe?g|png|gif|svg|bmp|webp|mp4|m4v|webm))/gi,Js=1e4,zs=3e4,ge=0,xe=1,Ks=0,Ys=1,$e=O.default,se=y.join(process.env.BLOCKLET_DATA_DIR,"site-state"),Ws=["production","draft"],Qs=["production"];function Oe(e){return(e==null?void 0:e.replace(/\//g,"|"))||""}function Xs(){var t;const e=$e.env.languages.map(s=>({locale:s.code,name:s.name})),n=(t=e[0])==null?void 0:t.locale;return{pageIds:[],pages:{},routeIds:[],routes:{},dataSourceIds:[],dataSources:{},components:{},supportedLocales:e,config:{defaultLocale:n},resources:{}}}const j=class j extends V.Doc{constructor(t){super();k(this,"syncedStore");k(this,"conns",new Map);k(this,"awareness");k(this,"releaseTimer");k(this,"awarenessChangeHandler",({added:t,updated:s,removed:o},r)=>{const a=t.concat(s,o);if(r!==null){const c=this.conns.get(r);c&&(t.forEach(p=>{c.add(p)}),o.forEach(p=>{c.delete(p)}))}const i=x.createEncoder();x.writeVarUint(i,xe),x.writeVarUint8Array(i,ie.encodeAwarenessUpdate(this.awareness,a));const d=x.toUint8Array(i);this.conns.forEach((c,p)=>this.send(p,d))});k(this,"updateHandler",t=>{const s=x.createEncoder();x.writeVarUint(s,ge),ve.writeUpdate(s,t);const o=x.toUint8Array(s);this.conns.forEach((r,a)=>this.send(a,o))});k(this,"ensureDataStructure",()=>{var d;const{supportedLocales:t,pages:s,pageIds:o,config:r,routes:a,routeIds:i}=this.syncedStore;{const c=new Set(Object.keys(s));let p=0;for(;p<o.length;){const S=o[p];c.has(S)?(c.delete(S),p++):o.splice(p,1)}}{const c=new Set(Object.keys(a));let p=0;for(;p<i.length;){const S=i[p];c.has(S)?(c.delete(S),p++):i.splice(p,1)}}t.splice(0,t.length),t.push(...$e.env.languages.map(c=>({locale:c.code,name:c.name}))),r.defaultLocale=(d=t[0])==null?void 0:d.locale;{let c=0;const p=new Set;for(;c<t.length;){const{locale:S}=t[c];p.has(S)?t.splice(c,1):(c++,p.add(S))}}});k(this,"send",(t,s)=>{t.readyState!==Ks&&t.readyState!==Ys&&this.closeConn(t);try{t.send(s,o=>{o&&this.closeConn(t)})}catch{this.closeConn(t)}});k(this,"closeConn",t=>{if(t.removeAllListeners(),this.conns.has(t)){const s=this.conns.get(t);this.conns.delete(t),s&&ie.removeAwarenessStates(this.awareness,Array.from(s),null)}t.close(),this.checkAndScheduleRelease()});k(this,"autoSave",it.default(()=>{E.mkdirSync(y.dirname(this.draftYjsFilePath),{recursive:!0}),E.writeFileSync(this.draftYjsFilePath,V.encodeStateAsUpdate(this))},Js));k(this,"save",({flush:t=!1}={})=>{this.autoSave(),t&&this.autoSave.flush()});k(this,"publish",async({mode:t,routes:s})=>{const o=await this.getState("draft"),r=await this.getState("production");await qe(o,r,{routes:s,mergeMode:"replace",deleteRoutes:!0,publishMode:t}),r.config.publishedAt=new Date().getTime(),Gs(this.syncedStore,s),await this.setState(t,r)});k(this,"mergeState",async(t,s)=>{var i,d,c;const o=JSON.parse(JSON.stringify(s));(i=t.config).fontFamily??(i.fontFamily={});const r=(d=o.config)==null?void 0:d.fontFamily,a=(c=t.config)==null?void 0:c.fontFamily;t.config.fontFamily.title=(r==null?void 0:r.title)||(a==null?void 0:a.title),t.config.fontFamily.description=(r==null?void 0:r.description)||(a==null?void 0:a.description),await new Promise((p,S)=>{this.transact(async()=>{try{const m=await qe(t,s);p(m)}catch(m){S(m)}})})});k(this,"addConnection",t=>{if(this.conns.has(t))return;this.cancelRelease(),t.binaryType="arraybuffer",this.conns.set(t,new Set),t.on("message",r=>this.messageListener(t,new Uint8Array(r)));let s=!0;const o=setInterval(()=>{if(!s)this.conns.has(t)&&this.closeConn(t),clearInterval(o);else if(this.conns.has(t)){s=!1;try{t.ping()}catch{this.closeConn(t),clearInterval(o)}}},zs);t.on("close",()=>{this.closeConn(t),clearInterval(o)}),t.on("pong",()=>{s=!0});{const r=x.createEncoder();x.writeVarUint(r,ge),ve.writeSyncStep1(r,this),this.send(t,x.toUint8Array(r));const a=this.awareness.getStates();if(a.size>0){const i=x.createEncoder();x.writeVarUint(i,xe),x.writeVarUint8Array(i,ie.encodeAwarenessUpdate(this.awareness,Array.from(a.keys()))),this.send(t,x.toUint8Array(i))}}});k(this,"messageListener",(t,s)=>{try{const o=x.createEncoder(),r=ke.createDecoder(s),a=ke.readVarUint(r);switch(a){case ge:x.writeVarUint(o,ge),ve.readSyncMessage(r,o,this,null),x.length(o)>1&&(this.ensureDataStructure(),this.send(t,x.toUint8Array(o)));break;case xe:{ie.applyAwarenessUpdate(this.awareness,ke.readVarUint8Array(r),t);break}default:w.warn(`Unsupported messageType ${a}`)}}catch(o){w.error(o)}this.save()});this.options=t,E.existsSync(this.draftYjsFilePath)&&V.applyUpdate(this,E.readFileSync(this.draftYjsFilePath)),this.syncedStore=Gt.reactive(ee.syncedStore({pages:{},pageIds:[],components:{},supportedLocales:[],config:{},resources:{},routeIds:[],routes:{},dataSourceIds:[],dataSources:{}},this)),this.initObserver(),this.on("update",this.updateHandler),this.awareness=new ie.Awareness(this),this.awareness.on("update",this.awarenessChangeHandler),this.ensureDataStructure()}static safeDeleteProjectStateDir(t){if(!t)throw new Error("Should provide project context");try{const s=y.join(se,t),o=y.join(se,`@del-${t}`);E.renameSync(s,o)}catch(s){w.error("Failed to safe delete project state dir:",s)}}static get projectIds(){return Ne.globSync("*/",{cwd:se,ignore:["@del-*","@tmp-*",".*","staging","production","@backup-*"]})}static get allShared(){return this.projectIds.map(t=>j.shared(t))}static shared(t){if(!t)throw new Error("Should provide project context");let s=j.sharedInstances[t];return s||(s=new j({path:y.join(se,t)}),j.sharedInstances[t]=s,Pt({projectId:t,pages:Te,components:Pe}),s)}static async getProductionState(t){var o,r;let s=j.productionStates.get(t);if(!s){const a=y.join(se,t,"production");if(s=await Ke(a,{includeResources:!0})??Xs(),!((o=s==null?void 0:s.config)!=null&&o.defaultLocale)){s.config??(s.config={});const i=$e.env.languages.map(d=>({locale:d.code,name:d.name}));s.config.defaultLocale=(r=i[0])==null?void 0:r.locale}j.productionStates.set(t,s)}return{...s,resources:await je().then(async a=>{var S,m;const{pages:i,components:d}=ms.default(a,"pages","components");let c=d;const p=await K.findByPk(t);if(p!=null&&p.useAllResources)c=d;else{const l=(await Ce.findAll({where:{projectId:t}})).map(b=>b.componentId);c=Object.fromEntries(Object.entries(d||{}).filter(([b])=>l.includes(b)))}return Object.keys(((S=s==null?void 0:s.resources)==null?void 0:S.components)||{}).length>0&&(c={...c,...(m=s==null?void 0:s.resources)==null?void 0:m.components}),{pages:i,components:c}}).catch(()=>({}))}}destroy(){this.cancelRelease(),this.save({flush:!0}),this.conns.forEach((s,o)=>this.closeConn(o)),this.awareness.destroy();const t=y.basename(this.options.path);delete j.sharedInstances[t],super.destroy()}initObserver(){Hs(this.syncedStore),Bs(this.syncedStore)}get draftYjsFilePath(){return y.join(this.options.path,"draft.yjs")}static async getStateByProjectId(t,s){if(s==="draft"){const o=j.shared(t);return JSON.parse(JSON.stringify(o.syncedStore))}return j.getProductionState(t)}async getState(t){if(t==="draft")return JSON.parse(JSON.stringify(this.syncedStore));const s=y.basename(this.options.path);return j.getProductionState(s)}async setState(t,s){const o=await It(s,{exportAssets:!1,includeResources:!0}),r=this.getPublishDir(t);if(E.mkdirSync(y.dirname(r),{recursive:!0}),E.rmSync(r,{force:!0,recursive:!0}),E.renameSync(o,r),t==="production"){const a=y.basename(this.options.path);j.productionStates.set(a,s)}}getPublishDir(t){return y.join(this.options.path,t)}checkAndScheduleRelease(){this.conns.size===0&&this.scheduleRelease()}scheduleRelease(){this.cancelRelease();const t=y.basename(this.options.path);this.releaseTimer=setTimeout(()=>{w.info(`[SiteState] releasing instance due to no active connections: ${t}`),this.conns.size===0&&(this.releaseTimer=void 0,this.destroy())},j.RELEASE_DELAY),w.info(`[SiteState] scheduled release for project ${t} in ${j.RELEASE_DELAY/1e3}s`)}cancelRelease(){if(this.releaseTimer){clearTimeout(this.releaseTimer),this.releaseTimer=void 0;const t=y.basename(this.options.path);w.info(`[SiteState] cancelled scheduled release for project ${t}`)}}static async pageUrlMap(t,s){var a,i;let{projectIds:o}=this;s&&(o=[s]);const r={};for(const d of o){const c=await K.findByPk(d);if(!c)continue;const p=await j.getStateByProjectId(d,t),S=c.slug||d,m=gs.default(O.default.env.languages.map(l=>l.code),p.supportedLocales.map(l=>l.locale)),u=(l,f)=>{S&&(r[$.joinURL("/",S,l)]={...f,shouldRedirect:!0,mainPage:!0}),r[$.joinURL("/",d,l)]={...f,shouldRedirect:!0,mainPage:!0};for(const b of m){const _={...f,locale:b};r[$.joinURL("/",b,d,l)]=_,S&&(r[$.joinURL("/",b,S,l)]=_)}};if(t==="draft")for(const l of p.routeIds||[]){const f=(a=p==null?void 0:p.routes)==null?void 0:a[l];if(!f)continue;if(f.params&&f.params.length>0){const T=we.generateParamCombinations({basePath:f.path,params:f.params,routeId:f.id,paramsOptions:f.paramsOptions,currentIndex:0,currentParams:[],currentOptionIds:[],result:[]});for(const M of T){const Y=M.path,te={projectId:d,projectSlug:S,pageSlug:Y,pageId:f.displayTemplateId||"",routeId:l,defaultLocale:m==null?void 0:m[0],locales:m,publishedAt:p.config.publishedAt,isPublic:f.isPublic&&((i=M==null?void 0:M.routeMetaData)==null?void 0:i.isPublic)};u(Y,te)}}const b=f.path,_={projectId:d,projectSlug:S,pageSlug:b,pageId:f.displayTemplateId||"",routeId:l,defaultLocale:m==null?void 0:m[0],locales:m,publishedAt:p.config.publishedAt,isPublic:f.isPublic};u(b,_)}for(const l of p.pageIds){const f=p.pages[l];if(!f||t==="production"&&!f.isPublic)continue;const b=f.slug,_=c.slug||d,T={projectId:d,projectSlug:_,pageSlug:b,pageId:l,defaultLocale:m==null?void 0:m[0],locales:m,publishedAt:p.config.publishedAt,isPublic:f.isPublic,templateConfig:f.templateConfig};u(b,T)}}return r}getDocumentSize(){return V.encodeStateAsUpdate(this).byteLength}static getInstancesSizeInfo(){const t=[];for(const[s,o]of Object.entries(j.sharedInstances)){const r=o.getDocumentSize();t.push({projectId:s,sizeInBytes:r,sizeInMB:`${(r/(1024*1024)).toFixed(2)} MB`,activeConnections:o.conns.size})}return t}static startPeriodicCheck(){this.periodicCheckTimer||(this.periodicCheckTimer=setInterval(()=>{this.performPeriodicCheck()},this.PERIODIC_CHECK_INTERVAL),w.info(`[SiteState] periodic check started, interval: ${this.PERIODIC_CHECK_INTERVAL/(60*60*1e3)} hours`))}static stopPeriodicCheck(){this.periodicCheckTimer&&(clearInterval(this.periodicCheckTimer),this.periodicCheckTimer=void 0,w.info("[SiteState] periodic check stopped"))}static performPeriodicCheck(){const t=Object.keys(j.sharedInstances).length,s=[],o=[];for(const[r,a]of Object.entries(j.sharedInstances))a.conns.size===0?s.push({projectId:r,instance:a}):o.push({projectId:r,connections:a.conns.size});if(w.info(`[SiteState] periodic check summary: total instances: ${t}, with connections: ${o.length}, without connections: ${s.length}`),s.length>0){w.info(`[SiteState] releasing ${s.length} instances without connections:`,s.map(a=>a.projectId));let r=0;for(const{projectId:a,instance:i}of s)try{w.info(`[SiteState] releasing instance due to periodic check: ${a}`),i.destroy(),r++}catch(d){w.error(`[SiteState] failed to release instance ${a} during periodic check:`,d)}w.info(`[SiteState] periodic check completed: ${r}/${s.length} instances released successfully`)}else t>0?w.debug("[SiteState] periodic check: all instances have active connections"):w.debug("[SiteState] periodic check: no instances exist")}};k(j,"PRODUCTION_CACHE_TTL",7*24*60*60*1e3),k(j,"RELEASE_DELAY",5*60*1e3),k(j,"PERIODIC_CHECK_INTERVAL",2*60*60*1e3),k(j,"sharedInstances",{}),k(j,"productionStates",new He.LRUCache({max:100,ttl:j.PRODUCTION_CACHE_TTL})),k(j,"periodicCheckTimer");let z=j;async function Zs(e,n,t){if(!e||!E.existsSync(e)||!E.lstatSync(e).isFile())return null;let s=t[e];return s||(s=(async()=>{var o;try{const r=(o=await Vs({filePath:e,fileName:n}))==null?void 0:o.data;return r==null?void 0:r.filename}catch(r){return w.error(`Failed to upload asset ${e}:`,r),null}})(),t[e]=s),s}const Et=async(e,n)=>{const t=y.basename(e),s=await Be.call({name:Je,path:$.joinURL("/uploads",t),responseType:"stream",method:"GET"});if(s.status>=200&&s.status<400){const o=E.createWriteStream(n);await ss.pipeline(s.data,o)}else throw new Error(`download asset failed ${s.status}`)},wt=async(e,n)=>{await Promise.all(e.map(async t=>{try{await Et(t,y.join(n,y.basename(t)))}catch(s){w.error(`Failed to export assets: ${t}, ${s}`)}}))};function bt(e){return ze.test(e)?[e]:le.test(e)?(et.lastIndex=0,Array.from(e.matchAll(et)).map(t=>t[1]).filter(t=>!!t)):[]}async function he(e,n,t){const{getFilename:s,exportAssets:o}=t,r=y.join(n,s(e));if(E.mkdirSync(y.dirname(r),{recursive:!0}),E.writeFileSync(r,ne.stringify(e)),o){const i=Ie(e,d=>typeof d=="string"&&(ze.test(d)||le.test(d))).map(d=>{const c=Ge.default(e,d);return bt(c)}).flat().filter(Boolean);await wt(i,y.dirname(r))}}const tt=new He.LRUCache({max:20,ttl:30*24*60*60*1e3});async function st(e,n,t){var i;const s=Ie(e,d=>typeof d=="string"&&(ze.test(d)||le.test(d))),o=hs.default(2),r=s.map(d=>o(async()=>{try{const c=Ge.default(e,d),p=bt(c);for(const S of p){const m=y.basename(S),u=t.getFilePath(S,d),l=u?`${u}:${m}`:m,f=tt.get(l);if(f){le.test(c)||Qe.default(e,d,f);return}const b=await Zs(u,m,n);b&&(le.test(c)||Qe.default(e,d,b),tt.set(l,b))}}catch(c){w.error(`Failed to process upload for path ${d.join(".")}:`,c.message||c.reason)}})),a=await Promise.allSettled(r);(i=t.onFinish)==null||i.call(t,a)}async function It(e,{exportAssets:n,pageIds:t="all",componentIds:s="all",rawConfig:o,includeResources:r=!1,routeIds:a="all"}={}){var re,I,g,C,D,W,A,L,H,Q,J,ae;const i=t==="all"?e.pageIds:t,d=de.getComponentDependencies({state:e,pageIds:i,componentIds:s==="all"?Object.keys(e.components):s}),c=a==="all"?e.routeIds:a,p=h=>({id:h.id,name:h.name,isTemplateSection:h.isTemplateSection??!1,templateDescription:h.templateDescription,llmConfig:h.llmConfig,component:h.component,config:h.config,visibility:h.visibility,sections:h.sections,sectionIds:h.sectionIds}),S=(h,P)=>{var R;return{id:h.id,createdAt:h.createdAt,updatedAt:h.updatedAt,publishedAt:h.publishedAt,isPublic:h.isPublic??!0,templateConfig:h.templateConfig,meta:((R=h.locales)==null?void 0:R[P])??{},sections:q(h.sectionIds.map(B=>{const U=h.sections[B];return U&&p(U)})),dataSource:Object.fromEntries(Object.entries(h.dataSource||{}).map(([B,U])=>[B,(U==null?void 0:U[P])??{}]))}},m=h=>({id:h.id,createdAt:h.createdAt,updatedAt:h.updatedAt,publishedAt:h.publishedAt,path:h.path,handler:h.handler,isPublic:h.isPublic??!0,params:h.params??[],enabledGenerate:h.enabledGenerate??!1,displayTemplateId:h.displayTemplateId,dataSource:h.dataSource}),u=q(c.map(h=>{const P=e.routes[h];return P&&m(P)})),l=q(e.supportedLocales.map(h=>h.locale).flatMap(h=>i.map(P=>{const R=e.pages[P];return R&&{locale:h,slug:R.slug,page:S(R,h)}}))),f=St(),b=y.join(f,"pages");E.mkdirSync(b,{recursive:!0});const _=y.join(f,"components");E.mkdirSync(_,{recursive:!0});const T=y.join(f,"routes");E.mkdirSync(T,{recursive:!0});for(const{locale:h,slug:P,page:R}of l)await he(R,b,{getFilename:()=>`${Oe(P)||"index"}.${h}.yml`,exportAssets:n});for(const h of u)await he(h,T,{getFilename:()=>`${Oe(h.path)||"index"}.yml`,exportAssets:n});for(const h of d){const P=(re=e.components[h])==null?void 0:re.data;P&&await he(P,_,{getFilename:R=>`${R.name||"unnamed"}.${R.id}.yml`,exportAssets:n})}const M=y.join(f,".blocklet/pages/pages.config.yml");E.mkdirSync(y.dirname(M),{recursive:!0});const Y={pages:q(i.map(h=>{const P=e.pages[h];return P&&{id:h,slug:P.slug}})),routes:q(c.map(h=>{const P=e.routes[h];return P&&{id:h,path:P.path}})),components:q(d.map(h=>{var R;const P=(R=e.components[h])==null?void 0:R.data;return P&&{id:h,name:P.name}})),...r?{resources:{components:q(Object.keys(((I=e.resources)==null?void 0:I.components)||{}).filter(h=>d.includes(h)).map(h=>{var P,R,B,U;return{id:h,name:(U=(B=(R=(P=e.resources)==null?void 0:P.components)==null?void 0:R[h])==null?void 0:B.component)==null?void 0:U.name}}))}}:{},supportedLocales:e.supportedLocales,config:e.config};E.writeFileSync(M,ne.stringify(Y));const te=y.join(f,"config.source.json");if(o&&E.writeFileSync(te,JSON.stringify(o)),r){const h=y.join(f,"resources"),P=y.join(h,"components");E.mkdirSync(P,{recursive:!0});for(const U of Object.keys(((g=e==null?void 0:e.resources)==null?void 0:g.components)??{}).filter(G=>d.includes(G))){const G=(W=(D=(C=e.resources)==null?void 0:C.components)==null?void 0:D[U])==null?void 0:W.component;G&&await he(G,P,{getFilename:X=>`${X.name||"unnamed"}.${X.id}.yml`,exportAssets:n})}const R=y.join(f,"chunks");E.mkdirSync(R,{recursive:!0});const{chunks:B}=await je();for(const U of Object.keys(((A=e==null?void 0:e.resources)==null?void 0:A.components)??{}).filter(G=>d.includes(G))){const G=(Q=(H=(L=e.resources)==null?void 0:L.components)==null?void 0:H[U])==null?void 0:Q.component;if(G&&((J=G.renderer)==null?void 0:J.type)==="react-component"){const X=((ae=G.renderer)==null?void 0:ae.chunks)??[];if((X==null?void 0:X.length)>0)for(const De of X){const We=y.join(R,De),_e=B==null?void 0:B[De];try{_e&&E.existsSync(_e)&&!E.existsSync(We)&&E.copyFileSync(_e,We)}catch(jt){w.error(`copy chunk ${De} error`,jt.message)}}}}}return f}async function Ke(e,{importAssets:n,includeResources:t}={}){var r,a,i,d;if(!E.existsSync(e))return null;let s,o=!1;try{E.lstatSync(e).isDirectory()?s=e:/\.(tgz|gz|tar)$/.test(e)&&(o=!0,s=St(),await ns.x({file:e,C:s}));const c=Ne.globSync("**/.blocklet/pages/pages.config.yml",{cwd:s,absolute:!0}).at(0),p=c&&y.join(y.dirname(c),"../../pages"),S=c&&y.join(y.dirname(c),"../../components"),m=c&&y.join(y.dirname(c),"../../chunks"),u=c&&y.join(y.dirname(c),"../../routes");if(!c)return null;const l=ne.parse(E.readFileSync(c).toString()),f=(I,g,C)=>{let D=y.join(I,`${g}${C?`.${C}`:""}.yml`);return(!E.existsSync(D)||!E.lstatSync(D).isFile())&&(D=y.join(I,g,`index${C?`.${C}`:""}.yml`),!E.existsSync(D)||!E.lstatSync(D))?null:ne.parse(E.readFileSync(D).toString())},b=(I,g)=>{try{const C=Ne.globSync(`*.${g}.yml`,{cwd:I,absolute:!0})[0];return C?ne.parse(E.readFileSync(C).toString()):null}catch(C){w.error("parse component error",C)}return null},_=(I,g)=>{let C=y.join(I,`${g}.yml`);return(!E.existsSync(C)||!E.lstatSync(C).isFile())&&(C=y.join(I,g,"index.yml"),!E.existsSync(C)||!E.lstatSync(C))?null:ne.parse(E.readFileSync(C).toString())},T=q(l.pages.map(({slug:I})=>{var W;const g=q(l.supportedLocales.map(({locale:A})=>{const L=p?f(p,Oe(I),A):void 0;if(L)return{locale:A,page:L};const H=p?f(p,I,A):void 0;return H&&{locale:A,page:H}})),C=(W=g[0])==null?void 0:W.page;if(!C)return null;const D=C.sections.map(A=>({id:A.id||Se(),component:A.component,config:A.config,name:A.name,isTemplateSection:A.isTemplateSection??!1,templateDescription:A.templateDescription,llmConfig:A.llmConfig,visibility:A.visibility,sections:A.sections,sectionIds:A.sectionIds}));return{id:C.id||Se(),createdAt:C.createdAt,updatedAt:C.updatedAt,publishedAt:C.publishedAt,isPublic:C.isPublic??!0,templateConfig:C.templateConfig,slug:I,sections:Object.fromEntries(D.map(A=>[A.id,A])),sectionIds:D.map(A=>A.id),locales:Object.fromEntries(g.map(({locale:A,page:L})=>[A,L.meta])),dataSource:C.dataSource?Object.fromEntries([...new Set(g.flatMap(({page:A})=>Object.keys(A.dataSource??{})))].map(A=>[A,Object.fromEntries(g.map(({locale:L,page:H})=>{var J;const Q=(J=H.dataSource)==null?void 0:J[A];return[L,Q||{}]}))])):Object.fromEntries([...new Set(g.flatMap(({page:A})=>A.sections.map(L=>L.id)))].map(A=>[A,Object.fromEntries(g.map(({locale:L,page:H})=>{var ae;const Q=(ae=H.dataSource)==null?void 0:ae[A];if(Q)return[L,Q];const J=H.sections.find(h=>h.id===A);return[L,(J==null?void 0:J.properties)||{}]}))]))}})),M=q(((r=l==null?void 0:l.routes)==null?void 0:r.map(({path:I})=>{const g=u?_(u,Oe(I)):void 0;return{...g,id:(g==null?void 0:g.id)||Se(),createdAt:(g==null?void 0:g.createdAt)??new Date().toISOString(),updatedAt:(g==null?void 0:g.updatedAt)??new Date().toISOString(),publishedAt:new Date(0).toISOString(),path:(g==null?void 0:g.path)??`/${g==null?void 0:g.id}`,params:g==null?void 0:g.params,handler:(g==null?void 0:g.handler)??"Pages Kit",isPublic:(g==null?void 0:g.isPublic)??!0,enabledGenerate:(g==null?void 0:g.enabledGenerate)??!1,displayTemplateId:(g==null?void 0:g.displayTemplateId)??void 0,dataSource:(g==null?void 0:g.dataSource)??{}}}))??[]),Y=S?q(((a=l.components)==null?void 0:a.map(({id:I})=>b(S,I)))??[]):[];if(n){const I=(...g)=>{w.info(`[${o?y.basename(e):y.basename(y.join(e,"../../../../"))}] importAssets:`,...g)};try{I("wait image-bin api ready"),await ys.default({resources:[`${Be.getComponentWebEndpoint(Ss)}/api/sdk/uploads`],validateStatus:D=>D>=200&&D<=500}),I("image-bin api is ready");const g={},C={};I("start to upload assets"),await Promise.allSettled([st(Y,g,{getFilePath:D=>S&&y.join(S,D),onFinish:D=>{I(`upload ${D.length} component assets`)}}),st(T,C,{getFilePath:(D,W)=>{const A=Ge.default(T,W.slice(0,1));return p&&y.join(p,y.dirname(A.slug),D)},onFinish:D=>{I(`upload ${D.length} page assets`)}})]),I("upload assets done"),global.gc&&global.gc()}catch(g){I("Error during asset import:",g)}}const te={};if(t){const I=c&&y.join(y.dirname(c),"../../resources/components"),g=q(((d=(i=l.resources)==null?void 0:i.components)==null?void 0:d.map(({id:C})=>b(I,C)))??[]);g.length>0&&(te.components=Object.fromEntries(g.map((C,D)=>[C.id,{index:D,component:C}])))}const re={};if(m&&E.existsSync(m)){const I=E.readdirSync(m);for(const g of I)re[g]=y.join(m,g)}return{supportedLocales:l.supportedLocales,pageIds:T.map(I=>I.id),components:Object.fromEntries(Y.map((I,g)=>[I.id,{index:g,data:I}])),pages:Object.fromEntries(T.map(I=>[I.id,I])),config:l.config||{},resources:te,chunks:re,routeIds:M.map(I=>I.id),routes:Object.fromEntries(M.map(I=>[I.id,I])),dataSourceIds:[],dataSources:{}}}finally{o&&s&&E.rmSync(s,{force:!0,recursive:!0})}}async function qe(e,n,{routes:t,mergeMode:s="byUpdateTime",deleteRoutes:o=!1,publishMode:r=void 0}={}){try{r&&ft(r)}catch(m){w.error("clear preload page cache error",{error:m})}const{pages:a,pageIds:i,routeIds:d,routes:c,supportedLocales:p}=e;if(r==="production"){let m=t??[],u=null;for(const l of d??[]){const f=c==null?void 0:c[l];if(f!=null&&f.params&&(f==null?void 0:f.params.length)>0&&(f!=null&&f.paramsOptions)&&(f==null?void 0:f.paramsOptions.length)>0){const b=we.generateParamCombinations({basePath:f.path,params:f.params,routeId:f.id,paramsOptions:f.paramsOptions,currentIndex:0,currentParams:[],currentOptionIds:[],result:[]}),_=Object.fromEntries(b.map(T=>[`${l}-${T.paramOptionIds.join("-")}`,T]));u={...u||{},..._},t||(m=[...m,...b.map(T=>`${l}-${T.paramOptionIds.join("-")}`)])}else t||m.push(l)}w.info("routeIds to be published: ",m);for(const l of m){let f=l;if(f.includes("-")){const[T]=f.split("-");f=T}const b=c==null?void 0:c[f];if(!b){const T=n.pageIds.indexOf(f);T!==-1&&o&&(n.pageIds.splice(T,1),delete n.pages[f]);for(const M of n.pageIds)M.includes(`${f}-`)&&(n.pageIds.splice(n.pageIds.indexOf(M),1),delete n.pages[M]);w.info("delete main route page",f);continue}if(l.includes("-")&&!(u!=null&&u[l])){const T=n.pageIds.indexOf(l);T!==-1&&o&&(n.pageIds.splice(T,1),delete n.pages[l]),w.info("delete page",l);continue}if(!b.displayTemplateId){w.info("no display template",l);continue}const _=a[b.displayTemplateId];if(!_){w.info("no template page",l);continue}if(n.pageIds.includes(l)){if(w.info("has need update page",l),s==="replace")n.pages[l]=Re({page:_,route:b,state:e,routeId:l,routePathInfo:u==null?void 0:u[l]}),w.info("replace page",l);else if(s==="byUpdateTime"){const T=n.pages[b.id];(!T||b.updatedAt&&b.updatedAt>T.updatedAt)&&(n.pages[l]=Re({page:_,route:b,state:e,routeId:l,routePathInfo:u==null?void 0:u[l]}),w.info("replace page by update time",l))}}else n.pageIds.push(l),n.pages[l]=Re({page:_,route:b,state:e,routeId:l,routePathInfo:u==null?void 0:u[l]}),w.info("add page",l)}if(o&&!t)for(const l of n.pageIds)m!=null&&m.includes(l)||(delete n.pages[l],w.info("delete page",l)),n.pageIds=[...n.pageIds].filter(f=>m==null?void 0:m.includes(f))}else{for(const m of i){const u=a[m];if(u)if(n.pageIds.includes(u.id)){if(s==="replace")n.pages[u.id]=u;else if(s==="byUpdateTime"){const l=n.pages[u.id];(!l||u.updatedAt&&u.updatedAt>l.updatedAt)&&(n.pages[u.id]=u)}}else n.pageIds.push(u.id),n.pages[u.id]=u}for(const m of d){const u=c[m];if(u)if(n.routeIds.includes(u.id)){if(s==="replace")n.routes[u.id]=u;else if(s==="byUpdateTime"){const l=n.routes[u.id];(!l||u.updatedAt&&u.updatedAt>l.updatedAt)&&(n.routes[u.id]=u)}}else n.routeIds.push(u.id),n.routes[u.id]=u}}if(n.supportedLocales.splice(0,n.supportedLocales.length),n.supportedLocales.push(...fs.default(p)),o)for(const m of Object.keys(n.components))delete n.components[m];let S=JSON.parse(JSON.stringify(e.components));S=Object.fromEntries(await Promise.all(Object.entries(S).map(async([m,u])=>{const l=await Ot(u==null?void 0:u.data);return[m,{...u,data:l}]}))),Object.assign(n.components,S),Object.assign(n.config,JSON.parse(JSON.stringify(e.config))),ct.default(e.resources.components)||(n.resources.components=JSON.parse(JSON.stringify(e.resources.components||{})))}const Ot=Ve(async e=>{var n;if(!ct.default(e==null?void 0:e.properties))return e;if(((n=e==null?void 0:e.renderer)==null?void 0:n.type)==="react-component"){const{script:t}=(e==null?void 0:e.renderer)||{};if(t&&t.includes("PROPERTIES_SCHEMA"))try{const s=await yt(t,"PROPERTIES_SCHEMA",e.id);s&&s.length>0&&e&&(e.properties={},s.forEach((o,r)=>{e!=null&&e.properties&&(e.properties[o.id]={index:r,data:o})}))}catch(s){w.error("checkPropertiesFromCode error",{componentId:e.id,name:e.name},{error:s})}}return e},{keyGenerator:e=>{var c,p,S,m;const n=(e==null?void 0:e.id)||"",t=(e==null?void 0:e.name)||"",s=((c=e==null?void 0:e.renderer)==null?void 0:c.type)||"",o=(e==null?void 0:e.properties)||{},r=(e==null?void 0:e.updatedAt)||"",a=Z.createHash("md5").update(JSON.stringify(o)).digest("hex");let i="",d="";return((p=e==null?void 0:e.renderer)==null?void 0:p.type)==="react-component"&&(i=Z.createHash("md5").update(((S=e==null?void 0:e.renderer)==null?void 0:S.script)||"").digest("hex"),d=Z.createHash("md5").update(((m=e==null?void 0:e.renderer)==null?void 0:m.editComponent)||"").digest("hex")),JSON.stringify(["checkPropertiesFromCode",n,t,s,a,r,i,d])},lruOptions:{max:100,ttl:1e3*60*60},subdir:"checkPropertiesFromCode"});let Ae,oe,Te,Pe,Ye;function At(){return Ae=(async()=>{const e=Be.getResources({types:[{did:Je,type:Ue},{did:qs,type:Ue}]});oe=(await Promise.all(e.map(async t=>{const s=t.path?await Ke(t.path,{importAssets:!1}):void 0;return s?{blockletId:t.did,state:s,blockletTitle:t.title}:void 0}))).filter(t=>!!t),Te=oe.reduce((t,s)=>Object.assign(t,Object.fromEntries(Object.values(s.state.pages).map(o=>o?[o==null?void 0:o.id,{page:o,blockletId:s.blockletId}]:[]))),{});const n=oe.reduce((t,s)=>Object.assign(t,Object.fromEntries(Object.values(s.state.components).map(o=>[o.data.id,{blockletId:s.blockletId,component:o.data}]))),{});Pe=Object.fromEntries(await Promise.all(Object.entries(n).map(async([t,s])=>{const o=await Ot(s.component);return[t,{...s,component:o}]}))),Ye=oe.reduce((t,s)=>Object.assign(t,s.state.chunks),{})})(),Ae}function Ct(e){const n=it.default(async()=>{await At().catch(t=>{w.error("load resource states error",{error:t})}),await(e==null?void 0:e({states:oe,pages:Te,components:Pe,chunks:Ye}))},3e3,{leading:!1,trailing:!0});return n(),O.default.events.on(O.default.Events.componentAdded,n),O.default.events.on(O.default.Events.componentRemoved,n),O.default.events.on(O.default.Events.componentStarted,n),O.default.events.on(O.default.Events.componentStopped,n),O.default.events.on(O.default.Events.componentUpdated,n),O.default.events.on(Fe,n),()=>{O.default.events.off(O.default.Events.componentAdded,n),O.default.events.off(O.default.Events.componentRemoved,n),O.default.events.off(O.default.Events.componentStarted,n),O.default.events.off(O.default.Events.componentStopped,n),O.default.events.off(O.default.Events.componentUpdated,n),O.default.events.off(Fe,n)}}const Tt=Symbol.for("GLOBAL_RESOURCE_STATES_LISTENER_KEY"),Ee=globalThis;var nt;(nt=Ee[Tt])==null||nt.call(Ee);Ee[Tt]=Ct(async({pages:e,components:n})=>{const{projectIds:t}=z;w.info(`start update resource states projects(${t.length})`,t),await Promise.race([new Promise(s=>{setTimeout(()=>{s({})},30*1e3)}),Promise.all(t.map(async s=>{Pt({projectId:s,pages:e,components:n})}))]).catch(s=>{w.error("update resource states failed:",s)})});z.startPeriodicCheck();process.on("beforeExit",()=>{z.stopPeriodicCheck()});process.on("SIGINT",()=>{z.stopPeriodicCheck(),process.exit(0)});process.on("SIGTERM",()=>{z.stopPeriodicCheck(),process.exit(0)});async function Pt({projectId:e,pages:n,components:t}){const s=z.sharedInstances[e];if(!s){w.info(`projectId: ${e} not found in sharedInstances`);return}s.syncedStore.resources.pages=n;const o=await K.findByPk(e);if(o!=null&&o.useAllResources)s.syncedStore.resources.components=t;else{const a=(await Ce.findAll({where:{projectId:e}})).map(d=>d.componentId),i=Object.fromEntries(Object.entries(t||{}).filter(([d])=>a.includes(d)));s.syncedStore.resources.components=i}w.info(`update [${e}] resource states:`,{pages:Object.keys(s.syncedStore.resources.pages||{}).length,components:Object.keys(s.syncedStore.resources.components||{}).length})}async function en(){w.info("trigger reload all project resource"),O.default.events.emit(Fe)}async function je({ensureLoaded:e=!0}={}){return e&&(Ae??(Ae=At()),await Ae),{states:oe,pages:Te,components:Pe,chunks:Ye}}exports.COMPONENT_DID=Je;exports.CUSTOM_COMPONENT_CACHE_DURATION_IN_SECONDS=ut;exports.GET_SERVER_SIDE_PROPS_TIMEOUT_IN_SECONDS=Me;exports.PUBLISH_MODES=Qs;exports.Project=K;exports.RESOURCE_TYPE=Ue;exports.SITE_STATE_PATH=se;exports.STATE_MODES=Ws;exports.SiteState=z;exports.clearPreloadComponentsCache=pt;exports.clearPreloadComponentsCacheByMode=ft;exports.downloadAsset=Et;exports.downloadAssets=wt;exports.fromPackage=Ke;exports.getComponentFromState=pe;exports.getComponentFromStateByName=Us;exports.getExportSchemaValueFromCode=yt;exports.getMultiTenantAllProjectAccessPassports=bs;exports.getPreloadComponent=gt;exports.getPreloadComponents=Ns;exports.getPreloadComponentsCacheKey=mt;exports.getResourceStates=je;exports.initPackResourceStates=Ct;exports.isMultiTenant=ws;exports.logger=w;exports.mergeState=qe;exports.nextId=Se;exports.toPackage=It;exports.triggerReloadAllProjectResource=en;
57
+ `,filename:`${t}.js`,functionName:`get${n}SchemaWrapper`})}catch(o){return E.error(`获取 ${n} 失败`,{componentId:t,error:o}),null}return null},{keyGenerator:(e,n,t)=>{const s=Z.createHash("md5").update(e).digest("hex");return JSON.stringify(["getExportSchemaValueFromCode",s,n,t])},lruOptions:{max:100,ttl:1e3*60*60}}),$s="z8iZiDFg3vkkrPwsiba1TLXy3H9XHzFERsP8o",Ue="page",Fe="trigger-reload-project-resource",Je=$s,qs="z2qa7BQdkEb3TwYyEYC1psK6uvmGnHSUHt5RM";function be(e){e.observeDeep(n=>{n.some(t=>t.changes.keys.has("updatedAt")||t.changes.keys.has("publishedAt"))||e.set("updatedAt",new Date().toISOString())})}function St(){return w.mkdtempSync(y.join(O.default.env.dataDir,"tmp-"))}function Ie(e,n,t=[]){return Array.isArray(e)?e.flatMap((s,o)=>Ie(s,n,[...t,o])):typeof e=="object"?e===null?[]:Object.entries(e).flatMap(([s,o])=>Ie(o,n,[...t,s])):n(e)?[t]:[]}function q(e){return e.filter(n=>n!=null)}function Hs(e){e.pages&&Object.keys(e.pages).forEach(t=>{const s=ee.getYjsValue(e.pages[t]);s&&s instanceof V.Map&&be(s)});const n=ee.getYjsValue(e.pages);n&&n instanceof V.Map&&n.observe(t=>{t.changes.keys.forEach((s,o)=>{if(s.action==="add"){const r=ee.getYjsValue(e.pages[o]);r&&r instanceof V.Map&&be(r)}})})}function Bs(e){e.routes&&Object.keys(e.routes).forEach(t=>{var o;const s=ee.getYjsValue((o=e.routes)==null?void 0:o[t]);s&&s instanceof V.Map&&be(s)});const n=ee.getYjsValue(e.routes);n&&n instanceof V.Map&&n.observe(t=>{t.changes.keys.forEach((s,o)=>{var r;if(s.action==="add"){const i=ee.getYjsValue((r=e.routes)==null?void 0:r[o]);i&&i instanceof V.Map&&be(i)}})})}function Gs(e,n){var t;for(const s of n||Object.keys(e.routes||{})){let o=s,r=[];if(s.includes("-")){const[i,...u]=s.split("-");o=i,r=u||[]}if(((t=e.routes)==null?void 0:t[o])!==void 0){e.routes[o].publishedAt=new Date().toISOString();const i=e.routes[o];if(!i||!i.params||i.params.length===0)continue;if(s.includes("-")&&r.length>0){const u=Ee.getRouteMetaDataByOptionIds(r,i);u&&(u.publishedAt=new Date().toISOString())}if(!n){const u=Ee.generateParamCombinations({basePath:i.path,params:i.params,routeId:i.id,paramsOptions:i.paramsOptions,currentIndex:0,currentParams:[],currentOptionIds:[],result:[]});for(const d of u)d.routeMetaData??(d.routeMetaData={}),d.routeMetaData.publishedAt=new Date().toISOString()}}}}function Re({page:e,route:n,state:t,routeId:s,routePathInfo:o}){var i,u,d,a,p,S,f,l,c;E.info(`Executing datasource data assembly, routeId: ${s}, routePathInfo: ${JSON.stringify(o)}`);const r={...Bt.cloneDeep(e),id:s,slug:(o==null?void 0:o.path)??n.path,createdAt:n.createdAt,updatedAt:((i=o==null?void 0:o.routeMetaData)==null?void 0:i.updatedAt)??n.updatedAt,publishedAt:((u=o==null?void 0:o.routeMetaData)==null?void 0:u.publishedAt)??n.publishedAt,isPublic:(((d=o==null?void 0:o.routeMetaData)==null?void 0:d.isPublic)??n.isPublic)&&n.isPublic};for(const m of t.supportedLocales){if(n.dataSource){let b=n.id;o&&(b=o.paramOptionIds.join("-"));const _=((S=(p=(a=n.dataSource.pathDataMappings)==null?void 0:a[b])==null?void 0:p.dataCache)==null?void 0:S[m.locale])??((c=(l=(f=n.dataSource.pathDataMappings)==null?void 0:f[b])==null?void 0:l.dataCache)==null?void 0:c[t.config.defaultLocale||"en"]);if(!_)continue;Ht.setPageDataSource(r,t,m.locale,_)}o&&o.routeMetaData&&(o.routeMetaData.publishedAt=new Date().toISOString())}return r}const{uploadToMediaKit:Vs}=require("@blocklet/uploader-server"),Se=es.customAlphabet("abcdefghijklmnopqrstuvwxyz0123456789",16),ze=/^\w+(\w|-|\.)+\w+\.(jpe?g|png|gif|svg|bmp|webp|mp4|m4v|webm)$/,le=/mediakit:\/\/([a-f0-9]{32}\.(jpe?g|png|gif|svg|bmp|webp|mp4|m4v|webm))/i,et=/mediakit:\/\/([a-f0-9]{32}\.(jpe?g|png|gif|svg|bmp|webp|mp4|m4v|webm))/gi,Js=1e4,zs=3e4,ge=0,xe=1,Ks=0,Ys=1,$e=O.default,se=y.join(process.env.BLOCKLET_DATA_DIR,"site-state"),Ws=["production","draft"],Qs=["production"];function Oe(e){return(e==null?void 0:e.replace(/\//g,"|"))||""}function Xs(){var t;const e=$e.env.languages.map(s=>({locale:s.code,name:s.name})),n=(t=e[0])==null?void 0:t.locale;return{pageIds:[],pages:{},routeIds:[],routes:{},dataSourceIds:[],dataSources:{},components:{},supportedLocales:e,config:{defaultLocale:n},resources:{}}}const j=class j extends V.Doc{constructor(t){super();k(this,"syncedStore");k(this,"conns",new Map);k(this,"awareness");k(this,"releaseTimer");k(this,"awarenessChangeHandler",({added:t,updated:s,removed:o},r)=>{const i=t.concat(s,o);if(r!==null){const a=this.conns.get(r);a&&(t.forEach(p=>{a.add(p)}),o.forEach(p=>{a.delete(p)}))}const u=x.createEncoder();x.writeVarUint(u,xe),x.writeVarUint8Array(u,ie.encodeAwarenessUpdate(this.awareness,i));const d=x.toUint8Array(u);this.conns.forEach((a,p)=>this.send(p,d))});k(this,"updateHandler",t=>{const s=x.createEncoder();x.writeVarUint(s,ge),ve.writeUpdate(s,t);const o=x.toUint8Array(s);this.conns.forEach((r,i)=>this.send(i,o))});k(this,"ensureDataStructure",()=>{var d;const{supportedLocales:t,pages:s,pageIds:o,config:r,routes:i,routeIds:u}=this.syncedStore;{const a=new Set(Object.keys(s));let p=0;for(;p<o.length;){const S=o[p];a.has(S)?(a.delete(S),p++):o.splice(p,1)}}{const a=new Set(Object.keys(i));let p=0;for(;p<u.length;){const S=u[p];a.has(S)?(a.delete(S),p++):u.splice(p,1)}}t.splice(0,t.length),t.push(...$e.env.languages.map(a=>({locale:a.code,name:a.name}))),r.defaultLocale=(d=t[0])==null?void 0:d.locale;{let a=0;const p=new Set;for(;a<t.length;){const{locale:S}=t[a];p.has(S)?t.splice(a,1):(a++,p.add(S))}}});k(this,"send",(t,s)=>{t.readyState!==Ks&&t.readyState!==Ys&&this.closeConn(t);try{t.send(s,o=>{o&&this.closeConn(t)})}catch{this.closeConn(t)}});k(this,"closeConn",t=>{if(t.removeAllListeners(),this.conns.has(t)){const s=this.conns.get(t);this.conns.delete(t),s&&ie.removeAwarenessStates(this.awareness,Array.from(s),null)}t.close(),this.checkAndScheduleRelease()});k(this,"autoSave",it.default(()=>{w.mkdirSync(y.dirname(this.draftYjsFilePath),{recursive:!0}),w.writeFileSync(this.draftYjsFilePath,V.encodeStateAsUpdate(this))},Js));k(this,"save",({flush:t=!1}={})=>{this.autoSave(),t&&this.autoSave.flush()});k(this,"publish",async({mode:t,routes:s})=>{const o=await this.getState("draft"),r=await this.getState("production");await qe(o,r,{routes:s,mergeMode:"replace",deleteRoutes:!0,publishMode:t}),r.config.publishedAt=new Date().getTime(),Gs(this.syncedStore,s),await this.setState(t,r)});k(this,"mergeState",async(t,s)=>{var u,d,a;const o=JSON.parse(JSON.stringify(s));(u=t.config).fontFamily??(u.fontFamily={});const r=(d=o.config)==null?void 0:d.fontFamily,i=(a=t.config)==null?void 0:a.fontFamily;t.config.fontFamily.title=(r==null?void 0:r.title)||(i==null?void 0:i.title),t.config.fontFamily.description=(r==null?void 0:r.description)||(i==null?void 0:i.description),await new Promise((p,S)=>{this.transact(async()=>{try{const f=await qe(t,s);p(f)}catch(f){S(f)}})})});k(this,"addConnection",t=>{if(this.conns.has(t))return;this.cancelRelease(),t.binaryType="arraybuffer",this.conns.set(t,new Set),t.on("message",r=>this.messageListener(t,new Uint8Array(r)));let s=!0;const o=setInterval(()=>{if(!s)this.conns.has(t)&&this.closeConn(t),clearInterval(o);else if(this.conns.has(t)){s=!1;try{t.ping()}catch{this.closeConn(t),clearInterval(o)}}},zs);t.on("close",()=>{this.closeConn(t),clearInterval(o)}),t.on("pong",()=>{s=!0});{const r=x.createEncoder();x.writeVarUint(r,ge),ve.writeSyncStep1(r,this),this.send(t,x.toUint8Array(r));const i=this.awareness.getStates();if(i.size>0){const u=x.createEncoder();x.writeVarUint(u,xe),x.writeVarUint8Array(u,ie.encodeAwarenessUpdate(this.awareness,Array.from(i.keys()))),this.send(t,x.toUint8Array(u))}}});k(this,"messageListener",(t,s)=>{try{const o=x.createEncoder(),r=ke.createDecoder(s),i=ke.readVarUint(r);switch(i){case ge:x.writeVarUint(o,ge),ve.readSyncMessage(r,o,this,null),x.length(o)>1&&(this.ensureDataStructure(),this.send(t,x.toUint8Array(o)));break;case xe:{ie.applyAwarenessUpdate(this.awareness,ke.readVarUint8Array(r),t);break}default:E.warn(`Unsupported messageType ${i}`)}}catch(o){E.error(o)}this.save()});this.options=t,w.existsSync(this.draftYjsFilePath)&&V.applyUpdate(this,w.readFileSync(this.draftYjsFilePath)),this.syncedStore=Gt.reactive(ee.syncedStore({pages:{},pageIds:[],components:{},supportedLocales:[],config:{},resources:{},routeIds:[],routes:{},dataSourceIds:[],dataSources:{}},this)),this.initObserver(),this.on("update",this.updateHandler),this.awareness=new ie.Awareness(this),this.awareness.on("update",this.awarenessChangeHandler),this.ensureDataStructure()}static safeDeleteProjectStateDir(t){if(!t)throw new Error("Should provide project context");try{const s=y.join(se,t),o=y.join(se,`@del-${t}`);w.renameSync(s,o)}catch(s){E.error("Failed to safe delete project state dir:",s)}}static get projectIds(){return Ne.globSync("*/",{cwd:se,ignore:["@del-*","@tmp-*",".*","staging","production","@backup-*"]})}static get allShared(){return this.projectIds.map(t=>j.shared(t))}static shared(t){if(!t)throw new Error("Should provide project context");let s=j.sharedInstances[t];return s||(s=new j({path:y.join(se,t)}),j.sharedInstances[t]=s,Pt({projectId:t,pages:Te,components:Pe}),s)}static async getProductionState(t){var o,r;let s=j.productionStates.get(t);if(!s){const i=y.join(se,t,"production");if(s=await Ke(i,{includeResources:!0})??Xs(),!((o=s==null?void 0:s.config)!=null&&o.defaultLocale)){s.config??(s.config={});const u=$e.env.languages.map(d=>({locale:d.code,name:d.name}));s.config.defaultLocale=(r=u[0])==null?void 0:r.locale}j.productionStates.set(t,s)}return{...s,resources:await je().then(async i=>{var S,f;const{pages:u,components:d}=ms.default(i,"pages","components");let a=d;const p=await K.findByPk(t);if(p!=null&&p.useAllResources)a=d;else{const c=(await Ce.findAll({where:{projectId:t}})).map(b=>b.componentId);a=Object.fromEntries(Object.entries(d||{}).filter(([b])=>c.includes(b)))}return Object.keys(((S=s==null?void 0:s.resources)==null?void 0:S.components)||{}).length>0&&(a={...a,...(f=s==null?void 0:s.resources)==null?void 0:f.components}),{pages:u,components:a}}).catch(()=>({}))}}destroy(){this.cancelRelease(),this.save({flush:!0}),this.conns.forEach((s,o)=>this.closeConn(o)),this.awareness.destroy();const t=y.basename(this.options.path);delete j.sharedInstances[t],super.destroy()}initObserver(){Hs(this.syncedStore),Bs(this.syncedStore)}get draftYjsFilePath(){return y.join(this.options.path,"draft.yjs")}static async getStateByProjectId(t,s){if(s==="draft"){const o=j.shared(t);return JSON.parse(JSON.stringify(o.syncedStore))}return j.getProductionState(t)}async getState(t){if(t==="draft")return JSON.parse(JSON.stringify(this.syncedStore));const s=y.basename(this.options.path);return j.getProductionState(s)}async setState(t,s){const o=await It(s,{exportAssets:!1,includeResources:!0}),r=this.getPublishDir(t);if(w.mkdirSync(y.dirname(r),{recursive:!0}),w.rmSync(r,{force:!0,recursive:!0}),w.renameSync(o,r),t==="production"){const i=y.basename(this.options.path);j.productionStates.set(i,s)}}getPublishDir(t){return y.join(this.options.path,t)}checkAndScheduleRelease(){this.conns.size===0&&this.scheduleRelease()}scheduleRelease(){this.cancelRelease();const t=y.basename(this.options.path);this.releaseTimer=setTimeout(()=>{E.info(`[SiteState] releasing instance due to no active connections: ${t}`),this.conns.size===0&&(this.releaseTimer=void 0,this.destroy())},j.RELEASE_DELAY),E.info(`[SiteState] scheduled release for project ${t} in ${j.RELEASE_DELAY/1e3}s`)}cancelRelease(){if(this.releaseTimer){clearTimeout(this.releaseTimer),this.releaseTimer=void 0;const t=y.basename(this.options.path);E.info(`[SiteState] cancelled scheduled release for project ${t}`)}}static async pageUrlMap(t,s){var i,u;let{projectIds:o}=this;s&&(o=[s]);const r={};for(const d of o){const a=await K.findByPk(d);if(!a)continue;const p=await j.getStateByProjectId(d,t),S=a.slug||d,f=gs.default(O.default.env.languages.map(c=>c.code),p.supportedLocales.map(c=>c.locale)),l=(c,m)=>{S&&(r[$.joinURL("/",S,c)]={...m,shouldRedirect:!0,mainPage:!0}),r[$.joinURL("/",d,c)]={...m,shouldRedirect:!0,mainPage:!0};for(const b of f){const _={...m,locale:b};r[$.joinURL("/",b,d,c)]=_,S&&(r[$.joinURL("/",b,S,c)]=_)}};if(t==="draft")for(const c of p.routeIds||[]){const m=(i=p==null?void 0:p.routes)==null?void 0:i[c];if(!m)continue;if(m.params&&m.params.length>0){const T=Ee.generateParamCombinations({basePath:m.path,params:m.params,routeId:m.id,paramsOptions:m.paramsOptions,currentIndex:0,currentParams:[],currentOptionIds:[],result:[]});for(const M of T){const Y=M.path,te={projectId:d,projectSlug:S,pageSlug:Y,pageId:m.displayTemplateId||"",routeId:c,defaultLocale:f==null?void 0:f[0],locales:f,publishedAt:p.config.publishedAt,isPublic:m.isPublic&&((u=M==null?void 0:M.routeMetaData)==null?void 0:u.isPublic)};l(Y,te)}}const b=m.path,_={projectId:d,projectSlug:S,pageSlug:b,pageId:m.displayTemplateId||"",routeId:c,defaultLocale:f==null?void 0:f[0],locales:f,publishedAt:p.config.publishedAt,isPublic:m.isPublic};l(b,_)}for(const c of p.pageIds){const m=p.pages[c];if(!m||t==="production"&&!m.isPublic)continue;const b=m.slug,_=a.slug||d,T={projectId:d,projectSlug:_,pageSlug:b,pageId:c,defaultLocale:f==null?void 0:f[0],locales:f,publishedAt:p.config.publishedAt,isPublic:m.isPublic,templateConfig:m.templateConfig};l(b,T)}}return r}getDocumentSize(){return V.encodeStateAsUpdate(this).byteLength}static getInstancesSizeInfo(){const t=[];for(const[s,o]of Object.entries(j.sharedInstances)){const r=o.getDocumentSize();t.push({projectId:s,sizeInBytes:r,sizeInMB:`${(r/(1024*1024)).toFixed(2)} MB`,activeConnections:o.conns.size})}return t}static startPeriodicCheck(){this.periodicCheckTimer||(this.periodicCheckTimer=setInterval(()=>{this.performPeriodicCheck()},this.PERIODIC_CHECK_INTERVAL),E.info(`[SiteState] periodic check started, interval: ${this.PERIODIC_CHECK_INTERVAL/(60*60*1e3)} hours`))}static stopPeriodicCheck(){this.periodicCheckTimer&&(clearInterval(this.periodicCheckTimer),this.periodicCheckTimer=void 0,E.info("[SiteState] periodic check stopped"))}static performPeriodicCheck(){const t=Object.keys(j.sharedInstances).length,s=[],o=[];for(const[r,i]of Object.entries(j.sharedInstances))i.conns.size===0?s.push({projectId:r,instance:i}):o.push({projectId:r,connections:i.conns.size});if(E.info(`[SiteState] periodic check summary: total instances: ${t}, with connections: ${o.length}, without connections: ${s.length}`),s.length>0){E.info(`[SiteState] releasing ${s.length} instances without connections:`,s.map(i=>i.projectId));let r=0;for(const{projectId:i,instance:u}of s)try{E.info(`[SiteState] releasing instance due to periodic check: ${i}`),u.destroy(),r++}catch(d){E.error(`[SiteState] failed to release instance ${i} during periodic check:`,d)}E.info(`[SiteState] periodic check completed: ${r}/${s.length} instances released successfully`)}else t>0?E.debug("[SiteState] periodic check: all instances have active connections"):E.debug("[SiteState] periodic check: no instances exist")}};k(j,"PRODUCTION_CACHE_TTL",7*24*60*60*1e3),k(j,"RELEASE_DELAY",5*60*1e3),k(j,"PERIODIC_CHECK_INTERVAL",2*60*60*1e3),k(j,"sharedInstances",{}),k(j,"productionStates",new He.LRUCache({max:100,ttl:j.PRODUCTION_CACHE_TTL})),k(j,"periodicCheckTimer");let z=j;async function Zs(e,n,t){if(!e||!w.existsSync(e)||!w.lstatSync(e).isFile())return null;let s=t[e];return s||(s=(async()=>{var o;try{const r=(o=await Vs({filePath:e,fileName:n}))==null?void 0:o.data;return r==null?void 0:r.filename}catch(r){return E.error(`Failed to upload asset ${e}:`,r),null}})(),t[e]=s),s}const wt=async(e,n)=>{const t=y.basename(e),s=await Be.call({name:Je,path:$.joinURL("/uploads",t),responseType:"stream",method:"GET"});if(s.status>=200&&s.status<400){const o=w.createWriteStream(n);await ss.pipeline(s.data,o)}else throw new Error(`download asset failed ${s.status}`)},Et=async(e,n)=>{await Promise.all(e.map(async t=>{try{await wt(t,y.join(n,y.basename(t)))}catch(s){E.error(`Failed to export assets: ${t}, ${s}`)}}))};function bt(e){return ze.test(e)?[e]:le.test(e)?(et.lastIndex=0,Array.from(e.matchAll(et)).map(t=>t[1]).filter(t=>!!t)):[]}async function he(e,n,t){const{getFilename:s,exportAssets:o}=t,r=y.join(n,s(e));if(w.mkdirSync(y.dirname(r),{recursive:!0}),w.writeFileSync(r,ne.stringify(e)),o){const u=Ie(e,d=>typeof d=="string"&&(ze.test(d)||le.test(d))).map(d=>{const a=Ge.default(e,d);return bt(a)}).flat().filter(Boolean);await Et(u,y.dirname(r))}}const tt=new He.LRUCache({max:20,ttl:30*24*60*60*1e3});async function st(e,n,t){var u;const s=Ie(e,d=>typeof d=="string"&&(ze.test(d)||le.test(d))),o=hs.default(2),r=s.map(d=>o(async()=>{try{const a=Ge.default(e,d),p=bt(a);for(const S of p){const f=y.basename(S),l=t.getFilePath(S,d),c=l?`${l}:${f}`:f,m=tt.get(c);if(m){le.test(a)||Qe.default(e,d,m);return}const b=await Zs(l,f,n);b&&(le.test(a)||Qe.default(e,d,b),tt.set(c,b))}}catch(a){E.error(`Failed to process upload for path ${d.join(".")}:`,a.message||a.reason)}})),i=await Promise.allSettled(r);(u=t.onFinish)==null||u.call(t,i)}async function It(e,{exportAssets:n,pageIds:t="all",componentIds:s="all",rawConfig:o,includeResources:r=!1,routeIds:i="all"}={}){var re,I,g,C,D,W,A,L,H,Q,J,ae;const u=t==="all"?e.pageIds:t,d=de.getComponentDependencies({state:e,pageIds:u,componentIds:s==="all"?Object.keys(e.components):s}),a=i==="all"?e.routeIds:i,p=h=>({id:h.id,name:h.name,isTemplateSection:h.isTemplateSection??!1,templateDescription:h.templateDescription,llmConfig:h.llmConfig,component:h.component,config:h.config,visibility:h.visibility,sections:h.sections,sectionIds:h.sectionIds}),S=(h,P)=>{var R;return{id:h.id,createdAt:h.createdAt,updatedAt:h.updatedAt,publishedAt:h.publishedAt,isPublic:h.isPublic??!0,templateConfig:h.templateConfig,meta:((R=h.locales)==null?void 0:R[P])??{},sections:q(h.sectionIds.map(B=>{const U=h.sections[B];return U&&p(U)})),dataSource:Object.fromEntries(Object.entries(h.dataSource||{}).map(([B,U])=>[B,(U==null?void 0:U[P])??{}]))}},f=h=>({id:h.id,createdAt:h.createdAt,updatedAt:h.updatedAt,publishedAt:h.publishedAt,path:h.path,handler:h.handler,isPublic:h.isPublic??!0,params:h.params??[],enabledGenerate:h.enabledGenerate??!1,displayTemplateId:h.displayTemplateId,dataSource:h.dataSource}),l=q(a.map(h=>{const P=e.routes[h];return P&&f(P)})),c=q(e.supportedLocales.map(h=>h.locale).flatMap(h=>u.map(P=>{const R=e.pages[P];return R&&{locale:h,slug:R.slug,page:S(R,h)}}))),m=St(),b=y.join(m,"pages");w.mkdirSync(b,{recursive:!0});const _=y.join(m,"components");w.mkdirSync(_,{recursive:!0});const T=y.join(m,"routes");w.mkdirSync(T,{recursive:!0});for(const{locale:h,slug:P,page:R}of c)await he(R,b,{getFilename:()=>`${Oe(P)||"index"}.${h}.yml`,exportAssets:n});for(const h of l)await he(h,T,{getFilename:()=>`${Oe(h.path)||"index"}.yml`,exportAssets:n});for(const h of d){const P=(re=e.components[h])==null?void 0:re.data;P&&await he(P,_,{getFilename:R=>`${R.name||"unnamed"}.${R.id}.yml`,exportAssets:n})}const M=y.join(m,".blocklet/pages/pages.config.yml");w.mkdirSync(y.dirname(M),{recursive:!0});const Y={pages:q(u.map(h=>{const P=e.pages[h];return P&&{id:h,slug:P.slug}})),routes:q(a.map(h=>{const P=e.routes[h];return P&&{id:h,path:P.path}})),components:q(d.map(h=>{var R;const P=(R=e.components[h])==null?void 0:R.data;return P&&{id:h,name:P.name}})),...r?{resources:{components:q(Object.keys(((I=e.resources)==null?void 0:I.components)||{}).filter(h=>d.includes(h)).map(h=>{var P,R,B,U;return{id:h,name:(U=(B=(R=(P=e.resources)==null?void 0:P.components)==null?void 0:R[h])==null?void 0:B.component)==null?void 0:U.name}}))}}:{},supportedLocales:e.supportedLocales,config:e.config};w.writeFileSync(M,ne.stringify(Y));const te=y.join(m,"config.source.json");if(o&&w.writeFileSync(te,JSON.stringify(o)),r){const h=y.join(m,"resources"),P=y.join(h,"components");w.mkdirSync(P,{recursive:!0});for(const U of Object.keys(((g=e==null?void 0:e.resources)==null?void 0:g.components)??{}).filter(G=>d.includes(G))){const G=(W=(D=(C=e.resources)==null?void 0:C.components)==null?void 0:D[U])==null?void 0:W.component;G&&await he(G,P,{getFilename:X=>`${X.name||"unnamed"}.${X.id}.yml`,exportAssets:n})}const R=y.join(m,"chunks");w.mkdirSync(R,{recursive:!0});const{chunks:B}=await je();for(const U of Object.keys(((A=e==null?void 0:e.resources)==null?void 0:A.components)??{}).filter(G=>d.includes(G))){const G=(Q=(H=(L=e.resources)==null?void 0:L.components)==null?void 0:H[U])==null?void 0:Q.component;if(G&&((J=G.renderer)==null?void 0:J.type)==="react-component"){const X=((ae=G.renderer)==null?void 0:ae.chunks)??[];if((X==null?void 0:X.length)>0)for(const De of X){const We=y.join(R,De),_e=B==null?void 0:B[De];try{_e&&w.existsSync(_e)&&!w.existsSync(We)&&w.copyFileSync(_e,We)}catch(jt){E.error(`copy chunk ${De} error`,jt.message)}}}}}return m}async function Ke(e,{importAssets:n,includeResources:t}={}){var r,i,u,d;if(!w.existsSync(e))return null;let s,o=!1;try{w.lstatSync(e).isDirectory()?s=e:/\.(tgz|gz|tar)$/.test(e)&&(o=!0,s=St(),await ns.x({file:e,C:s}));const a=Ne.globSync("**/.blocklet/pages/pages.config.yml",{cwd:s,absolute:!0}).at(0),p=a&&y.join(y.dirname(a),"../../pages"),S=a&&y.join(y.dirname(a),"../../components"),f=a&&y.join(y.dirname(a),"../../chunks"),l=a&&y.join(y.dirname(a),"../../routes");if(!a)return null;const c=ne.parse(w.readFileSync(a).toString()),m=(I,g,C)=>{let D=y.join(I,`${g}${C?`.${C}`:""}.yml`);return(!w.existsSync(D)||!w.lstatSync(D).isFile())&&(D=y.join(I,g,`index${C?`.${C}`:""}.yml`),!w.existsSync(D)||!w.lstatSync(D))?null:ne.parse(w.readFileSync(D).toString())},b=(I,g)=>{try{const C=Ne.globSync(`*.${g}.yml`,{cwd:I,absolute:!0})[0];return C?ne.parse(w.readFileSync(C).toString()):null}catch(C){E.error("parse component error",C)}return null},_=(I,g)=>{let C=y.join(I,`${g}.yml`);return(!w.existsSync(C)||!w.lstatSync(C).isFile())&&(C=y.join(I,g,"index.yml"),!w.existsSync(C)||!w.lstatSync(C))?null:ne.parse(w.readFileSync(C).toString())},T=q(c.pages.map(({slug:I})=>{var W;const g=q(c.supportedLocales.map(({locale:A})=>{const L=p?m(p,Oe(I),A):void 0;if(L)return{locale:A,page:L};const H=p?m(p,I,A):void 0;return H&&{locale:A,page:H}})),C=(W=g[0])==null?void 0:W.page;if(!C)return null;const D=C.sections.map(A=>({id:A.id||Se(),component:A.component,config:A.config,name:A.name,isTemplateSection:A.isTemplateSection??!1,templateDescription:A.templateDescription,llmConfig:A.llmConfig,visibility:A.visibility,sections:A.sections,sectionIds:A.sectionIds}));return{id:C.id||Se(),createdAt:C.createdAt,updatedAt:C.updatedAt,publishedAt:C.publishedAt,isPublic:C.isPublic??!0,templateConfig:C.templateConfig,slug:I,sections:Object.fromEntries(D.map(A=>[A.id,A])),sectionIds:D.map(A=>A.id),locales:Object.fromEntries(g.map(({locale:A,page:L})=>[A,L.meta])),dataSource:C.dataSource?Object.fromEntries([...new Set(g.flatMap(({page:A})=>Object.keys(A.dataSource??{})))].map(A=>[A,Object.fromEntries(g.map(({locale:L,page:H})=>{var J;const Q=(J=H.dataSource)==null?void 0:J[A];return[L,Q||{}]}))])):Object.fromEntries([...new Set(g.flatMap(({page:A})=>A.sections.map(L=>L.id)))].map(A=>[A,Object.fromEntries(g.map(({locale:L,page:H})=>{var ae;const Q=(ae=H.dataSource)==null?void 0:ae[A];if(Q)return[L,Q];const J=H.sections.find(h=>h.id===A);return[L,(J==null?void 0:J.properties)||{}]}))]))}})),M=q(((r=c==null?void 0:c.routes)==null?void 0:r.map(({path:I})=>{const g=l?_(l,Oe(I)):void 0;return{...g,id:(g==null?void 0:g.id)||Se(),createdAt:(g==null?void 0:g.createdAt)??new Date().toISOString(),updatedAt:(g==null?void 0:g.updatedAt)??new Date().toISOString(),publishedAt:new Date(0).toISOString(),path:(g==null?void 0:g.path)??`/${g==null?void 0:g.id}`,params:g==null?void 0:g.params,handler:(g==null?void 0:g.handler)??"Pages Kit",isPublic:(g==null?void 0:g.isPublic)??!0,enabledGenerate:(g==null?void 0:g.enabledGenerate)??!1,displayTemplateId:(g==null?void 0:g.displayTemplateId)??void 0,dataSource:(g==null?void 0:g.dataSource)??{}}}))??[]),Y=S?q(((i=c.components)==null?void 0:i.map(({id:I})=>b(S,I)))??[]):[];if(n){const I=(...g)=>{E.info(`[${o?y.basename(e):y.basename(y.join(e,"../../../../"))}] importAssets:`,...g)};try{I("wait image-bin api ready"),await ys.default({resources:[`${Be.getComponentWebEndpoint(Ss)}/api/sdk/uploads`],validateStatus:D=>D>=200&&D<=500}),I("image-bin api is ready");const g={},C={};I("start to upload assets"),await Promise.allSettled([st(Y,g,{getFilePath:D=>S&&y.join(S,D),onFinish:D=>{I(`upload ${D.length} component assets`)}}),st(T,C,{getFilePath:(D,W)=>{const A=Ge.default(T,W.slice(0,1));return p&&y.join(p,y.dirname(A.slug),D)},onFinish:D=>{I(`upload ${D.length} page assets`)}})]),I("upload assets done"),global.gc&&global.gc()}catch(g){I("Error during asset import:",g)}}const te={};if(t){const I=a&&y.join(y.dirname(a),"../../resources/components"),g=q(((d=(u=c.resources)==null?void 0:u.components)==null?void 0:d.map(({id:C})=>b(I,C)))??[]);g.length>0&&(te.components=Object.fromEntries(g.map((C,D)=>[C.id,{index:D,component:C}])))}const re={};if(f&&w.existsSync(f)){const I=w.readdirSync(f);for(const g of I)re[g]=y.join(f,g)}return{supportedLocales:c.supportedLocales,pageIds:T.map(I=>I.id),components:Object.fromEntries(Y.map((I,g)=>[I.id,{index:g,data:I}])),pages:Object.fromEntries(T.map(I=>[I.id,I])),config:c.config||{},resources:te,chunks:re,routeIds:M.map(I=>I.id),routes:Object.fromEntries(M.map(I=>[I.id,I])),dataSourceIds:[],dataSources:{}}}finally{o&&s&&w.rmSync(s,{force:!0,recursive:!0})}}async function qe(e,n,{routes:t,mergeMode:s="byUpdateTime",deleteRoutes:o=!1,publishMode:r=void 0}={}){try{r&&ft(r)}catch(f){E.error("clear preload page cache error",{error:f})}const{pages:i,pageIds:u,routeIds:d,routes:a,supportedLocales:p}=e;if(r==="production"){let f=t??[],l=null;for(const c of d??[]){const m=a==null?void 0:a[c];if(m!=null&&m.params&&(m==null?void 0:m.params.length)>0&&(m!=null&&m.paramsOptions)&&(m==null?void 0:m.paramsOptions.length)>0){const b=Ee.generateParamCombinations({basePath:m.path,params:m.params,routeId:m.id,paramsOptions:m.paramsOptions,currentIndex:0,currentParams:[],currentOptionIds:[],result:[]}),_=Object.fromEntries(b.map(T=>[`${c}-${T.paramOptionIds.join("-")}`,T]));l={...l||{},..._},t||(f=[...f,...b.map(T=>`${c}-${T.paramOptionIds.join("-")}`)])}else t||f.push(c)}E.info("routeIds to be published: ",f);for(const c of f){let m=c;if(m.includes("-")){const[T]=m.split("-");m=T}const b=a==null?void 0:a[m];if(!b){const T=n.pageIds.indexOf(m);T!==-1&&o&&(n.pageIds.splice(T,1),delete n.pages[m]);for(const M of n.pageIds)M.includes(`${m}-`)&&(n.pageIds.splice(n.pageIds.indexOf(M),1),delete n.pages[M]);E.info("delete main route page",m);continue}if(c.includes("-")&&!(l!=null&&l[c])){const T=n.pageIds.indexOf(c);T!==-1&&o&&(n.pageIds.splice(T,1),delete n.pages[c]),E.info("delete page",c);continue}if(!b.displayTemplateId){E.info("no display template",c);continue}const _=i[b.displayTemplateId];if(!_){E.info("no template page",c);continue}if(n.pageIds.includes(c)){if(E.info("has need update page",c),s==="replace")n.pages[c]=Re({page:_,route:b,state:e,routeId:c,routePathInfo:l==null?void 0:l[c]}),E.info("replace page",c);else if(s==="byUpdateTime"){const T=n.pages[b.id];(!T||b.updatedAt&&b.updatedAt>T.updatedAt)&&(n.pages[c]=Re({page:_,route:b,state:e,routeId:c,routePathInfo:l==null?void 0:l[c]}),E.info("replace page by update time",c))}}else n.pageIds.push(c),n.pages[c]=Re({page:_,route:b,state:e,routeId:c,routePathInfo:l==null?void 0:l[c]}),E.info("add page",c)}if(o&&!t)for(const c of n.pageIds)f!=null&&f.includes(c)||(delete n.pages[c],E.info("delete page",c)),n.pageIds=[...n.pageIds].filter(m=>f==null?void 0:f.includes(m))}else{for(const f of u){const l=i[f];if(l)if(n.pageIds.includes(l.id)){if(s==="replace")n.pages[l.id]=l;else if(s==="byUpdateTime"){const c=n.pages[l.id];(!c||l.updatedAt&&l.updatedAt>c.updatedAt)&&(n.pages[l.id]=l)}}else n.pageIds.push(l.id),n.pages[l.id]=l}for(const f of d){const l=a[f];if(l)if(n.routeIds.includes(l.id)){if(s==="replace")n.routes[l.id]=l;else if(s==="byUpdateTime"){const c=n.routes[l.id];(!c||l.updatedAt&&l.updatedAt>c.updatedAt)&&(n.routes[l.id]=l)}}else n.routeIds.push(l.id),n.routes[l.id]=l}}if(n.supportedLocales.splice(0,n.supportedLocales.length),n.supportedLocales.push(...fs.default(p)),o)for(const f of Object.keys(n.components))delete n.components[f];let S=JSON.parse(JSON.stringify(e.components));S=Object.fromEntries(await Promise.all(Object.entries(S).map(async([f,l])=>{const c=await Ot(l==null?void 0:l.data);return[f,{...l,data:c}]}))),Object.assign(n.components,S),Object.assign(n.config,JSON.parse(JSON.stringify(e.config))),ct.default(e.resources.components)||(n.resources.components=JSON.parse(JSON.stringify(e.resources.components||{})))}const Ot=Ve(async e=>{var n;if(!ct.default(e==null?void 0:e.properties))return e;if(((n=e==null?void 0:e.renderer)==null?void 0:n.type)==="react-component"){const{script:t}=(e==null?void 0:e.renderer)||{};if(t&&t.includes("PROPERTIES_SCHEMA"))try{const s=await yt(t,"PROPERTIES_SCHEMA",e.id);s&&s.length>0&&e&&(e.properties={},s.forEach((o,r)=>{e!=null&&e.properties&&(e.properties[o.id]={index:r,data:o})}))}catch(s){E.error("checkPropertiesFromCode error",{componentId:e.id,name:e.name},{error:s})}}return e},{keyGenerator:e=>{var a,p,S,f;const n=(e==null?void 0:e.id)||"",t=(e==null?void 0:e.name)||"",s=((a=e==null?void 0:e.renderer)==null?void 0:a.type)||"",o=(e==null?void 0:e.properties)||{},r=(e==null?void 0:e.updatedAt)||"",i=Z.createHash("md5").update(JSON.stringify(o)).digest("hex");let u="",d="";return((p=e==null?void 0:e.renderer)==null?void 0:p.type)==="react-component"&&(u=Z.createHash("md5").update(((S=e==null?void 0:e.renderer)==null?void 0:S.script)||"").digest("hex"),d=Z.createHash("md5").update(((f=e==null?void 0:e.renderer)==null?void 0:f.editComponent)||"").digest("hex")),JSON.stringify(["checkPropertiesFromCode",n,t,s,i,r,u,d])},lruOptions:{max:100,ttl:1e3*60*60},subdir:"checkPropertiesFromCode"});let Ae,oe,Te,Pe,Ye;function At(){return Ae=(async()=>{const e=Be.getResources({types:[{did:Je,type:Ue},{did:qs,type:Ue}]});oe=(await Promise.all(e.map(async t=>{const s=t.path?await Ke(t.path,{importAssets:!1}):void 0;return s?{blockletId:t.did,state:s,blockletTitle:t.title}:void 0}))).filter(t=>!!t),Te=oe.reduce((t,s)=>Object.assign(t,Object.fromEntries(Object.values(s.state.pages).map(o=>o?[o==null?void 0:o.id,{page:o,blockletId:s.blockletId}]:[]))),{});const n=oe.reduce((t,s)=>Object.assign(t,Object.fromEntries(Object.values(s.state.components).map(o=>[o.data.id,{blockletId:s.blockletId,component:o.data}]))),{});Pe=Object.fromEntries(await Promise.all(Object.entries(n).map(async([t,s])=>{const o=await Ot(s.component);return[t,{...s,component:o}]}))),Ye=oe.reduce((t,s)=>Object.assign(t,s.state.chunks),{})})(),Ae}function Ct(e){const n=it.default(async()=>{await At().catch(t=>{E.error("load resource states error",{error:t})}),await(e==null?void 0:e({states:oe,pages:Te,components:Pe,chunks:Ye}))},3e3,{leading:!1,trailing:!0});return n(),O.default.events.on(O.default.Events.componentAdded,n),O.default.events.on(O.default.Events.componentRemoved,n),O.default.events.on(O.default.Events.componentStarted,n),O.default.events.on(O.default.Events.componentStopped,n),O.default.events.on(O.default.Events.componentUpdated,n),O.default.events.on(Fe,n),()=>{O.default.events.off(O.default.Events.componentAdded,n),O.default.events.off(O.default.Events.componentRemoved,n),O.default.events.off(O.default.Events.componentStarted,n),O.default.events.off(O.default.Events.componentStopped,n),O.default.events.off(O.default.Events.componentUpdated,n),O.default.events.off(Fe,n)}}const Tt=Symbol.for("GLOBAL_RESOURCE_STATES_LISTENER_KEY"),we=globalThis;var nt;(nt=we[Tt])==null||nt.call(we);we[Tt]=Ct(async({pages:e,components:n})=>{const{projectIds:t}=z;E.info(`start update resource states projects(${t.length})`,t),await Promise.race([new Promise(s=>{setTimeout(()=>{s({})},30*1e3)}),Promise.all(t.map(async s=>{Pt({projectId:s,pages:e,components:n})}))]).catch(s=>{E.error("update resource states failed:",s)})});z.startPeriodicCheck();process.on("beforeExit",()=>{z.stopPeriodicCheck()});process.on("SIGINT",()=>{z.stopPeriodicCheck(),process.exit(0)});process.on("SIGTERM",()=>{z.stopPeriodicCheck(),process.exit(0)});async function Pt({projectId:e,pages:n,components:t}){const s=z.sharedInstances[e];if(!s){E.info(`projectId: ${e} not found in sharedInstances`);return}s.syncedStore.resources.pages=n;const o=await K.findByPk(e);if(o!=null&&o.useAllResources)s.syncedStore.resources.components=t;else{const i=(await Ce.findAll({where:{projectId:e}})).map(d=>d.componentId),u=Object.fromEntries(Object.entries(t||{}).filter(([d])=>i.includes(d)));s.syncedStore.resources.components=u}E.info(`update [${e}] resource states:`,{pages:Object.keys(s.syncedStore.resources.pages||{}).length,components:Object.keys(s.syncedStore.resources.components||{}).length})}async function en(){E.info("trigger reload all project resource"),O.default.events.emit(Fe)}async function je({ensureLoaded:e=!0}={}){return e&&(Ae??(Ae=At()),await Ae),{states:oe,pages:Te,components:Pe,chunks:Ye}}exports.COMPONENT_DID=Je;exports.CUSTOM_COMPONENT_CACHE_DURATION_IN_SECONDS=ut;exports.GET_SERVER_SIDE_PROPS_TIMEOUT_IN_SECONDS=Me;exports.PUBLISH_MODES=Qs;exports.Project=K;exports.RESOURCE_TYPE=Ue;exports.SITE_STATE_PATH=se;exports.STATE_MODES=Ws;exports.SiteState=z;exports.clearPreloadComponentsCache=pt;exports.clearPreloadComponentsCacheByMode=ft;exports.downloadAsset=wt;exports.downloadAssets=Et;exports.fromPackage=Ke;exports.getComponentFromState=pe;exports.getComponentFromStateByName=Us;exports.getExportSchemaValueFromCode=yt;exports.getMultiTenantAllProjectAccessPassports=bs;exports.getPreloadComponent=gt;exports.getPreloadComponents=Ns;exports.getPreloadComponentsCacheKey=mt;exports.getResourceStates=je;exports.initPackResourceStates=Ct;exports.isMultiTenant=Es;exports.logger=E;exports.mergeState=qe;exports.nextId=Se;exports.toPackage=It;exports.triggerReloadAllProjectResource=en;
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});require("@blocklet/pages-kit/builtin/utils");require("@blocklet/pages-kit/types");require("@blocklet/pages-kit/utils/property");require("@blocklet/quickjs");require("@blocklet/sdk/lib/config");require("lru-cache");require("node-fetch");require("ufo");require("crypto");const e=require("./chunks/site-state-D5jk8eJT.js");exports.CUSTOM_COMPONENT_CACHE_DURATION_IN_SECONDS=e.CUSTOM_COMPONENT_CACHE_DURATION_IN_SECONDS;exports.GET_SERVER_SIDE_PROPS_TIMEOUT_IN_SECONDS=e.GET_SERVER_SIDE_PROPS_TIMEOUT_IN_SECONDS;exports.clearPreloadComponentsCache=e.clearPreloadComponentsCache;exports.clearPreloadComponentsCacheByMode=e.clearPreloadComponentsCacheByMode;exports.getComponentFromState=e.getComponentFromState;exports.getComponentFromStateByName=e.getComponentFromStateByName;exports.getExportSchemaValueFromCode=e.getExportSchemaValueFromCode;exports.getPreloadComponent=e.getPreloadComponent;exports.getPreloadComponents=e.getPreloadComponents;exports.getPreloadComponentsCacheKey=e.getPreloadComponentsCacheKey;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});require("@blocklet/pages-kit/builtin/utils");require("@blocklet/pages-kit/types");require("@blocklet/pages-kit/utils/property");require("@blocklet/quickjs");require("@blocklet/sdk/lib/config");require("lru-cache");require("node-fetch");require("ufo");require("crypto");const e=require("./chunks/site-state-D00xEf4T.js");exports.CUSTOM_COMPONENT_CACHE_DURATION_IN_SECONDS=e.CUSTOM_COMPONENT_CACHE_DURATION_IN_SECONDS;exports.GET_SERVER_SIDE_PROPS_TIMEOUT_IN_SECONDS=e.GET_SERVER_SIDE_PROPS_TIMEOUT_IN_SECONDS;exports.clearPreloadComponentsCache=e.clearPreloadComponentsCache;exports.clearPreloadComponentsCacheByMode=e.clearPreloadComponentsCacheByMode;exports.getComponentFromState=e.getComponentFromState;exports.getComponentFromStateByName=e.getComponentFromStateByName;exports.getExportSchemaValueFromCode=e.getExportSchemaValueFromCode;exports.getPreloadComponent=e.getPreloadComponent;exports.getPreloadComponents=e.getPreloadComponents;exports.getPreloadComponentsCacheKey=e.getPreloadComponentsCacheKey;
@@ -1,4 +1,4 @@
1
- "use strict";const B=require("@arcblock/did-auth-storage-nedb"),O=require("@blocklet/sdk/lib/config"),H=require("@blocklet/sdk/lib/service/auth"),R=require("@blocklet/sdk/lib/wallet"),z=require("@blocklet/sdk/lib/wallet-authenticator"),J=require("@blocklet/sdk/lib/wallet-handler"),P=require("path"),C=require("./chunks/site-state-D5jk8eJT.js"),G=require("@arcblock/crawler-middleware"),Y=require("@blocklet/pages-kit/types"),Q=require("@blocklet/pages-kit/utils/common"),V=require("@blocklet/pages-kit/utils/preload"),X=require("@blocklet/sdk/lib/component"),Z=require("cheerio/slim"),F=require("express"),x=require("fs"),ee=require("lodash/get"),te=require("mustache"),I=require("ufo"),d=n=>n&&n.__esModule?n:{default:n};function ne(n){if(n&&n.__esModule)return n;const t=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(n){for(const e in n)if(e!=="default"){const i=Object.getOwnPropertyDescriptor(n,e);Object.defineProperty(t,e,i.get?i:{enumerable:!0,get:()=>n[e]})}}return t.default=n,Object.freeze(t)}const oe=d(B),a=d(O),ce=d(H),re=d(R),le=d(z),se=d(J),ae=d(P),W=ne(Z),ie=d(ee),de=d(te),ue=(n={})=>{const t={data:new Map,timers:new Map,set:(e,i,h=n.ttl||36e5)=>{n.max&&t.data.size>=n.max&&t.delete(t.data.keys().next().value),t.timers.has(e)&&clearTimeout(t.timers.get(e)),t.timers.set(e,setTimeout(()=>t.delete(e),h)),t.data.set(e,i)},get:e=>t.data.get(e),has:e=>t.data.has(e),delete:e=>(t.timers.has(e)&&clearTimeout(t.timers.get(e)),t.timers.delete(e),t.data.delete(e)),clear:()=>{t.data.clear();for(const e of t.timers.values())clearTimeout(e);t.timers.clear()}};return t},L=ue({max:1,ttl:1e3*30});re.default();const pe=new le.default;new se.default({authenticator:pe,tokenStorage:new oe.default({dbPath:ae.default.join(a.default.env.dataDir,"auth.db")})});const fe=new ce.default,he=async()=>{try{const n=L.get("blockletInfo");if(n)return n;const{blocklet:t}=await fe.getBlocklet();return L.set("blockletInfo",t),t}catch{return null}},me=["/assets/"];function ge({app:n,viteDevServer:t,state:e}){let i;if(t){const o=x.readFileSync(P.resolve(process.cwd(),"./index.html"),"utf-8");n.use(async(b,v,T)=>{const A=b.originalUrl;i=await t.transformIndexHtml(A,o),T()})}else i=x.readFileSync(P.resolve(process.env.BLOCKLET_APP_DIR,"dist/index.html"),"utf-8");const h=F.Router();h.use((o,b,v)=>{if(o.headers["x-unique-record"]==="dial_http"){C.logger.info("[html] dial http request, return 200 status code"),b.status(200).send("ok");return}v()}),a.default.env.preferences.snapkitEnabled&&a.default.env.preferences.snapkitEndpoint&&a.default.env.SNAP_KIT_ACCESS_KEY&&h.use(G.createSnapshotMiddleware({endpoint:a.default.env.preferences.snapkitEndpoint,accessKey:a.default.env.SNAP_KIT_ACCESS_KEY,cacheMax:a.default.env.preferences.snapkitCacheSize||100})),h.get("/:path(*)?",async(o,b,v)=>{var E,M,j;if(me.some(s=>{var p;return(p=o.path)==null?void 0:p.startsWith(s)})){v();return}const T=performance.now(),A=()=>Math.round(performance.now()-T),D="production";let r,m,S=i;if(o.path.startsWith("/pages")){const s=o.params.lang,p=o.cookies.nf_lang,k=new Set([...a.default.env.languages.map(w=>w.code)]);let _=(s&&k.has(s)?s:void 0)||(k.has(p)?p:void 0)||[...k][0];if((!_||!((E=e.supportedLocales)!=null&&E.find(w=>w.locale===_)))&&(_=((j=(M=e.supportedLocales)==null?void 0:M[0])==null?void 0:j.locale)||""),_){const w=[];Object.values(e.pages).forEach(l=>{const N=Object.values((l==null?void 0:l.sections)??{}).filter(f=>{var y;return f.component==="custom-component"&&((y=f.config)==null?void 0:y.componentId)}).map(f=>{var y,$;return{id:f.id,componentId:f.config.componentId,useCache:f.config.useCache,cacheDuration:f.config.cacheDuration,properties:($=(y=l==null?void 0:l.dataSource)==null?void 0:y[f.id])==null?void 0:$[_]}});w.push(...N)});const K=new Promise(l=>{setTimeout(()=>{l({})},90*1e3)});try{await Promise.race([K,C.getPreloadComponents({mode:D,req:o,state:e,locale:_,instances:w,module:Y.PreloadComponentScriptModule.UMD_FN}).then(l=>{l&&(m=V.injectPreloadComponents(l))})])}catch(l){C.logger.warn("getPreloadComponents timeout in promise race, skip inject html elements",l)}}}try{const s=(r==null?void 0:r.title)||a.default.env.appName,p=(r==null?void 0:r.description)||a.default.env.appDescription,k=I.withQuery(I.joinURL(a.default.env.appUrl,"/.well-known/service/blocklet/og.png"),{title:s,description:p});S=de.default.render(i,{ogTitle:s,ogDescription:p,ogImage:_e(r==null?void 0:r.image)||k,pagesPublishedAt:(e==null?void 0:e.config.publishedAt)||new Date().getTime()})}catch{}const c=e==null?void 0:e.config.fontFamily,U=o.query.mode==="draft"||o.url.includes("preview"),g=W.load(S);let u=r==null?void 0:r.backgroundColor;if(u&&Q.isMuiColorKey(u)){const s=await he();u=ie.default(s,`settings.theme.light.palette.${u}`,u)}g("head").find("#injected-head-elements").replaceWith(`
1
+ "use strict";const B=require("@arcblock/did-auth-storage-nedb"),O=require("@blocklet/sdk/lib/config"),H=require("@blocklet/sdk/lib/service/auth"),R=require("@blocklet/sdk/lib/wallet"),z=require("@blocklet/sdk/lib/wallet-authenticator"),J=require("@blocklet/sdk/lib/wallet-handler"),P=require("path"),C=require("./chunks/site-state-D00xEf4T.js"),G=require("@arcblock/crawler-middleware"),Y=require("@blocklet/pages-kit/types"),Q=require("@blocklet/pages-kit/utils/common"),V=require("@blocklet/pages-kit/utils/preload"),X=require("@blocklet/sdk/lib/component"),Z=require("cheerio/slim"),F=require("express"),x=require("fs"),ee=require("lodash/get"),te=require("mustache"),I=require("ufo"),d=n=>n&&n.__esModule?n:{default:n};function ne(n){if(n&&n.__esModule)return n;const t=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(n){for(const e in n)if(e!=="default"){const i=Object.getOwnPropertyDescriptor(n,e);Object.defineProperty(t,e,i.get?i:{enumerable:!0,get:()=>n[e]})}}return t.default=n,Object.freeze(t)}const oe=d(B),a=d(O),ce=d(H),re=d(R),le=d(z),se=d(J),ae=d(P),W=ne(Z),ie=d(ee),de=d(te),ue=(n={})=>{const t={data:new Map,timers:new Map,set:(e,i,h=n.ttl||36e5)=>{n.max&&t.data.size>=n.max&&t.delete(t.data.keys().next().value),t.timers.has(e)&&clearTimeout(t.timers.get(e)),t.timers.set(e,setTimeout(()=>t.delete(e),h)),t.data.set(e,i)},get:e=>t.data.get(e),has:e=>t.data.has(e),delete:e=>(t.timers.has(e)&&clearTimeout(t.timers.get(e)),t.timers.delete(e),t.data.delete(e)),clear:()=>{t.data.clear();for(const e of t.timers.values())clearTimeout(e);t.timers.clear()}};return t},L=ue({max:1,ttl:1e3*30});re.default();const pe=new le.default;new se.default({authenticator:pe,tokenStorage:new oe.default({dbPath:ae.default.join(a.default.env.dataDir,"auth.db")})});const fe=new ce.default,he=async()=>{try{const n=L.get("blockletInfo");if(n)return n;const{blocklet:t}=await fe.getBlocklet();return L.set("blockletInfo",t),t}catch{return null}},me=["/assets/"];function ge({app:n,viteDevServer:t,state:e}){let i;if(t){const o=x.readFileSync(P.resolve(process.cwd(),"./index.html"),"utf-8");n.use(async(b,v,T)=>{const A=b.originalUrl;i=await t.transformIndexHtml(A,o),T()})}else i=x.readFileSync(P.resolve(process.env.BLOCKLET_APP_DIR,"dist/index.html"),"utf-8");const h=F.Router();h.use((o,b,v)=>{if(o.headers["x-unique-record"]==="dial_http"){C.logger.info("[html] dial http request, return 200 status code"),b.status(200).send("ok");return}v()}),a.default.env.preferences.snapkitEnabled&&a.default.env.preferences.snapkitEndpoint&&a.default.env.SNAP_KIT_ACCESS_KEY&&h.use(G.createSnapshotMiddleware({endpoint:a.default.env.preferences.snapkitEndpoint,accessKey:a.default.env.SNAP_KIT_ACCESS_KEY,cacheMax:a.default.env.preferences.snapkitCacheSize||100})),h.get("/:path(*)?",async(o,b,v)=>{var E,M,j;if(me.some(s=>{var p;return(p=o.path)==null?void 0:p.startsWith(s)})){v();return}const T=performance.now(),A=()=>Math.round(performance.now()-T),D="production";let r,m,S=i;if(o.path.startsWith("/pages")){const s=o.params.lang,p=o.cookies.nf_lang,k=new Set([...a.default.env.languages.map(w=>w.code)]);let _=(s&&k.has(s)?s:void 0)||(k.has(p)?p:void 0)||[...k][0];if((!_||!((E=e.supportedLocales)!=null&&E.find(w=>w.locale===_)))&&(_=((j=(M=e.supportedLocales)==null?void 0:M[0])==null?void 0:j.locale)||""),_){const w=[];Object.values(e.pages).forEach(l=>{const N=Object.values((l==null?void 0:l.sections)??{}).filter(f=>{var y;return f.component==="custom-component"&&((y=f.config)==null?void 0:y.componentId)}).map(f=>{var y,$;return{id:f.id,componentId:f.config.componentId,useCache:f.config.useCache,cacheDuration:f.config.cacheDuration,properties:($=(y=l==null?void 0:l.dataSource)==null?void 0:y[f.id])==null?void 0:$[_]}});w.push(...N)});const K=new Promise(l=>{setTimeout(()=>{l({})},90*1e3)});try{await Promise.race([K,C.getPreloadComponents({mode:D,req:o,state:e,locale:_,instances:w,module:Y.PreloadComponentScriptModule.UMD_FN}).then(l=>{l&&(m=V.injectPreloadComponents(l))})])}catch(l){C.logger.warn("getPreloadComponents timeout in promise race, skip inject html elements",l)}}}try{const s=(r==null?void 0:r.title)||a.default.env.appName,p=(r==null?void 0:r.description)||a.default.env.appDescription,k=I.withQuery(I.joinURL(a.default.env.appUrl,"/.well-known/service/blocklet/og.png"),{title:s,description:p});S=de.default.render(i,{ogTitle:s,ogDescription:p,ogImage:_e(r==null?void 0:r.image)||k,pagesPublishedAt:(e==null?void 0:e.config.publishedAt)||new Date().getTime()})}catch{}const c=e==null?void 0:e.config.fontFamily,U=o.query.mode==="draft"||o.url.includes("preview"),g=W.load(S);let u=r==null?void 0:r.backgroundColor;if(u&&Q.isMuiColorKey(u)){const s=await he();u=ie.default(s,`settings.theme.light.palette.${u}`,u)}g("head").find("#injected-head-elements").replaceWith(`
2
2
  ${u?`<meta name="theme-color" content="${u}" /><style>html,body,#app {background-color: ${u};}</style>`:""}
3
3
  ${c!=null&&c.title?`<link rel="preload" as="style" href="https://fonts.googleapis.com/css?family=${c.title}&display=swap">`:""}
4
4
  ${c!=null&&c.description&&(c==null?void 0:c.description)!==(c==null?void 0:c.title)?`<link rel="preload" as="style" href="https://fonts.googleapis.com/css?family=${c.description}&display=swap">`:""}
@@ -1 +1 @@
1
- "use strict";const c=require("./chunks/site-state-D5jk8eJT.js"),M=require("async_hooks"),U=require("express"),F=require("fs"),J=require("joi"),X=require("lodash/groupBy"),W=require("lodash/sortBy"),B=require("path"),$=require("@blocklet/sdk/lib/middlewares/auth"),G=require("@blocklet/sdk/lib/component"),y=t=>t&&t.__esModule?t:{default:t},l=y(F),I=y(J),D=y(X),K=y(W),k=y(B),v=y($);new M.AsyncLocalStorage;const Y=async(t,e,o)=>{var n,s,r,i;try{const{projectId:u}=t.params;if(!u)return o();const f=await c.Project.findByPk(u);if(!f)return e==null?void 0:e.status(404).json({error:"Project not found"});const _=(n=t.user)==null?void 0:n.did,E=((s=t.user)==null?void 0:s.role)||"UNKNOWN_ROLE";if(!_)return e==null?void 0:e.status(401).json({error:"Authentication required"});if(c.isMultiTenant()){const w=f.createdBy===_,a=(i=(r=c.getMultiTenantAllProjectAccessPassports())==null?void 0:r.includes)==null?void 0:i.call(r,E);if(!w&&!a)return e==null?void 0:e.status(403).json({error:"No permission to access this project in multi-tenant mode"})}else if(!["owner","admin","pagesEditor"].includes(E))return e==null?void 0:e.status(403).json({error:"No permission to access this project in single-tenant mode"});t.project=f,t.projectId=u,o()}catch(u){c.logger.error("Project middleware error:",u),e==null||e.status(500).json({error:"Internal server error"})}};function b(t,e){return new Promise((o,n)=>{const s=l.default.createReadStream(t),r=l.default.createWriteStream(e);s.on("error",n),r.on("error",n),r.on("finish",o),s.pipe(r)})}async function N(t,e){await l.default.promises.mkdir(e,{recursive:!0});const o=await l.default.promises.readdir(t,{withFileTypes:!0});for(const n of o){const s=k.default.join(t,n.name),r=k.default.join(e,n.name);n.isDirectory()?await N(s,r):await b(s,r)}}async function z(t,e){(await l.default.promises.stat(t)).isDirectory()?await N(t,e):await b(t,e)}const O=(t,e,o)=>c.isMultiTenant()?v.default()(t,e,o):v.default({roles:["owner","admin","pagesEditor"]})(t,e,o),H=(t,e)=>{const o=G.getResourceExportDir({projectId:t,releaseId:e});return B.join(o,c.COMPONENT_DID,c.RESOURCE_TYPE)},h=U.Router(),T="@page",q="@component",P=":",S="ALL",L="@project",C=({pageId:t,projectId:e})=>[T,e,t].join(P),Q=t=>{const[e,o,n]=t.split(P);if(e===T)return{pageId:n,projectId:o}},A=({componentId:t,projectId:e})=>[q,e,t].join(P),V=t=>{const[e,o,n]=t.split(P);if(e===q)return{componentId:n,projectId:o}},Z=t=>[L,t].join(P),tt=t=>{const[e,o]=t.split(P);if(e===L)return o},et=t=>{try{return JSON.parse(t)}catch{}return{}};async function x(t){const e=await c.SiteState.getStateByProjectId(t,"production"),o=await c.Project.findByPk(t),n=e.pageIds.map(r=>{const i=e.pages[r];if(i)return{id:C({pageId:r,projectId:t}),name:i.slug}}).filter(Boolean),s=K.default(Object.values(e.components),r=>r.index).map(({data:r})=>({id:A({componentId:r.id,projectId:t}),name:r.name||r.id}));return{id:Z(t),name:(o==null?void 0:o.name)||"Unnamed Project",children:[{id:C({pageId:S,projectId:t}),name:"Pages",children:n},{id:A({componentId:S,projectId:t}),name:"Components",children:s}]}}h.get("/resources",O,async(t,e)=>{const{projectId:o}=et(t.query.resourcesParams);if(o){t.params={...t.params,projectId:o},await Y(t,e,()=>{});const r=await x(o);e.json({resources:[r]});return}const n=await c.Project.findAll({where:{}}),s=await Promise.all(n.map(r=>x(r.id)));e.json({resources:s})});const ot=I.default.object({projectId:I.default.string().required().min(1),releaseId:I.default.string().allow(""),resources:I.default.array().items(I.default.string()).required(),locale:I.default.string().allow("")});h.post("/resources",O,async(t,e)=>{const{resources:o,projectId:n,releaseId:s}=await ot.validateAsync(t.body),r="production",i=[],u=[];for(const a of o){if(tt(a))continue;const{pageId:m,projectId:j}=Q(a)||{};if(m)m===S||m&&j&&i.push({pageId:m,projectId:j});else{const{componentId:p,projectId:d}=V(a)||{};p===S||p&&d&&u.push({componentId:p,projectId:d})}}const f=D.default(i,"projectId"),_=D.default(u,"projectId"),E=new Set([...Object.keys(f),...Object.keys(_)]),w=H(n,s);l.default.rmSync(w,{recursive:!0,force:!0}),l.default.mkdirSync(w,{recursive:!0});for(const a of E){const m=await c.SiteState.getStateByProjectId(a,r),j=f[a],p=_[a],d=j==null?void 0:j.map(g=>g.pageId),R=p==null?void 0:p.map(g=>g.componentId);if(d!=null&&d.length||R!=null&&R.length){const g=await c.toPackage(m,{exportAssets:!0,pageIds:d,componentIds:R});await z(g,w),l.default.rmSync(g,{recursive:!0,force:!0})}c.logger.info(`Exported resources for project ${a}`,{pageIds:d,componentIds:R})}e.json({})});h.get("/all-resources",O,async(t,e)=>{const{states:o}=await c.getResourceStates(),n=o==null?void 0:o.map(s=>{const r={blockletId:s.blockletId,blockletTitle:s.blockletTitle,components:{}};if(s.state.components&&(r.components=s.state.components),Object.keys(r.components).length!==0)return r}).filter(Boolean);e.json(n)});module.exports=h;
1
+ "use strict";const c=require("./chunks/site-state-D00xEf4T.js"),M=require("async_hooks"),U=require("express"),F=require("fs"),J=require("joi"),X=require("lodash/groupBy"),W=require("lodash/sortBy"),B=require("path"),$=require("@blocklet/sdk/lib/middlewares/auth"),G=require("@blocklet/sdk/lib/component"),y=t=>t&&t.__esModule?t:{default:t},l=y(F),I=y(J),D=y(X),K=y(W),k=y(B),v=y($);new M.AsyncLocalStorage;const Y=async(t,e,o)=>{var n,s,r,i;try{const{projectId:u}=t.params;if(!u)return o();const f=await c.Project.findByPk(u);if(!f)return e==null?void 0:e.status(404).json({error:"Project not found"});const _=(n=t.user)==null?void 0:n.did,E=((s=t.user)==null?void 0:s.role)||"UNKNOWN_ROLE";if(!_)return e==null?void 0:e.status(401).json({error:"Authentication required"});if(c.isMultiTenant()){const w=f.createdBy===_,a=(i=(r=c.getMultiTenantAllProjectAccessPassports())==null?void 0:r.includes)==null?void 0:i.call(r,E);if(!w&&!a)return e==null?void 0:e.status(403).json({error:"No permission to access this project in multi-tenant mode"})}else if(!["owner","admin","pagesEditor"].includes(E))return e==null?void 0:e.status(403).json({error:"No permission to access this project in single-tenant mode"});t.project=f,t.projectId=u,o()}catch(u){c.logger.error("Project middleware error:",u),e==null||e.status(500).json({error:"Internal server error"})}};function b(t,e){return new Promise((o,n)=>{const s=l.default.createReadStream(t),r=l.default.createWriteStream(e);s.on("error",n),r.on("error",n),r.on("finish",o),s.pipe(r)})}async function N(t,e){await l.default.promises.mkdir(e,{recursive:!0});const o=await l.default.promises.readdir(t,{withFileTypes:!0});for(const n of o){const s=k.default.join(t,n.name),r=k.default.join(e,n.name);n.isDirectory()?await N(s,r):await b(s,r)}}async function z(t,e){(await l.default.promises.stat(t)).isDirectory()?await N(t,e):await b(t,e)}const O=(t,e,o)=>c.isMultiTenant()?v.default()(t,e,o):v.default({roles:["owner","admin","pagesEditor"]})(t,e,o),H=(t,e)=>{const o=G.getResourceExportDir({projectId:t,releaseId:e});return B.join(o,c.COMPONENT_DID,c.RESOURCE_TYPE)},h=U.Router(),T="@page",q="@component",P=":",S="ALL",L="@project",C=({pageId:t,projectId:e})=>[T,e,t].join(P),Q=t=>{const[e,o,n]=t.split(P);if(e===T)return{pageId:n,projectId:o}},A=({componentId:t,projectId:e})=>[q,e,t].join(P),V=t=>{const[e,o,n]=t.split(P);if(e===q)return{componentId:n,projectId:o}},Z=t=>[L,t].join(P),tt=t=>{const[e,o]=t.split(P);if(e===L)return o},et=t=>{try{return JSON.parse(t)}catch{}return{}};async function x(t){const e=await c.SiteState.getStateByProjectId(t,"production"),o=await c.Project.findByPk(t),n=e.pageIds.map(r=>{const i=e.pages[r];if(i)return{id:C({pageId:r,projectId:t}),name:i.slug}}).filter(Boolean),s=K.default(Object.values(e.components),r=>r.index).map(({data:r})=>({id:A({componentId:r.id,projectId:t}),name:r.name||r.id}));return{id:Z(t),name:(o==null?void 0:o.name)||"Unnamed Project",children:[{id:C({pageId:S,projectId:t}),name:"Pages",children:n},{id:A({componentId:S,projectId:t}),name:"Components",children:s}]}}h.get("/resources",O,async(t,e)=>{const{projectId:o}=et(t.query.resourcesParams);if(o){t.params={...t.params,projectId:o},await Y(t,e,()=>{});const r=await x(o);e.json({resources:[r]});return}const n=await c.Project.findAll({where:{}}),s=await Promise.all(n.map(r=>x(r.id)));e.json({resources:s})});const ot=I.default.object({projectId:I.default.string().required().min(1),releaseId:I.default.string().allow(""),resources:I.default.array().items(I.default.string()).required(),locale:I.default.string().allow("")});h.post("/resources",O,async(t,e)=>{const{resources:o,projectId:n,releaseId:s}=await ot.validateAsync(t.body),r="production",i=[],u=[];for(const a of o){if(tt(a))continue;const{pageId:m,projectId:j}=Q(a)||{};if(m)m===S||m&&j&&i.push({pageId:m,projectId:j});else{const{componentId:p,projectId:d}=V(a)||{};p===S||p&&d&&u.push({componentId:p,projectId:d})}}const f=D.default(i,"projectId"),_=D.default(u,"projectId"),E=new Set([...Object.keys(f),...Object.keys(_)]),w=H(n,s);l.default.rmSync(w,{recursive:!0,force:!0}),l.default.mkdirSync(w,{recursive:!0});for(const a of E){const m=await c.SiteState.getStateByProjectId(a,r),j=f[a],p=_[a],d=j==null?void 0:j.map(g=>g.pageId),R=p==null?void 0:p.map(g=>g.componentId);if(d!=null&&d.length||R!=null&&R.length){const g=await c.toPackage(m,{exportAssets:!0,pageIds:d,componentIds:R});await z(g,w),l.default.rmSync(g,{recursive:!0,force:!0})}c.logger.info(`Exported resources for project ${a}`,{pageIds:d,componentIds:R})}e.json({})});h.get("/all-resources",O,async(t,e)=>{const{states:o}=await c.getResourceStates(),n=o==null?void 0:o.map(s=>{const r={blockletId:s.blockletId,blockletTitle:s.blockletTitle,components:{}};if(s.state.components&&(r.components=s.state.components),Object.keys(r.components).length!==0)return r}).filter(Boolean);e.json(n)});module.exports=h;
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("./chunks/site-state-D5jk8eJT.js");require("@blocklet/pages-kit/utils/property");require("@blocklet/pages-kit/utils/route");require("@blocklet/sdk/lib/component");require("@blocklet/sdk/lib/config");require("@reactivedata/reactive");require("@syncedstore/core");require("crypto");require("fs");require("glob");require("lib0/decoding");require("lib0/encoding");require("lodash/cloneDeep");require("lodash/debounce");require("lodash/get");require("lodash/isEmpty");require("lodash/pick");require("lodash/set");require("lodash/union");require("lru-cache");require("nanoid");require("p-limit");require("path");require("stream/promises");require("tar");require("ufo");require("wait-on");require("y-protocols/awareness");require("y-protocols/sync");require("yaml");require("yjs");const t=require("@blocklet/pages-kit/types/state");exports.PUBLISH_MODES=e.PUBLISH_MODES;exports.SITE_STATE_PATH=e.SITE_STATE_PATH;exports.STATE_MODES=e.STATE_MODES;exports.default=e.SiteState;exports.downloadAsset=e.downloadAsset;exports.downloadAssets=e.downloadAssets;exports.fromPackage=e.fromPackage;exports.getResourceStates=e.getResourceStates;exports.initPackResourceStates=e.initPackResourceStates;exports.mergeState=e.mergeState;exports.nextId=e.nextId;exports.toPackage=e.toPackage;exports.triggerReloadAllProjectResource=e.triggerReloadAllProjectResource;Object.keys(t).forEach(r=>{r!=="default"&&!Object.prototype.hasOwnProperty.call(exports,r)&&Object.defineProperty(exports,r,{enumerable:!0,get:()=>t[r]})});
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("./chunks/site-state-D00xEf4T.js");require("@blocklet/pages-kit/utils/property");require("@blocklet/pages-kit/utils/route");require("@blocklet/sdk/lib/component");require("@blocklet/sdk/lib/config");require("@reactivedata/reactive");require("@syncedstore/core");require("crypto");require("fs");require("glob");require("lib0/decoding");require("lib0/encoding");require("lodash/cloneDeep");require("lodash/debounce");require("lodash/get");require("lodash/isEmpty");require("lodash/pick");require("lodash/set");require("lodash/union");require("lru-cache");require("nanoid");require("p-limit");require("path");require("stream/promises");require("tar");require("ufo");require("wait-on");require("y-protocols/awareness");require("y-protocols/sync");require("yaml");require("yjs");const t=require("@blocklet/pages-kit/types/state");exports.PUBLISH_MODES=e.PUBLISH_MODES;exports.SITE_STATE_PATH=e.SITE_STATE_PATH;exports.STATE_MODES=e.STATE_MODES;exports.default=e.SiteState;exports.downloadAsset=e.downloadAsset;exports.downloadAssets=e.downloadAssets;exports.fromPackage=e.fromPackage;exports.getResourceStates=e.getResourceStates;exports.initPackResourceStates=e.initPackResourceStates;exports.mergeState=e.mergeState;exports.nextId=e.nextId;exports.toPackage=e.toPackage;exports.triggerReloadAllProjectResource=e.triggerReloadAllProjectResource;Object.keys(t).forEach(r=>{r!=="default"&&!Object.prototype.hasOwnProperty.call(exports,r)&&Object.defineProperty(exports,r,{enumerable:!0,get:()=>t[r]})});