nemar-cli 0.8.49-dev.1335 → 0.8.49-dev.1348

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/index.js +2 -2
  2. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -95,7 +95,7 @@ ${W.dim(`eta: ${D.eta}`)}`:"";process.stderr.write(`${F}
95
95
  ${$} ${D.message}
96
96
  ${J}${Q}
97
97
  ${F}
98
- `)}var wf=!1;var IW=P(()=>{jD()});var Pf;var Tf=P(()=>{Pf={name:"nemar-cli",version:"0.8.49-dev.1335",description:"CLI for NEMAR (Neuroelectromagnetic Data Archive and Tools Resource) dataset management",type:"module",main:"dist/index.js",bin:{nemar:"dist/index.js"},scripts:{dev:"bun run src/index.ts",build:"bun build src/index.ts --outdir dist --target bun --minify && sed '1s|#!/usr/bin/env node|#!/usr/bin/env bun|' dist/index.js > dist/index.js.tmp && mv dist/index.js.tmp dist/index.js",test:"bun test",lint:"biome check src/","lint:fix":"biome check --fix src/",format:"biome format --write src/",typecheck:"tsc --noEmit",prepublishOnly:"bun run build",prepare:"husky",postinstall:"bun scripts/postinstall-check.mjs",deploy:"wrangler deploy",preview:"wrangler dev"},keywords:["nemar","bids","neuroimaging","eeg","emg","datalad","cli"],author:"NEMAR Team",license:"CC-BY-NC-ND-4.0",repository:{type:"git",url:"git+https://github.com/nemarOrg/nemar-cli.git"},bugs:{url:"https://github.com/nemarOrg/nemar-cli/issues"},homepage:"https://docs.nemar.org",engines:{bun:">=1.0.0"},files:["dist","scripts/postinstall-check.mjs","README.md","LICENSE"],dependencies:{chalk:"^5.3.0",commander:"^12.1.0",conf:"^13.0.1","fuse.js":"^7.1.0",inquirer:"^9.2.15",ora:"^8.0.1",zod:"^3.23.8"},"lint-staged":{"src/**/*.{ts,tsx}":["biome check --fix"],"backend/src/**/*.{ts,tsx}":["biome check --fix"]},devDependencies:{"@biomejs/biome":"1.9.4","@types/bcryptjs":"^3.0.0","@types/bun":"latest","@types/inquirer":"^9.0.7",bcryptjs:"^3.0.3",husky:"^9.1.7","lint-staged":"^16.3.2",typescript:"^5.5.4",wrangler:"^4.70.0",yaml:"^2.8.4"}}});var g4;var DQ=P(()=>{Tf();g4=Pf.version});function C0(D){if(D instanceof Error)return D.message;return String(D)}function If(){if(process.env.TEST_API_URL)return process.env.TEST_API_URL;if(kW)return SW;return BD().apiUrl||SW}async function g(D,F={},$=!1){let J=`${If()}${D}`,Q={"Content-Type":"application/json","X-CLI-Version":g4,...F.headers};if($){let X=BD();if(!X.apiKey&&$===!0)throw new h(401,"Not authenticated. Run 'nemar auth login' first.");if(X.apiKey)Q.Authorization=`Bearer ${X.apiKey}`}let Y;try{Y=await fetch(J,{...F,headers:Q})}catch(X){throw new h(0,`Network error: Could not connect to ${If()}`,{originalError:X instanceof Error?X.message:String(X)})}let B;try{B=await Y.json()}catch{throw new h(Y.status,`Invalid response from server (status ${Y.status})`)}if(!Y.ok){if(Y.status===503&&(B.mode==="read-only"||B.mode==="full")){let X=typeof B.message==="string"?B.message:"NEMAR is in maintenance mode. Please retry shortly.",G=typeof B.eta==="string"?B.eta:null,H=new $Q(B.mode,X,G,B.details);throw eJ(H),H}throw new h(Y.status,B.error||B.message||"Request failed",B.details,typeof B.step==="string"?B.step:void 0)}return B}async function kf(D){return g(`/auth/check-username?username=${encodeURIComponent(D)}`)}async function vf(D){return g(`/auth/check-github?username=${encodeURIComponent(D)}`)}async function yf(D){return g("/auth/signup",{method:"POST",body:JSON.stringify(D)})}async function xf(D){return g("/auth/login",{method:"POST",body:JSON.stringify({api_key:D})})}async function _f(D){return g("/auth/resend-verification",{method:"POST",body:JSON.stringify({email:D})})}async function ff(D,F){return g("/auth/retrieve-key",{method:"POST",body:JSON.stringify({email:D,password:F})})}async function gf(D){return g("/auth/request-key-regeneration",{method:"POST",body:JSON.stringify({email:D})})}async function JQ(){return g("/users/me",{},!0)}async function hf(D,F){let $=new URLSearchParams;if(D)$.set("status",D);if(F)$.set("role",F);let J=$.toString()?`?${$.toString()}`:"";return g(`/admin/users${J}`,{},!0)}async function bf(D){return g(`/admin/approve/${D}`,{method:"POST"},!0)}async function uf(D){return g(`/admin/revoke/${D}`,{method:"POST"},!0)}async function mf(D,F){return g(`/admin/users/${D}/role`,{method:"POST",body:JSON.stringify({role:F})},!0)}async function vW(D,F){return g(`/admin/datasets/${D}/visibility`,{method:"PATCH",body:JSON.stringify({visibility:F})},!0)}async function lf(D){return g(`/datasets/${D}/publish`,{method:"POST"},!0)}async function pf(D){return g(`/admin/datasets/${D}/ci`,{},!0)}async function h4(D){return g(`/admin/datasets/${D}/ci`,{method:"POST"},!0)}async function yW(D){return g(`/admin/datasets/${D}/ci/validate`,{method:"POST"},!0)}async function xW(D){return g(`/admin/datasets/${D}/ci/sync`,{method:"POST"},!0)}async function QQ(D){return g(`/datasets/${D}/ci/status`,{},!0)}async function df(D){return g(`/datasets/${D}/manifest`,{},!0)}async function YQ(D,F){return g(`/datasets/${D}/manifest/${F}`,{},!0)}function cf(D){let F=D;if(!F.status)F.status="active";else if(!["active","archived","deleted"].includes(F.status))throw Error(`Invalid dataset status: ${F.status}`);if(!F.visibility)F.visibility="private";else if(!["public","private"].includes(F.visibility))throw Error(`Invalid dataset visibility: ${F.visibility}`);return F}async function y9(D={}){let F=new URLSearchParams;if(D.mine)F.set("mine","true");if(D.search)F.set("search",D.search);if(D.modality)F.set("modality",D.modality);if(D.author)F.set("author",D.author);if(D.task)F.set("task",D.task);if(D.license)F.set("license",D.license);if(D.hasDoi)F.set("has_doi","true");if(D.recent)F.set("recent",String(D.recent));if(D.sort)F.set("sort",D.sort);if(D.limit!=null)F.set("limit",String(D.limit));if(D.offset!=null)F.set("offset",String(D.offset));if(D.owner)F.set("owner",D.owner);let $=F.toString()?`?${F.toString()}`:"",J=await g(`/datasets${$}`,{},D.mine?!0:"optional");return J.datasets=J.datasets.map(cf),J}async function nf(D){return g(`/datasets/resolve/${D}`,{},"optional")}async function af(D,F={}){let $=new URLSearchParams({q:D});if(F.modality)$.set("modality",F.modality);if(F.limit)$.set("limit",String(F.limit));return g(`/datasets/search?${$.toString()}`,{},"optional")}async function uD(D){let F=await g(`/datasets/${D}`,{},"optional");return cf(F.dataset)}async function of(D){return g(`/datasets/${D}/versions`,{},!0)}async function BQ(D){return g("/datasets",{method:"POST",body:JSON.stringify(D)},!0)}async function XQ(D){return g(`/datasets/${D}/finalize`,{method:"POST"},!0)}async function w8(D,F){return g(`/datasets/${D}/upload-credentials`,{method:"POST",body:JSON.stringify({duration_seconds:F})},!0)}async function GQ(D,F){return g(`/datasets/${D}/download-credentials`,{method:"POST",body:JSON.stringify({duration_seconds:F})},!0)}async function sf(D,F){return g(`/admin/datasets/${D}/doi/concept`,{method:"POST",body:JSON.stringify(F)},!0)}async function x9(D){return g(`/admin/datasets/${D}/doi`,{},!0)}async function _W(D,F){return g(`/admin/datasets/${D}/doi/update`,{method:"POST",body:JSON.stringify(F)},!0)}async function fW(D){return g(`/datasets/${D}/request-access`,{method:"POST"},!0)}async function rf(D,F){return g(`/datasets/${D}/invite`,{method:"POST",body:JSON.stringify({username:F})},!0)}async function tf(D){return g(`/datasets/${D}/collaborators`,{},!0)}async function ef(D){return g("/sandbox/complete",{method:"POST",body:JSON.stringify({dataset_id:D})},!0)}async function Dg(){return g("/sandbox/reset",{method:"POST"},!0)}async function Fg(){return g("/sandbox/status",{},!0)}async function WQ(D){return g(`/datasets/${D}/publish/request`,{method:"POST"},!0)}async function $g(D){return g(`/datasets/${D}/publish/status`,{},!0)}async function Jg(D){return g(`/datasets/${D}/publish/resend`,{method:"POST"},!0)}async function Qg(D){let F=D?`?status=${D}`:"";return g(`/admin/publish/requests${F}`,{},!0)}async function Yg(D,F){return g(`/admin/publish/${D}/deny`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({reason:F})},!0)}function CE0(D,F=[]){if(D){let $=v9.indexOf(D);if($>=0)return $+1}return Math.min(F.length+1,v9.length)}function OE0(D){if(!(D instanceof h))return!1;if(D.statusCode===0)return!0;if(D.statusCode===429)return!0;if(D.statusCode>=500&&D.statusCode<600)return!0;if(D.statusCode===403&&/repository has been locked/i.test(D.message))return!0;return!1}async function HQ(D,F=!1,$=!1,J=!1,Q,Y){let G,H,q=0,K=!1,V,E=F,Z=[],L;function A(M,N,j,S){if(!Y)return;Y({step:M,stepIndex:CE0(M,N),stepTotal:v9.length,s3LockLocked:j,s3LockTotal:S,s3LockResumed:M==="s3_lock"&&K?!0:void 0})}for(let M=1;M<=5;M++)try{let N,j=!0;do{if(N=await g(`/admin/publish/${D}/approve`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({resume:j?E:!0,sandbox:$,s3_lock_continuation_token:G,s3_lock_total:H,skip_ci_check:J})},!0),j=!1,N.step_results)Z.push(...N.step_results);if(N.s3_lock_total!==void 0)H=N.s3_lock_total;if(N.s3_lock_batch_count!==void 0)q+=N.s3_lock_batch_count;let S=N.step??N.step_results?.[N.step_results.length-1]?.step;if(S&&(S!==V||S==="s3_lock"))A(S,N.steps_completed??[],S==="s3_lock"?q:void 0,S==="s3_lock"?H:void 0),V=S;if(N.hasMore&&N.s3_lock_continuation_token!==void 0)G=N.s3_lock_continuation_token;else break}while(N.hasMore);if(Z.length>0)N.step_results=Sf(Z);return N}catch(N){if(L=N,M===5||!OE0(N)){if(N instanceof h&&Z.length>0)N.stepResults=Sf(Z);throw N}let S=N;if(Q?.({attempt:M,maxAttempts:5,delayMs:1e4,step:S.step,error:S.message}),await new Promise((O)=>setTimeout(O,1e4)),E=!0,G!==void 0)K=!0}throw L}function Sf(D){let F=new Map;for(let $ of D)F.set($.step,$);return Array.from(F.values())}async function Bg(D,F){return g(`/admin/datasets/${D}/enrichment`,{method:"POST",body:JSON.stringify(F)},!0)}async function Xg(D){return g(`/admin/datasets/${D}/files`,{},!0)}async function Gg(D){let F,$=0,J=[],Q=!0;while(Q){let Y=await g(`/admin/datasets/${D}/s3-lock`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({continuation_token:F})},!0);if($+=Y.locked,Y.failed?.length)J.push(...Y.failed);if(Q=Y.hasMore,F=Y.continuation_token,Q&&!F)throw new h(500,"S3 lock paginated response missing continuation_token; aborting to avoid infinite loop")}return{locked:$,failed:J}}async function Wg(D){return g(`/admin/datasets/${D}/reset`,{method:"POST"},!0)}async function Hg(D,F=!1){return g(`/admin/datasets/${D}`,{method:"DELETE",headers:{"Content-Type":"application/json"},body:JSON.stringify({force:F})},!0)}async function qg(D){return g("/admin/datasets/bulk-delete",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({dataset_ids:D})},!0)}async function Kg(D){return g("/admin/datasets/import",{method:"POST",body:JSON.stringify(D)},!0)}async function zg(D){return g(`/admin/datasets/${D}/sync`,{method:"POST"},!0)}async function Eg(){return g("/admin/sync/status",{},!0)}async function qQ(D,F){return g(`/admin/datasets/${D}/reindex`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(F??{})},!0)}async function Vg(D,F){return g("/admin/datasets/reindex/bulk",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({filter:D,...F??{}})},!0)}async function Zg(){return g("/admin/email-preferences",{},!0)}async function Ug(D){return g("/admin/email-preferences",{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(D)},!0)}async function Lg(){return g("/notices",{},"optional")}async function Ag(){return g("/admin/notices",{},!0)}async function Mg(D){return g("/admin/notices",{method:"POST",body:JSON.stringify(D)},!0)}async function Ng(D){return g(`/admin/notices/${D}`,{method:"DELETE"},!0)}async function gW(D){return g("/admin/notify",{method:"POST",body:JSON.stringify(D)},!0)}async function Rg(){return g("/admin/summary/coverage",{},!0)}async function Cg(D,F,$){return g("/admin/manifest/dispatch",{method:"POST",body:JSON.stringify({dataset_id:D,version:F,skip_canary:$?.skipCanary??!1})},!0)}var SW="https://nemar-api-dev.sccn-org.workers.dev",FQ,h,$Q,kW,v9;var s8=P(()=>{f4();IW();DQ();FQ=/^\d{4}-\d{4}-\d{4}-\d{3}[\dX]$/;h=class h extends Error{statusCode;details;step;constructor(D,F,$,J){super(F);this.statusCode=D;this.details=$;this.step=J;this.name="ApiError"}};$Q=class $Q extends h{mode;eta;constructor(D,F,$,J){super(503,F,J);this.mode=D;this.eta=$;this.name="MaintenanceError"}};kW=SW.includes("workers.dev");v9=["ci_check","enrichment_check","repo_public","s3_public_read","tag_protect","doi_create","update_metadata","update_readme","create_tag","create_release","upload_to_zenodo","publish_doi","version_doi","s3_lock","sync_nemar","notify_user"]});function jg(D){hW=D}function bW(){return hW}function _9(D){if(hW)process.stderr.write(`${D}
98
+ `)}var wf=!1;var IW=P(()=>{jD()});var Pf;var Tf=P(()=>{Pf={name:"nemar-cli",version:"0.8.49-dev.1348",description:"CLI for NEMAR (Neuroelectromagnetic Data Archive and Tools Resource) dataset management",type:"module",main:"dist/index.js",bin:{nemar:"dist/index.js"},scripts:{dev:"bun run src/index.ts",build:"bun build src/index.ts --outdir dist --target bun --minify && sed '1s|#!/usr/bin/env node|#!/usr/bin/env bun|' dist/index.js > dist/index.js.tmp && mv dist/index.js.tmp dist/index.js",test:"bun test",lint:"biome check src/","lint:fix":"biome check --fix src/",format:"biome format --write src/",typecheck:"tsc --noEmit",prepublishOnly:"bun run build",prepare:"husky",postinstall:"bun scripts/postinstall-check.mjs",deploy:"wrangler deploy",preview:"wrangler dev"},keywords:["nemar","bids","neuroimaging","eeg","emg","datalad","cli"],author:"NEMAR Team",license:"CC-BY-NC-ND-4.0",repository:{type:"git",url:"git+https://github.com/nemarOrg/nemar-cli.git"},bugs:{url:"https://github.com/nemarOrg/nemar-cli/issues"},homepage:"https://docs.nemar.org",engines:{bun:">=1.0.0"},files:["dist","scripts/postinstall-check.mjs","README.md","LICENSE"],dependencies:{chalk:"^5.3.0",commander:"^12.1.0",conf:"^13.0.1","fuse.js":"^7.1.0",inquirer:"^9.2.15",ora:"^8.0.1",zod:"^3.23.8"},"lint-staged":{"src/**/*.{ts,tsx}":["biome check --fix"],"backend/src/**/*.{ts,tsx}":["biome check --fix"]},devDependencies:{"@biomejs/biome":"1.9.4","@types/bcryptjs":"^3.0.0","@types/bun":"latest","@types/inquirer":"^9.0.7",bcryptjs:"^3.0.3",husky:"^9.1.7","lint-staged":"^16.3.2",typescript:"^5.5.4",wrangler:"^4.70.0",yaml:"^2.8.4"}}});var g4;var DQ=P(()=>{Tf();g4=Pf.version});function C0(D){if(D instanceof Error)return D.message;return String(D)}function If(){if(process.env.TEST_API_URL)return process.env.TEST_API_URL;if(kW)return SW;return BD().apiUrl||SW}async function g(D,F={},$=!1){let J=`${If()}${D}`,Q={"Content-Type":"application/json","X-CLI-Version":g4,...F.headers};if($){let X=BD();if(!X.apiKey&&$===!0)throw new h(401,"Not authenticated. Run 'nemar auth login' first.");if(X.apiKey)Q.Authorization=`Bearer ${X.apiKey}`}let Y;try{Y=await fetch(J,{...F,headers:Q})}catch(X){throw new h(0,`Network error: Could not connect to ${If()}`,{originalError:X instanceof Error?X.message:String(X)})}let B;try{B=await Y.json()}catch{throw new h(Y.status,`Invalid response from server (status ${Y.status})`)}if(!Y.ok){if(Y.status===503&&(B.mode==="read-only"||B.mode==="full")){let X=typeof B.message==="string"?B.message:"NEMAR is in maintenance mode. Please retry shortly.",G=typeof B.eta==="string"?B.eta:null,H=new $Q(B.mode,X,G,B.details);throw eJ(H),H}throw new h(Y.status,B.error||B.message||"Request failed",B.details,typeof B.step==="string"?B.step:void 0)}return B}async function kf(D){return g(`/auth/check-username?username=${encodeURIComponent(D)}`)}async function vf(D){return g(`/auth/check-github?username=${encodeURIComponent(D)}`)}async function yf(D){return g("/auth/signup",{method:"POST",body:JSON.stringify(D)})}async function xf(D){return g("/auth/login",{method:"POST",body:JSON.stringify({api_key:D})})}async function _f(D){return g("/auth/resend-verification",{method:"POST",body:JSON.stringify({email:D})})}async function ff(D,F){return g("/auth/retrieve-key",{method:"POST",body:JSON.stringify({email:D,password:F})})}async function gf(D){return g("/auth/request-key-regeneration",{method:"POST",body:JSON.stringify({email:D})})}async function JQ(){return g("/users/me",{},!0)}async function hf(D,F){let $=new URLSearchParams;if(D)$.set("status",D);if(F)$.set("role",F);let J=$.toString()?`?${$.toString()}`:"";return g(`/admin/users${J}`,{},!0)}async function bf(D){return g(`/admin/approve/${D}`,{method:"POST"},!0)}async function uf(D){return g(`/admin/revoke/${D}`,{method:"POST"},!0)}async function mf(D,F){return g(`/admin/users/${D}/role`,{method:"POST",body:JSON.stringify({role:F})},!0)}async function vW(D,F){return g(`/admin/datasets/${D}/visibility`,{method:"PATCH",body:JSON.stringify({visibility:F})},!0)}async function lf(D){return g(`/datasets/${D}/publish`,{method:"POST"},!0)}async function pf(D){return g(`/admin/datasets/${D}/ci`,{},!0)}async function h4(D){return g(`/admin/datasets/${D}/ci`,{method:"POST"},!0)}async function yW(D){return g(`/admin/datasets/${D}/ci/validate`,{method:"POST"},!0)}async function xW(D){return g(`/admin/datasets/${D}/ci/sync`,{method:"POST"},!0)}async function QQ(D){return g(`/datasets/${D}/ci/status`,{},!0)}async function df(D){return g(`/datasets/${D}/manifest`,{},!0)}async function YQ(D,F){return g(`/datasets/${D}/manifest/${F}`,{},!0)}function cf(D){let F=D;if(!F.status)F.status="active";else if(!["active","archived","deleted"].includes(F.status))throw Error(`Invalid dataset status: ${F.status}`);if(!F.visibility)F.visibility="private";else if(!["public","private"].includes(F.visibility))throw Error(`Invalid dataset visibility: ${F.visibility}`);return F}async function y9(D={}){let F=new URLSearchParams;if(D.mine)F.set("mine","true");if(D.search)F.set("search",D.search);if(D.modality)F.set("modality",D.modality);if(D.author)F.set("author",D.author);if(D.task)F.set("task",D.task);if(D.license)F.set("license",D.license);if(D.hasDoi)F.set("has_doi","true");if(D.recent)F.set("recent",String(D.recent));if(D.sort)F.set("sort",D.sort);if(D.limit!=null)F.set("limit",String(D.limit));if(D.offset!=null)F.set("offset",String(D.offset));if(D.owner)F.set("owner",D.owner);let $=F.toString()?`?${F.toString()}`:"",J=await g(`/datasets${$}`,{},D.mine?!0:"optional");return J.datasets=J.datasets.map(cf),J}async function nf(D){return g(`/datasets/resolve/${D}`,{},"optional")}async function af(D,F={}){let $=new URLSearchParams({q:D});if(F.modality)$.set("modality",F.modality);if(F.limit)$.set("limit",String(F.limit));return g(`/datasets/search?${$.toString()}`,{},"optional")}async function uD(D){let F=await g(`/datasets/${D}`,{},"optional");return cf(F.dataset)}async function of(D){return g(`/datasets/${D}/versions`,{},!0)}async function BQ(D){return g("/datasets",{method:"POST",body:JSON.stringify(D)},!0)}async function XQ(D){return g(`/datasets/${D}/finalize`,{method:"POST"},!0)}async function w8(D,F){return g(`/datasets/${D}/upload-credentials`,{method:"POST",body:JSON.stringify({duration_seconds:F})},!0)}async function GQ(D,F){return g(`/datasets/${D}/download-credentials`,{method:"POST",body:JSON.stringify({duration_seconds:F})},!0)}async function sf(D,F){return g(`/admin/datasets/${D}/doi/concept`,{method:"POST",body:JSON.stringify(F)},!0)}async function x9(D){return g(`/admin/datasets/${D}/doi`,{},!0)}async function _W(D,F){return g(`/admin/datasets/${D}/doi/update`,{method:"POST",body:JSON.stringify(F)},!0)}async function fW(D){return g(`/datasets/${D}/request-access`,{method:"POST"},!0)}async function rf(D,F){return g(`/datasets/${D}/invite`,{method:"POST",body:JSON.stringify({username:F})},!0)}async function tf(D){return g(`/datasets/${D}/collaborators`,{},!0)}async function ef(D){return g("/sandbox/complete",{method:"POST",body:JSON.stringify({dataset_id:D})},!0)}async function Dg(){return g("/sandbox/reset",{method:"POST"},!0)}async function Fg(){return g("/sandbox/status",{},!0)}async function WQ(D){return g(`/datasets/${D}/publish/request`,{method:"POST"},!0)}async function $g(D){return g(`/datasets/${D}/publish/status`,{},!0)}async function Jg(D){return g(`/datasets/${D}/publish/resend`,{method:"POST"},!0)}async function Qg(D){let F=D?`?status=${D}`:"";return g(`/admin/publish/requests${F}`,{},!0)}async function Yg(D,F){return g(`/admin/publish/${D}/deny`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({reason:F})},!0)}function CE0(D,F=[]){if(D){let $=v9.indexOf(D);if($>=0)return $+1}return Math.min(F.length+1,v9.length)}function OE0(D){if(!(D instanceof h))return!1;if(D.statusCode===0)return!0;if(D.statusCode===429)return!0;if(D.statusCode>=500&&D.statusCode<600)return!0;if(D.statusCode===403&&/repository has been locked/i.test(D.message))return!0;return!1}async function HQ(D,F=!1,$=!1,J=!1,Q,Y){let G,H,q=0,K=!1,V,E=F,Z=[],L;function A(M,N,j,S){if(!Y)return;Y({step:M,stepIndex:CE0(M,N),stepTotal:v9.length,s3LockLocked:j,s3LockTotal:S,s3LockResumed:M==="s3_lock"&&K?!0:void 0})}for(let M=1;M<=5;M++)try{let N,j=!0;do{if(N=await g(`/admin/publish/${D}/approve`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({resume:j?E:!0,sandbox:$,s3_lock_continuation_token:G,s3_lock_total:H,skip_ci_check:J})},!0),j=!1,N.step_results)Z.push(...N.step_results);if(N.s3_lock_total!==void 0)H=N.s3_lock_total;if(N.s3_lock_batch_count!==void 0)q+=N.s3_lock_batch_count;let S=N.step??N.step_results?.[N.step_results.length-1]?.step;if(S&&(S!==V||S==="s3_lock"))A(S,N.steps_completed??[],S==="s3_lock"?q:void 0,S==="s3_lock"?H:void 0),V=S;if(N.hasMore&&N.s3_lock_continuation_token!==void 0)G=N.s3_lock_continuation_token;else break}while(N.hasMore);if(Z.length>0)N.step_results=Sf(Z);return N}catch(N){if(L=N,M===5||!OE0(N)){if(N instanceof h&&Z.length>0)N.stepResults=Sf(Z);throw N}let S=N;if(Q?.({attempt:M,maxAttempts:5,delayMs:1e4,step:S.step,error:S.message}),await new Promise((O)=>setTimeout(O,1e4)),E=!0,G!==void 0)K=!0}throw L}function Sf(D){let F=new Map;for(let $ of D)F.set($.step,$);return Array.from(F.values())}async function Bg(D,F){return g(`/admin/datasets/${D}/enrichment`,{method:"POST",body:JSON.stringify(F)},!0)}async function Xg(D){return g(`/admin/datasets/${D}/files`,{},!0)}async function Gg(D){let F,$=0,J=[],Q=!0;while(Q){let Y=await g(`/admin/datasets/${D}/s3-lock`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({continuation_token:F})},!0);if($+=Y.locked,Y.failed?.length)J.push(...Y.failed);if(Q=Y.hasMore,F=Y.continuation_token,Q&&!F)throw new h(500,"S3 lock paginated response missing continuation_token; aborting to avoid infinite loop")}return{locked:$,failed:J}}async function Wg(D){return g(`/admin/datasets/${D}/reset`,{method:"POST"},!0)}async function Hg(D,F=!1){return g(`/admin/datasets/${D}`,{method:"DELETE",headers:{"Content-Type":"application/json"},body:JSON.stringify({force:F})},!0)}async function qg(D){return g("/admin/datasets/bulk-delete",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({dataset_ids:D})},!0)}async function Kg(D){return g("/admin/datasets/import",{method:"POST",body:JSON.stringify(D)},!0)}async function zg(D){return g(`/admin/datasets/${D}/sync`,{method:"POST"},!0)}async function Eg(){return g("/admin/sync/status",{},!0)}async function qQ(D,F){return g(`/admin/datasets/${D}/reindex`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(F??{})},!0)}async function Vg(D,F){return g("/admin/datasets/reindex/bulk",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({filter:D,...F??{}})},!0)}async function Zg(){return g("/admin/email-preferences",{},!0)}async function Ug(D){return g("/admin/email-preferences",{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(D)},!0)}async function Lg(){return g("/notices",{},"optional")}async function Ag(){return g("/admin/notices",{},!0)}async function Mg(D){return g("/admin/notices",{method:"POST",body:JSON.stringify(D)},!0)}async function Ng(D){return g(`/admin/notices/${D}`,{method:"DELETE"},!0)}async function gW(D){return g("/admin/notify",{method:"POST",body:JSON.stringify(D)},!0)}async function Rg(){return g("/admin/summary/coverage",{},!0)}async function Cg(D,F,$){return g("/admin/manifest/dispatch",{method:"POST",body:JSON.stringify({dataset_id:D,version:F,skip_canary:$?.skipCanary??!1})},!0)}var SW="https://nemar-api-dev.sccn-org.workers.dev",FQ,h,$Q,kW,v9;var s8=P(()=>{f4();IW();DQ();FQ=/^\d{4}-\d{4}-\d{4}-\d{3}[\dX]$/;h=class h extends Error{statusCode;details;step;constructor(D,F,$,J){super(F);this.statusCode=D;this.details=$;this.step=J;this.name="ApiError"}};$Q=class $Q extends h{mode;eta;constructor(D,F,$,J){super(503,F,J);this.mode=D;this.eta=$;this.name="MaintenanceError"}};kW=SW.includes("workers.dev");v9=["ci_check","enrichment_check","repo_public","s3_public_read","tag_protect","doi_create","update_metadata","update_readme","create_tag","create_release","upload_to_zenodo","publish_doi","version_doi","s3_lock","sync_nemar","notify_user"]});function jg(D){hW=D}function bW(){return hW}function _9(D){if(hW)process.stderr.write(`${D}
99
99
  `)}var hW=!1;function GD(D){if(D===0)return"0 B";let F=["B","KB","MB","GB","TB"],$=Math.min(Math.floor(Math.log(D)/Math.log(1024)),F.length-1);return`${(D/1024**$).toFixed($===0?0:1)} ${F[$]}`}function wg(D){return`${GD(D)}/s`}function jE0(D){if(D<60)return`${Math.round(D)}s`;if(D<3600)return`${Math.floor(D/60)}m ${Math.round(D%60)}s`;return`${Math.floor(D/3600)}h ${Math.floor(D%3600/60)}m`}function wE0(D,F=20){let $=Math.round(D/100*F),J=F-$;return`[${"=".repeat($)}${" ".repeat(J)}]`}class KQ{filesCompleted=0;filesTotal;bytesTotal=0;inFlight=new Map;currentFile="";startTime;lastUpdateTime;lastBytesTransferred=0;totalBytesTransferred=0;speedSamples=[];lastRenderedLine="";constructor(D=0,F=0){this.filesTotal=D,this.bytesTotal=F,this.startTime=Date.now(),this.lastUpdateTime=this.startTime}inFlightBytes(){let D=0;for(let F of this.inFlight.values())D+=F.transferred;return D}processLine(D){let F=D.file??D.action?.file;if(D.ok===!0||D.success===!0){this.filesCompleted++;let $=F??this.currentFile,J=$?this.inFlight.get($):void 0,Q=J?J.total||J.transferred:0;if(this.totalBytesTransferred+=Q,$)this.inFlight.delete($);this.render();return}if(D["byte-progress"]!==void 0){let $=F??this.currentFile;if(!$)return;this.currentFile=$;let J=this.inFlight.get($)??{transferred:0,total:0};if(J.transferred=D["byte-progress"]??J.transferred,D["total-size"]!==void 0)J.total=D["total-size"];this.inFlight.set($,J);let Q=Date.now(),Y=(Q-this.lastUpdateTime)/1000;if(Y>0.5){let B=this.totalBytesTransferred+this.inFlightBytes(),G=(B-this.lastBytesTransferred)/Y;if(G>0){if(this.speedSamples.push(G),this.speedSamples.length>5)this.speedSamples.shift()}this.lastBytesTransferred=B,this.lastUpdateTime=Q}this.render()}}incrementFilesCompleted(){this.filesCompleted++}setFilesTotal(D){this.filesTotal=D}setBytesTotal(D){this.bytesTotal=D}getPercent(){let D=this.totalBytesTransferred+this.inFlightBytes();if(this.bytesTotal>0)return Math.min(100,Math.round(D/this.bytesTotal*100));if(this.filesTotal>0)return Math.min(100,Math.round(this.filesCompleted/this.filesTotal*100));return null}getProgress(){return{filesCompleted:this.filesCompleted,filesTotal:this.filesTotal,bytesTransferred:this.totalBytesTransferred+this.inFlightBytes(),bytesTotal:this.bytesTotal,currentFile:this.currentFile||void 0}}render(){let D=this.speedSamples.length>0?this.speedSamples.reduce((B,X)=>B+X,0)/this.speedSamples.length:0,F=this.totalBytesTransferred+this.inFlightBytes(),$=0,J=!1;if(this.bytesTotal>0)$=Math.min(100,Math.round(F/this.bytesTotal*100)),J=!0;else if(this.filesTotal>0)$=Math.min(100,Math.round(this.filesCompleted/this.filesTotal*100)),J=!0;let Q=this.filesTotal>0?`${this.filesCompleted}/${this.filesTotal} files`:`${this.filesCompleted} files`,Y;if(J)Y=`${wE0($)} ${$}% ${Q}`;else Y=Q;if(F>0){let B=this.bytesTotal>0?`${GD(F)}/${GD(this.bytesTotal)}`:GD(F);Y+=` | ${B}`}if(D>0)Y+=` | ${wg(D)}`;if(D>0){let B=0;if(this.bytesTotal>0)B=Math.max(0,this.bytesTotal-F);else for(let X of this.inFlight.values())if(X.total>X.transferred)B+=X.total-X.transferred;if(B>0){let X=B/D;if(X>0)Y+=` | ETA ${jE0(X)}`}}if(Y!==this.lastRenderedLine)process.stderr.write(`\r${W.cyan(Y)}${" ".repeat(10)}`),this.lastRenderedLine=Y}finish(D){let F=(Date.now()-this.startTime)/1000;if(process.stderr.write(`\r${" ".repeat(this.lastRenderedLine.length+15)}\r`),D>0){let $=F>0?`${wg(this.totalBytesTransferred/F)}`:"",J=[`${D} file${D!==1?"s":""} downloaded`,this.totalBytesTransferred>0?GD(this.totalBytesTransferred):"",$].filter(Boolean).join(" | ");process.stderr.write(`${W.green(J)}
100
100
  `)}}}var uW=P(()=>{jD()});var bg={};a4(bg,{verifyGitHubAuth:()=>g9,toS3Credentials:()=>CD,switchBranch:()=>fE0,setKeyPresent:()=>hg,selectAnnexS3Remote:()=>aW,saveDataset:()=>t8,runCommand:()=>I,resolveUpstreamRef:()=>$H,readRemoteHeadDatasetVersion:()=>FH,readLocalDatasetVersion:()=>DH,pushToGitHub:()=>r1,pushBranch:()=>vF,markInheritedOpenNeuroRemotesIgnored:()=>iW,listDatasetVersions:()=>sW,isWorkingTreeDirty:()=>JH,isGitAnnexDataset:()=>j1,isDataladDataset:()=>mE0,initOrEnableSpecialRemote:()=>_g,initDataset:()=>o6,gitMergeFastForward:()=>YH,gitFetchOrigin:()=>QH,gitAnnexAdd:()=>s6,getVersionCommit:()=>rW,getRemoteUuid:()=>WH,getLocalDatasetInfo:()=>oW,getKeyHashDirs:()=>bE0,getKeyHashDir:()=>gg,getDatasetStats:()=>yE0,getDatasetIdFromRemote:()=>D6,getDatasetData:()=>ZQ,getCurrentBranch:()=>e8,getAnnexWhereisAll:()=>GH,getAnnexS3Remotes:()=>b9,formatBytes:()=>GD,ensureLocalMainBranch:()=>u9,ensureGitAnnexInitialized:()=>cW,enableS3Remote:()=>u4,dropUnusedAnnexObjects:()=>BH,dropFiles:()=>nW,detectImportMarker:()=>VQ,createRevertBranch:()=>tW,createDataladDataset:()=>uE0,countPendingDownload:()=>EQ,copyToAnnexRemote:()=>P8,configureS3Remote:()=>T8,configureLargefiles:()=>b4,configureGitHubRemote:()=>r8,commitRevert:()=>eW,collectFileManifest:()=>XH,cloneDataset:()=>t1,clearAnnexCredentials:()=>vD,checkPrerequisites:()=>f9,checkGitHubSSH:()=>kg,checkGitAnnexInstalled:()=>dW,checkDownloadPrerequisites:()=>kF,checkAWSCredentials:()=>SE0,batchSetKeysPresent:()=>HH,annexRemoteExists:()=>xg,acceptGitHubInvitation:()=>h9,NEMAR_S3_REMOTE_NAME:()=>zQ,ANNEX_REMOTE_EXISTS_RE:()=>yg});import{existsSync as lW,readFileSync as TE0,statSync as PE0}from"fs";import{join as pW}from"path";var{spawn:Sg}=globalThis.Bun;async function I(D,F={}){let $=Sg({cmd:D,cwd:F.cwd,stdout:"pipe",stderr:"pipe",env:{...process.env,GIT_TERMINAL_PROMPT:"0",...F.env}}),J=!1,Q;if(F.timeout)Q=setTimeout(()=>{J=!0,$.kill()},F.timeout);if(bW()){let G=F.cwd?` (cwd=${F.cwd})`:"";_9(W.dim(`$ ${D.join(" ")}${G}`))}let Y=await new Response($.stdout).text(),B=await new Response($.stderr).text(),X=await $.exited;if(Q)clearTimeout(Q);if(bW()){if(Y.trim())_9(W.dim(Y.trimEnd()));if(B.trim())_9(W.yellow(B.trimEnd()));_9(W.dim(`(exit ${X})`))}if(J)return{stdout:Y,stderr:B||`Command timed out after ${Math.round(F.timeout/1000)}s`,exitCode:X??1};return{stdout:Y,stderr:B,exitCode:X}}function Tg(D){return D.split(".").map((F)=>{let $=Number.parseInt(F.replace(/[^0-9]/g,""),10);return Number.isNaN($)?0:$})}function IE0(D,F){let $=Tg(D),J=Tg(F);for(let Q=0;Q<Math.max($.length,J.length);Q++){let Y=$[Q]||0,B=J[Q]||0;if(Y>B)return!0;if(Y<B)return!1}return!0}async function dW(){try{let{stdout:F,exitCode:$,stderr:J}=await I(["git-annex","version"]);if($!==0)return console.warn("git-annex version returned non-zero exit code:",$),console.warn("stderr:",J),{installed:!1,minVersion:"10.0",error:`Version check failed: ${J.trim()}`};let Q=F.match(/version:\s*(\d+\.\d+)/),Y=Q?Q[1]:void 0;if(!Y)console.warn("Could not parse git-annex version from output:",F);return{installed:!0,version:Y,minVersion:"10.0",compatible:Y?IE0(Y,"10.0"):void 0}}catch(F){let $=F instanceof Error?F.message:String(F);if($.includes("ENOENT")||$.includes("not found"))return console.info("git-annex not found in PATH"),{installed:!1,minVersion:"10.0"};return console.error("Error checking git-annex installation:",$),{installed:!1,minVersion:"10.0",error:$}}}async function kg(){if(process.env.GH_TOKEN)return{accessible:!0,username:"token-auth",useHttps:!0};try{let{stdout:D,stderr:F}=await I(["ssh","-T","-o","BatchMode=yes","-o","StrictHostKeyChecking=accept-new","-o","ConnectTimeout=10","git@github.com"]),$=D+F,J=$.match(/Hi ([^!]+)!/);if(J)return{accessible:!0,username:J[1]};if($.includes("Permission denied"))return{accessible:!1};return{accessible:$.includes("successfully authenticated")}}catch(D){let F=D instanceof Error?D.message:String(D);if(F.includes("ENOENT")||F.includes("not found"))console.info("SSH command not found");else console.error("Error checking GitHub SSH access:",F);return{accessible:!1}}}async function SE0(){if(process.env.AWS_ACCESS_KEY_ID&&process.env.AWS_SECRET_ACCESS_KEY)return{configured:!0,source:"environment"};try{let{stdout:D,exitCode:F}=await I(["aws","configure","get","aws_access_key_id"]);if(F===0&&D.trim())return{configured:!0,source:"aws-cli"}}catch(D){let F=D instanceof Error?D.message:String(D);if(F.includes("ENOENT")||F.includes("not found"))console.info("AWS CLI not found in PATH");else console.error("Error checking AWS credentials:",F)}return{configured:!1}}function vg(){let D=process.platform;if(D==="darwin")return"brew install git-annex";if(D==="linux")return"apt install git-annex (Debian/Ubuntu)";return"See https://git-annex.branchable.com/install/"}async function f9(){let[D,F]=await Promise.all([dW(),kg()]),$=[];if(!D.installed)$.push(`git-annex is not installed. Install: ${vg()}`);else if(D.compatible===!1)$.push(`git-annex version ${D.version} is too old. Required: >= ${D.minVersion}`);if(!F.accessible){if(!(await fg()).token)$.push("GitHub authentication not configured. Run 'gh auth login' to authenticate.")}return{gitAnnex:D,githubSSH:F,allPassed:$.length===0,errors:$}}async function j1(D){if(!lW(pW(D,".git")))return!1;try{let{exitCode:F}=await I(["git","annex","info"],{cwd:D});return F===0}catch(F){let $=F instanceof Error?F.message:String(F);if(!$.includes("ENOENT")&&!$.includes("not found"))console.error(`Error checking if ${D} is a git-annex dataset:`,$);return!1}}async function o6(D,F={}){if(!F.force&&await j1(D))return{success:!0};try{let $={};if(F.author)$.GIT_AUTHOR_NAME=F.author.name,$.GIT_AUTHOR_EMAIL=F.author.email,$.GIT_COMMITTER_NAME=F.author.name,$.GIT_COMMITTER_EMAIL=F.author.email;let{stderr:J,exitCode:Q}=await I(["git","init","-b","main",D],{...Object.keys($).length>0?{env:$}:{}});if(Q!==0)return{success:!1,error:J.trim()||"Failed to initialize git repository"};let Y=Object.keys($).length>0?{env:$}:{},{stderr:B,exitCode:X}=await I(["git","annex","init"],{cwd:D,...Y});if(X!==0)return{success:!1,error:B.trim()||"Failed to initialize git-annex"};let{stderr:G,exitCode:H}=await I(["git","commit","--allow-empty","-m","Initialize dataset"],{cwd:D,...Y});if(H!==0)return{success:!1,error:G.trim()||"Failed to create initial commit"};let{stderr:q,exitCode:K}=await I(["git","annex","adjust","--unlock"],{cwd:D,...Y});if(K!==0)return{success:!1,error:q.trim()||"Failed to switch to unlocked mode"};return{success:!0}}catch($){return{success:!1,error:$.message}}}async function cW(D){try{let{exitCode:F,stderr:$}=await I(["git","annex","info"],{cwd:D});if(F===0)return{success:!0};if($.includes("First run: git-annex init")){let{stderr:J,exitCode:Q}=await I(["git","annex","init"],{cwd:D});if(Q!==0)return{success:!1,error:J.trim()||"Failed to initialize git-annex"};return{success:!0}}return{success:!1,error:$.trim()||"Failed to check git-annex status"}}catch(F){return{success:!1,error:F.message}}}async function b4(D,F){let $=["*.edf","*.bdf","*.set","*.fif","*.vhdr","*.eeg","*.cnt","*.fdt"],J=["*.tsv","*.json","*.md","*.txt","*.yml","*.yaml","README*","LICENSE*","CHANGES*",".bidsignore",".gitignore"],Q=$.map((G)=>`include=${G}`).join(" or "),Y=J.map((G)=>`exclude=${G}`).join(" and "),B=`(${Q} or largerthan=100kb) and ${Y}`,X=F||B;try{let{stderr:G,exitCode:H}=await I(["git","annex","config","--set","annex.largefiles",X],{cwd:D});if(H!==0)return{success:!1,error:G.trim()||"Failed to configure largefiles"};return{success:!0}}catch(G){return{success:!1,error:G.message}}}async function s6(D,F="."){try{let{stderr:$,exitCode:J}=await I(["git","annex","add",F],{cwd:D});if(J!==0)return{success:!1,error:$.trim()||"Failed to add files to git-annex"};return{success:!0}}catch($){return{success:!1,error:$.message}}}function CD(D){return{accessKeyId:D.access_key_id,secretAccessKey:D.secret_access_key,sessionToken:D.session_token}}function mW(D){let F=[/^\(merging .* into .*\.\.\.\)$/,/^\(recording state in git\.\.\.\)$/,/^\(scanning for /,/^\(checking /];return D.split(`
101
101
  `).filter(($)=>{let J=$.trim();if(!J)return!1;if(J.includes("setting annex-ignore"))return!1;if(F.some((Q)=>Q.test(J)))return!1;return!0}).join(`
@@ -381,7 +381,7 @@ nemar.org Sync Status (${F.total} datasets)
381
381
  `)),console.log(` Synced: ${W.green(F.synced)} Failed: ${W.red(F.failed)} Pending: ${W.yellow(F.pending)}
382
382
  `),F.datasets.length===0){console.log(W.dim(" No published datasets found."));return}console.log(W.dim(` ${"ID".padEnd(12)} ${"Name".padEnd(40)} ${"Status".padEnd(10)} ${"Last Sync".padEnd(20)}`)),console.log(W.dim(` ${"\u2500".repeat(85)}`));for(let $ of F.datasets){let J=$.nemar_sync_status||"pending",Q=J==="synced"?W.green:J==="failed"?W.red:W.yellow,Y=$.nemar_sync_at?new Date($.nemar_sync_at).toLocaleDateString():"-",B=$.name||$.dataset_id,X=B.length>38?`${B.substring(0,35)}...`:B;if(console.log(` ${$.dataset_id.padEnd(12)} ${X.padEnd(40)} ${Q(J.padEnd(10))} ${Y}`),$.nemar_sync_error)console.log(W.red(` Error: ${$.nemar_sync_error}`))}}catch(F){D.fail("Failed to fetch sync status"),console.error(W.red(C0(F)))}});o0.addCommand(UH);function Yh(D,F){let $=D.enrichment.status,J=$==="ok"?W.green("enrich:ok"):$==="failed"?W.red("enrich:failed"):W.dim("enrich:skipped"),Q=D.sync.status,Y=Q==="ok"?W.green("sync:ok"):Q==="failed"?W.red("sync:failed"):W.dim("sync:skipped"),B=D.sync.metadata_columns_written===!0?W.green("cols:written"):D.sync.metadata_columns_error?W.red("cols:failed"):"",X=F?.showRef&&D.enrichment.ref?W.dim(`@${D.enrichment.ref}`):"";if(console.log(` ${D.dataset_id.padEnd(12)} ${J}${X} ${Y} ${B}`),D.enrichment.error)console.log(W.red(` enrichment: ${D.enrichment.error}`));if(D.sync.errors?.length)for(let G of D.sync.errors)console.log(W.red(` sync: ${G}`));if(D.sync.metadata_columns_error)console.log(W.red(` metadata columns: ${D.sync.metadata_columns_error}`))}var Hh=new b0("reindex").description("Refresh dataset metadata: enrichment + nemar.org sync + first-class D1 columns");Hh.argument("[dataset-id]","Dataset ID to reindex (e.g., nm000103)").option("--all","Reindex every dataset with a GitHub repo").option("--missing-metadata","Reindex only datasets with NULL metadata columns").option("--stale","Reindex only datasets whose metadata is older than --older-than days").option("--older-than <days>","Threshold in days. Default 30 for --stale, 1 (24h) for --missing-metadata recency guard.").option("--skip-enrichment","Skip the LLM enrichment step").option("--skip-sync","Skip the nemar.org sync + D1 column refresh step").option("--ref <ref>","Ref to enrich from (single-dataset only; default: main)").option("--dry-run","List matched datasets without firing the reindex (bulk only)").action(async(D,F)=>{if(!y0())return;let $=[F.all,F.missingMetadata,F.stale].filter(Boolean).length;if(D&&$>0)console.error(W.red("Provide either a dataset-id OR a bulk flag (--all/--missing-metadata/--stale), not both")),process.exit(1);if(!D&&$===0)console.error(W.red("Provide a dataset-id or one of: --all, --missing-metadata, --stale")),process.exit(1);if($>1)console.error(W.red("Use only one of --all, --missing-metadata, --stale")),process.exit(1);if(F.skipEnrichment&&F.skipSync)console.error(W.red("--skip-enrichment and --skip-sync cannot both be set")),process.exit(1);if(D){let K=C(`Reindexing ${D}...`).start();try{let V={skip_enrichment:F.skipEnrichment===!0,skip_sync:F.skipSync===!0,...F.ref&&{ref:F.ref}},E=await qQ(D,V),Z=E.enrichment.status!=="failed"&&E.sync.status!=="failed";if(Z)K.succeed(`${D} reindexed`);else K.warn(`${D} reindexed with errors`);if(console.log(),Yh(E,{showRef:!0}),!Z)process.exit(1)}catch(V){K.fail(`Failed to reindex ${D}`),console.error(W.red(C0(V))),process.exit(1)}return}let J=F.all?"all":F.missingMetadata?"missing-metadata":"stale",Q={skip_enrichment:F.skipEnrichment===!0,skip_sync:F.skipSync===!0,dry_run:F.dryRun===!0};if(F.olderThan!==void 0){let K=Number.parseInt(F.olderThan,10);if(!Number.isFinite(K)||K<0)console.error(W.red(`Invalid --older-than: "${F.olderThan}"`)),process.exit(1);Q.older_than_days=K}else if(J==="missing-metadata")Q.older_than_days=1;else if(J==="stale")Q.older_than_days=30;let Y=F.dryRun?`Listing ${J} datasets...`:`Reindexing ${J} datasets...`,B=C(Y).start(),X;try{X=await Vg(J,Q)}catch(K){B.fail("Bulk reindex failed"),console.error(W.red(C0(K))),process.exit(1)}if(X.dry_run){if(B.succeed(`${X.total} datasets match filter=${J} (dry run, no changes)`),X.datasets)for(let K of X.datasets)console.log(W.dim(` - ${K}`));return}let G=X.results??[],H=G.filter((K)=>K.enrichment.status!=="failed"&&K.sync.status!=="failed").length,q=G.length-H;if(q===0)B.succeed(`${G.length}/${G.length} datasets reindexed in ${(X.elapsed_ms/1000).toFixed(1)}s`);else B.warn(`${H}/${G.length} ok; ${q} failed in ${(X.elapsed_ms/1000).toFixed(1)}s`);console.log();for(let K of G)Yh(K);if(q>0)process.exit(1)});o0.addCommand(Hh);var LH=new b0("email-preferences").description("Manage email notification preferences");LH.command("show").description("Show current email notification preferences").action(async()=>{if(!L0())console.error(W.red("Not authenticated. Run: nemar auth login")),process.exit(1);let D=C("Fetching email preferences...").start();try{let F=await Zg();D.succeed("Email notification preferences:"),console.log();let $=[{key:"user_approval",label:"User approval notifications"},{key:"publication_request",label:"Publication request notifications"},{key:"announcements",label:"Announcement emails"}];for(let J of $){let Y=F[J.key]?W.green("enabled"):W.dim("disabled");console.log(` ${J.label.padEnd(40)} ${Y}`)}console.log(),console.log(W.dim(" Use 'nemar admin email-preferences update' to change settings."))}catch(F){D.fail("Failed to fetch preferences"),console.error(W.red(C0(F)))}});LH.command("update").description("Update email notification preferences").option("--user-approval <bool>","Enable/disable user approval notifications").option("--publication-request <bool>","Enable/disable publication request notifications").option("--announcements <bool>","Enable/disable announcement emails").option("--all <bool>","Enable/disable all notifications").action(async(D)=>{if(!L0())console.error(W.red("Not authenticated. Run: nemar auth login")),process.exit(1);function F(Q){if(Q===void 0)return;let Y=Q.toLowerCase();if(Y==="true"||Y==="1"||Y==="on"||Y==="yes")return!0;if(Y==="false"||Y==="0"||Y==="off"||Y==="no")return!1;console.error(W.red(`Invalid boolean value: "${Q}". Use true/false, on/off, yes/no.`)),process.exit(1)}let $={};if(D.all!==void 0){let Q=F(D.all);$.user_approval=Q,$.publication_request=Q,$.announcements=Q}else{let Q=F(D.userApproval),Y=F(D.publicationRequest),B=F(D.announcements);if(Q===void 0&&Y===void 0&&B===void 0)console.error(W.red("No preferences specified.")),console.log(" --user-approval <bool> User approval notifications"),console.log(" --publication-request <bool> Publication request notifications"),console.log(" --announcements <bool> Announcement emails"),console.log(" --all <bool> All notifications"),process.exit(1);if(Q!==void 0)$.user_approval=Q;if(Y!==void 0)$.publication_request=Y;if(B!==void 0)$.announcements=B}let J=C("Updating email preferences...").start();try{let Q=await Ug($);J.succeed("Email preferences updated:"),console.log(),console.log(` User approval: ${Q.user_approval?W.green("enabled"):W.dim("disabled")}`),console.log(` Publication request: ${Q.publication_request?W.green("enabled"):W.dim("disabled")}`),console.log(` Announcements: ${Q.announcements?W.green("enabled"):W.dim("disabled")}`)}catch(Q){J.fail("Failed to update preferences"),console.error(W.red(C0(Q)))}});o0.addCommand(LH);var AQ=new b0("notice").description("Manage system notices displayed to CLI users");AQ.command("list").description("List all notices (including expired)").action(async()=>{if(!L0())console.error(W.red("Not authenticated. Run: nemar auth login")),process.exit(1);let D=C("Fetching notices...").start();try{let{notices:F}=await Ag();if(F.length===0){D.succeed("No notices found.");return}D.succeed(`${F.length} notice(s):`),console.log();for(let $ of F){let Q={critical:W.red.bold,warning:W.yellow,info:W.blue}[$.level]||W.white,Y=$.expires_at&&new Date($.expires_at)<new Date?W.dim(" (expired)"):"";if(console.log(` ${W.dim(`#${$.id}`)} ${Q(`[${$.level.toUpperCase()}]`)} ${W.dim(`scope:${$.scope}`)}${Y}`),console.log(` ${$.message}`),console.log(` ${W.dim(`Created: ${$.created_at}`)}`),$.expires_at)console.log(` ${W.dim(`Expires: ${$.expires_at}`)}`);console.log()}}catch(F){e0(F,D,"Failed to fetch notices")}});AQ.command("set").description("Create a new system notice").requiredOption("-m, --message <text>","Notice message text").option("-l, --level <level>","Notice level: info, warning, critical","info").option("-s, --scope <scope>","Target scope: all, admins, members","all").option("-e, --expires <datetime>","Expiry datetime (ISO 8601)").action(async(D)=>{if(!L0())console.error(W.red("Not authenticated. Run: nemar auth login")),process.exit(1);if(!["info","warning","critical"].includes(D.level))console.error(W.red(`Invalid level: ${D.level}. Use info, warning, or critical.`)),process.exit(1);if(!["all","admins","members"].includes(D.scope))console.error(W.red(`Invalid scope: ${D.scope}. Use all, admins, or members.`)),process.exit(1);let F=C("Creating notice...").start();try{let $=await Mg({message:D.message,level:D.level,scope:D.scope,expires_at:D.expires});if(F.succeed(`Notice created (ID: ${$.id})`),console.log(` Level: ${$.level}`),console.log(` Scope: ${$.scope}`),console.log(` Message: ${$.message}`),$.expires_at)console.log(` Expires: ${$.expires_at}`)}catch($){e0($,F,"Failed to create notice")}});AQ.command("clear <id>").description("Delete a notice by ID").option(j0,w0).option(g0,v0).action(async(D,F)=>{if(!L0())console.error(W.red("Not authenticated. Run: nemar auth login")),process.exit(1);let $=Number.parseInt(D,10);if(Number.isNaN($))console.error(W.red("Invalid notice ID")),process.exit(1);if(!await P0(`Delete notice #${$}?`,F,!1))return;let Q=C("Deleting notice...").start();try{await Ng($),Q.succeed(`Notice #${$} deleted`)}catch(Y){e0(Y,Q,"Failed to delete notice")}});o0.addCommand(AQ);o0.command("notify").description("Send an email to a group or a single user").option("--to <group>","Recipient group: all, admins, members").option("--user <username>","Send to a single user by username").requiredOption("--subject <text>","Email subject line").option("--body <text>","Email body (markdown)").option("--body-file <path>","Read email body from file (markdown)").option("--dry-run","Preview recipients without sending").option(j0,w0).option(g0,v0).action(async(D)=>{if(!L0())console.error(W.red("Not authenticated. Run: nemar auth login")),process.exit(1);if(D.to&&D.user)console.error(W.red("--to and --user are mutually exclusive. Provide exactly one.")),process.exit(1);if(!D.to&&!D.user)console.error(W.red("Provide either --to <group> or --user <username>.")),process.exit(1);if(D.to&&!["all","admins","members"].includes(D.to))console.error(W.red(`Invalid group: ${D.to}. Use all, admins, or members.`)),process.exit(1);let F;if(D.bodyFile){if(!Xh(D.bodyFile))console.error(W.red(`File not found: ${D.bodyFile}`)),process.exit(1);F=qV0(D.bodyFile,"utf-8")}else if(D.body)F=D.body;else console.error(W.red("Email body required. Use --body or --body-file.")),process.exit(1);let $=D.user?`user:${D.user}`:D.to,J=D.user?{user:D.user,subject:D.subject,body:F}:{to:D.to,subject:D.subject,body:F};if(D.dryRun){let X=C("Checking recipients...").start();try{let G=await gW({...J,dry_run:!0});if("dry_run"in G){X.succeed(`Dry run: ${G.recipient_count} recipient(s) for "${G.recipient_group}"`),console.log();for(let H of G.recipients)console.log(` ${H}`)}}catch(G){e0(G,X,"Failed to check recipients")}return}console.log(W.bold("Email preview:")),console.log(` To: ${W.cyan($)}`),console.log(` Subject: ${D.subject}`),console.log(` Body: ${F.length>100?`${F.substring(0,100)}...`:F}`),console.log();let Q=D.user?`Send this email to ${D.user}?`:"Send this broadcast email?";if(!await P0(Q,D,!1))return;let B=C(D.user?`Sending to ${D.user}...`:"Sending broadcast...").start();try{let X=await gW(J);if("broadcast_id"in X)if(X.failure_count>0){B.warn(`Email send: ${X.recipient_count} delivered, ${X.failure_count} failed`);for(let G of X.failed_recipients)console.log(W.red(` Failed: ${G}`))}else{let G=D.user?`Email sent to ${D.user}`:`Broadcast sent to ${X.recipient_count} recipient(s)`;B.succeed(`${G} (ID: ${X.broadcast_id})`)}}catch(X){e0(X,B,"Failed to send email")}});var EV0=1500;function VV0(D){switch(D.kind){case"ok":return W.green(`ok ${D.schema_version}`);case"stale":return W.yellow(`stale ${D.schema_version}`);case"missing":return W.red("missing");case"error":return W.red(`error ${D.status||"?"}: ${D.message}`)}}function ZV0(D){return D.kind==="stale"||D.kind==="missing"}function UV0(D){let $=D.replace(/[.+^${}()|[\]\\]/g,"\\$&").replace(/\*/g,".*").replace(/\?/g,".");return new RegExp(`^${$}$`)}var qh=new b0("summary").description("summary.json coverage across published dataset versions");qh.command("check").description("Report which (dataset_id, version) pairs have stale or missing summary.json").option("--fix","Dispatch generate-manifest for every stale/missing version").option("--id <id>","Limit to a single dataset_id (exact match)").option("--match <glob>","Limit to dataset_ids matching a glob pattern: `*` matches any run of chars, `?` matches one char. Examples: `on*`, `nm00010?`, `*99999`. Can be combined with --id (id wins if both passed).").option("--only-stale","Print only rows that are not ok (suppresses ok rows)").option("--json","Emit the full report as JSON instead of a table").option(j0,w0).option(g0,v0).action(async(D)=>{if(!y0())return;let F=C("Building coverage report...").start(),$;try{$=await Rg()}catch(V){e0(V,F,"Failed to fetch coverage report");return}F.succeed(`Coverage: target=schema ${$.target_schema}, versions=${$.totals.versions}`);let J=$.versions,Q=null;if(D.id){if(J=J.filter((V)=>V.dataset_id===D.id),Q=`dataset_id=${D.id}`,J.length===0){console.log(W.yellow(`No rows for ${Q}`));return}}else if(D.match){let V=UV0(D.match);if(J=J.filter((E)=>V.test(E.dataset_id)),Q=`--match ${D.match}`,J.length===0){console.log(W.yellow(`No rows match ${Q}`));return}console.log(W.dim(`Scoped to ${J.length} version(s) matching ${D.match}`))}if(D.json){console.log(JSON.stringify(Q?{...$,versions:J,totals:Bh(J)}:$,null,2));return}let Y=D.onlyStale?J.filter((V)=>V.state.kind!=="ok"):J;if(Y.length===0)console.log(W.green("All versions at target schema \u2014 no drift."));else{let V=Math.max(...Y.map((Z)=>Z.dataset_id.length),10),E=Math.max(...Y.map((Z)=>Z.version.length),7);for(let Z of Y)console.log(` ${Z.dataset_id.padEnd(V)} ${Z.version.padEnd(E)} ${VV0(Z.state)}`)}let B=Q?Bh(J):$.totals;if(console.log(),console.log(` Total: ${B.versions} ${W.green(`ok=${B.ok}`)} ${W.yellow(`stale=${B.stale}`)} ${W.red(`missing=${B.missing}`)} ${W.red(`error=${B.error}`)}`),!D.fix){if(B.stale+B.missing>0)console.log(W.dim(`
383
383
  Run with --fix to dispatch generate-manifest for the ${B.stale+B.missing} drifted version(s).`));return}let X=J.filter((V)=>ZV0(V.state));if(X.length===0){console.log(W.green(`
384
- Nothing to dispatch.`));return}let G=Q?` (scoped to ${Q})`:"",H=await P0(`Dispatch generate-manifest for ${X.length} version(s)${G}? Each dispatch queues a runner job on nemarDatasets/.github.`,D);if(H!=="confirmed"){console.log(W.dim(H==="declined"?"Skipped":"Cancelled"));return}let q=0,K=0;console.log();for(let[V,E]of X.entries()){let Z=`${E.dataset_id}@${E.version}`,L=C(`[${V+1}/${X.length}] dispatching ${Z}...`).start();try{await Cg(E.dataset_id,E.version),L.succeed(`[${V+1}/${X.length}] dispatched ${Z}`),q++}catch(A){L.fail(`[${V+1}/${X.length}] ${Z}: ${C0(A)}`),K++}if(V<X.length-1)await new Promise((A)=>setTimeout(A,EV0))}if(console.log(),console.log(K===0?W.green(`All ${q} dispatches succeeded.`):W.yellow(`${q} succeeded, ${K} failed.`)),console.log(W.dim("Workflow runs will appear on https://github.com/nemarDatasets/.github/actions. Re-run `nemar admin summary check` once they complete to verify drift cleared.")),K>0)process.exitCode=1});function Bh(D){return{versions:D.length,ok:D.filter((F)=>F.state.kind==="ok").length,stale:D.filter((F)=>F.state.kind==="stale").length,missing:D.filter((F)=>F.state.kind==="missing").length,error:D.filter((F)=>F.state.kind==="error").length}}o0.addCommand(qh);jD();x6();o3();s8();f4();r6();var Kh={git:{name:"git",purpose:"version control for dataset metadata",cmd:["git","--version"],required:!0,installInstructions:{macos:"brew install git (or install Xcode Command Line Tools)",linux:"sudo apt-get install git OR sudo dnf install git",windows:"winget install Git.Git (or https://git-scm.com/download/win)"}},"git-annex":{name:"git-annex",purpose:"large-file data transfer (upload/download)",cmd:["git-annex","version"],required:!0,installInstructions:{macos:"brew install git-annex",linux:"sudo apt-get install git-annex OR sudo dnf install git-annex",windows:"Download the installer from https://git-annex.branchable.com/install/Windows/"}},gh:{name:"GitHub CLI (gh)",purpose:"GitHub authentication + repository operations",cmd:["gh","--version"],required:!0,installInstructions:{macos:"brew install gh",linux:"See https://cli.github.com/manual/installation",windows:"winget install GitHub.cli (or: scoop install gh)"}},aws:{name:"AWS CLI",purpose:"S3 data upload/download",cmd:["aws","--version"],required:!0,installInstructions:{macos:"brew install awscli",linux:"pip install awscli OR sudo snap install aws-cli --classic",windows:"winget install Amazon.AWSCLI (or the MSI from https://aws.amazon.com/cli/)"}},deno:{name:"Deno",purpose:"BIDS validation",cmd:["deno","--version"],required:!0,installInstructions:{macos:"brew install deno (or: curl -fsSL https://deno.land/install.sh | sh)",linux:"curl -fsSL https://deno.land/install.sh | sh",windows:"winget install DenoLand.Deno (or: irm https://deno.land/install.ps1 | iex)"}}},LV0={upload:["git-annex","gh","aws"],download:["gh"],clone:["git","gh"],push:["git-annex","gh"],publish:["gh","aws"],update:["git","gh"],release:["git","gh"]};function AV0(){if(process.platform==="darwin")return"macos";if(process.platform==="win32")return"windows";return"linux"}function zh(D,F=AV0()){return D.installInstructions[F]}function MV0(D){let F=D.match(/(\d+\.\d+(?:\.\d+)?)/);return F?F[1]:void 0}async function Eh(D){try{let{exitCode:F,stdout:$}=await I(D.cmd);if(F!==0)return{available:!1};return{available:!0,version:MV0($)}}catch(F){let $=F instanceof Error?F.message:String(F);if(!$.includes("ENOENT")&&!$.includes("not found"))console.error(` Warning: ${D.name} check failed unexpectedly: ${$}`);return{available:!1}}}async function AH(){let D=Object.entries(Kh);return Promise.all(D.map(async([F,$])=>{let{available:J,version:Q}=await Eh($);return{key:F,name:$.name,purpose:$.purpose,required:$.required,available:J,version:Q,installInstruction:zh($)}}))}async function Vh(){let F=(await AH()).filter(($)=>$.required&&!$.available);if(F.length===0)return[];console.warn(`
384
+ Nothing to dispatch.`));return}let G=Q?` (scoped to ${Q})`:"",H=await P0(`Dispatch generate-manifest for ${X.length} version(s)${G}? Each dispatch queues a runner job on nemarDatasets/.github.`,D);if(H!=="confirmed"){console.log(W.dim(H==="declined"?"Skipped":"Cancelled"));return}let q=0,K=0;console.log();for(let[V,E]of X.entries()){let Z=`${E.dataset_id}@${E.version}`,L=C(`[${V+1}/${X.length}] dispatching ${Z}...`).start();try{await Cg(E.dataset_id,E.version),L.succeed(`[${V+1}/${X.length}] dispatched ${Z}`),q++}catch(A){L.fail(`[${V+1}/${X.length}] ${Z}: ${C0(A)}`),K++}if(V<X.length-1)await new Promise((A)=>setTimeout(A,EV0))}if(console.log(),console.log(K===0?W.green(`All ${q} dispatches succeeded.`):W.yellow(`${q} succeeded, ${K} failed.`)),console.log(W.dim("Workflow runs will appear on https://github.com/nemarDatasets/.github/actions. Re-run `nemar admin summary check` once they complete to verify drift cleared.")),K>0)process.exitCode=1});function Bh(D){return{versions:D.length,ok:D.filter((F)=>F.state.kind==="ok").length,stale:D.filter((F)=>F.state.kind==="stale").length,missing:D.filter((F)=>F.state.kind==="missing").length,error:D.filter((F)=>F.state.kind==="error").length}}o0.addCommand(qh);jD();x6();o3();s8();f4();r6();var Kh={git:{name:"git",purpose:"version control for dataset metadata",cmd:["git","--version"],required:!0,installInstructions:{macos:"brew install git (or install Xcode Command Line Tools)",linux:"sudo apt-get install git OR sudo dnf install git",windows:"winget install Git.Git (or https://git-scm.com/download/win)"}},"git-annex":{name:"git-annex",purpose:"large-file data transfer (upload/download)",cmd:["git-annex","version"],required:!0,installInstructions:{macos:"brew install git-annex",linux:"sudo apt-get install git-annex OR sudo dnf install git-annex",windows:"Download the installer from https://git-annex.branchable.com/install/Windows/"}},gh:{name:"GitHub CLI (gh)",purpose:"GitHub authentication + repository operations",cmd:["gh","--version"],required:!0,installInstructions:{macos:"brew install gh",linux:"See https://cli.github.com/manual/installation",windows:"winget install GitHub.cli (or: scoop install gh)"}},aws:{name:"AWS CLI",purpose:"S3 data upload/download",cmd:["aws","--version"],required:!0,installInstructions:{macos:"brew install awscli",linux:"pip install awscli OR sudo snap install aws-cli --classic",windows:"winget install Amazon.AWSCLI (or the MSI from https://aws.amazon.com/cli/)"}},deno:{name:"Deno",purpose:"BIDS validation",cmd:["deno","--version"],required:!0,installInstructions:{macos:"brew install deno (or: curl -fsSL https://deno.land/install.sh | sh)",linux:"curl -fsSL https://deno.land/install.sh | sh",windows:"winget install DenoLand.Deno (or: irm https://deno.land/install.ps1 | iex)"}}},LV0={upload:["git-annex","gh","aws","deno"],download:["gh"],clone:["git","gh"],push:["git-annex","gh"],publish:["gh","aws"],update:["git","gh"],release:["git","gh"]};function AV0(){if(process.platform==="darwin")return"macos";if(process.platform==="win32")return"windows";return"linux"}function zh(D,F=AV0()){return D.installInstructions[F]}function MV0(D){let F=D.match(/(\d+\.\d+(?:\.\d+)?)/);return F?F[1]:void 0}async function Eh(D){try{let{exitCode:F,stdout:$}=await I(D.cmd);if(F!==0)return{available:!1};return{available:!0,version:MV0($)}}catch(F){let $=F instanceof Error?F.message:String(F);if(!$.includes("ENOENT")&&!$.includes("not found"))console.error(` Warning: ${D.name} check failed unexpectedly: ${$}`);return{available:!1}}}async function AH(){let D=Object.entries(Kh);return Promise.all(D.map(async([F,$])=>{let{available:J,version:Q}=await Eh($);return{key:F,name:$.name,purpose:$.purpose,required:$.required,available:J,version:Q,installInstruction:zh($)}}))}async function Vh(){let F=(await AH()).filter(($)=>$.required&&!$.available);if(F.length===0)return[];console.warn(`
385
385
  Heads up: some tools NEMAR needs for uploading/validating aren't installed yet:`);for(let $ of F)console.warn(` - ${$.name} (${$.purpose})`),console.warn(` Install: ${$.installInstruction}`);return console.warn("Run `nemar doctor` anytime to re-check. You can finish signup without them.\n"),F}async function l4(D){let $=LV0[D].map((B)=>Kh[B]).filter(Boolean),Q=(await Promise.all($.map(async(B)=>({check:B,available:(await Eh(B)).available})))).filter((B)=>!B.available&&B.check.required).map((B)=>({tool:B.check.name,installInstruction:zh(B.check)}));if(Q.length===0)return;let Y=[`
386
386
  Missing required tools:`];for(let B of Q)Y.push(` ${B.tool} not installed`),Y.push(` Install: ${B.installInstruction}`);throw Error(Y.join(`
387
387
  `))}import{appendFileSync as NV0,existsSync as t6,mkdirSync as Zh,readFileSync as NQ,writeFileSync as RV0}from"fs";import{homedir as CV0}from"os";import{join as MQ}from"path";var{spawn:Uh}=globalThis.Bun;function p4(){let D=MQ(CV0(),".ssh");return{sshDir:D,privateKey:MQ(D,"nemar_ed25519"),publicKey:MQ(D,"nemar_ed25519.pub"),configFile:MQ(D,"config")}}function Lh(){let D=p4();return t6(D.privateKey)&&t6(D.publicKey)}async function Ah(D){let F=p4();if(!t6(F.sshDir))try{Zh(F.sshDir,{mode:448})}catch($){return{success:!1,error:`Cannot create ~/.ssh directory: ${$.message}`}}if(t6(F.privateKey))try{return{success:!0,publicKey:NQ(F.publicKey,"utf-8").trim()}}catch($){return{success:!1,error:`NEMAR SSH key exists but cannot read public key: ${$.message}`}}try{let $=Uh({cmd:["ssh-keygen","-t","ed25519","-f",F.privateKey,"-N","","-C",`nemar-cli-${D}`],stdout:"pipe",stderr:"pipe"}),J=await new Response($.stderr).text();if(await $.exited!==0)return{success:!1,error:`ssh-keygen failed: ${J}`};return{success:!0,publicKey:NQ(F.publicKey,"utf-8").trim()}}catch($){return{success:!1,error:`Failed to generate SSH key: ${$.message}`}}}function Mh(){let D=p4();if(!t6(D.publicKey))return null;try{return NQ(D.publicKey,"utf-8").trim()}catch{return null}}function OV0(){let D=p4();if(!t6(D.configFile))return!1;try{let F=NQ(D.configFile,"utf-8");return F.includes("IdentityFile ~/.ssh/nemar_ed25519")||F.includes(`IdentityFile ${D.privateKey}`)}catch{return!1}}function Nh(){let D=p4();if(!t6(D.sshDir))try{Zh(D.sshDir,{mode:448})}catch($){return{success:!1,error:`Cannot create ~/.ssh directory: ${$.message}`}}if(OV0())return{success:!0};let F=`
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nemar-cli",
3
- "version": "0.8.49-dev.1335",
3
+ "version": "0.8.49-dev.1348",
4
4
  "description": "CLI for NEMAR (Neuroelectromagnetic Data Archive and Tools Resource) dataset management",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",