indiekit 0.0.2 → 0.0.6

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/README.md CHANGED
@@ -6,13 +6,25 @@ Scaffold a new production-ready SaaS application in seconds.
6
6
 
7
7
  ## Usage
8
8
 
9
- You don't need to install anything. Just run:
9
+ To scaffold a new project, run the following command directly:
10
10
 
11
11
  ```bash
12
+ # ✅ Correct usage
12
13
  npx indiekit@latest
14
+
13
15
  # or
14
- pnpm create indiekit
16
+ pnpm dlx indiekit@latest
17
+
15
18
  # or
19
+ yarn dlx indiekit@latest
20
+ ```
21
+
22
+ **Note:** Do NOT use `npm init indiekit` or `pnpm create indiekit`. These commands attempt to run a package named `create-indiekit`, which is not this package. This CLI is named `indiekit` and should be executed directly.
23
+
24
+ ```bash
25
+ # ❌ Incorrect usage (will fail)
26
+ npm init indiekit
27
+ pnpm create indiekit
16
28
  yarn create indiekit
17
29
  ```
18
30
 
package/dist/index.js CHANGED
@@ -1,9 +1,9 @@
1
1
  #!/usr/bin/env node
2
- import{Command as N}from"commander";import b from"path";import l from"fs-extra";import C from"tiged";import p from"ora";import{input as A,select as P,confirm as _}from"@inquirer/prompts";import{execa as m}from"execa";import $ from"open";import v from"picocolors";import y from"picocolors";var w=()=>{console.log(),console.log(y.cyan(`
2
+ import{Command as O}from"commander";import r from"path";import n from"fs-extra";import _ from"tiged";import u from"ora";import{input as $,select as C,confirm as j}from"@inquirer/prompts";import{execa as g}from"execa";import N from"open";import E from"picocolors";import R from"crypto";import b from"picocolors";var k=()=>{console.log(),console.log(b.cyan(`
3
3
  \u2588\u2588\u2557\u2588\u2588\u2588\u2557 \u2588\u2588\u2557\u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2557\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2557 \u2588\u2588\u2557\u2588\u2588\u2557\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557
4
4
  \u2588\u2588\u2551\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2551\u2588\u2588\u2554\u2550\u2550\u2588\u2588\u2557\u2588\u2588\u2551\u2588\u2588\u2554\u2550\u2550\u2550\u2550\u255D \u2588\u2588\u2551 \u2588\u2588\u2554\u255D\u2588\u2588\u2551\u255A\u2550\u2550\u2588\u2588\u2554\u2550\u2550\u255D
5
5
  \u2588\u2588\u2551\u2588\u2588\u2554\u2588\u2588\u2557 \u2588\u2588\u2551\u2588\u2588\u2551 \u2588\u2588\u2551\u2588\u2588\u2551\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2588\u2588\u2588\u2554\u255D \u2588\u2588\u2551 \u2588\u2588\u2551
6
6
  \u2588\u2588\u2551\u2588\u2588\u2551\u255A\u2588\u2588\u2557\u2588\u2588\u2551\u2588\u2588\u2551 \u2588\u2588\u2551\u2588\u2588\u2551\u2588\u2588\u2554\u2550\u2550\u255D \u2588\u2588\u2554\u2550\u2588\u2588\u2557 \u2588\u2588\u2551 \u2588\u2588\u2551
7
7
  \u2588\u2588\u2551\u2588\u2588\u2551 \u255A\u2588\u2588\u2588\u2588\u2551\u2588\u2588\u2588\u2588\u2588\u2588\u2554\u255D\u2588\u2588\u2551\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2557 \u2588\u2588\u2551 \u2588\u2588\u2557\u2588\u2588\u2551 \u2588\u2588\u2551
8
8
  \u255A\u2550\u255D\u255A\u2550\u255D \u255A\u2550\u2550\u2550\u255D\u255A\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u255D\u255A\u2550\u2550\u2550\u2550\u2550\u2550\u255D \u255A\u2550\u255D \u255A\u2550\u255D\u255A\u2550\u255D \u255A\u2550\u255D
9
- `)),console.log(y.dim(" Next.js SaaS Starter Kit CLI")),console.log()};import a from"picocolors";var i={success:e=>console.log(a.green(`\u2714 ${e}`)),error:e=>console.log(a.red(`\u2716 ${e}`)),info:e=>console.log(a.blue(`\u2139 ${e}`)),warn:e=>console.log(a.yellow(`\u26A0 ${e}`))};var x=async e=>{w();let r=e[0];r||(r=await A({message:"Where should we create your new project?",default:"my-saas"}));let o=b.resolve(process.cwd(),r);l.existsSync(o)&&l.readdirSync(o).length>0&&(i.error(`Directory ${r} is not empty.`),process.exit(1));let g=await P({message:"Which version would you like to use?",choices:[{name:"Lite (Open Source) - Free, basic features",value:"lite"},{name:"Pro (Production SaaS) - Payments, Auth, Admin, AI",value:"pro"},{name:"Pro (B2B Multi-tenant) - Organizations, Roles, Invites",value:"b2b"}]}),c="Indie-Kit/nextjs-saas-starter",s=!1,n="";if(g==="pro"?(c="indie-kit/indie-kit",n="https://github.com/indie-kit/indie-kit.git",s=!0):g==="b2b"&&(c="indie-kit/b2b-boilerplate",n="https://github.com/indie-kit/b2b-boilerplate.git",s=!0),s){let t=p("Checking repository access...").start();try{await m("git",["ls-remote",n],{env:{GIT_TERMINAL_PROMPT:"0"}}),t.succeed("Access verified.")}catch{t.fail("Access denied."),i.error("You do not have access to this repository."),i.info("Opening access page..."),await $("https://indiekit.pro/app/repo-access?ref=cli&utm_source=cli&utm_medium=terminal"),process.exit(0)}}let u=p("Downloading template...").start();try{s?(await m("git",["clone","--depth","1",n,o]),await l.remove(b.join(o,".git"))):await C(c,{disableCache:!0,force:!0}).clone(o),u.succeed("Template downloaded successfully.")}catch(t){u.fail("Failed to download template."),i.error(t.message),process.exit(1)}let f=await _({message:"Install dependencies now?",default:!0});if(f){let t=p("Installing dependencies...").start(),h=process.env.npm_config_user_agent||"",I=h.startsWith("yarn")?"yarn":h.startsWith("pnpm")?"pnpm":"npm";try{await m(I,["install"],{cwd:o}),t.succeed("Dependencies installed.")}catch(j){t.fail("Failed to install dependencies."),i.error(j.message)}}i.success(`Project created at ${v.green(o)}`),console.log(),console.log("Next steps:"),console.log(` cd ${r}`),f||console.log(" pnpm install"),console.log(" pnpm dev"),console.log(),console.log(v.yellow('AI Tip: "Open in Cursor/Claude and run /bootstrap"'))};var k={name:"indiekit",version:"0.0.2",description:"The AI-Native Next.js SaaS CLI",private:!1,homepage:"https://indiekit.pro",bugs:{url:"https://indiekit.pro/contact"},keywords:["nextjs","saas","boilerplate","starter","ai","cli"],type:"module",bin:{indiekit:"./dist/index.js"},scripts:{dev:"tsup --watch",build:"tsup",start:"node dist/index.js",release:"bumpp"},files:["dist"],publishConfig:{access:"public"},repository:{type:"git",url:"git+https://github.com/indie-kit/indie-cli.git"},dependencies:{"@inquirer/prompts":"^8.2.0",commander:"^14.0.3",execa:"^9.6.1","fs-extra":"^11.3.3",open:"^11.0.0",ora:"^9.3.0",picocolors:"^1.1.1",tiged:"^2.12.7"},devDependencies:{"@types/fs-extra":"^11.0.4","@types/node":"^25.2.2",bumpp:"^10.4.1",tsup:"^8.5.1",typescript:"^5.9.3"}};var S=()=>k.version;var d=new N;d.name("indiekit").description("CLI to scaffold Next.js SaaS applications").version(S());d.argument("[directory]","Directory to create the project in").action(e=>{x(e?[e]:[])});d.parse(process.argv);
9
+ `)),console.log(b.dim(" Next.js SaaS Starter Kit CLI")),console.log()};import d from"picocolors";var i={success:t=>console.log(d.green(`\u2714 ${t}`)),error:t=>console.log(d.red(`\u2716 ${t}`)),info:t=>console.log(d.blue(`\u2139 ${t}`)),warn:t=>console.log(d.yellow(`\u26A0 ${t}`))};var T=async t=>{k();let a=t[0];a||(a=await $({message:"Where should we create your new project?",default:"my-saas"}));let o=r.resolve(process.cwd(),a);n.existsSync(o)&&n.readdirSync(o).length>0&&(i.error(`Directory ${a} is not empty.`),process.exit(1));let w=await C({message:"Which version would you like to use?",choices:[{name:"Lite (Open Source) - Free, basic features",value:"lite"},{name:"Pro (Production SaaS) - Payments, Auth, Admin, AI",value:"pro"},{name:"Pro (B2B Multi-tenant) - Organizations, Roles, Invites",value:"b2b"}]}),f="Indie-Kit/nextjs-saas-starter",p=!1,m="";if(w==="pro"?(f="indie-kit/indie-kit",m="https://github.com/indie-kit/indie-kit.git",p=!0):w==="b2b"&&(f="indie-kit/b2b-boilerplate",m="https://github.com/indie-kit/b2b-boilerplate.git",p=!0),p){let e=u("Checking repository access...").start();try{await g("git",["ls-remote",m],{env:{GIT_TERMINAL_PROMPT:"0"}}),e.succeed("Access verified.")}catch{e.fail("Access denied."),i.error("You do not have access to this repository."),i.info("Opening access page..."),await N("https://indiekit.pro/app/repo-access?ref=cli&utm_source=cli&utm_medium=terminal"),process.exit(0)}}let x=u("Downloading template...").start();try{p?(await g("git",["clone","--depth","1",m,o]),await n.remove(r.join(o,".git"))):await _(f,{disableCache:!0,force:!0}).clone(o),x.succeed("Template downloaded successfully.")}catch(e){x.fail("Failed to download template."),i.error(e.message),process.exit(1)}let S=await j({message:"Install dependencies now?",default:!0});if(S){let e=u("Installing dependencies...").start(),s=process.env.npm_config_user_agent||"",v=s.startsWith("yarn")?"yarn":s.startsWith("pnpm")?"pnpm":"npm";try{await g(v,["install"],{cwd:o}),e.succeed("Dependencies installed.")}catch(l){e.fail("Failed to install dependencies."),i.error(l.message)}}if(await j({message:"Initialize .env.local file with fresh secrets?",default:!0})){let e=u("Generating secrets...").start();try{let s=r.join(o,".env.example"),v=r.join(o,".env.local");if(n.existsSync(s)){let l=n.readFileSync(s,"utf-8"),P=R.randomBytes(32).toString("hex");l=l.replace(/BETTER_AUTH_SECRET=.*|NEXTAUTH_SECRET=.*/g,`BETTER_AUTH_SECRET="${P}"`),n.writeFileSync(v,l),e.succeed("Generated .env.local with secure keys.")}else e.warn("No .env.example found, skipping.")}catch{e.fail("Failed to setup .env.local")}}let h=r.join(o,"package.json");if(n.existsSync(h)){let e=n.readJsonSync(h);e.name=r.basename(o),e.version="0.1.0",n.writeJsonSync(h,e,{spaces:2})}i.success(`Project created at ${E.green(o)}`),console.log(),console.log("Next steps:"),console.log(` cd ${a}`),S||console.log(" pnpm install"),console.log(" pnpm dev"),console.log(),console.log(E.yellow('AI Tip: "Open in Cursor/Claude and run /bootstrap"'));let c=await C({message:"Open project in which editor?",choices:[{name:"Cursor (Recommended)",value:"cursor"},{name:"Claude (CLI)",value:"claude"},{name:"Antigravity",value:"antigravity"},{name:"Windsurf",value:"windsurf"},{name:"VS Code",value:"code"},{name:"None",value:"none"}]});if(c!=="none")try{await g(c,[o]),i.success(`Opened project in ${c}.`)}catch{i.warn(`Could not open ${c} automatically. Please run "${c} ." manually.`)}};var I={name:"indiekit",version:"0.0.6",description:"The AI-Native Next.js SaaS CLI",private:!1,homepage:"https://indiekit.pro",bugs:{url:"https://indiekit.pro/contact"},keywords:["nextjs","saas","boilerplate","starter","ai","cli"],type:"module",bin:{indiekit:"./dist/index.js"},scripts:{dev:"tsup --watch",build:"tsup",start:"node dist/index.js",release:"bumpp"},files:["dist"],publishConfig:{access:"public",provenance:!1},repository:{type:"git",url:"git+https://github.com/indie-kit/indie-cli.git"},dependencies:{"@inquirer/prompts":"^8.2.0",commander:"^14.0.3",execa:"^9.6.1","fs-extra":"^11.3.3",open:"^11.0.0",ora:"^9.3.0",picocolors:"^1.1.1",tiged:"^2.12.7"},devDependencies:{"@types/fs-extra":"^11.0.4","@types/node":"^25.2.2",bumpp:"^10.4.1",tsup:"^8.5.1",typescript:"^5.9.3"}};var A=()=>I.version;var y=new O;y.name("indiekit").description("CLI to scaffold Next.js SaaS applications").version(A());y.argument("[directory]","Directory to create the project in").action(t=>{T(t?[t]:[])});y.parse(process.argv);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "indiekit",
3
- "version": "0.0.2",
3
+ "version": "0.0.6",
4
4
  "description": "The AI-Native Next.js SaaS CLI",
5
5
  "private": false,
6
6
  "homepage": "https://indiekit.pro",
@@ -23,7 +23,8 @@
23
23
  "dist"
24
24
  ],
25
25
  "publishConfig": {
26
- "access": "public"
26
+ "access": "public",
27
+ "provenance": false
27
28
  },
28
29
  "repository": {
29
30
  "type": "git",