smart-registry 0.5.9 → 0.6.0-canary.1

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.
Files changed (2) hide show
  1. package/dist/bin/index.js +15 -15
  2. package/package.json +5 -3
package/dist/bin/index.js CHANGED
@@ -1,22 +1,22 @@
1
1
  #!/usr/bin/env node
2
- var B=Object.defineProperty,T=Object.defineProperties;var U=Object.getOwnPropertyDescriptors;var J=Object.getOwnPropertySymbols;var Z=Object.prototype.hasOwnProperty,G=Object.prototype.propertyIsEnumerable;var C=(s,i,r)=>i in s?B(s,i,{enumerable:!0,configurable:!0,writable:!0,value:r}):s[i]=r,k=(s,i)=>{for(var r in i||(i={}))Z.call(i,r)&&C(s,r,i[r]);if(J)for(var r of J(i))G.call(i,r)&&C(s,r,i[r]);return s},W=(s,i)=>T(s,U(i));import $ from"node:fs";import O from"node:path";import{parseArgs as L}from"node:util";import j from"node:fs";import H from"strip-json-comments";var M=async()=>{let s={},i=["registry","components","src/components"];if(j.existsSync("tsconfig.json")){let r=await j.promises.readFile("tsconfig.json","utf8"),{compilerOptions:o}=JSON.parse(H(r,{trailingCommas:!0}));if(o.paths){s=Object.entries(o.paths).reduce((t,[e,[n]])=>(t[e.replace(/\*$/,"")]=n.replace(/^\.\//,"").replace(/\*$/,""),t),{});for(let t of i)j.existsSync(t)&&(s["@/"]=t==="src/components"?"src/":"");if(!Object.keys(s).includes("@/"))throw new Error("No alias key '@/' found in compilerOptions.paths!");return s}}for(let r of i)if(j.existsSync(r))return s["@/"]=r==="src/components"?"src/":"",s;throw new Error("Could not resolve aliases!")};import A from"node:fs";import w from"node:path";import{glob as K}from"tinyglobby";var R=s=>{if(w.extname(s)!=="")return s.replace(process.cwd()+w.sep,"");{let r=s.split(/\/|\\/).slice(0,-1).join(w.sep);if(r=r.replace(/\/\//g,"/"),!A.existsSync(r))return"";let o=A.readdirSync(r);o=o.map(e=>r+w.sep+e);let t=o.find(e=>e.startsWith(s+"."));return t=t||o.find(e=>e.startsWith(s+"/index.")),(t==null?void 0:t.replace(process.cwd()+w.sep,""))||""}},V=async({patterns:s=["**",".**"],ignore:i=[]}={})=>{if(s=Array.isArray(s)?s:[s],i=Array.isArray(i)?i:[i],A.existsSync(".gitignore")){let r=(await A.promises.readFile(".gitignore","utf8")).split(`
3
- `).map(o=>o.trim()).filter(o=>o&&!o.startsWith("#")).map(o=>o.replace(/^\//,""));i=i.concat(r)}return await K(s,{ignore:i.filter(r=>!s.includes(r))})};import z from"node:fs";import x from"node:path";import I from"node:path";var f=(s,i={})=>{var o;s=i.aliases?s.replace(i.aliases["@/"],""):s,s=s.replace(process.cwd()+I.sep,"");let r=s.startsWith("registry/")?s.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(t,e)=>`blocks/${e?e+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(t,e)=>`${e?e+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(t,e)=>`components/${e?e+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(t,e)=>`hooks/${e?e+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(t,e)=>`lib/${e?e+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(t,e)=>`components/ui/${e?e+"/":""}`).replace(/\/default\//,"/").replace(/\.\.\//g,"").replace(/\.\//g,""):s.replace(/\/default\//,"/").replace(/\.\.\//g,"").replace(/\.\//g,"");return{type:r.endsWith("page.tsx")?"registry:page":((o=r.match(/^(blocks|components\/ui|components|hooks|lib|utils|helpers)/))==null?void 0:o[1].replace("blocks","registry:block").replace("components/ui","registry:ui").replace("components","registry:component").replace("hooks","registry:hook").replace("lib","registry:lib").replace("utils","registry:lib").replace("helpers","registry:lib"))||"registry:file",name:r.replace(/^(blocks|components\/ui|components|hooks|lib|utils|helpers)\//,"").replace(/\.[^\/.]+$/,""),import:"@/"+r.replace(process.cwd()+I.sep,"").replace(/\.[^/.]+$/,""),target:r,path:s}};var v=(s,i)=>Object.entries(i).sort(([o],[t])=>t.length-o.length).reduce((o,[t,e])=>o.replace(t,e),s),N=async(s,i={})=>{let{aliases:r={},resolved:o=new Set}=i,t={dependencies:[],files:[],content:{}};for(let e of s){if(e=e.replace(process.cwd()+x.sep,""),o.has(e))continue;o.add(e),t.files.push(e),t.content[e]=t.content[e]||await z.promises.readFile(e,"utf8");let n=t.content[e].match(/import\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]/g);if(!n)continue;let a=n.map(l=>{var h;return(h=l.match(/['"](.*)['"]/))==null?void 0:h[1]});for(let l of a)if(Object.keys(r).some(p=>l.startsWith(p))){let p=v(l,r);p=R(p),p&&!t.files.includes(p)&&t.files.push(p)}else if(l.startsWith(".")){let p=x.resolve(x.dirname(e),l);p=R(p),p&&!t.files.includes(p)&&t.files.push(p)}else{let p=["fs","path","util"],d=l.split("/").slice(0,2).join("/");d=d.startsWith("@")?d:d.split("/")[0],/^[a-zA-Z0-9@/-]+$/.test(d)&&!p.includes(d)&&!t.dependencies.includes(d)&&t.dependencies.push(d)}}for(let e of t.files){let n=await N([e],{aliases:r,resolved:o});n.dependencies.forEach(a=>{t.dependencies.includes(a)||t.dependencies.push(a)}),n.files.forEach(a=>{t.files.includes(a)||t.files.push(a)}),t.content[e]=n.content[e]||await z.promises.readFile(e,"utf8")}for(let e of t.files)t.content[e]=t.content[e].replace(/import\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]/g,n=>{var h,p,d;let a=(h=n.match(/['"](.*)['"]/))==null?void 0:h[1];if(Object.keys(r).some(u=>a.startsWith(u))){let u=v(a,r),b=(p=f(u,{aliases:r}))==null?void 0:p.import;return n.replace(a,b)}else if(a.startsWith(".")){let u=x.resolve(x.dirname(e),a),b=(d=f(u,{aliases:r}))==null?void 0:d.import;return n.replace(a,b)}else return n});return t.dependencies.sort(),t.files.sort((e,n)=>f(e,{aliases:r}).target.localeCompare(f(n,{aliases:r}).target)),t.files.sort((e,n)=>{let a=["registry:file","registry:block","registry:component","registry:ui","registry:hook","registry:lib"],l=f(e,{aliases:r}).type,h=f(n,{aliases:r}).type;return a.indexOf(l)-a.indexOf(h)}),t};var S="smart-registry",_="0.5.8";var E={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var q=`Version:
4
- ${S}@${_}
2
+ var U=Object.defineProperty,G=Object.defineProperties;var H=Object.getOwnPropertyDescriptors;var N=Object.getOwnPropertySymbols;var K=Object.prototype.hasOwnProperty,L=Object.prototype.propertyIsEnumerable;var D=(r,s,t)=>s in r?U(r,s,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[s]=t,f=(r,s)=>{for(var t in s||(s={}))K.call(s,t)&&D(r,t,s[t]);if(N)for(var t of N(s))L.call(s,t)&&D(r,t,s[t]);return r},$=(r,s)=>G(r,H(s));import E from"node:fs";import m from"node:path";import{parseArgs as se}from"node:util";import j from"node:fs";import R from"node:path";import Q from"strip-json-comments";var P=async r=>{let s={},t=["tsconfig.json","jsconfig.json"].find(o=>j.existsSync(R.resolve(r,o)));if(t){let o=await j.promises.readFile(R.resolve(r,t),"utf8"),{compilerOptions:e}=JSON.parse(Q(o,{trailingCommas:!0}));e.paths&&(s=Object.entries(e.paths).reduce((i,[n,[a]])=>(n.endsWith("*")&&a.endsWith("*")&&(i[n.replace(/\*$/,"")]=a.replace(/\*$/,"")),i),{}))}return s["@/"]||(s["@/"]=j.existsSync(R.resolve(r,"src"))?"./src/":"./"),s=Object.entries(s).sort(([o],[e])=>e.length-o.length).reduce((o,[e,i])=>(o[e]=i,o),{}),s};import _ from"node:fs";import X from"node:path";var I=async r=>{let s=X.resolve(r,"registry.json"),t={$schema:"https://ui.shadcn.com/schema/registry.json",name:"shadcn",homepage:"https://ui.shadcn.com",items:[]};return _.existsSync(s)&&(t=f({},JSON.parse(await _.promises.readFile(s,"utf8")))),t};import{glob as Y}from"tinyglobby";var h=async({cwd:r,patterns:s=["**",".**"],ignore:t=[]})=>(s=Array.isArray(s)?s:[s],s=s.flatMap(e=>e.includes("*")?e:[e+".*",e+"/**"]),s=s.filter(Boolean),t=typeof t=="string"?t.split(",").map(e=>e.trim()):t,t=t.filter(Boolean),await Y(s,{cwd:r,ignore:t.filter(e=>!s.includes(e))}));var J=["registry/**",["blocks/**","components/**","helpers/**","hooks/**","lib/**","ui/**","utils/**"],["src/blocks/**","src/components/**","src/helpers/**","src/hooks/**","src/lib/**","src/ui/**","src/utils/**"]];var M=async({cwd:r,patterns:s,ignore:t})=>{let o=[];if(s.length)o=await h({cwd:r,patterns:s,ignore:t});else for(let e of J)if(o=await h({cwd:r,patterns:e,ignore:t}),o.length)break;if(!o.length)throw new Error("No files/directories found to build the registry from!");return o};import V from"node:fs";import C from"node:path";var F=async({cwd:r,aliases:s,filepaths:t,resolved:o})=>{o=o!=null?o:new Set;let e={dependencies:[],files:[],content:{}};for(let i of t){if(o.has(i))continue;o.add(i),e.files.push(i),e.content[i]=e.content[i]||await V.promises.readFile(C.resolve(r,i),"utf8");let{dependencies:n,files:a}=await B({cwd:r,aliases:s,filepath:i,content:e.content[i]});e.dependencies.push(...n.filter(l=>!e.dependencies.includes(l))),e.files.push(...a.filter(l=>!e.files.includes(l)))}for(let i of e.files)if(!o.has(i)){let{dependencies:n,files:a}=await F({cwd:r,aliases:s,filepaths:[i],resolved:o});e.dependencies.push(...n.filter(l=>!e.dependencies.includes(l))),e.files.push(...a.filter(l=>!e.files.includes(l))),e.content[i]=e.content[i]||await V.promises.readFile(C.resolve(r,i),"utf8")}return e.dependencies=e.dependencies.sort(),e.files=e.files.sort(),e};import O from"node:path";var q={imports:/import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+[\s\S]+?from\s+['"][^'"]+['"]/g};var Z=async({cwd:r,current:s,aliases:t})=>{s=s.replace(new RegExp(`^${Object.keys(t).find(e=>s.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))}`),t[Object.keys(t).find(e=>s.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))]),s=s.replace(/\.\//g,"").replace(/\.\.\//g,"");let o=await h({cwd:r,patterns:s});return s=o.find(e=>e.startsWith(s+"."))||o.find(e=>e.startsWith(s+"/index"))||s,s.replace(r+"/","")},ee=async({cwd:r,filepath:s,current:t})=>{t=O.relative(r,O.resolve(r,O.dirname(s),t));let o=await h({cwd:r,patterns:t});return t=o.find(e=>e.startsWith(t+"."))||o.find(e=>e.startsWith(t+"/index"))||t,t.replace(r+"/","")},B=async({cwd:r,aliases:s,filepath:t,content:o})=>{let e={dependencies:[],files:[]},i=o.match(q.imports)||[];if(!i.length)return e;i=i.map(n=>{var a;return(a=n.match(/['"](.*)['"]/))==null?void 0:a[1].replace(/\/\//g,"/")});for(let n of i)Object.keys(s).some(l=>n.startsWith(l.replace(/\.\//g,"").replace(/\.\.\//g,"")))?(n=await Z({cwd:r,aliases:s,current:n}),e.files.push(n)):n.startsWith(".")?(n=await ee({cwd:r,filepath:t,current:n}),e.files.push(n)):n.startsWith("@")?e.dependencies.push(n.split("/").slice(0,2).join("/")):e.dependencies.push(n.replace(/\/.*/,""));return e};import z from"node:path";var d=(r,s={})=>{var o;r=s.aliases?r.replace(s.aliases["@/"],""):r,r=r.replace(process.cwd()+z.sep,"");let t=r.startsWith("registry/")?r.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(e,i)=>`blocks/${i?i+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(e,i)=>`${i?i+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(e,i)=>`components/${i?i+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(e,i)=>`hooks/${i?i+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(e,i)=>`lib/${i?i+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(e,i)=>`components/ui/${i?i+"/":""}`).replace(/\/default\//,"/").replace(/\.\.\//g,"").replace(/\.\//g,""):r.replace(/\/default\//,"/").replace(/\.\.\//g,"").replace(/\.\//g,"");return{type:t.endsWith("page.tsx")?"registry:page":((o=t.match(/^(blocks|components\/ui|components|hooks|lib|utils|helpers)/))==null?void 0:o[1].replace("blocks","registry:block").replace("components/ui","registry:ui").replace("components","registry:component").replace("hooks","registry:hook").replace("lib","registry:lib").replace("utils","registry:lib").replace("helpers","registry:lib"))||"registry:file",name:t.replace(/^(blocks|components\/ui|components|hooks|lib|utils|helpers)\//,"").replace(/\.[^\/.]+$/,""),import:"@/"+t.replace(process.cwd()+z.sep,"").replace(/\.[^/.]+$/,""),target:t,path:r}};var y="smart-registry",W="0.6.0-canary.1";var b={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var T=`Version:
3
+ ${y}@${W}
5
4
 
6
5
  Usage:
7
- $ ${S} [options]
6
+ $ ${y} [options] [files/directories] ...
7
+
8
+ Arguments:
9
+ files/directories files or directories to build the registry from (optional)
8
10
 
9
11
  Options:
10
- -f, --files Files to build the registry from
11
- -d, --directories Directories to build the registry from
12
- -i, --ignore Endings/Extensions to ignore (comma separated)
13
- e.g. -i ".spec.ts, .test.ts, demo.tsx"
14
- -v, --version Display version
15
- -h, --help Display help
12
+ -o, --output <path> destination directory for json files (default: "./public/r")
13
+ -c, --cwd <cwd> the working directory (default: "./")
14
+ -v, --version display version
15
+ -h, --help display help
16
16
 
17
17
  Author:
18
- ${E.name} <${E.email}> (${E.url})`,Q=s=>{try{return L(s)}catch(i){throw new Error(`Error parsing arguments: ${i.message}`)}},X=async()=>{var s,i,r,o,t;try{let{positionals:e,values:n}=Q({allowPositionals:!0,options:{files:{type:"string",multiple:!0,short:"f"},directories:{type:"string",multiple:!0,short:"d"},ignore:{type:"string",multiple:!0,short:"i"},help:{type:"boolean",short:"h"},version:{type:"boolean",short:"v"}}});e.length||(n.version&&(console.log(`${S}@${_}`),process.exit(0)),n.help&&(console.log(q),process.exit(0)));let a={files:n.files||[],directories:n.directories||[]},l=await M(),h=await V();if(!a.files.length&&!a.directories.length){let m=["registry","components"].map(c=>l["@/"]+c).find(c=>h.some(y=>y.startsWith(c+"/")));if(m)a.directories.push(m);else throw new Error("Neither registry nor components directory found")}let p=[...a.files.map(m=>v(m,l)),...a.directories.flatMap(m=>h.filter(c=>c.startsWith(v(m,l)+"/")))],d=O.resolve(process.cwd(),"registry.json"),u={};$.existsSync(d)&&(u=JSON.parse(await $.promises.readFile(d,"utf8")));let b=W(k({},u),{items:[]}),P=[];for(let m of p)if(!((s=n.ignore)!=null&&s.flatMap(c=>c.split(",").map(y=>y.trim())).some(c=>m.endsWith(c))))try{let c=await N([m,...((o=(r=(i=u.items)==null?void 0:i.find(g=>g.name===f(m,{aliases:l}).name))==null?void 0:r.files)==null?void 0:o.map(g=>g.path))||[]],{aliases:l}),y=k(W(k({$schema:"https://ui.shadcn.com/schema/registry-item.json",name:f(m,{aliases:l}).name,type:f(m,{aliases:l}).type||"registry:file"},c.dependencies.length&&{dependencies:c.dependencies}),{files:c.files.map(g=>({type:f(g,{aliases:l}).type||"registry:file",target:f(g,{aliases:l}).target||g,content:c.content[g],path:g}))}),Object.fromEntries(Object.entries(((t=u.items)==null?void 0:t.find(g=>g.name===f(m,{aliases:l}).name))||{}).filter(([g])=>!["$schema","name","type","files"].includes(g)))),F=O.resolve(process.cwd(),"public/r",y.name+".json");console.log(`- ${m.padEnd(Math.max(...p.map(g=>g.length))+2," ")} ${c.dependencies.length?"\u{1F4E6}"+String(c.dependencies.length).padEnd(2," "):" "} ${c.files.length-1?"\u{1F4C4}"+String(c.files.length).padEnd(2," "):" "} ${F.replace(process.cwd()+"/","")}`),await $.promises.mkdir(O.dirname(F),{recursive:!0}),await $.promises.writeFile(F,JSON.stringify(y,null,2)+`
19
- `),y.files.forEach(g=>delete g.content),b.items.push(y)}catch(c){P.push(m+": "+c.message);continue}b.items.sort((m,c)=>m.name.localeCompare(c.name)),await $.promises.writeFile(O.resolve(process.cwd(),"public/registry.json"),JSON.stringify(b,null,2)+`
20
- `),P.length&&(console.log(),P.forEach(m=>console.error(`\x1B[31m- ${m}\x1B[0m`))),process.exit(0)}catch(e){console.error(q),console.error(`
21
- ${e.message}
22
- `),process.exit(1)}};X();
18
+ ${b.name} <${b.email}> (${b.url})`,te=r=>{try{return se(r)}catch(s){throw new Error(`Error parsing arguments: ${s.message}`)}},re=async()=>{var r,s,t,o,e;try{let{positionals:i,values:n}=te({allowPositionals:!0,options:{cwd:{type:"string",short:"c"},ignore:{type:"string",short:"i",default:""},output:{type:"string",short:"o",default:"public/r"},help:{type:"boolean",short:"h"},version:{type:"boolean",short:"v"}}});i.length||(n.version&&(console.log(`${y}@${W}`),process.exit(0)),n.help&&(console.log(T),process.exit(0)));let a=m.resolve((r=n.cwd)!=null?r:process.cwd()),l=await P(a),w=await I(a),A=await M({cwd:a,patterns:i,ignore:n.ignore}),x=[],k=$(f({},w),{items:[]});for(let g of A)try{let p=await F({cwd:a,aliases:l,filepaths:[g,...((o=(t=(s=w.items)==null?void 0:s.find(c=>c.name===d(g,{aliases:l}).name))==null?void 0:t.files)==null?void 0:o.map(c=>c.path))||[]]}),u=f($(f({$schema:"https://ui.shadcn.com/schema/registry-item.json",name:d(g,{aliases:l}).name,type:d(g,{aliases:l}).type||"registry:file"},p.dependencies.length&&{dependencies:p.dependencies}),{files:p.files.map(c=>({type:d(c,{aliases:l}).type||"registry:file",target:d(c,{aliases:l}).target||c,content:p.content[c],path:c}))}),Object.fromEntries(Object.entries(((e=w.items)==null?void 0:e.find(c=>c.name===d(g,{aliases:l}).name))||{}).filter(([c])=>!["$schema","name","type","files"].includes(c)))),v=m.resolve(a,n.output,u.name+".json");console.log(`- ${m.relative(process.cwd(),m.resolve(a,g)).padEnd(Math.max(...A.map(c=>m.relative(process.cwd(),m.resolve(a,c)).length))+2," ")} ${p.dependencies.length?"\u{1F4E6}"+String(p.dependencies.length).padEnd(2," "):" "} ${p.files.length-1?"\u{1F4C4}"+String(p.files.length).padEnd(2," "):" "} ${m.relative(process.cwd(),v)}`),await E.promises.mkdir(m.dirname(v),{recursive:!0}),await E.promises.writeFile(v,JSON.stringify(u,null,2)+`
19
+ `),u.files.forEach(c=>delete c.content),k.items.push(u)}catch(p){x.push(g+": "+p.message);continue}k.items.sort((g,p)=>g.name.localeCompare(p.name)),await E.promises.writeFile(m.resolve(a,n.output,"registry.json"),JSON.stringify(k,null,2)+`
20
+ `),x.length&&(console.log(),x.forEach(g=>console.error(`\x1B[31m- ${g}\x1B[0m`))),process.exit(0)}catch(i){console.error(T),console.error(`
21
+ ${i.message}
22
+ `),process.exit(1)}};re();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "smart-registry",
3
- "version": "0.5.9",
3
+ "version": "0.6.0-canary.1",
4
4
  "description": "A zero-configuration (no registry.json required), shadcn add / open in v0 compatible registry builder.",
5
5
  "keywords": [
6
6
  "smart-registry"
@@ -22,7 +22,7 @@
22
22
  ],
23
23
  "scripts": {
24
24
  "build": "tsup",
25
- "cli": "bun run build && node dist/bin/index.js",
25
+ "cli": "bash scripts/cli.sh",
26
26
  "dev": "tsup --watch",
27
27
  "prepare": "if [ \"$NODE_ENV\" != \"production\" ]; then npx simple-git-hooks; fi",
28
28
  "publish:latest": "NODE_ENV=production changeset publish",
@@ -39,6 +39,7 @@
39
39
  },
40
40
  "lint-staged": {
41
41
  "*": "prettier --write --ignore-unknown",
42
+ "public/**/*": "prettier --ignore",
42
43
  "package.json": "sort-package-json"
43
44
  },
44
45
  "prettier": {
@@ -64,5 +65,6 @@
64
65
  "sort-package-json": "^2.14.0",
65
66
  "tsup": "^8.3.5",
66
67
  "typescript": "^5.7.2"
67
- }
68
+ },
69
+ "packageManager": "pnpm@10.5.2+sha512.da9dc28cd3ff40d0592188235ab25d3202add8a207afbedc682220e4a0029ffbff4562102b9e6e46b4e3f9e8bd53e6d05de48544b0c57d4b0179e22c76d1199b"
68
70
  }