@tigrisdata/cli 2.8.0 → 2.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/auth/client.js +1 -1
- package/dist/auth/config.js +1 -1
- package/dist/auth/fly.js +1 -0
- package/dist/auth/s3-client.js +1 -1
- package/dist/auth/storage.js +1 -1
- package/dist/chunk-2XAO2OYD.js +1 -0
- package/dist/chunk-4V35SYMM.js +9 -0
- package/dist/chunk-BETAO4PB.js +1 -0
- package/dist/{chunk-UUITLEOI.js → chunk-DOUR5YEY.js} +1 -1
- package/dist/chunk-E4MLGABW.js +1 -0
- package/dist/{chunk-4CKYRXYB.js → chunk-F2VBJEK7.js} +1 -1
- package/dist/chunk-GZ7JBHFT.js +1 -0
- package/dist/chunk-KH63ANUX.js +1 -0
- package/dist/chunk-N7F2D3XT.js +1 -0
- package/dist/chunk-SJCYBKF2.js +8 -0
- package/dist/{chunk-I52LJ637.js → chunk-SYGTCM6P.js} +1 -1
- package/dist/chunk-TNOMT3EP.js +4 -0
- package/dist/{chunk-2BGB3HM3.js → chunk-USCKVLDO.js} +1 -1
- package/dist/cli-core.js +1 -0
- package/dist/cli.js +1 -1
- package/dist/constants.js +1 -1
- package/dist/index.js +1 -1
- package/dist/lib/access-keys/assign.js +1 -1
- package/dist/lib/access-keys/create.js +1 -1
- package/dist/lib/access-keys/delete.js +1 -1
- package/dist/lib/access-keys/get.js +1 -1
- package/dist/lib/access-keys/list.js +1 -1
- package/dist/lib/buckets/create.js +1 -1
- package/dist/lib/buckets/delete.js +1 -1
- package/dist/lib/buckets/get.js +1 -1
- package/dist/lib/buckets/list.js +1 -1
- package/dist/lib/buckets/set.js +1 -1
- package/dist/lib/configure/index.js +1 -1
- package/dist/lib/cp.js +1 -1
- package/dist/lib/credentials/test.js +1 -1
- package/dist/lib/forks/create.js +1 -1
- package/dist/lib/forks/list.js +1 -1
- package/dist/lib/iam/policies/create.js +1 -1
- package/dist/lib/iam/policies/delete.js +1 -1
- package/dist/lib/iam/policies/edit.js +1 -1
- package/dist/lib/iam/policies/get.js +1 -1
- package/dist/lib/iam/policies/list.js +1 -1
- package/dist/lib/iam/users/invite.js +5 -0
- package/dist/lib/iam/users/list.js +9 -0
- package/dist/lib/iam/users/remove.js +5 -0
- package/dist/lib/iam/users/revoke-invitation.js +5 -0
- package/dist/lib/iam/users/update-role.js +5 -0
- package/dist/lib/login/credentials.js +1 -1
- package/dist/lib/login/oauth.js +1 -1
- package/dist/lib/login/select.js +1 -1
- package/dist/lib/logout.js +1 -1
- package/dist/lib/ls.js +1 -1
- package/dist/lib/mk.js +1 -1
- package/dist/lib/mv.js +1 -1
- package/dist/lib/objects/delete.js +1 -1
- package/dist/lib/objects/get.js +1 -1
- package/dist/lib/objects/list.js +1 -1
- package/dist/lib/objects/put.js +1 -1
- package/dist/lib/objects/set.js +1 -1
- package/dist/lib/organizations/create.js +5 -2
- package/dist/lib/organizations/list.js +2 -2
- package/dist/lib/organizations/select.js +1 -1
- package/dist/lib/rm.js +1 -1
- package/dist/lib/snapshots/list.js +1 -1
- package/dist/lib/snapshots/take.js +1 -1
- package/dist/lib/stat.js +1 -1
- package/dist/lib/touch.js +1 -1
- package/dist/lib/whoami.js +1 -1
- package/dist/specs.yaml +115 -2
- package/dist/utils/messages.js +1 -1
- package/dist/utils/specs.js +1 -1
- package/dist/utils/update-check.js +1 -1
- package/package.json +26 -23
- package/dist/chunk-2HJMXAYU.js +0 -8
- package/dist/chunk-7F4WI32C.js +0 -1
- package/dist/chunk-BP52O7NB.js +0 -1
- package/dist/chunk-DC3ZKGQV.js +0 -1
- package/dist/chunk-KBDSESA4.js +0 -4
- package/dist/chunk-LY55GPPO.js +0 -1
- package/dist/chunk-TF2BX3PY.js +0 -10
package/dist/lib/mv.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as
|
|
1
|
+
import{a as x}from"../chunk-CQCBYE3X.js";import{a as v}from"../chunk-JRALYIRA.js";import{a as F,b as y,d as S,g as C,h as I,i as j}from"../chunk-LCWHZUZZ.js";import{b as A}from"../chunk-USCKVLDO.js";import"../chunk-E4MLGABW.js";import"../chunk-DOUR5YEY.js";import"../chunk-KH63ANUX.js";import"../chunk-2XAO2OYD.js";import*as N from"readline";import{get as B,put as T,remove as E,list as L,head as G}from"@tigrisdata/storage";async function D(i){let n=N.createInterface({input:process.stdin,output:process.stdout});return new Promise(a=>{n.question(`${i} (y/N): `,d=>{n.close(),a(d.toLowerCase()==="y")})})}async function H(i){let n=v(i,["src"]),a=v(i,["dest"]),d=v(i,["force","f","F"]),h=!!v(i,["recursive","r"]);(!n||!a)&&(console.error("both src and dest arguments are required"),process.exit(1)),(!F(n)||!F(a))&&(console.error("Both src and dest must be remote Tigris paths (t3:// or tigris://)"),process.exit(1));let e=y(n),t=y(a);e.bucket||(console.error("Invalid source path"),process.exit(1)),t.bucket||(console.error("Invalid destination path"),process.exit(1));let $=n.endsWith("/");!e.path&&!$&&(console.error("Cannot move a bucket. Provide a path within the bucket."),process.exit(1));let c=await A(),l=e.path.includes("*"),p=e.path.endsWith("/")||!e.path&&$;if(!l&&!p&&e.path&&(p=await S(e.bucket,e.path,c)),p&&!l&&!h&&(console.error("Source is a remote folder (not moved). Use -r to move recursively."),process.exit(1)),l||p){let r=l?I(e.path):e.path?e.path.endsWith("/")?e.path:`${e.path}/`:"",o=!l&&e.path&&!e.path.endsWith("/")?e.path.split("/").filter(Boolean).pop()??"":"",f=[t.path?.replace(/\/$/,"")||"",o].filter(Boolean).join("/"),z=f?`${f}/`:"";e.bucket===t.bucket&&r===z&&(console.error("Source and destination are the same"),process.exit(1));let{items:q,error:R}=await j(e.bucket,r||void 0,c);R&&(console.error(R.message),process.exit(1));let b=q.filter(s=>s.name!==r);if(l){let s=e.path.split("/").pop(),m=C(s);b=b.filter(g=>{let k=r?g.name.slice(r.length):g.name;return!h&&k.includes("/")?!1:m.test(k.split("/").pop())})}let{data:O}=await L({prefix:r,limit:1,config:{...c,bucket:e.bucket}}),P=r?O?.items?.some(s=>s.name===r):!1;if(b.length===0&&!P){console.log("No objects to move");return}let U=b.length+(P?1:0);if(!d&&!await D(`Are you sure you want to move ${U} object(s)?`)){console.log("Aborted");return}let w=0;for(let s of b){let m=r?s.name.slice(r.length):s.name,g=f?`${f}/${m}`:m,k=await W(c,e.bucket,s.name,t.bucket,g);k.error?console.error(`Failed to move ${s.name}: ${k.error}`):(console.log(`Moved t3://${e.bucket}/${s.name} -> t3://${t.bucket}/${g}`),w++)}let M=!1;if(P)if(f){let s=`${f}/`,m=await W(c,e.bucket,r,t.bucket,s);m.error?console.error(`Failed to move folder marker: ${m.error}`):M=!0}else{let{error:s}=await E(r,{config:{...c,bucket:e.bucket}});s?console.error(`Failed to remove source folder marker: ${s.message}`):M=!0}w===0&&M&&(w=1),console.log(`Moved ${w} object(s)`)}else{let r=e.path.split("/").pop(),o;if(t.path?t.path.endsWith("/")?o=`${t.path}${r}`:await S(t.bucket,t.path,c)?o=`${t.path}/${r}`:o=t.path:o=r,e.bucket===t.bucket&&e.path===o&&(console.error("Source and destination are the same"),process.exit(1)),!d&&!await D(`Are you sure you want to move 't3://${e.bucket}/${e.path}'?`)){console.log("Aborted");return}let u=await W(c,e.bucket,e.path,t.bucket,o,!0);u.error&&(console.error(u.error),process.exit(1)),console.log(`Moved t3://${e.bucket}/${e.path} -> t3://${t.bucket}/${o}`)}process.exit(0)}async function W(i,n,a,d,h,e=!1){if(a.endsWith("/")){let{error:o}=await T(h,"",{config:{...i,bucket:d}});if(o)return{error:o.message};let{error:u}=await E(a,{config:{...i,bucket:n}});return u?{error:`Copied but failed to delete source: ${u.message}`}:{}}let t;if(e){let{data:o}=await G(a,{config:{...i,bucket:n}});t=o?.size}let{data:$,error:c}=await B(a,"stream",{config:{...i,bucket:n}});if(c)return{error:c.message};let l=t!==void 0&&t>100*1024*1024,{error:p}=await T(h,$,{multipart:l,onUploadProgress:e?({loaded:o})=>{if(t!==void 0&&t>0){let u=Math.round(o/t*100);process.stdout.write(`\rMoving: ${x(o)} / ${x(t)} (${u}%)`)}else process.stdout.write(`\rMoving: ${x(o)}`)}:void 0,config:{...i,bucket:d}});if(e&&process.stdout.write("\r"+" ".repeat(60)+"\r"),p)return{error:p.message};let{error:r}=await E(a,{config:{...i,bucket:n}});return r?{error:`Copied but failed to delete source: ${r.message}`}:{}}export{H as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as
|
|
1
|
+
import{a as f,b as a,c as r,g}from"../../chunk-SYGTCM6P.js";import{a as i}from"../../chunk-JRALYIRA.js";import{b as m}from"../../chunk-USCKVLDO.js";import"../../chunk-BETAO4PB.js";import"../../chunk-E4MLGABW.js";import"../../chunk-DOUR5YEY.js";import"../../chunk-KH63ANUX.js";import"../../chunk-2XAO2OYD.js";import{remove as k}from"@tigrisdata/storage";var e=g("objects","delete");async function y(s){f(e);let n=i(s,["bucket"]),t=i(s,["key"]);n||(r(e,"Bucket name is required"),process.exit(1)),t||(r(e,"Object key is required"),process.exit(1));let p=await m(),u=Array.isArray(t)?t:[t];for(let o of u){let{error:c}=await k(o,{config:{...p,bucket:n}});c&&(r(e,c.message,{key:o}),process.exit(1)),a(e,{key:o})}}export{y as default};
|
package/dist/lib/objects/get.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as
|
|
1
|
+
import{a as p,b as n,c,g as f}from"../../chunk-SYGTCM6P.js";import{a as m}from"../../chunk-JRALYIRA.js";import{b as l}from"../../chunk-USCKVLDO.js";import"../../chunk-BETAO4PB.js";import"../../chunk-E4MLGABW.js";import"../../chunk-DOUR5YEY.js";import"../../chunk-KH63ANUX.js";import"../../chunk-2XAO2OYD.js";import{createWriteStream as j,writeFileSync as k}from"fs";import{Readable as d}from"stream";import{pipeline as u}from"stream/promises";import{extname as w}from"path";import{get as h}from"@tigrisdata/storage";var e=f("objects","get"),S=new Set([".js",".ts",".jsx",".tsx",".mjs",".cjs",".py",".rb",".php",".java",".go",".rs",".c",".cpp",".h",".hpp",".cs",".swift",".kt",".scala",".clj",".ex",".exs",".erl",".sh",".bash",".zsh",".fish",".ps1",".bat",".cmd",".sql",".graphql",".gql",".json",".yaml",".yml",".toml",".ini",".cfg",".conf",".xml",".plist",".env",".properties",".html",".htm",".css",".scss",".sass",".less",".styl",".md",".markdown",".mdx",".rst",".txt",".text",".csv",".tsv",".log",".ejs",".hbs",".pug",".jade",".njk",".twig",".liquid",".svg",".gitignore",".dockerignore",".editorconfig"]);function y(r,o){let t=w(o||r).toLowerCase();return S.has(t)?"string":"stream"}async function q(r){p(e);let o=m(r,["bucket"]),s=m(r,["key"]),t=m(r,["output","o","O"]),x=m(r,["mode","m","M"]);o||(c(e,"Bucket name is required"),process.exit(1)),s||(c(e,"Object key is required"),process.exit(1));let g=await l();if((x||y(s,t))==="stream"){let{data:i,error:a}=await h(s,"stream",{config:{...g,bucket:o}});if(a&&(c(e,a.message),process.exit(1)),t){let b=j(t);await u(d.fromWeb(i),b),n(e,{key:s,output:t})}else await u(d.fromWeb(i),process.stdout),n(e)}else{let{data:i,error:a}=await h(s,"string",{config:{...g,bucket:o}});a&&(c(e,a.message),process.exit(1)),t?(k(t,i),n(e,{key:s,output:t})):(console.log(i),n(e))}}export{q as default};
|
package/dist/lib/objects/list.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a
|
|
1
|
+
import{a,b as m,c as s,d as p,g as d}from"../../chunk-SYGTCM6P.js";import{a as g,f as l}from"../../chunk-CQCBYE3X.js";import{a as e}from"../../chunk-JRALYIRA.js";import{b as u}from"../../chunk-USCKVLDO.js";import"../../chunk-BETAO4PB.js";import"../../chunk-E4MLGABW.js";import"../../chunk-DOUR5YEY.js";import"../../chunk-KH63ANUX.js";import"../../chunk-2XAO2OYD.js";import{list as h}from"@tigrisdata/storage";var t=d("objects","list");async function j(i){a(t);let n=e(i,["bucket"]),k=e(i,["prefix","p","P"]),b=e(i,["format","f","F"],"table");n||(s(t,"Bucket name is required"),process.exit(1));let y=await u(),{data:o,error:c}=await h({prefix:k||void 0,config:{...y,bucket:n}});if(c&&(s(t,c.message),process.exit(1)),!o.items||o.items.length===0){p(t);return}let f=o.items.map(r=>({key:r.name,size:g(r.size),modified:r.lastModified})),x=l(f,b,"objects","object",[{key:"key",header:"Key"},{key:"size",header:"Size"},{key:"modified",header:"Modified"}]);console.log(x),m(t,{count:f.length})}export{j as default};
|
package/dist/lib/objects/put.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as
|
|
1
|
+
import{a as l,b as g,c as o,g as b}from"../../chunk-SYGTCM6P.js";import{a as n,f as S}from"../../chunk-CQCBYE3X.js";import{a as t}from"../../chunk-JRALYIRA.js";import{b as y}from"../../chunk-USCKVLDO.js";import"../../chunk-BETAO4PB.js";import"../../chunk-E4MLGABW.js";import"../../chunk-DOUR5YEY.js";import"../../chunk-KH63ANUX.js";import"../../chunk-2XAO2OYD.js";import{createReadStream as F,statSync as O}from"fs";import{Readable as h}from"stream";import{put as q}from"@tigrisdata/storage";var r=b("objects","put");async function v(s){l(r);let p=t(s,["bucket"]),d=t(s,["key"]),i=t(s,["file"]),k=t(s,["access","a","A"],"private"),T=t(s,["content-type","contentType","t","T"]),x=t(s,["format","f","F"],"table");p||(o(r,"Bucket name is required"),process.exit(1)),d||(o(r,"Object key is required"),process.exit(1));let z=!process.stdin.isTTY;!i&&!z&&(o(r,"File path is required (or pipe data via stdin)"),process.exit(1));let f,e;if(i){try{e=O(i).size}catch{o(r,`File not found: ${i}`),process.exit(1)}let c=F(i);f=h.toWeb(c)}else f=h.toWeb(process.stdin);let w=await y(),R=!i||e!==void 0&&e>100*1024*1024,{data:a,error:u}=await q(d,f,{access:k==="public"?"public":"private",contentType:T,multipart:R,onUploadProgress:({loaded:c,percentage:m})=>{e!==void 0&&e>0?process.stdout.write(`\rUploading: ${n(c)} / ${n(e)} (${m}%)`):process.stdout.write(`\rUploading: ${n(c)}`)},config:{...w,bucket:p}});process.stdout.write("\r"+" ".repeat(60)+"\r"),u&&(o(r,u.message),process.exit(1));let j=[{path:a.path,size:n(a.size??e??0),contentType:a.contentType||"-",modified:a.modified}],$=S(j,x,"objects","object",[{key:"path",header:"Path"},{key:"size",header:"Size"},{key:"contentType",header:"Content-Type"},{key:"modified",header:"Modified"}]);console.log($),g(r,{key:d,bucket:p})}export{v as default};
|
package/dist/lib/objects/set.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as
|
|
1
|
+
import{a as p,b as u,c as t,g as f}from"../../chunk-SYGTCM6P.js";import{a as c}from"../../chunk-JRALYIRA.js";import{b as g}from"../../chunk-USCKVLDO.js";import"../../chunk-BETAO4PB.js";import"../../chunk-E4MLGABW.js";import"../../chunk-DOUR5YEY.js";import"../../chunk-KH63ANUX.js";import"../../chunk-2XAO2OYD.js";import{updateObject as b}from"@tigrisdata/storage";var e=f("objects","set");async function k(s){p(e);let i=c(s,["bucket"]),r=c(s,["key"]),n=c(s,["access","a","A"]),o=c(s,["new-key","n","newKey"]);i||(t(e,"Bucket name is required"),process.exit(1)),r||(t(e,"Object key is required"),process.exit(1)),n||(t(e,"Access level is required (--access public|private)"),process.exit(1));let m=await g(),{error:a}=await b(r,{access:n==="public"?"public":"private",...o&&{key:o},config:{...m,bucket:i}});a&&(t(e,a.message),process.exit(1)),u(e,{key:r,bucket:i})}export{k as default};
|
|
@@ -1,4 +1,7 @@
|
|
|
1
|
-
import{a as
|
|
1
|
+
import{a as g,b as c,c as t,f as l,g as u}from"../../chunk-SYGTCM6P.js";import{a as f}from"../../chunk-JRALYIRA.js";import{b as m}from"../../chunk-USCKVLDO.js";import"../../chunk-BETAO4PB.js";import"../../chunk-E4MLGABW.js";import{g as e,k as r,s as a}from"../../chunk-DOUR5YEY.js";import{a as s}from"../../chunk-GZ7JBHFT.js";import"../../chunk-KH63ANUX.js";import"../../chunk-2XAO2OYD.js";import{createOrganization as O}from"@tigrisdata/iam";var i=u("organizations","create");async function w(d){if(g(i),a()!=="oauth"){r()?console.log(`You are using access key credentials, which belong to a single organization.
|
|
2
2
|
Organization creation is only available with OAuth login.
|
|
3
3
|
|
|
4
|
-
Run "tigris login" to login with your Tigris account.`):console.log('Not authenticated. Please run "tigris login" to login with your Tigris account.');return}let
|
|
4
|
+
Run "tigris login" to login with your Tigris account.`):console.log('Not authenticated. Please run "tigris login" to login with your Tigris account.');return}let p=e();if(s(p??void 0)){console.log(`Organization creation is not available for Fly.io users.
|
|
5
|
+
Your organizations are managed through Fly.io.
|
|
6
|
+
|
|
7
|
+
Visit https://fly.io to manage your organizations.`);return}let o=f(d,["name","N"]);o||(t(i,"Organization name is required"),process.exit(1));let h=await m(),{data:y,error:n}=await O(o,{config:h});n&&(t(i,n.message),process.exit(1));let z=y.id;c(i,{name:o,id:z}),l(i,{name:o})}export{w as default};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{a as O
|
|
1
|
+
import{a as O,b as r,c as k,d as S,g as C}from"../../chunk-SYGTCM6P.js";import{f as I}from"../../chunk-CQCBYE3X.js";import{a as F}from"../../chunk-JRALYIRA.js";import{b as x}from"../../chunk-USCKVLDO.js";import"../../chunk-BETAO4PB.js";import{b as z}from"../../chunk-E4MLGABW.js";import{f as u,g as f,k as p,s as h}from"../../chunk-DOUR5YEY.js";import{a as w,b as y}from"../../chunk-GZ7JBHFT.js";import"../../chunk-KH63ANUX.js";import"../../chunk-2XAO2OYD.js";import{listOrganizations as b}from"@tigrisdata/iam";import E from"enquirer";var i=C("organizations","list");async function N(T){if(O(i),h()!=="oauth"){p()?console.log(`You are using access key credentials, which belong to a single organization.
|
|
2
2
|
Organization listing and selection is only available with OAuth login.
|
|
3
3
|
|
|
4
|
-
Run "tigris login" to login with your Tigris account.`):console.log('Not authenticated. Please run "tigris login" to login with your Tigris account.');return}let
|
|
4
|
+
Run "tigris login" to login with your Tigris account.`):console.log('Not authenticated. Please run "tigris login" to login with your Tigris account.');return}let c=F(T,["format","f","F"],"select"),A=await z().getAccessToken(),a=await y(A),M=a?.some(t=>w(t.id))??!1,n;if(M&&a)n=a.map(t=>({id:t.id,name:t.name,slug:t.name}));else{let t=await x(),{data:l,error:s}=await b({config:t});s&&(k(i,s.message),process.exit(1)),n=l?.organizations??[]}if(n.length===0){S(i);return}let o=f();if(c==="select"){let t=n.map(e=>({name:e.id,message:`${e.name} (${e.id})`,hint:e.id===o?"currently selected":void 0})),m=(await E.prompt({type:"select",name:"organization",message:"Select an organization:",choices:t.map(e=>e.message),initial:o?n.findIndex(e=>e.id===o):0})).organization.match(/\(([^)]+)\)$/),d=m?m[1]:n[0].id;await u(d);let $=n.find(e=>e.id===d);r(i,{name:$?.name});return}let g=n.map(t=>({id:t.id,name:t.name,slug:t.slug,selected:t.id===o?"*":""})),U=I(g,c,"organizations","organization",[{key:"selected",header:" ",width:1},{key:"id",header:"ID"},{key:"name",header:"Name"},{key:"slug",header:"Slug"}]);console.log(U),r(i,{count:g.length})}export{N as default};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{a as
|
|
1
|
+
import{a as m,b as u,c as t,g as d}from"../../chunk-SYGTCM6P.js";import{a as p}from"../../chunk-JRALYIRA.js";import{b as f}from"../../chunk-USCKVLDO.js";import"../../chunk-BETAO4PB.js";import"../../chunk-E4MLGABW.js";import{f as g,k as c,s as l}from"../../chunk-DOUR5YEY.js";import"../../chunk-KH63ANUX.js";import"../../chunk-2XAO2OYD.js";import{listOrganizations as O}from"@tigrisdata/iam";var i=d("organizations","select");async function x(h){if(m(i),l()!=="oauth"){c()?console.log(`You are using access key credentials, which belong to a single organization.
|
|
2
2
|
Organization selection is only available with OAuth login.
|
|
3
3
|
|
|
4
4
|
Run "tigris login" to login with your Tigris account.`):console.log('Not authenticated. Please run "tigris login" to login with your Tigris account.');return}let n=p(h,["name","N"]);n||(t(i,"Organization name or ID is required"),process.exit(1));let z=await f(),{data:w,error:a}=await O({config:z});a&&(t(i,a.message),process.exit(1));let r=w?.organizations??[],e=r.find(o=>o.id===n||o.name===n);if(!e){let o=r.map(s=>` - ${s.name} (${s.id})`).join(`
|
package/dist/lib/rm.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as g}from"../chunk-JRALYIRA.js";import{a as A,b as F,d as I,g as S,h as W,i as j}from"../chunk-LCWHZUZZ.js";import{b as P}from"../chunk-
|
|
1
|
+
import{a as g}from"../chunk-JRALYIRA.js";import{a as A,b as F,d as I,g as S,h as W,i as j}from"../chunk-LCWHZUZZ.js";import{b as P}from"../chunk-USCKVLDO.js";import"../chunk-E4MLGABW.js";import"../chunk-DOUR5YEY.js";import"../chunk-KH63ANUX.js";import"../chunk-2XAO2OYD.js";import*as E from"readline";import{remove as w,removeBucket as T,list as q}from"@tigrisdata/storage";async function $(l){let s=E.createInterface({input:process.stdin,output:process.stdout});return new Promise(m=>{s.question(`${l} (y/N): `,d=>{s.close(),m(d.toLowerCase()==="y")})})}async function C(l){let s=g(l,["path"]),m=g(l,["force","f","F"]),d=!!g(l,["recursive","r"]);s||(console.error("path argument is required"),process.exit(1)),A(s)||(console.error("Path must be a remote Tigris path (t3:// or tigris://)"),process.exit(1));let{bucket:e,path:o}=F(s);e||(console.error("Invalid path"),process.exit(1));let i=await P(),b=s.endsWith("/");if(!o&&!b){if(!m&&!await $(`Are you sure you want to delete bucket '${e}'?`)){console.log("Aborted");return}let{error:t}=await T(e,{config:i});t&&(console.error(t.message),process.exit(1)),console.log(`Removed bucket '${e}'`);return}let n=o.includes("*"),u=o.endsWith("/")||!o&&b;if(!n&&!u&&(u=await I(e,o,i)),u&&!n&&!d&&(console.error("Source is a remote folder (not removed). Use -r to remove recursively."),process.exit(1)),n||u){let t=n?W(o):o?o.endsWith("/")?o:`${o}/`:"",{items:p,error:x}=await j(e,t||void 0,i);x&&(console.error(x.message),process.exit(1));let f=p;if(n){let r=o.split("/").pop(),a=S(r);f=f.filter(R=>{let k=t?R.name.slice(t.length):R.name;return!d&&k.includes("/")?!1:a.test(k.split("/").pop())})}let c=t,M=f.some(r=>r.name===c),v=!1;if(!M&&!n){let{data:r}=await q({prefix:c,limit:1,config:{...i,bucket:e}});v=r?.items?.some(a=>a.name===c)||!1}let y=f.length+(v?1:0);if(y===0){console.log("No objects to remove");return}if(!m&&!await $(`Are you sure you want to delete ${y} object(s)?`)){console.log("Aborted");return}let h=0;for(let r of f){let{error:a}=await w(r.name,{config:{...i,bucket:e}});a?console.error(`Failed to remove ${r.name}: ${a.message}`):(console.log(`Removed t3://${e}/${r.name}`),h++)}if(v){let{error:r}=await w(c,{config:{...i,bucket:e}});r?console.error(`Failed to remove ${c}: ${r.message}`):(console.log(`Removed t3://${e}/${c}`),h++)}console.log(`Removed ${h} object(s)`)}else{if(!m&&!await $(`Are you sure you want to delete 't3://${e}/${o}'?`)){console.log("Aborted");return}let{error:t}=await w(o,{config:{...i,bucket:e}});t&&(console.error(t.message),process.exit(1)),console.log(`Removed t3://${e}/${o}`)}process.exit(0)}export{C as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as
|
|
1
|
+
import{a as c,b as p,c as o,d as f,g as u}from"../../chunk-SYGTCM6P.js";import{f as d}from"../../chunk-CQCBYE3X.js";import{a as n}from"../../chunk-JRALYIRA.js";import{b as g}from"../../chunk-USCKVLDO.js";import"../../chunk-BETAO4PB.js";import"../../chunk-E4MLGABW.js";import"../../chunk-DOUR5YEY.js";import"../../chunk-KH63ANUX.js";import"../../chunk-2XAO2OYD.js";import{listBucketSnapshots as y}from"@tigrisdata/storage";var t=u("snapshots","list");async function x(s){c(t);let a=n(s,["name"]),l=n(s,["format","f","F"],"table");a||(o(t,"Bucket name is required"),process.exit(1));let h=await g(),{data:e,error:i}=await y(a,{config:h});if(i&&(o(t,i.message),process.exit(1)),!e||e.length===0){f(t);return}let m=e.map(r=>({name:r.name||"",version:r.version||"",created:r.creationDate})),k=d(m,l,"snapshots","snapshot",[{key:"name",header:"Name"},{key:"version",header:"Version"},{key:"created",header:"Created"}]);console.log(k),p(t,{count:m.length})}export{x as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as
|
|
1
|
+
import{a as m,b as p,c as n,g as c}from"../../chunk-SYGTCM6P.js";import{a as e}from"../../chunk-JRALYIRA.js";import{b as f}from"../../chunk-USCKVLDO.js";import"../../chunk-BETAO4PB.js";import"../../chunk-E4MLGABW.js";import"../../chunk-DOUR5YEY.js";import"../../chunk-KH63ANUX.js";import"../../chunk-2XAO2OYD.js";import{createBucketSnapshot as h}from"@tigrisdata/storage";var t=c("snapshots","take");async function u(o){m(t);let s=e(o,["name"]),a=e(o,["snapshot-name","snapshotName"]);s||(n(t,"Bucket name is required"),process.exit(1));let g=await f(),{data:r,error:i}=await h(s,{name:a,config:g});i&&(n(t,i.message),process.exit(1)),p(t,{name:s,snapshotName:a||r?.snapshotVersion,version:r?.snapshotVersion})}export{u as default};
|
package/dist/lib/stat.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as v,b as c,c as s,g as b}from"../chunk-
|
|
1
|
+
import{a as v,b as c,c as s,g as b}from"../chunk-SYGTCM6P.js";import{a as l,f as u}from"../chunk-CQCBYE3X.js";import{f as k}from"../chunk-LCWHZUZZ.js";import{b as S}from"../chunk-USCKVLDO.js";import"../chunk-BETAO4PB.js";import"../chunk-E4MLGABW.js";import"../chunk-DOUR5YEY.js";import"../chunk-KH63ANUX.js";import"../chunk-2XAO2OYD.js";import{getStats as j,getBucketInfo as y,head as I}from"@tigrisdata/storage";var e=b("stat");async function x(f){v(e);let d=f.path||f._positional?.[0],m=f.format||"table",p=await S();if(!d){let{data:t,error:a}=await j({config:p});a&&(s(e,a.message),process.exit(1));let r=[{metric:"Active Buckets",value:String(t.stats.activeBuckets)},{metric:"Total Objects",value:String(t.stats.totalObjects)},{metric:"Total Unique Objects",value:String(t.stats.totalUniqueObjects)},{metric:"Total Storage",value:l(t.stats.totalStorageBytes)}],g=u(r,m,"stats","stat",[{key:"metric",header:"Metric"},{key:"value",header:"Value"}]);console.log(g),c(e),process.exit(0)}let{bucket:i,path:n}=k(d);if(i||(s(e,"Invalid path"),process.exit(1)),!n||n==="/"){let{data:t,error:a}=await y(i,{config:p});a&&(s(e,a.message),process.exit(1));let r=[{metric:"Number of Objects",value:t.sizeInfo.numberOfObjects?.toString()??"N/A"},{metric:"Total Size",value:t.sizeInfo.size!==void 0?l(t.sizeInfo.size):"N/A"},{metric:"All Versions Count",value:t.sizeInfo.numberOfObjectsAllVersions?.toString()??"N/A"},{metric:"Snapshots Enabled",value:t.isSnapshotEnabled?"Yes":"No"},{metric:"Default Tier",value:t.settings.defaultTier},{metric:"Allow Object ACL",value:t.settings.allowObjectAcl?"Yes":"No"},{metric:"Has Forks",value:t.forkInfo?.hasChildren?"Yes":"No"}];t.forkInfo?.parents?.length&&(r.push({metric:"Forked From",value:t.forkInfo.parents[0].bucketName}),r.push({metric:"Fork Snapshot",value:t.forkInfo.parents[0].snapshot}));let g=u(r,m,"bucket-info","info",[{key:"metric",header:"Metric"},{key:"value",header:"Value"}]);console.log(g),c(e,{bucket:i}),process.exit(0)}let{data:o,error:h}=await I(n,{config:{...p,bucket:i}});h&&(s(e,h.message),process.exit(1)),o||(s(e,"Object not found"),process.exit(1));let O=[{metric:"Path",value:o.path},{metric:"Size",value:l(o.size)},{metric:"Content-Type",value:o.contentType||"N/A"},{metric:"Content-Disposition",value:o.contentDisposition||"N/A"},{metric:"Modified",value:o.modified.toISOString()}],A=u(O,m,"object-info","info",[{key:"metric",header:"Metric"},{key:"value",header:"Value"}]);console.log(A),c(e,{bucket:i,path:n}),process.exit(0)}export{x as default};
|
package/dist/lib/touch.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as n}from"../chunk-JRALYIRA.js";import{f as i}from"../chunk-LCWHZUZZ.js";import{b as s}from"../chunk-
|
|
1
|
+
import{a as n}from"../chunk-JRALYIRA.js";import{f as i}from"../chunk-LCWHZUZZ.js";import{b as s}from"../chunk-USCKVLDO.js";import"../chunk-E4MLGABW.js";import"../chunk-DOUR5YEY.js";import"../chunk-KH63ANUX.js";import"../chunk-2XAO2OYD.js";import{put as p}from"@tigrisdata/storage";async function f(c){let r=n(c,["path"]);r||(console.error("path argument is required"),process.exit(1));let{bucket:o,path:e}=i(r);o||(console.error("Invalid path"),process.exit(1)),e||(console.error("Object key is required (use mk to create buckets)"),process.exit(1));let a=await s(),{error:t}=await p(e,"",{config:{...a,bucket:o}});t&&(console.error(t.message),process.exit(1)),console.log(`Created '${o}/${e}'`),process.exit(0)}export{f as default};
|
package/dist/lib/whoami.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{c,e as h,g as O}from"../chunk-
|
|
1
|
+
import{c,e as h,g as O}from"../chunk-SYGTCM6P.js";import{b as $}from"../chunk-USCKVLDO.js";import"../chunk-BETAO4PB.js";import{b as z}from"../chunk-E4MLGABW.js";import{g as f,k as p,s as A}from"../chunk-DOUR5YEY.js";import"../chunk-KH63ANUX.js";import"../chunk-2XAO2OYD.js";import{listOrganizations as C}from"@tigrisdata/iam";var s=O("whoami");async function y(){try{let i=A(),d=p(),l,u;if(i==="oauth"){let n=z();if(!await n.isAuthenticated()){h(s);return}let a=await n.getIdTokenClaims();l=a.email,u=a.sub}else if(d)l=void 0,u=d.accessKeyId;else{h(s);return}let e=[];if(e.push(""),e.push("User Information:"),e.push(` Email: ${l||"N/A"}`),e.push(` User ID: ${u||"N/A"}`),i==="oauth"){let n=await $(),o=f(),{data:a,error:g}=await C({config:n});g&&(c(s,g.message),process.exit(1));let r=a?.organizations??[];if(r.length>0){if(e.push(""),e.push(`Organizations (${r.length}):`),r.forEach(t=>{let w=t.id===o?">":" ";e.push(` ${w} ${t.name} (${t.id})`)}),o){let t=r.find(m=>m.id===o);t&&(e.push(""),e.push(`Active: ${t.name}`))}}else e.push(""),e.push("Organizations: None")}else e.push(""),e.push("Login method: Access Key Credentials"),e.push(" (Organization listing requires OAuth login: tigris login)");e.push(""),console.log(e.join(`
|
|
2
2
|
`))}catch(i){i instanceof Error?c(s,i.message):c(s),process.exit(1)}}export{y as default};
|
package/dist/specs.yaml
CHANGED
|
@@ -1017,11 +1017,12 @@ commands:
|
|
|
1017
1017
|
# IAM - Identity and Access Management
|
|
1018
1018
|
#########################
|
|
1019
1019
|
- name: iam
|
|
1020
|
-
description: Identity and Access Management - manage policies,
|
|
1020
|
+
description: Identity and Access Management - manage policies, users, and permissions
|
|
1021
1021
|
examples:
|
|
1022
1022
|
- "tigris iam policies list"
|
|
1023
|
-
- "tigris iam policies get arn:aws:iam::org_id:policy/my-policy"
|
|
1024
1023
|
- "tigris iam policies create my-policy --document policy.json"
|
|
1024
|
+
- "tigris iam users list"
|
|
1025
|
+
- "tigris iam users invite user@example.com --role member"
|
|
1025
1026
|
commands:
|
|
1026
1027
|
- name: policies
|
|
1027
1028
|
description: Manage IAM policies. Policies define permissions for access keys
|
|
@@ -1137,3 +1138,115 @@ commands:
|
|
|
1137
1138
|
required: false
|
|
1138
1139
|
examples:
|
|
1139
1140
|
- arn:aws:iam::org_id:policy/my-policy
|
|
1141
|
+
|
|
1142
|
+
- name: users
|
|
1143
|
+
description: Manage organization users and invitations
|
|
1144
|
+
alias: u
|
|
1145
|
+
examples:
|
|
1146
|
+
- "tigris iam users list"
|
|
1147
|
+
- "tigris iam users invite user@example.com --role member"
|
|
1148
|
+
- "tigris iam users remove user@example.com"
|
|
1149
|
+
commands:
|
|
1150
|
+
- name: list
|
|
1151
|
+
description: List all users and pending invitations in the organization
|
|
1152
|
+
alias: l
|
|
1153
|
+
examples:
|
|
1154
|
+
- "tigris iam users list"
|
|
1155
|
+
- "tigris iam users list --format json"
|
|
1156
|
+
messages:
|
|
1157
|
+
onStart: ''
|
|
1158
|
+
onSuccess: ''
|
|
1159
|
+
onFailure: 'Failed to list users'
|
|
1160
|
+
onEmpty: 'No users found in this organization'
|
|
1161
|
+
arguments:
|
|
1162
|
+
- name: format
|
|
1163
|
+
description: Output format
|
|
1164
|
+
alias: f
|
|
1165
|
+
options: [json, table, xml]
|
|
1166
|
+
default: table
|
|
1167
|
+
- name: invite
|
|
1168
|
+
description: Invite users to the organization by email
|
|
1169
|
+
alias: i
|
|
1170
|
+
examples:
|
|
1171
|
+
- "tigris iam users invite user@example.com"
|
|
1172
|
+
- "tigris iam users invite user@example.com --role admin"
|
|
1173
|
+
- "tigris iam users invite user1@example.com,user2@example.com"
|
|
1174
|
+
messages:
|
|
1175
|
+
onStart: 'Sending invitation...'
|
|
1176
|
+
onSuccess: "Invitation sent to '{{email}}'"
|
|
1177
|
+
onFailure: 'Failed to send invitation'
|
|
1178
|
+
arguments:
|
|
1179
|
+
- name: email
|
|
1180
|
+
description: Email address(es) to invite (comma-separated for multiple)
|
|
1181
|
+
type: positional
|
|
1182
|
+
required: true
|
|
1183
|
+
multiple: true
|
|
1184
|
+
examples:
|
|
1185
|
+
- user@example.com
|
|
1186
|
+
- user1@example.com,user2@example.com
|
|
1187
|
+
- name: role
|
|
1188
|
+
description: Role to assign to the invited user(s)
|
|
1189
|
+
alias: r
|
|
1190
|
+
options: [admin, member]
|
|
1191
|
+
default: member
|
|
1192
|
+
- name: revoke-invitation
|
|
1193
|
+
description: Revoke pending invitations. If no invitation ID provided, shows interactive selection
|
|
1194
|
+
alias: ri
|
|
1195
|
+
examples:
|
|
1196
|
+
- "tigris iam users revoke-invitation"
|
|
1197
|
+
- "tigris iam users revoke-invitation invitation_id"
|
|
1198
|
+
- "tigris iam users revoke-invitation id1,id2,id3"
|
|
1199
|
+
messages:
|
|
1200
|
+
onStart: 'Revoking invitation...'
|
|
1201
|
+
onSuccess: "Invitation(s) revoked"
|
|
1202
|
+
onFailure: 'Failed to revoke invitation'
|
|
1203
|
+
onEmpty: 'No pending invitations found'
|
|
1204
|
+
arguments:
|
|
1205
|
+
- name: resource
|
|
1206
|
+
description: Invitation ID(s) (comma-separated for multiple). If omitted, shows interactive selection
|
|
1207
|
+
type: positional
|
|
1208
|
+
required: false
|
|
1209
|
+
multiple: true
|
|
1210
|
+
- name: update-role
|
|
1211
|
+
description: Update user roles in the organization. If no user ID provided, shows interactive selection
|
|
1212
|
+
alias: ur
|
|
1213
|
+
examples:
|
|
1214
|
+
- "tigris iam users update-role --role admin"
|
|
1215
|
+
- "tigris iam users update-role user_id --role member"
|
|
1216
|
+
- "tigris iam users update-role id1,id2 --role admin"
|
|
1217
|
+
- "tigris iam users update-role id1,id2 --role admin,member"
|
|
1218
|
+
messages:
|
|
1219
|
+
onStart: 'Updating user role...'
|
|
1220
|
+
onSuccess: "Role updated"
|
|
1221
|
+
onFailure: 'Failed to update user role'
|
|
1222
|
+
onEmpty: 'No users found in this organization'
|
|
1223
|
+
arguments:
|
|
1224
|
+
- name: resource
|
|
1225
|
+
description: User ID(s) (comma-separated for multiple). If omitted, shows interactive selection
|
|
1226
|
+
type: positional
|
|
1227
|
+
required: false
|
|
1228
|
+
multiple: true
|
|
1229
|
+
- name: role
|
|
1230
|
+
description: Role(s) to assign (comma-separated). Each role pairs with the corresponding user ID. If one role is given, it applies to all users
|
|
1231
|
+
alias: r
|
|
1232
|
+
required: true
|
|
1233
|
+
options: [admin, member]
|
|
1234
|
+
multiple: true
|
|
1235
|
+
- name: remove
|
|
1236
|
+
description: Remove users from the organization. If no user ID provided, shows interactive selection
|
|
1237
|
+
alias: rm
|
|
1238
|
+
examples:
|
|
1239
|
+
- "tigris iam users remove"
|
|
1240
|
+
- "tigris iam users remove user@example.com"
|
|
1241
|
+
- "tigris iam users remove user@example.com,user@example.net"
|
|
1242
|
+
messages:
|
|
1243
|
+
onStart: 'Removing user...'
|
|
1244
|
+
onSuccess: "User(s) removed"
|
|
1245
|
+
onFailure: 'Failed to remove user'
|
|
1246
|
+
onEmpty: 'No users found in this organization'
|
|
1247
|
+
arguments:
|
|
1248
|
+
- name: resource
|
|
1249
|
+
description: User ID(s) (comma-separated for multiple). If omitted, shows interactive selection
|
|
1250
|
+
type: positional
|
|
1251
|
+
required: false
|
|
1252
|
+
multiple: true
|
package/dist/utils/messages.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a,b,c,d,e,f,g}from"../chunk-
|
|
1
|
+
import{a,b,c,d,e,f,g}from"../chunk-SYGTCM6P.js";import"../chunk-BETAO4PB.js";export{g as msg,e as printAlreadyDone,d as printEmpty,c as printFailure,f as printHint,a as printStart,b as printSuccess};
|
package/dist/utils/specs.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a,b,c,d}from"../chunk-
|
|
1
|
+
import{a,b,c,d,e}from"../chunk-BETAO4PB.js";export{e as buildPromptChoices,d as getArgumentSpec,c as getCommandSpec,b as loadSpecs,a as setSpecs};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{b as a,c as b}from"../chunk-
|
|
1
|
+
import{b as a,c as b}from"../chunk-SJCYBKF2.js";import"../chunk-2XAO2OYD.js";export{b as checkForUpdates,a as isNewerVersion};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tigrisdata/cli",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.10.0",
|
|
4
4
|
"description": "Command line interface for Tigris object storage",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"exports": {
|
|
@@ -24,8 +24,8 @@
|
|
|
24
24
|
"build": "tsup",
|
|
25
25
|
"dev": "export $(grep -v '^#' .env | xargs) && tsup --watch",
|
|
26
26
|
"cli": "node dist/cli.js",
|
|
27
|
-
"lint": "eslint src
|
|
28
|
-
"lint:fix": "eslint src --
|
|
27
|
+
"lint": "eslint src",
|
|
28
|
+
"lint:fix": "eslint src --fix",
|
|
29
29
|
"format": "prettier --write \"src/**/*.ts\"",
|
|
30
30
|
"format:check": "prettier --check \"src/**/*.ts\"",
|
|
31
31
|
"test": "vitest run",
|
|
@@ -35,6 +35,9 @@
|
|
|
35
35
|
"publint": "publint",
|
|
36
36
|
"updatedocs": "tsx scripts/update-docs.ts",
|
|
37
37
|
"postinstall": "node postinstall.cjs",
|
|
38
|
+
"generate:registry": "tsx scripts/generate-registry.ts",
|
|
39
|
+
"build:binary": "npm run generate:registry && tsx scripts/build-binaries.ts",
|
|
40
|
+
"build:binary:current": "npm run generate:registry && bun build src/cli-binary.ts --compile --outfile=bin/tigris",
|
|
38
41
|
"prepublishOnly": "npm run build",
|
|
39
42
|
"clean": "rm -rf dist",
|
|
40
43
|
"semantic-release": "semantic-release",
|
|
@@ -79,35 +82,35 @@
|
|
|
79
82
|
]
|
|
80
83
|
},
|
|
81
84
|
"dependencies": {
|
|
82
|
-
"@aws-sdk/client-s3": "^3.
|
|
83
|
-
"@aws-sdk/credential-providers": "^3.
|
|
85
|
+
"@aws-sdk/client-s3": "^3.994.0",
|
|
86
|
+
"@aws-sdk/credential-providers": "^3.994.0",
|
|
84
87
|
"@smithy/shared-ini-file-loader": "^4.4.3",
|
|
85
|
-
"@tigrisdata/iam": "^1.
|
|
88
|
+
"@tigrisdata/iam": "^1.3.0",
|
|
86
89
|
"@tigrisdata/storage": "^2.13.0",
|
|
87
|
-
"axios": "^1.
|
|
88
|
-
"commander": "^
|
|
90
|
+
"axios": "^1.13.5",
|
|
91
|
+
"commander": "^14.0.3",
|
|
89
92
|
"enquirer": "^2.4.1",
|
|
90
93
|
"jose": "^6.1.3",
|
|
91
|
-
"open": "^
|
|
92
|
-
"yaml": "^2.
|
|
94
|
+
"open": "^11.0.0",
|
|
95
|
+
"yaml": "^2.8.2"
|
|
93
96
|
},
|
|
94
97
|
"devDependencies": {
|
|
95
|
-
"@commitlint/cli": "^20.2
|
|
96
|
-
"@commitlint/config-conventional": "^20.2
|
|
98
|
+
"@commitlint/cli": "^20.4.2",
|
|
99
|
+
"@commitlint/config-conventional": "^20.4.2",
|
|
100
|
+
"@eslint/js": "^10.0.1",
|
|
97
101
|
"@semantic-release/changelog": "^6.0.3",
|
|
98
102
|
"@semantic-release/git": "^10.0.1",
|
|
99
|
-
"@types/node": "^
|
|
100
|
-
"
|
|
101
|
-
"
|
|
102
|
-
"
|
|
103
|
-
"
|
|
104
|
-
"
|
|
105
|
-
"prettier": "^3.0.0",
|
|
106
|
-
"publint": "^0.2.0",
|
|
103
|
+
"@types/node": "^22.19.11",
|
|
104
|
+
"dotenv": "^17.3.1",
|
|
105
|
+
"eslint": "^10.0.0",
|
|
106
|
+
"husky": "^9.1.7",
|
|
107
|
+
"prettier": "^3.8.1",
|
|
108
|
+
"publint": "^0.3.17",
|
|
107
109
|
"semantic-release": "^25.0.3",
|
|
108
|
-
"tsup": "^8.
|
|
110
|
+
"tsup": "^8.5.1",
|
|
109
111
|
"tsx": "^4.21.0",
|
|
110
|
-
"typescript": "^5.
|
|
111
|
-
"
|
|
112
|
+
"typescript": "^5.9.3",
|
|
113
|
+
"typescript-eslint": "^8.56.0",
|
|
114
|
+
"vitest": "^4.0.18"
|
|
112
115
|
}
|
|
113
116
|
}
|
package/dist/chunk-2HJMXAYU.js
DELETED
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import{c as p,d,e as u}from"./chunk-BP52O7NB.js";import{readFileSync as C,writeFileSync as N,mkdirSync as T}from"fs";import{join as m}from"path";import{homedir as f}from"os";import k from"https";var c="2.8.0";var g=m(f(),".tigris","update-check.json");function h(){try{let t=C(g,"utf-8"),s=JSON.parse(t);return typeof s.latestVersion=="string"&&typeof s.lastChecked=="number"?s:null}catch{return null}}function v(t){try{T(m(f(),".tigris"),{recursive:!0}),N(g,JSON.stringify(t),"utf-8")}catch{}}function _(t,s){let r=e=>{let o=(e.startsWith("v")?e.slice(1):e).split(".");if(o.length!==3)return null;let a=o.map(Number);return a.some(isNaN)?null:a},i=r(t),n=r(s);if(!i||!n)return!1;for(let e=0;e<3;e++){if(n[e]>i[e])return!0;if(n[e]<i[e])return!1}return!1}function E(){try{let t=k.get(p,{timeout:5e3},s=>{let r="";s.on("data",i=>{r+=i}),s.on("end",()=>{try{let i=JSON.parse(r);if(typeof i.version=="string"){let n=h();v({...n,latestVersion:i.version,lastChecked:Date.now()})}}catch{}})});t.on("error",()=>{}),t.on("timeout",()=>{t.destroy()}),t.end(),t.on("socket",s=>{s.unref()})}catch{}}function D(){if(process.env.TIGRIS_NO_UPDATE_CHECK==="1"||!process.stdout.isTTY)return;let t=h(),s=Number(process.env.TIGRIS_UPDATE_NOTIFY_INTERVAL_MS)||216e5;if(t&&_(c,t.latestVersion)&&(!t.lastNotified||Date.now()-t.lastNotified>s)){let i=`Update available: ${c} \u2192 ${t.latestVersion}`,n="Run `npm install -g @tigrisdata/cli` to upgrade.",e=Math.max(i.length,n.length)+4,l="\u250C"+"\u2500".repeat(e-2)+"\u2510",o="\u2514"+"\u2500".repeat(e-2)+"\u2518",a=y=>"\u2502 "+y.padEnd(e-4)+" \u2502";console.log(`
|
|
2
|
-
${l}
|
|
3
|
-
${a("")}
|
|
4
|
-
${a(i)}
|
|
5
|
-
${a(n)}
|
|
6
|
-
${a("")}
|
|
7
|
-
${o}
|
|
8
|
-
`),v({...t,lastNotified:Date.now()})}let r=Number(process.env.TIGRIS_UPDATE_CHECK_INTERVAL_MS)||864e5;(!t||Date.now()-t.lastChecked>r)&&E()}export{c as a,_ as b,D as c};
|
package/dist/chunk-7F4WI32C.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{a as n,b as i}from"./chunk-BP52O7NB.js";function I(){let e=process.env.TIGRIS_ENV==="development",t=e?"auth-dev.tigris.dev":process.env.AUTH0_DOMAIN??"auth.tigris.dev",s=e?"JdJVYIyw0O1uHi5L5OJH903qaWBgd3gF":process.env.AUTH0_CLIENT_ID??"DMejqeM3CQ4IqTjEcd3oA9eEiT40hn8D",o=e?"https://tigris-api-dev":process.env.AUTH0_AUDIENCE??"https://tigris-os-api";return{domain:t,clientId:s,audience:o}}var p=process.env.TIGRIS_CLAIMS_NAMESPACE||"https://tigris";function T(){return process.env.TIGRIS_STORAGE_ENDPOINT||process.env.TIGRIS_IAM_ENDPOINT?{endpoint:process.env.TIGRIS_STORAGE_ENDPOINT||n,iamEndpoint:process.env.TIGRIS_IAM_ENDPOINT||i}:{endpoint:process.env.AWS_ENDPOINT_URL_S3||n,iamEndpoint:process.env.AWS_ENDPOINT_URL_IAM||i}}export{I as a,p as b,T as c};
|
package/dist/chunk-BP52O7NB.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
var t="https://t3.storage.dev",s="https://iam.storageapi.dev",o="https://registry.npmjs.org/@tigrisdata/cli/latest",_=864e5,e=216e5;export{t as a,s as b,o as c,_ as d,e};
|
package/dist/chunk-DC3ZKGQV.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{a as p,b as u}from"./chunk-7F4WI32C.js";import{a as c,b as s,c as l,d as h,e as g,r as k}from"./chunk-UUITLEOI.js";import a from"axios";import w from"open";import{createRemoteJWKSet as T,jwtVerify as y}from"jose";var f=class{config;baseUrl;jwks=null;constructor(){this.config=p(),this.baseUrl=`https://${this.config.domain}`}getJWKS(){return this.jwks||(this.jwks=T(new URL(`${this.baseUrl}/.well-known/jwks.json`))),this.jwks}async verifyIdToken(e){let{payload:t}=await y(e,this.getJWKS(),{issuer:`${this.baseUrl}/`,audience:this.config.clientId});return t}async login(e){let o=(await a.post(`${this.baseUrl}/oauth/device/code`,{client_id:this.config.clientId,audience:this.config.audience,scope:"openid profile email offline_access"},{headers:{"Content-Type":"application/x-www-form-urlencoded"}})).data;e?.onDeviceCode?.(o.user_code,o.verification_uri),await this.sleep(2e3);try{await w(o.verification_uri_complete)}catch{}e?.onWaiting?.();let n=await this.pollForToken(o.device_code,o.interval||5);await c(n),k("oauth"),await this.extractAndStoreOrganizations(n.idToken)}async pollForToken(e,t){let n=0;for(;n<60;){n++;try{let r=(await a.post(`${this.baseUrl}/oauth/token`,{client_id:this.config.clientId,device_code:e,grant_type:"urn:ietf:params:oauth:grant-type:device_code"},{headers:{"Content-Type":"application/x-www-form-urlencoded"}})).data;if(!r.id_token)throw new Error("No ID token found. Please try again.");if((await this.verifyIdToken(r.id_token)).email_verified===!1)throw console.log("Email not verified. Please verify your email and try again."),new Error("Email not verified. Please verify your email and try again.");let m=Date.now()+(r.expires_in||3600)*1e3;return{accessToken:r.access_token,refreshToken:r.refresh_token,idToken:r.id_token,expiresAt:m}}catch(i){if(a.isAxiosError(i)&&i.response){let r=i.response.data?.error;if(r==="authorization_pending"){await this.sleep(t*1e3);continue}if(r==="slow_down"){t+=5,await this.sleep(t*1e3);continue}throw new Error(i.response.data?.error_description||"Authentication failed")}throw i}}throw new Error("Authentication timed out. Please try again.")}async getAccessToken(){let e=await s();if(!e)throw new Error('Not authenticated. Please run "tigris login" to authenticate.');let t=300*1e3;return Date.now()+t>=e.expiresAt&&(e=await this.refreshAccessToken(e)),e.accessToken}async refreshAccessToken(e){let t=null;if(e?.refreshToken?t=e:t=await s(),!t)throw new Error('No refresh token available. Please run "tigris login" to re-authenticate.');try{let n=(await a.post(`${this.baseUrl}/oauth/token`,{client_id:this.config.clientId,grant_type:"refresh_token",refresh_token:t.refreshToken,scope:"openid profile email offline_access"},{headers:{"Content-Type":"application/x-www-form-urlencoded"}})).data,i={accessToken:n.access_token,refreshToken:n.refresh_token||t.refreshToken,idToken:n.id_token||t.idToken,expiresAt:Date.now()+(n.expires_in||3600)*1e3};return await c(i),i}catch{throw await l(),new Error('Token refresh failed. Please run "tigris login" to re-authenticate.')}}async getIdTokenClaims(){let e=await s();if(!e||!e.idToken)throw new Error('Not authenticated. Please run "tigris login" to authenticate.');try{return await this.verifyIdToken(e.idToken)}catch{throw new Error('ID token verification failed. Please run "tigris login" to re-authenticate.')}}async extractAndStoreOrganizations(e){if(e)try{let o=(await this.verifyIdToken(e))[u];if(!o)return;let n=o?.ns?.map(i=>typeof i=="object"&&i!==null?{id:i.id,name:i.name,displayName:i.name}:{id:i,name:i,displayName:i})||[];if(n.length===0)return;h(n)}catch{}}async getOrganizations(){return await this.getAccessToken(),g()}async logout(){await l()}async isAuthenticated(){return await s()!==null}sleep(e){return new Promise(t=>setTimeout(t,e))}},d=null;function S(){return d||(d=new f),d}export{f as a,S as b};
|
package/dist/chunk-KBDSESA4.js
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import{a as s,b as e,c,e as g,f as l,g as u}from"./chunk-I52LJ637.js";import{b as a}from"./chunk-DC3ZKGQV.js";import{f as r}from"./chunk-UUITLEOI.js";var t=u("login","oauth");async function f(){s(t);try{let n=a();if(await n.isAuthenticated()){g(t);return}await n.login({onDeviceCode:(o,p)=>{console.log(`
|
|
2
|
-
Your confirmation code: ${o}
|
|
3
|
-
`),console.log(`If browser doesn't open, visit: ${p}`)},onWaiting:()=>console.log(`
|
|
4
|
-
Waiting for authentication...`)});let i=await n.getOrganizations();if(i.length>0){let o=i[0];await r(o.id),e(t,{org:o.displayName||o.name}),i.length>1&&l(t,{count:i.length})}else e(t,{org:"none"})}catch{c(t),process.exit(1)}}var A=f;export{f as a,A as b};
|
package/dist/chunk-LY55GPPO.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{readFileSync as p}from"fs";import{join as l,dirname as u}from"path";import{fileURLToPath as f}from"url";import*as i from"yaml";var d=f(import.meta.url),S=u(d),m=null,g=l(S,"specs.yaml");function A(){if(!m){let n=p(g,"utf8");m=i.parse(n,{schema:"core"})}return m}function y(n,e){let s=A(),t=n.split(" ").filter(Boolean),r,a=s.commands;for(let o of t){if(r=a.find(c=>c.name===o),!r)return null;a=r.commands||[]}return r?e&&r.commands?r.commands.find(o=>o.name===e)||null:r:null}function x(n,e,s){let t=y(n,s);return!t||!t.arguments?null:t.arguments.find(r=>r.name===e)||null}function P(n){return n.options?Array.isArray(n.options)&&typeof n.options[0]=="string"?n.options.map(e=>({name:e,message:e.charAt(0).toUpperCase()+e.slice(1),value:e})):Array.isArray(n.options)&&typeof n.options[0]=="object"?n.options.map(e=>({name:e.value,message:e.description?`${e.name} - ${e.description}`:e.name,value:e.value})):null:null}export{A as a,y as b,x as c,P as d};
|
package/dist/chunk-TF2BX3PY.js
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import{a as C,c as w}from"./chunk-2HJMXAYU.js";import{a as y}from"./chunk-LY55GPPO.js";import{Command as S}from"commander";import{existsSync as A}from"fs";import{join as x,dirname as k}from"path";import{fileURLToPath as R}from"url";process.on("unhandledRejection",e=>{(e===""||e===void 0)&&(console.error(`
|
|
2
|
-
Operation cancelled`),process.exit(1)),console.error(`
|
|
3
|
-
Error:`,e instanceof Error?e.message:e),process.exit(1)});process.on("uncaughtException",e=>{console.error(`
|
|
4
|
-
Error:`,e.message),process.exit(1)});var V=R(import.meta.url),b=k(V),m=y();function U(e){return/^[a-zA-Z0-9_-]+$/.test(e)}function _(e){if(e.length===0)return!1;let t=x(b,"lib",...e)+".js";if(A(t))return!0;let o=x(b,"lib",...e,"index.js");return!!A(o)}function D(e){let t;e.type==="positional"?t=` ${e.name}`:(t=` --${e.name}`,e.alias&&typeof e.alias=="string"&&e.alias.length===1&&(t+=`, -${e.alias}`));let o=26,i=t.length>=o?t+" ":t.padEnd(o),n=e.description;return e.options&&(Array.isArray(e.options)&&typeof e.options[0]=="string"?n+=` (options: ${e.options.join(", ")})`:n+=` (options: ${e.options.map(a=>a.value).join(", ")})`),e.default&&(n+=` [default: ${e.default}]`),e.required&&(n+=" [required]"),e["required-when"]&&(n+=` [required when: ${e["required-when"]}]`),e.multiple&&(n+=" [multiple values: comma-separated]"),e.type==="positional"&&(n+=" [positional argument]"),e.examples&&e.examples.length>0&&(n+=` (examples: ${e.examples.join(", ")})`),`${i}${n}`}function d(e,t){let o=t.join(" ");if(console.log(`
|
|
5
|
-
${m.name} ${o} - ${e.description}
|
|
6
|
-
`),e.commands&&e.commands.length>0){let i=e.commands.filter(n=>g(n,[...t,n.name]));i.length>0&&(console.log("Commands:"),i.forEach(n=>{let a=` ${n.name}`;if(n.alias){let r=Array.isArray(n.alias)?n.alias:[n.alias];a+=` (${r.join(", ")})`}let s=a.padEnd(24);console.log(`${s}${n.description}`)}),console.log())}e.arguments&&e.arguments.length>0&&(console.log("Arguments:"),e.arguments.forEach(i=>{console.log(D(i))}),console.log()),e.examples&&e.examples.length>0&&(console.log("Examples:"),e.examples.forEach(i=>{console.log(` ${i}`)}),console.log()),e.commands&&e.commands.length>0&&console.log(`Use "${m.name} ${o} <command> help" for more information about a command.`)}function g(e,t){return _(t)?!0:e.commands?e.commands.some(o=>g(o,[...t,o.name])):!1}function v(){console.log(`Tigris CLI Version: ${C}
|
|
7
|
-
`),console.log(`Usage: tigris [command] [options]
|
|
8
|
-
`),console.log("Commands:"),m.commands.filter(t=>g(t,[t.name])).forEach(t=>{let o=` ${t.name}`;if(t.alias){let n=Array.isArray(t.alias)?t.alias:[t.alias];o+=` (${n.join(", ")})`}let i=o.padEnd(24);console.log(`${i}${t.description}`)}),console.log(`
|
|
9
|
-
Use "${m.name} <command> help" for more information about a command.`)}function p(e,t=[]){t.forEach(o=>{if(o.type==="positional"){let i=o.required?`<${o.name}>`:`[${o.name}]`;e.argument(i,o.description)}else{let n=o.alias&&typeof o.alias=="string"&&o.alias.length===1?`-${o.alias}, --${o.name}`:`--${o.name}`;o.type==="flag"||(o.type==="boolean"?n+=" [value]":o.options?n+=" <value>":n+=o.required||o["required-when"]?" <value>":" [value]"),e.option(n,o.description,o.default)}})}function E(e,t){for(let o of e){if(o["required-when"]){let[i,n]=o["required-when"].split("="),a=h(t,i,e),s=h(t,o.name,e);if(a===n&&!s)return console.error(`--${o.name} is required when --${i} is ${n}`),!1}if(o.required&&!h(t,o.name,e))return console.error(`--${o.name} is required`),!1}return!0}function h(e,t,o){if(o){let n=o.find(a=>a.name===t);if(n&&n.alias&&typeof n.alias=="string"){let a=n.alias.charAt(0).toUpperCase()+n.alias.slice(1);if(e[a]!==void 0)return e[a]}}let i=[t,t.replace(/-/g,""),t.replace(/-/g,"").toLowerCase(),t.charAt(0).toUpperCase(),H(t)];for(let n of i)if(e[n]!==void 0)return e[n]}function H(e){return e.replace(/-([a-z])/g,(t,o)=>o.toUpperCase())}async function I(e){let t=[`./lib/${e.join("/")}.js`,`./lib/${e.join("/")}/index.js`];for(let i of t){let n=await import(i).catch(()=>null);if(n)return{module:n,error:null}}return{module:null,error:`Command not found: ${e.join(" ")}`}}async function j(e,t=[],o={},i){if(i){let l=i.replace(/\\n/g,`
|
|
10
|
-
`);console.log(l)}let{module:n,error:a}=await I(e);(a||!n)&&(console.error(a),process.exit(1));let s=e[e.length-1],r=n.default||n[s];typeof r!="function"&&(console.error(`Command not implemented: ${e.join(" ")}`),process.exit(1)),await r({...o,_positional:t})}function u(e,t,o){let i;"optsWithGlobals"in o&&typeof o.optsWithGlobals=="function"?i=o.optsWithGlobals():"opts"in o&&typeof o.opts=="function"?i=o.opts():i=o;let n={...i};return e.filter(s=>s.type==="positional").forEach((s,r)=>{t[r]!==void 0&&(s.multiple?n[s.name]=t[r].split(",").map(l=>l.trim()):n[s.name]=t[r])}),e.forEach(s=>{s.multiple&&s.type!=="positional"&&n[s.name]&&typeof n[s.name]=="string"&&(n[s.name]=n[s.name].split(",").map(r=>r.trim()))}),n}function q(e,t,o=[]){for(let i of t){U(i.name)||(console.error(`Invalid command name "${i.name}": only alphanumeric, hyphens, and underscores allowed`),process.exit(1));let n=[...o,i.name],a=e.command(i.name).description(i.description);if(i.alias&&(Array.isArray(i.alias)?i.alias:[i.alias]).forEach(r=>a.alias(r)),i.commands&&i.commands.length>0){if(q(a,i.commands,n),i.default){let s=i.commands.find(r=>r.name===i.default);if(s){p(a,i.arguments),p(a,s.arguments);let r=[...i.arguments||[],...s.arguments||[]];a.action(async(...l)=>{let $=l.pop(),f=l;r.length>0&&!E(r,u(r,f,$))||await j([...n,s.name],f,u(r,f,$),i.message||s.message)})}}else a.action(()=>{d(i,n)});a.command("help").description("Show help for this command").action(()=>{d(i,n)})}else p(a,i.arguments),a.action(async(...s)=>{let r=s.pop(),l=s;i.arguments&&!E(i.arguments,u(i.arguments,l,r))||await j(n,l,u(i.arguments||[],l,r),i.message)}),a.command("help").description("Show help for this command").action(()=>{d(i,n)})}}var c=new S;c.name(m.name).description(m.description).version(m.version);q(c,m.commands);c.command("help").description("Show general help").action(()=>{v()});c.action(()=>{v()});c.parse();w();
|