nemar-cli 0.8.42 → 0.8.43-PR665.720d7c4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +3 -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 jf=!1;var IW=P(()=>{yD()});var Tf;var wf=P(()=>{Tf={name:"nemar-cli",version:"0.8.42",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","docs:generate":"bun run scripts/generate-docs.ts","docs:serve":"mkdocs serve","docs:build":"mkdocs build",prepare:"husky",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://nemar-cli.pages.dev",engines:{bun:">=1.0.0"},files:["dist","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(()=>{wf();g4=Tf.version});function C0(D){if(D instanceof Error)return D.message;return String(D)}function Pf(){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=`${Pf()}${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 ${Pf()}`,{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 Sf(D){return g(`/auth/check-username?username=${encodeURIComponent(D)}`)}async function kf(D){return g(`/auth/check-github?username=${encodeURIComponent(D)}`)}async function vf(D){return g("/auth/signup",{method:"POST",body:JSON.stringify(D)})}async function yf(D){return g("/auth/login",{method:"POST",body:JSON.stringify({api_key:D})})}async function xf(D){return g("/auth/resend-verification",{method:"POST",body:JSON.stringify({email:D})})}async function _f(D,F){return g("/auth/retrieve-key",{method:"POST",body:JSON.stringify({email:D,password:F})})}async function ff(D){return g("/auth/request-key-regeneration",{method:"POST",body:JSON.stringify({email:D})})}async function JQ(){return g("/users/me",{},!0)}async function gf(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 hf(D){return g(`/admin/approve/${D}`,{method:"POST"},!0)}async function bf(D){return g(`/admin/revoke/${D}`,{method:"POST"},!0)}async function uf(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 mf(D){return g(`/datasets/${D}/publish`,{method:"POST"},!0)}async function lf(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 pf(D){return g(`/datasets/${D}/manifest`,{},!0)}async function YQ(D,F){return g(`/datasets/${D}/manifest/${F}`,{},!0)}function df(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.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(df),J}async function cf(D){return g(`/datasets/resolve/${D}`,{},"optional")}async function nf(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 bD(D){let F=await g(`/datasets/${D}`,{},"optional");return df(F.dataset)}async function af(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 of(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 sf(D,F){return g(`/datasets/${D}/invite`,{method:"POST",body:JSON.stringify({username:F})},!0)}async function rf(D){return g(`/datasets/${D}/collaborators`,{},!0)}async function tf(D){return g("/sandbox/complete",{method:"POST",body:JSON.stringify({dataset_id:D})},!0)}async function ef(){return g("/sandbox/reset",{method:"POST"},!0)}async function Dg(){return g("/sandbox/status",{},!0)}async function WQ(D){return g(`/datasets/${D}/publish/request`,{method:"POST"},!0)}async function Fg(D){return g(`/datasets/${D}/publish/status`,{},!0)}async function $g(D){return g(`/datasets/${D}/publish/resend`,{method:"POST"},!0)}async function Jg(D){let F=D?`?status=${D}`:"";return g(`/admin/publish/requests${F}`,{},!0)}async function Qg(D,F){return g(`/admin/publish/${D}/deny`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({reason:F})},!0)}function UE0(D,F=[]){if(D){let $=v9.indexOf(D);if($>=0)return $+1}return Math.min(F.length+1,v9.length)}function LE0(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:UE0(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=If(Z);return N}catch(N){if(L=N,M===5||!LE0(N)){if(N instanceof h&&Z.length>0)N.stepResults=If(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 If(D){let F=new Map;for(let $ of D)F.set($.step,$);return Array.from(F.values())}async function Yg(D,F){return g(`/admin/datasets/${D}/enrichment`,{method:"POST",body:JSON.stringify(F)},!0)}async function Bg(D){return g(`/admin/datasets/${D}/files`,{},!0)}async function Xg(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 Gg(D){return g(`/admin/datasets/${D}/reset`,{method:"POST"},!0)}async function Wg(D,F=!1){return g(`/admin/datasets/${D}`,{method:"DELETE",headers:{"Content-Type":"application/json"},body:JSON.stringify({force:F})},!0)}async function Hg(D){return g("/admin/datasets/bulk-delete",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({dataset_ids:D})},!0)}async function qg(D){return g("/admin/datasets/import",{method:"POST",body:JSON.stringify(D)},!0)}async function Kg(D){return g(`/admin/datasets/${D}/sync`,{method:"POST"},!0)}async function zg(){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 Eg(D,F){return g("/admin/datasets/reindex/bulk",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({filter:D,...F??{}})},!0)}async function Vg(){return g("/admin/email-preferences",{},!0)}async function Zg(D){return g("/admin/email-preferences",{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(D)},!0)}async function Ug(){return g("/notices",{},"optional")}async function Lg(){return g("/admin/notices",{},!0)}async function Ag(D){return g("/admin/notices",{method:"POST",body:JSON.stringify(D)},!0)}async function Mg(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 Ng(){return g("/admin/summary/coverage",{},!0)}async function Rg(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://api.nemar.org",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 Og(D){hW=D}function bW(){return hW}function _9(D){if(hW)process.stderr.write(`${D}
|
|
98
|
+
`)}var jf=!1;var IW=P(()=>{yD()});var Tf;var wf=P(()=>{Tf={name:"nemar-cli",version:"0.8.43-PR665.720d7c4",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","docs:generate":"bun run scripts/generate-docs.ts","docs:serve":"mkdocs serve","docs:build":"mkdocs build",prepare:"husky",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://nemar-cli.pages.dev",engines:{bun:">=1.0.0"},files:["dist","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(()=>{wf();g4=Tf.version});function C0(D){if(D instanceof Error)return D.message;return String(D)}function Pf(){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=`${Pf()}${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 ${Pf()}`,{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 Sf(D){return g(`/auth/check-username?username=${encodeURIComponent(D)}`)}async function kf(D){return g(`/auth/check-github?username=${encodeURIComponent(D)}`)}async function vf(D){return g("/auth/signup",{method:"POST",body:JSON.stringify(D)})}async function yf(D){return g("/auth/login",{method:"POST",body:JSON.stringify({api_key:D})})}async function xf(D){return g("/auth/resend-verification",{method:"POST",body:JSON.stringify({email:D})})}async function _f(D,F){return g("/auth/retrieve-key",{method:"POST",body:JSON.stringify({email:D,password:F})})}async function ff(D){return g("/auth/request-key-regeneration",{method:"POST",body:JSON.stringify({email:D})})}async function JQ(){return g("/users/me",{},!0)}async function gf(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 hf(D){return g(`/admin/approve/${D}`,{method:"POST"},!0)}async function bf(D){return g(`/admin/revoke/${D}`,{method:"POST"},!0)}async function uf(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 mf(D){return g(`/datasets/${D}/publish`,{method:"POST"},!0)}async function lf(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 pf(D){return g(`/datasets/${D}/manifest`,{},!0)}async function YQ(D,F){return g(`/datasets/${D}/manifest/${F}`,{},!0)}function df(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.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(df),J}async function cf(D){return g(`/datasets/resolve/${D}`,{},"optional")}async function nf(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 bD(D){let F=await g(`/datasets/${D}`,{},"optional");return df(F.dataset)}async function af(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 of(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 sf(D,F){return g(`/datasets/${D}/invite`,{method:"POST",body:JSON.stringify({username:F})},!0)}async function rf(D){return g(`/datasets/${D}/collaborators`,{},!0)}async function tf(D){return g("/sandbox/complete",{method:"POST",body:JSON.stringify({dataset_id:D})},!0)}async function ef(){return g("/sandbox/reset",{method:"POST"},!0)}async function Dg(){return g("/sandbox/status",{},!0)}async function WQ(D){return g(`/datasets/${D}/publish/request`,{method:"POST"},!0)}async function Fg(D){return g(`/datasets/${D}/publish/status`,{},!0)}async function $g(D){return g(`/datasets/${D}/publish/resend`,{method:"POST"},!0)}async function Jg(D){let F=D?`?status=${D}`:"";return g(`/admin/publish/requests${F}`,{},!0)}async function Qg(D,F){return g(`/admin/publish/${D}/deny`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({reason:F})},!0)}function UE0(D,F=[]){if(D){let $=v9.indexOf(D);if($>=0)return $+1}return Math.min(F.length+1,v9.length)}function LE0(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:UE0(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=If(Z);return N}catch(N){if(L=N,M===5||!LE0(N)){if(N instanceof h&&Z.length>0)N.stepResults=If(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 If(D){let F=new Map;for(let $ of D)F.set($.step,$);return Array.from(F.values())}async function Yg(D,F){return g(`/admin/datasets/${D}/enrichment`,{method:"POST",body:JSON.stringify(F)},!0)}async function Bg(D){return g(`/admin/datasets/${D}/files`,{},!0)}async function Xg(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 Gg(D){return g(`/admin/datasets/${D}/reset`,{method:"POST"},!0)}async function Wg(D,F=!1){return g(`/admin/datasets/${D}`,{method:"DELETE",headers:{"Content-Type":"application/json"},body:JSON.stringify({force:F})},!0)}async function Hg(D){return g("/admin/datasets/bulk-delete",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({dataset_ids:D})},!0)}async function qg(D){return g("/admin/datasets/import",{method:"POST",body:JSON.stringify(D)},!0)}async function Kg(D){return g(`/admin/datasets/${D}/sync`,{method:"POST"},!0)}async function zg(){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 Eg(D,F){return g("/admin/datasets/reindex/bulk",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({filter:D,...F??{}})},!0)}async function Vg(){return g("/admin/email-preferences",{},!0)}async function Zg(D){return g("/admin/email-preferences",{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(D)},!0)}async function Ug(){return g("/notices",{},"optional")}async function Lg(){return g("/admin/notices",{},!0)}async function Ag(D){return g("/admin/notices",{method:"POST",body:JSON.stringify(D)},!0)}async function Mg(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 Ng(){return g("/admin/summary/coverage",{},!0)}async function Rg(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://api.nemar.org",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 Og(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 jg(D){return`${GD(D)}/s`}function AE0(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 ME0(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=`${ME0($)} ${$}% ${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+=` | ${jg(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 ${AE0(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?`${jg(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(()=>{yD()});var hg={};a4(hg,{verifyGitHubAuth:()=>g9,toS3Credentials:()=>CD,switchBranch:()=>SE0,setKeyPresent:()=>gg,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:()=>_E0,initOrEnableSpecialRemote:()=>xg,initDataset:()=>o6,gitMergeFastForward:()=>YH,gitFetchOrigin:()=>QH,gitAnnexAdd:()=>s6,getVersionCommit:()=>rW,getRemoteUuid:()=>WH,getLocalDatasetInfo:()=>oW,getKeyHashDirs:()=>yE0,getKeyHashDir:()=>fg,getDatasetStats:()=>TE0,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:()=>xE0,countPendingDownload:()=>EQ,copyToAnnexRemote:()=>P8,configureS3Remote:()=>T8,configureLargefiles:()=>b4,configureGitHubRemote:()=>r8,commitRevert:()=>eW,collectFileManifest:()=>XH,cloneDataset:()=>t1,clearAnnexCredentials:()=>kD,checkPrerequisites:()=>f9,checkGitHubSSH:()=>Sg,checkGitAnnexInstalled:()=>dW,checkDownloadPrerequisites:()=>kF,checkAWSCredentials:()=>OE0,batchSetKeysPresent:()=>HH,annexRemoteExists:()=>yg,acceptGitHubInvitation:()=>h9,NEMAR_S3_REMOTE_NAME:()=>zQ,ANNEX_REMOTE_EXISTS_RE:()=>vg});import{existsSync as lW,readFileSync as NE0,statSync as RE0}from"fs";import{join as pW}from"path";var{spawn:Ig}=globalThis.Bun;async function I(D,F={}){let $=Ig({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 wg(D){return D.split(".").map((F)=>{let $=Number.parseInt(F.replace(/[^0-9]/g,""),10);return Number.isNaN($)?0:$})}function CE0(D,F){let $=wg(D),J=wg(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?CE0(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 Sg(){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 OE0(){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 kg(){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(),Sg()]),$=[];if(!D.installed)$.push(`git-annex is not installed. Install: ${kg()}`);else if(D.compatible===!1)$.push(`git-annex version ${D.version} is too old. Required: >= ${D.minVersion}`);if(!F.accessible){if(!(await _g()).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(`
|
|
@@ -646,7 +646,8 @@ Examples:
|
|
|
646
646
|
$ nemar dataset list --modality eeg # EEG datasets only
|
|
647
647
|
$ nemar dataset list --search "motor" # Search by keyword
|
|
648
648
|
$ nemar dataset list --doi --sort size # Published, by size
|
|
649
|
-
$ nemar dataset search "resting state EEG" # Semantic search`).action(async(D)=>{if(D.mine&&D.owner)console.log(W.red("Error: --mine and --owner cannot be used together")),console.log("Use --mine for your datasets, or --owner <username> for another user's."),process.exit(1);if(D.mine&&!L0())console.log(W.red("Error: Not authenticated")),console.log("Run 'nemar auth login' to see your datasets"),process.exit(1);let F=D.all?200:Math.min(Number.parseInt(D.limit,10)||20,200),$=0;if(D.page)$=(Math.max(Number.parseInt(D.page,10)||1,1)-1)*F;else if(D.offset)$=Math.max(Number.parseInt(D.offset,10)||0,0);let J=C("Fetching datasets...").start(),Q;try{Q=await y9({mine:!!D.mine,search:D.search,modality:D.modality,author:D.author,task:D.task,hasDoi:!!D.doi,recent:D.recent?Number.parseInt(D.recent,10)||30:void 0,sort:D.sort,limit:F,offset:$,owner:D.owner}),J.stop()}catch(X){if(J.fail("Failed to fetch datasets"),X instanceof h)console.log(W.red(` ${X.message}`));else console.log(W.red(` ${X.message}`));process.exit(1)}let Y=Q.datasets,B=Q.total_count??Q.count;if(D.json){console.log(JSON.stringify({datasets:Y,total_count:B,limit:F,offset
|
|
649
|
+
$ nemar dataset search "resting state EEG" # Semantic search`).action(async(D)=>{if(D.mine&&D.owner)console.log(W.red("Error: --mine and --owner cannot be used together")),console.log("Use --mine for your datasets, or --owner <username> for another user's."),process.exit(1);if(D.mine&&!L0())console.log(W.red("Error: Not authenticated")),console.log("Run 'nemar auth login' to see your datasets"),process.exit(1);let F=D.all?200:Math.min(Number.parseInt(D.limit,10)||20,200),$=0;if(D.page)$=(Math.max(Number.parseInt(D.page,10)||1,1)-1)*F;else if(D.offset)$=Math.max(Number.parseInt(D.offset,10)||0,0);let J=C("Fetching datasets...").start(),Q;try{Q=await y9({mine:!!D.mine,search:D.search,modality:D.modality,author:D.author,task:D.task,hasDoi:!!D.doi,recent:D.recent?Number.parseInt(D.recent,10)||30:void 0,sort:D.sort,limit:F,offset:$,owner:D.owner}),J.stop()}catch(X){if(J.fail("Failed to fetch datasets"),X instanceof h)console.log(W.red(` ${X.message}`));else console.log(W.red(` ${X.message}`));process.exit(1)}let Y=Q.datasets,B=Q.total_count??Q.count;if(D.json){console.log(JSON.stringify({datasets:Y,total_count:B,limit:F,offset:$,fallback:Q.fallback,warning:Q.warning},null,2));return}if(Q.warning)console.log(W.yellow(`
|
|
650
|
+
\u26A0 ${Q.warning}`));if(Y.length===0){if(console.log(),D.mine)console.log(W.yellow("You don't have any datasets yet.")),console.log(W.dim("Create one with: nemar dataset upload <path>"));else if(D.owner)console.log(W.yellow(`No datasets found for user '${D.owner}'.`));else if(D.search||D.modality||D.author)console.log(W.yellow("No datasets match your filters.")),console.log(W.dim("Try broader search terms or remove filters."));else console.log(W.yellow("No datasets found."));return}NZ0(Y,{limit:F,offset:$,totalCount:B})});QD.command("search <query>").description("Search datasets using semantic matching").option("--modality <type>","Filter by modality (eeg, emg, meg, etc.)").option("--json","Output as JSON for scripting").option("--limit <n>","Limit results (default: 20)","20").addHelpText("after",`
|
|
650
651
|
Description:
|
|
651
652
|
Performs semantic search across the NEMAR dataset catalog. Unlike
|
|
652
653
|
--search on the list command (which uses exact text matching), this
|
package/package.json
CHANGED