create-instant-app 0.22.120 → 0.22.121

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/dist/index.js +1 -1
  2. package/package.json +3 -3
package/dist/index.js CHANGED
@@ -8,7 +8,7 @@ import{Command as _e,Option as l}from"commander";import*as F from"@clack/prompts
8
8
  `+Ne.split(`
9
9
  `).map(e=>`${J.gray("\u2502")}${J.hex("#EA580D").bold(" "+e)}`).join(`
10
10
  `))};import f from"path";import g from"fs-extra";import Se from"degit";import b from"chalk";var x=()=>{let e=process.env.npm_config_user_agent;return e?e.startsWith("yarn")?"yarn":e.startsWith("pnpm")?"pnpm":e.startsWith("bun")?"bun":"npm":"npm"};import{renderUnwrap as Ce,UI as h}from"instant-cli/ui";import Ee from"slugify";import Oe from"ignore";var K=async(e,t)=>{let n=f.resolve(process.cwd(),t);if(g.existsSync(n))if(g.readdirSync(n).length===0)h.log(`${b.cyan.bold(e.appName)} exists but is empty, continuing...`,h.ciaModifier(null));else{let i=await Ce(new h.Select({promptText:b.redBright(`${b.bold("Warning:")} ${b.bold(e.appName)} already exists and isn't empty. How would you like to proceed?`),options:[{label:"Abort installation",value:"abort"},{label:"Clear the directory and continue installation",value:"clear"}],defaultValue:"abort",modifyOutput:h.ciaModifier()}));i==="abort"&&(h.log("Aborting installation..."),process.exit(1)),i==="clear"&&g.emptyDirSync(n)}if(await $e({projectDir:n,baseTemplateName:e.base}),g.pathExistsSync(f.join(n,"pnpm-lock.yaml"))&&g.removeSync(f.join(n,"pnpm-lock.yaml")),x()==="pnpm"&&e.base==="expo"&&g.appendFile(f.join(n,".npmrc"),`node-linker=hoisted
11
- enable-pre-post-scripts=true`),e.base==="expo"){let i=Ee.default(t);R(f.join(n,"app.json"),'"name": "expo-template"',`"name": "${t}"`),R(f.join(n,"app.json"),'"slug": "expo-template"',`"slug": "${i}"`),R(f.join(n,"app/_layout.tsx"),'"My Instant App"',`"${t}"`)}let o=e.appName==="."?"App":b.hex("#EA570B").bold(e.appName);return h.log(b.dim(`${o} scaffolded successfully!`),h.ciaModifier(null)),n},R=(e,t,n)=>{let i=g.readFileSync(e,"utf8").replaceAll(t,n);g.writeFileSync(e,i)},je=async({projectDir:e,baseTemplateName:t})=>{let n=`instantdb/instant/examples/${t}`;await Se(n).clone(e)};async function Me(e,t){let n=f.join(e,".gitignore"),o=Oe();o.add(".git");try{let i=await g.readFile(n,"utf8");o.add(i)}catch{}await g.copy(e,t,{filter:i=>{let a=f.relative(e,i);return a===""?!0:!o.ignores(a)}})}var $e=async({projectDir:e,baseTemplateName:t})=>{if(process.env.INSTANT_CLI_DEV&&process.env.INSTANT_REPO_FOLDER){let n=f.join(process.env.INSTANT_REPO_FOLDER,"examples",t);await Me(n,e);return}process.env.INSTANT_CLI_DEV&&h.log(b.bold.yellowBright(`WARNING: INSTANT_CLI_DEV is TRUE but no INSTANT_REPO_FOLDER is set.
11
+ enable-pre-post-scripts=true`),e.base==="expo"){let i=Ee.default(t);R(f.join(n,"app.json"),'"name": "expo-template"',`"name": "${t}"`),R(f.join(n,"app.json"),'"slug": "expo-template"',`"slug": "${i}"`),R(f.join(n,"app/_layout.tsx"),'"My Instant App"',`"${t}"`)}let o=e.appName==="."?"App":b.hex("#EA570B").bold(e.appName);return h.log(b.dim(`${o} scaffolded successfully!`),h.ciaModifier(null)),n},R=(e,t,n)=>{let i=g.readFileSync(e,"utf8").replaceAll(t,n);g.writeFileSync(e,i)},je=async({projectDir:e,baseTemplateName:t})=>{let n=`instantdb/instant/examples/${t}`;await Se(n).clone(e)};async function Me(e,t){let n=f.join(e,".gitignore"),o=Oe();o.add(".git");try{let i=await g.readFile(n,"utf8");o.add(i)}catch{}await g.copy(e,t,{filter:i=>{let a=f.relative(e,i);return a===""?!0:!o.ignores(a)}})}var $e=async({projectDir:e,baseTemplateName:t})=>{if(process.env.INSTANT_REPO_FOLDER){let n=f.join(process.env.INSTANT_REPO_FOLDER,"examples",t);await Me(n,e);return}process.env.INSTANT_CLI_DEV&&h.log(b.bold.yellowBright(`WARNING: INSTANT_CLI_DEV is TRUE but no INSTANT_REPO_FOLDER is set.
12
12
  Using git to clone from main...`),h.ciaModifier(null)),await je({projectDir:e,baseTemplateName:t})};import{execa as Fe}from"execa";import{renderUnwrap as Re,UI as E}from"instant-cli/ui";var X=async(e,t)=>{let n=Fe(e,["install"],{cwd:t}),o=await Re(new E.Spinner({promise:n,workingText:`Installing dependencies with ${e}...`,doneText:"Successfully installed dependencies!",modifyOutput:E.ciaModifier(null)}));o.exitCode!==0&&(E.log(o.stderr,E.ciaModifier(null)),process.exit(1))};import ht from"chalk";import y from"fs-extra";import c from"path";import q from"path";import{fileURLToPath as Ge}from"url";var De=Ge(import.meta.url),Be=q.dirname(De),k=q.join(Be,"../");var Z=({projectDir:e,ruleFilesToAdd:t})=>{if(t!==null)switch(t){case"cursor":y.ensureDirSync(c.join(e,".cursor/rules")),y.copyFileSync(c.join(k,"template/rules/cursor-rules.md"),c.join(e,".cursor/rules/instant.mdc"));break;case"claude":y.copyFileSync(c.join(k,"template/rules/AGENTS.md"),c.join(e,"CLAUDE.md"));break;case"codex":y.copyFileSync(c.join(k,"template/rules/AGENTS.md"),c.join(e,"AGENTS.md"));break;case"gemini":y.copyFileSync(c.join(k,"template/rules/AGENTS.md"),c.join(e,"GEMINI.md"));break;case"zed":y.copyFileSync(c.join(k,"template/rules/AGENTS.md"),c.join(e,"AGENTS.md"));break;case"windsurf":y.ensureDirSync(c.join(e,".windsurf/rules")),y.copyFileSync(c.join(k,"template/rules/windsurf-rules.md"),c.join(e,".windsurf/rules/instant.md"));break}};import{execSync as D}from"child_process";import G from"path";import*as te from"@clack/prompts";import Q from"chalk";import{execa as P}from"execa";import ne from"fs-extra";import{renderUnwrap as ee,UI as A}from"instant-cli/ui";var Ue=e=>{try{return D("git --version",{cwd:e}),!0}catch{return!1}},We=e=>ne.existsSync(G.join(e,".git")),Le=async e=>{try{return await P("git",["rev-parse","--is-inside-work-tree"],{cwd:e,stdout:"ignore"}),!0}catch{return!1}},Ve=()=>{let t=D("git --version").toString().trim().split(" ")[2],n=t?.split(".")[0],o=t?.split(".")[1];return{major:Number(n),minor:Number(o)}},ze=()=>D("git config --global init.defaultBranch || echo main").toString().trim(),oe=async e=>{if(!Ue(e)){te.log.warn("Git is not installed. Skipping Git initialization.");return}let t=We(e),n=await Le(e),o=G.parse(e).name;if(n&&t){if(!await ee(new A.Confirmation({promptText:`${Q.redBright.bold("Warning:")} Git is already initialized in "${o}". Initializing a new git repository would delete the previous history. Would you like to continue anyways?`,defaultValue:!1,modifyOutput:A.ciaModifier()})))return;ne.removeSync(G.join(e,".git"))}else if(n&&!t&&!await ee(new A.Confirmation({promptText:`${Q.redBright.bold("Warning:")} "${o}" is already in a git worktree.
13
13
  Would you still like to initialize a new git repository in this directory?
14
14
  `,defaultValue:!1,modifyOutput:A.ciaModifier()})))return;try{let i=ze(),{major:a,minor:r}=Ve();a<2||a==2&&r<28?(await P("git",["init"],{cwd:e}),await P("git",["symbolic-ref","HEAD",`refs/heads/${i}`],{cwd:e})):await P("git",["init",`--initial-branch=${i}`],{cwd:e}),await P("git",["add","."],{cwd:e}),await P("git",["commit","-m","Initial commit (create-instant-app)"],{cwd:e}),A.log("Git repository initialized successfully.",A.ciaModifier(null))}catch{}};import Je from"env-paths";import*as Ye from"@clack/prompts";import{mkdir as Ke,readFile as Xe,writeFile as qe}from"node:fs/promises";import Ze from"open";import{join as Qe}from"node:path";import{randomUUID as ae}from"node:crypto";import{version as He}from"@instantdb/version";var re=!!process.env.INSTANT_CLI_DEV,ie=re?"http://localhost:3000":"https://instantdb.com",B=process.env.INSTANT_CLI_API_URI||(re?"http://localhost:8888":"https://api.instantdb.com");async function T({path:e,body:t,method:n="GET",authToken:o,metadata:i}){let r={"Content-Type":"application/json","X-Instant-Source":"create-instant-app","X-Instant-Version":He,"X-Instant-Command":"create"};o&&(r.Authorization=`Bearer ${o}`),i&&(r["X-Instant-Metadata"]=JSON.stringify(i));let p=await fetch(`${B}${e}`,{method:n??"GET",headers:r,body:t?JSON.stringify(t):void 0,signal:AbortSignal.timeout(3e5)}),s;try{s=await p.json()}catch{s=null}if(!p.ok){let u=s.message||s.hint?.errors?.[0]?.message||"There was an error";throw new Error(u)}return s}import{renderUnwrap as O,UI as d}from"instant-cli/ui";var et=!!process.env.INSTANT_CLI_DEV,tt=!!process.env.INSTANT_CLI_FORCE_EPHEMERAL;function pe(){let e=`instantdb-${et?"dev":"prod"}`,{config:t}=Je(e);return{authConfigFilePath:Qe(t,"a"),appConfigDirPath:t}}var nt=async(e,t,n,o)=>{let i=ae(),a=ae();return await T({method:"POST",authToken:t,path:"/dash/apps",body:{id:i,title:e,admin_token:a,org_id:n},metadata:o}),{appID:i,adminToken:a,source:"created"}},U=(e,t,n)=>{T({method:"POST",path:`/dash/apps/${e}/track-import`,authToken:t,metadata:n}).catch(()=>{})},le=async e=>await T({method:"GET",path:"/dash",authToken:e}),ce=async(e,t)=>await T({method:"GET",path:`/dash/orgs/${t}`,authToken:e});var ot=async(e,t)=>{try{let n=await le(e),o=n.apps.find(i=>i.id===t);if(o)return{appId:o.id,adminToken:o.admin_token};for(let i of n.orgs){let{apps:a}=await ce(e,i.id),r=a.find(p=>p.id===t);if(r)return{appId:r.id,adminToken:r.admin_token}}return null}catch{return null}},rt=async(e,t)=>{try{return await T({method:"GET",path:`/dash/apps/${e}/schema/pull`,authToken:t}),!0}catch{return!1}},it=async()=>tt?null:process.env.INSTANT_CLI_AUTH_TOKEN?process.env.INSTANT_CLI_AUTH_TOKEN:await Xe(pe().authConfigFilePath,"utf-8").catch(()=>null),se=async(e,t)=>{let n=await T({authToken:null,method:"POST",path:"/dash/apps/ephemeral",body:{title:e,rules:{$users:{view:"true"},$files:{allow:{view:"true",create:"true",delete:"true"}}}},metadata:t});return{appId:n.app.id,adminToken:n.app["admin-token"]}},de=async(e,t)=>{let n=await it();if(e?.app){if(e.token){if(!await rt(e.app,e.token))throw new Error("Invalid app ID and token combination. Please verify both the app ID and token are correct.");return d.log(`Linking to app: ${e.app}`,d.ciaModifier(null)),U(e.app,e.token,t),{appId:e.app,adminToken:e.token,approach:"import"}}if(n){let r=await ot(n,e.app);if(!r)throw new Error(`You don't have access to app "${e.app}". Please check the app ID or use --token to provide a token.`);return d.log(`Linking to app: ${e.app}`,d.ciaModifier(null)),U(r.appId,n,t),{appId:r.appId,adminToken:r.adminToken,approach:"import"}}throw new Error(`You must be logged in or provide --token when using --app. Either run 'npx instant-cli login' first, or use: --app ${e.app} --token <token>`)}if(!n){let r=await O(new d.Select({promptText:"You are not logged in.",options:[{label:"Login to your Instant account",value:"login"},{label:"Create a temporary app",value:"ephemeral"},{label:"Create an app later",value:"skip"}],modifyOutput:d.ciaModifier()}));if(r==="login"){let p=await T({authToken:null,method:"POST",path:"/dash/cli/auth/register"}).catch(xe=>{throw new Error("Failed to register",{cause:xe})}),{secret:s,ticket:u}=p;Ze(`${ie}/dash?ticket=${u}`);let _=st({secret:s}),w=await O(new d.Spinner({promise:_,workingText:"Waiting for login in browser",disappearWhenDone:!0,modifyOutput:d.ciaModifier(null)}));await pt(w.token),n=w.token}if(r==="skip")return d.log("Skipping app link step",d.ciaModifier(null)),null;if(r==="ephemeral"){let p=await O(new d.TextInput({defaultValue:"my-cool-app",prompt:"Enter a name for your temporary app:",placeholder:"my-cool-app",modifyOutput:d.ciaModifier()}));return{...await se(p,t),approach:"ephemeral"}}}if(!n)return null;let o=await le(n).catch(r=>{throw new Error("Failed to fetch dashboard",{cause:r})}),i=o.orgs.filter(r=>r.role!=="app-member");o.orgs=i;let a=await O(new d.AppSelector({startingMenuIndex:0,allowCreate:!0,allowEphemeral:!0,api:{getDash(){return o},createEphemeralApp(r){return se(r,t)},getAppsForOrg:async r=>{let{apps:p}=await ce(n,r);return{apps:p}},createApp:async(r,p)=>{let{appID:s,adminToken:u}=await nt(r,n,p,t);return{appId:s,adminToken:u}}},modifyOutput:d.ciaModifier()}));return a?.approach==="import"&&U(a.appId,n,t),a};function at(e){return new Promise(t=>setTimeout(t,e))}async function st({secret:e}){for(let t=1;t<=120;t++){await at(1e3);let n=await fetch(`${B}/dash/cli/auth/check`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({secret:e})});if(!(!n.ok&&(await n.json()).hint.errors?.[0]?.issue==="waiting-for-user")&&n.ok)return n.json()}throw new Error("Timed out waiting for login")}async function pt(e){let t=pe();return await Ke(t.appConfigDirPath,{recursive:!0}),qe(t.authConfigFilePath,e,"utf-8")}import lt from"fs-extra";import ct from"path";var dt={"next-js-app-dir":"NEXT_PUBLIC_INSTANT_APP_ID","vite-vanilla":"VITE_INSTANT_APP_ID",expo:"EXPO_PUBLIC_INSTANT_APP_ID"},ue=(e,t,n,o)=>{let i=ct.join(t,".env"),r=`${dt[e.base]}=${n}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "create-instant-app",
3
- "version": "0.22.120",
3
+ "version": "0.22.121",
4
4
  "description": "Scaffold a new web/mobile app with InstantDB",
5
5
  "homepage": "https://github.com/instantdb/instant/tree/main/client/packages/create-instant-app",
6
6
  "repository": {
@@ -35,8 +35,8 @@
35
35
  "ora": "6.3.1",
36
36
  "slugify": "^1.6.6",
37
37
  "sort-package-json": "^2.10.0",
38
- "@instantdb/version": "0.22.120",
39
- "instant-cli": "0.22.120"
38
+ "@instantdb/version": "0.22.121",
39
+ "instant-cli": "0.22.121"
40
40
  },
41
41
  "devDependencies": {
42
42
  "@anthropic-ai/sdk": "^0.60.0",