rapidkit 0.35.0 → 0.36.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.
@@ -1,3 +1,3 @@
1
- import {n,q as q$1,g}from'./chunk-YBS2HGO3.js';import {h,i,f,e}from'./chunk-UZW5QFRW.js';import {a}from'./chunk-VKLL63TL.js';import T from'fs';import w from'path';import S from'chalk';import {execa}from'execa';function ue(e){return T.existsSync(w.join(e,"bun.lock"))||T.existsSync(w.join(e,"bunfig.toml"))?"bun":T.existsSync(w.join(e,"pnpm-lock.yaml"))?"pnpm":T.existsSync(w.join(e,"yarn.lock"))?"yarn":(T.existsSync(w.join(e,"package-lock.json")),"npm")}function de(e,t,r=ue(e)){return r==="npm"?`npm run ${t}`:`${r} run ${t}`}function le(e,t=ue(e)){return `${t} install`}var Ee={"python-fastapi":{runtime:"python",framework:"FastAPI",markers:["pyproject.toml","fastapi"],commands:{init:"python -m pip install -e .",test:"pytest",build:"python -m build",start:"uvicorn main:app --reload"},errorPatterns:{setup:["ModuleNotFoundError","No module named","pip: command not found"],"test-failure":["FAILED","ERROR","test session started"],dependency:["ImportError","missing.*dependency"],runtime:["TypeError","AttributeError","ValueError"],timeout:["timeout","Timeout","timed out"],unknown:[]},healthCheck:{stage:"start",type:"http",value:"http://localhost:8000/docs"},validation:{command:"python -m pip list | grep fastapi",error:"FastAPI not installed"}},"python-django":{runtime:"python",framework:"Django",markers:["manage.py","django"],commands:{init:"python manage.py migrate",test:"python manage.py test",build:"python manage.py collectstatic --noinput",start:"python manage.py runserver 0.0.0.0:8000"},errorPatterns:{setup:["ModuleNotFoundError","ProgrammingError.*migrate"],"test-failure":["FAILED","ERROR","Ran.*test"],dependency:["ImportError","missing.*dependency"],runtime:["DatabaseError","ImproperlyConfigured"],timeout:["timeout","Timeout"],unknown:[]},healthCheck:{stage:"start",type:"port",value:8e3},dependencies:["init"]},"node-nestjs":{runtime:"node",framework:"NestJS",markers:["package.json","@nestjs/core"],commands:{init:"npm install",test:"npm run test",build:"npm run build",start:"npm run start"},errorPatterns:{setup:["npm ERR!","ENOENT","not found"],"test-failure":["Tests.*failed","FAIL","fail.*test"],dependency:["Cannot find module","ERR_MODULE_NOT_FOUND"],runtime:["TypeError","Error: ","ReferenceError"],timeout:["timeout","TIMEOUT"],unknown:[]},healthCheck:{stage:"start",type:"port",value:3e3}},"node-express":{runtime:"node",framework:"Express",markers:["package.json","express"],commands:{init:"npm install",test:"npm run test",build:"npm run build",start:"npm start"},errorPatterns:{setup:["npm ERR!","ENOENT"],"test-failure":["failed","FAIL"],dependency:["Cannot find module"],runtime:["Error","TypeError"],timeout:["timeout"],unknown:[]}},"go-fiber":{runtime:"go",framework:"Fiber",markers:["go.mod","fiber"],commands:{init:"go mod download && go mod tidy",test:"go test ./...",build:"go build -o app .",start:"./app"},errorPatterns:{setup:["go: .*not found","cannot find","go mod tidy"],"test-failure":["FAIL","--- FAIL"],dependency:["missing.*module"],runtime:["panic","fatal","Error"],timeout:["timeout","context deadline"],unknown:[]},dependencies:["init"]},"go-gin":{runtime:"go",framework:"Gin",markers:["go.mod","gin-gonic"],commands:{init:"go mod download && go mod tidy",test:"go test ./...",build:"go build -o app .",start:"./app"},errorPatterns:{setup:["go: .*not found"],"test-failure":["FAIL"],dependency:["missing.*module"],runtime:["panic"],timeout:["timeout"],unknown:[]}},"java-springboot":{runtime:"java",framework:"Spring Boot",markers:["pom.xml","build.gradle","spring-boot"],commands:{init:"mvn dependency:go-offline",test:"mvn test",build:"mvn package -DskipTests",start:"mvn spring-boot:run"},errorPatterns:{setup:["\\[ERROR\\]","BUILD FAILURE","missing dependencies"],"test-failure":["\\[ERROR\\] Tests run:","BUILD FAILURE"],dependency:["missing.*dependency"],runtime:["Exception","Error","NullPointerException"],timeout:["timeout","Timeout"],unknown:[]},healthCheck:{stage:"start",type:"port",value:8080}},"php-laravel":{runtime:"php",framework:"Laravel",markers:["composer.json","artisan","app/Models"],commands:{init:"composer install && php artisan migrate:fresh --seed",test:"php artisan test",build:"php artisan config:cache && php artisan route:cache && php artisan view:cache",start:"php artisan serve --host=0.0.0.0 --port=8000"},errorPatterns:{setup:["Composer.*lock","Fatal error","Class.*not found"],"test-failure":["FAILED","Tests.*failed"],dependency:["Class.*not found","require.*failed"],runtime:["Fatal error","Exception","Error"],timeout:["timeout","Timeout"],unknown:[]},healthCheck:{stage:"start",type:"port",value:8e3},dependencies:["init"]},"php-symfony":{runtime:"php",framework:"Symfony",markers:["composer.json","symfony.lock","bin/console"],commands:{init:"composer install && php bin/console doctrine:database:create",test:"php bin/phpunit",build:"php bin/console cache:clear --env=prod",start:"symfony serve --no-tls"},errorPatterns:{setup:["Composer.*error","Fatal error"],"test-failure":["FAILED","failure"],dependency:["Class.*not found"],runtime:["Fatal error","Exception"],timeout:["timeout"],unknown:[]},dependencies:["init"]},"rust-actix":{runtime:"rust",framework:"Actix-web",markers:["Cargo.toml","actix"],commands:{init:"cargo fetch",test:"cargo test",build:"cargo build --release",start:"cargo run --release"},errorPatterns:{setup:["error: .*could not find","failed.*download"],"test-failure":["test result:","FAILED"],dependency:["can.t find.*crate"],runtime:["error\\[E","thread.*panicked"],timeout:["timeout"],unknown:[]},validation:{command:"cargo --version",error:"Rust/Cargo not installed"}},"rust-axum":{runtime:"rust",framework:"Axum",markers:["Cargo.toml","axum"],commands:{init:"cargo fetch",test:"cargo test",build:"cargo build --release",start:"cargo run --release"},errorPatterns:{setup:["error: .*could not find"],"test-failure":["test result:","FAILED"],dependency:["can.t find.*crate"],runtime:["error\\[E"],timeout:["timeout"],unknown:[]}},"rust-rocket":{runtime:"rust",framework:"Rocket",markers:["Cargo.toml","rocket"],commands:{init:"cargo fetch",test:"cargo test",build:"cargo build --release",start:"cargo run --release"},errorPatterns:{setup:["error: .*could not find"],"test-failure":["FAILED"],dependency:["can.t find"],runtime:["error\\[E"],timeout:["timeout"],unknown:[]}},"dotnet-aspnetcore":{runtime:"dotnet",framework:"ASP.NET Core",markers:[".csproj",".sln","Program.cs"],commands:{init:"dotnet restore",test:"dotnet test",build:"dotnet build -c Release",start:"dotnet run"},errorPatterns:{setup:["error CS","CSPROJ.*not found","NuGet.*restore"],"test-failure":["Failed:.*test","FAILED"],dependency:["error NU1101"],runtime:["error CS","Exception"],timeout:["timeout"],unknown:[]},healthCheck:{stage:"start",type:"port",value:5e3}},"elixir-phoenix":{runtime:"elixir",framework:"Phoenix",markers:["mix.exs","phoenix"],commands:{init:"mix setup",test:"mix test",build:"mix compile --all-warnings",start:"mix phx.server"},errorPatterns:{setup:["\\*\\* \\(.*Error\\)","Mix.InstallError"],"test-failure":["\\d+\\sfailed","FAILED"],dependency:["dependencies are not available"],runtime:["\\*\\* \\(","RuntimeError"],timeout:["timeout"],unknown:[]},healthCheck:{stage:"start",type:"port",value:4e3},dependencies:["init"]},"ruby-rails":{runtime:"ruby",framework:"Rails",markers:["Gemfile","config/application.rb","bin/rails"],commands:{init:"bundle install && rails db:prepare",test:"rails test",build:"rails assets:precompile",start:"rails server --binding=0.0.0.0 --port=3000"},errorPatterns:{setup:["Bundler::.*Error","Gem::.*Error"],"test-failure":["failures,","error,","FAILED"],dependency:["Could not find.*gem"],runtime:["Error","Exception","NoMethodError"],timeout:["timeout"],unknown:[]},healthCheck:{stage:"start",type:"port",value:3e3},dependencies:["init"]},"ruby-sinatra":{runtime:"ruby",framework:"Sinatra",markers:["Gemfile","app.rb","sinatra"],commands:{init:"bundle install",test:"rspec",build:`echo "Sinatra apps don't require build"`,start:"ruby app.rb"},errorPatterns:{setup:["Bundler.*Error","Gem.*Error"],"test-failure":["failure","FAILED"],dependency:["Could not find.*gem"],runtime:["Error","NoMethodError"],timeout:["timeout"],unknown:[]}}},Ce={init:{python:["pip install -e .","poetry install","pip install -r requirements.txt"],node:["npm install","pnpm install","yarn install"],go:["go mod download && go mod tidy","go get ./..."],java:["mvn dependency:go-offline","gradle dependencies"],php:["composer install"],rust:["cargo fetch"],dotnet:["dotnet restore"],elixir:["mix deps.get"],ruby:["bundle install"],"jvm-generic":["mvn dependency:go-offline","gradle dependencies"],unknown:[]},test:{python:["pytest","python -m unittest","python -m pytest"],node:["npm test","npm run test"],go:["go test ./...","make test"],java:["mvn test","gradle test"],php:["php artisan test","phpunit","pest"],rust:["cargo test"],dotnet:["dotnet test"],elixir:["mix test"],ruby:["rspec","ruby -m minitest"],"jvm-generic":["mvn test","gradle test"],unknown:[]},build:{python:["python -m build","python setup.py build"],node:["npm run build"],go:["go build -o app .","go build ./..."],java:["mvn package -DskipTests","gradle build -x test"],php:['echo "PHP build: typically no build step"'],rust:["cargo build --release"],dotnet:["dotnet build -c Release"],elixir:["mix compile"],ruby:["gem build *.gemspec"],"jvm-generic":["mvn package -DskipTests","gradle build"],unknown:[]},start:{python:["python app.py","python main.py","uvicorn main:app --reload"],node:["npm start","node index.js","node src/index.js"],go:["./app","go run main.go","go run ./..."],java:["mvn spring-boot:run","gradle bootRun","java -jar target/*.jar"],php:["php -S 0.0.0.0:8000","php artisan serve"],rust:["cargo run --release","./target/release/app"],dotnet:["dotnet run"],elixir:["mix phx.server","iex -S mix"],ruby:["rails server","ruby app.rb","bundle exec puma"],"jvm-generic":["java -jar *.jar","gradle run"],unknown:[]}};function pe(e$1,t,r){if(t){let o=t.trim().toLowerCase().replace(/[_.\s]+/g,"-"),a=e(t),f=`${e$1}-${a==="gofiber"?"fiber":a==="gogin"?"gin":a==="dotnet"?"aspnetcore":a!=="unknown"?a:o==="fiber"?"fiber":o==="aspnetcore"||o==="asp-net-core"?"aspnetcore":o}`,g=Ee[f];if(g&&g.commands[r])return g.commands[r]}let n=Ce[r]?.[e$1]??[];return n.length>0?n[0]:void 0}var Pe={test:"test",build:"build",start:"start"};function H(e){if(e.stage==="init")return e.runtime==="node"?le(e.projectPath):pe(e.runtime,e.framework,e.stage);if(e.runtime==="node"){let t=Pe[e.stage];if(t){let r=g(e.projectPath,t,{framework:e.framework});if(r)return de(e.projectPath,r.scriptName)}}return pe(e.runtime,e.framework,e.stage)}function Fe(e){let t=h(e).map(r=>r==="python"?"python":r==="node"||r==="bun"?"node":r==="go"?"go":r==="java"?"java":r==="php"?"php":r==="rust"?"rust":r==="dotnet"?"dotnet":r==="elixir"?"elixir":r==="ruby"?"ruby":r==="clojure"||r==="scala"||r==="kotlin"?"jvm-generic":null).filter(r=>r!==null).filter((r,n,o)=>o.indexOf(r)===n);return {primary:t.length>0?t[0]:"unknown",secondary:t.slice(1)}}function me(e){return Fe(e).primary}function ge(e,t){if(!e)return "unknown";t||(t={setup:["ModuleNotFoundError","npm ERR!","error:","not found"],"test-failure":["FAILED","FAIL","failed"],dependency:["cannot find module","import.*error"],runtime:["Exception","Error:","panic","TypeError"],timeout:["timeout","Timeout","deadline exceeded"],unknown:[]});for(let[r,n]of Object.entries(t))for(let o of n)if(new RegExp(o,"i").test(e))return r;return "unknown"}async function z(e){let t=e.split(/[&|;]\s*/)[0].trim().split(/\s+/)[0];if(["echo","cd","pwd","test","true","false","exit"].includes(t))return {valid:true};try{let n=process.platform==="win32"?"where":"which";if((await execa(n,[t],{reject:false})).exitCode===0)return {valid:true}}catch{}return {valid:false,reason:`Command '${t}' not found or not executable`}}function fe(e,t,r){if(!t)return e;let n=typeof t=="object"&&!Array.isArray(t)&&("dev"in t||"staging"in t||"prod"in t||"default"in t)&&!Object.keys(t).some(o=>["init","test","build","start"].includes(o))?t:{};return r&&typeof n[r]=="string"?n[r]:typeof n.default=="string"?n.default:e}var ye={init:"init",test:"test",build:"build",start:"start"};function Ae(e){return e in ye?ye[e]:null}function he(e,t,r=q$1(e)){let n=Ae(t);if(!n)return {supported:false,reason:`Workspace stage "${t}" is not part of the RapidKit fleet contract.`};if(!r.projectRoot)return {supported:false,reason:"No RapidKit project metadata was detected for this target."};let o=r.commandMap[n];return !o||o.status!=="supported"?{supported:false,reason:o?.reason??`Command "${n}" is not supported for this project runtime/framework.`}:{supported:true}}var $e=new Set(["init","test","build","start"]),Ne=new Set([".git","node_modules",".rapidkit",".venv","dist","build","coverage","htmlcov"]);async function W(e){try{return await T.promises.access(e,T.constants.F_OK),true}catch{return false}}async function q(e){let t=await T.promises.readFile(e,"utf-8");return JSON.parse(t)}async function De(e,t){await T.promises.mkdir(w.dirname(e),{recursive:true}),await T.promises.writeFile(e,`${JSON.stringify(t,null,2)}
2
- `,"utf-8");}function A(e){return e.replace(/\\/g,"/")}function Ie(e){let t=e?.trim();return t?t.startsWith("project:")?t.slice(8).trim()||null:t:null}async function Te(e){return a(e,{skipDirs:Ne,includeHiddenDirs:false,descendIntoMatchedProjects:false,isProjectDir:async(t,r)=>await W(w.join(t,".rapidkit","context.json"))||await W(w.join(t,".rapidkit","project.json"))?true:w.resolve(t)===w.resolve(r)?false:h(t).length>0})}async function We(e){for(let t of [w.join(".rapidkit","project.json"),w.join(".rapidkit","context.json")]){let r=w.join(e,t);if(await W(r))try{let n=await q(r),o=n.name??n.projectName??n.slug;if(typeof o=="string"&&o.trim())return o.trim()}catch{}}return null}async function Me(e,t,r){let n=Ie(r);if(!n)return {projects:t,normalizedScope:null};let o=A(n).toLowerCase(),a=[];for(let d of t){let f=A(w.relative(e,d)),g=w.basename(d),p=await We(d);[f,g,p].filter(i=>typeof i=="string"&&i.length>0).map(i=>A(i).toLowerCase()).includes(o)&&a.push(d);}if(a.length===0)throw new Error(`Workspace run scope did not match any project: ${r}`);return {projects:a,normalizedScope:n}}async function Oe(e,t,r){let n=await execa("git",["diff","--name-only",`${r}...HEAD`],{cwd:e,reject:false});if(n.exitCode!==0)return new Set(t);let o=n.stdout.split(/\r?\n/).map(d=>d.trim()).filter(d=>d.length>0).map(d=>A(d));if(o.length===0)return new Set;let a=new Set;for(let d of t){let f=A(w.relative(e,d));if(!f||f===".")continue;let g=`${f}/`;o.some(p=>p===f||p.startsWith(g))&&a.add(d);}return a}async function Le(e,t,r){let n=w.join(e,".rapidkit","workspace.contract.json");if(await W(n))try{let s=await Ge(e,t,r,n);if(s.graphStatus!=="missing")return s}catch{return {expanded:r,graphStatus:"invalid",expansionDepth:0}}let o=w.join(e,".rapidkit","workspace-dependency-graph.json");if(!await W(o))return {expanded:r,graphStatus:"missing",expansionDepth:0};let a;try{a=await q(o);}catch{return {expanded:r,graphStatus:"invalid",expansionDepth:0}}let d=new Set(t.map(s=>w.resolve(s))),f=new Map;if(!a||typeof a!="object"||Array.isArray(a))return {expanded:r,graphStatus:"invalid",expansionDepth:0};let g=Array.isArray(a.projects)?a.projects:[];for(let s of g){if(!s||typeof s!="object"||Array.isArray(s))continue;let x=s,j=typeof x.path=="string"?x.path:"",y=w.resolve(e,j);if(!d.has(y))continue;let c=Array.isArray(x.dependsOn)?x.dependsOn.filter(l=>typeof l=="string"):[];for(let l of c){let v=w.resolve(e,l);d.has(v)&&(f.has(v)||f.set(v,new Set),f.get(v)?.add(y));}}let p=new Set(r),b=[...p],i=0;for(;b.length>0;){let s=b.shift();if(!s)continue;let x=f.get(s);if(x)for(let j of x)p.has(j)||(p.add(j),b.push(j),i+=1);}return {expanded:p,graphStatus:"loaded",expansionDepth:i}}async function Ge(e,t,r,n){let o=await q(n);if(!o||typeof o!="object"||Array.isArray(o))return {expanded:r,graphStatus:"invalid",expansionDepth:0};let a=o,d=Array.isArray(a.projects)?a.projects:null;if(!d)return {expanded:r,graphStatus:"invalid",expansionDepth:0};let f=new Map,g=new Map;for(let y of t){let c=A(w.relative(e,y));g.set(c,w.resolve(y));}let p=new Map,b=new Map,i=new Map;for(let y of d){if(!y||typeof y!="object"||Array.isArray(y))continue;let c=y,l=typeof c.slug=="string"?c.slug:"",v=typeof c.relativePath=="string"?A(c.relativePath):l,R=g.get(v);!l||!R||f.set(l,R);}for(let y of d){if(!y||typeof y!="object"||Array.isArray(y))continue;let c=y,l=typeof c.slug=="string"?c.slug:"",v=f.get(l);if(!v)continue;let R=c.contracts&&typeof c.contracts=="object"&&!Array.isArray(c.contracts)?c.contracts:{},M=Array.isArray(R.dependsOn)?R.dependsOn.filter(h=>typeof h=="string"):[],$=Array.isArray(R.publishes)?R.publishes.filter(h=>typeof h=="string"):[],N=Array.isArray(R.consumes)?R.consumes.filter(h=>typeof h=="string"):[];for(let h of M){let C=f.get(h);C&&(i.has(C)||i.set(C,new Set),i.get(C)?.add(v));}for(let h of $)p.has(h)||p.set(h,new Set),p.get(h)?.add(v);for(let h of N)b.has(h)||b.set(h,new Set),b.get(h)?.add(v);}for(let[y,c]of p.entries()){let l=b.get(y);if(l)for(let v of c){i.has(v)||i.set(v,new Set);for(let R of l)R!==v&&i.get(v)?.add(R);}}let s=new Set(r),x=[...s],j=0;for(;x.length>0;){let y=x.shift();if(!y)continue;let c=i.get(y);if(c)for(let l of c)s.has(l)||(s.add(l),x.push(l),j+=1);}return {expanded:s,graphStatus:"loaded",expansionDepth:j}}async function _e(e,t){if(typeof t=="boolean")return t;let r=w.join(e,".rapidkit","policies.yml");if(!await W(r))return true;let n="";try{n=await T.promises.readFile(r,"utf-8");}catch{return true}let o=n.match(/^[\t ]*rules\.enforce_workspace_run_gates:\s*(true|false)\s*(?:#.*)?$/m);return o?o[1]==="true":true}async function J(e,t){let r=process.argv[1];if(!r)return {exitCode:1,stdout:"",stderr:"RapidKit entrypoint is unavailable for nested workspace-run execution."};let n=await execa(process.execPath,[r,...e],{cwd:t,reject:false,env:{...process.env,RAPIDKIT_WORKSPACE_RUN_CHILD:"1"}});return {exitCode:Number(n.exitCode??1),stdout:n.stdout,stderr:n.stderr}}function Be(e){return e==="node"||e==="go"||e==="java"||e==="python"||e==="dotnet"}function Ve(){return process.env.VITEST==="true"||process.env.VITEST==="1"||process.env.NODE_ENV==="test"}async function Ke(e){let t=process.cwd();try{process.chdir(e);let{handleInitCommand:r}=await import('./index.js');return {exitCode:await r(["init"]),stdout:"",stderr:""}}finally{process.chdir(t);}}async function He(e$1){let t=i=>{let s=f(i);return s==="node"||s==="bun"?"node":s==="python"?"python":s==="go"?"go":s==="java"?"java":s==="php"?"php":s==="ruby"?"ruby":s==="rust"?"rust":s==="dotnet"?"dotnet":s==="elixir"?"elixir":s==="clojure"||s==="scala"||s==="kotlin"?"jvm-generic":me(e$1)},r=i=>{if(!i)return;let s=e(i);if(new Set(["fastapi","django","flask","nestjs","express","fastify","koa","gofiber","gogin","echo","springboot","laravel","symfony","rails","sinatra","dotnet","actix","axum","rocket","phoenix"]).has(s))return s},n$1=n(e$1),o=n$1?.detection??i(e$1,n$1?.projectJson??null),a=n$1?.contextJson,d=t(o.runtime),f$1=r(o.key),g={},p=new Set(["init","test","build","start"]);if(a?.commands&&typeof a.commands=="object")for(let[i,s]of Object.entries(a.commands))typeof s=="string"&&p.has(i)&&(g[i]=s);let b;if(a?.commandEnvironments&&typeof a.commandEnvironments=="object"){let i=a.commandEnvironments;b={dev:typeof i.dev=="string"?i.dev:void 0,staging:typeof i.staging=="string"?i.staging:void 0,prod:typeof i.prod=="string"?i.prod:void 0,default:typeof i.default=="string"?i.default:void 0};}return {runtime:d,framework:f$1,commandOverrides:Object.keys(g).length>0?g:void 0,environmentCommandVariants:b,environment:typeof a?.environment=="string"?a.environment:void 0}}async function ze(e,t,r,n,o,a,d){let f=!o?.[t]&&Be(r),g;if(o&&o[t]?g=o[t]:f?g=`rapidkit ${t}`:g=H({projectPath:e,runtime:r,framework:n,stage:t}),!g)return {exitCode:127,command:`<stage not supported for ${r}>`,message:`No stage command found for runtime '${r}' and framework '${n||"unknown"}'`,errorCategory:"runtime"};let p=fe(g,a,d);if(!p)return {exitCode:127,command:g,message:"Failed to resolve stage command",errorCategory:"runtime"};let b=H({projectPath:e,runtime:r,framework:n,stage:t});if(f){if(b){let c=await z(b);if(!c.valid)return {exitCode:127,command:p,message:c.reason||"Command not available",errorCategory:"setup"}}}else {let c=await z(p);if(!c.valid)return {exitCode:127,command:p,message:c.reason||"Command not available",errorCategory:"setup"}}let i=0,s="",x="",j;try{let c=f?t==="init"&&Ve()?await Ke(e):await J([t],e):await execa(p,[],{cwd:e,reject:false,shell:true});if(i=Number(c.exitCode??0),s=c.stdout,x=c.stderr,i!==0){let l=`${s}
3
- ${x}`;j=ge(l);}}catch(c){return {exitCode:1,command:p,message:c instanceof Error?c.message:"Command execution failed",errorCategory:"runtime"}}return {exitCode:i,command:p,errorCategory:j,healthStatus:void 0,message:i!==0?`Stage failed with exit code ${i}`:void 0}}function ke(e){try{return JSON.parse(e)}catch{return null}}function Je(e){switch(e){case "dotnet":return "Install .NET 8+ SDK, then rerun `npx rapidkit setup dotnet` or `npx rapidkit init`.";case "go":return "Install Go 1.21+, then rerun `npx rapidkit setup go` or `npx rapidkit init`.";case "java":case "jvm-generic":return "Install Java 21+ and Maven/Gradle, then rerun `npx rapidkit setup java` or `npx rapidkit init`.";case "node":return "Install Node.js LTS and npm/pnpm/yarn, then rerun `npx rapidkit setup node` or `npx rapidkit init`.";case "python":return "Install Python 3.10+ and pip/Poetry, then rerun `npx rapidkit setup python` or `npx rapidkit init`.";default:return null}}async function Ue(e){let t=[],r=await J(["doctor","workspace","--json"],e);if(r.exitCode!==0)t.push({gate:"doctor-workspace",status:"fail",summary:"doctor workspace command failed"});else {let a=ke(r.stdout)?.healthScore,d=Number(a?.errors??0);Number.isFinite(d)&&d>0?t.push({gate:"doctor-workspace",status:"fail",summary:`doctor workspace reports ${d} error(s)`}):t.push({gate:"doctor-workspace",status:"pass",summary:"doctor workspace passed"});}let n=await J(["readiness","--json"],e);if(n.exitCode!==0)t.push({gate:"readiness",status:"fail",summary:"readiness command failed"});else {let o=ke(n.stdout),a=String(o?.overallStatus??"").toLowerCase();a==="fail"?t.push({gate:"readiness",status:"fail",summary:"readiness overall status is fail"}):a==="warn"?t.push({gate:"readiness",status:"warn",summary:"readiness overall status is warn"}):t.push({gate:"readiness",status:"pass",summary:"readiness overall status is pass"});}return t}function qe(e){return $e.has(e)}function Ye(e,t){let r=Math.max(1,Math.min(4,t)),n=Number(e??r);return Number.isFinite(n)?Math.max(1,Math.min(16,Math.trunc(n))):r}async function Rt(e){if(!qe(e.stage))throw new Error(`Unsupported workspace run stage: ${e.stage}`);let t=Date.now(),r=w.resolve(e.workspacePath),n=await Te(r),{projects:o,normalizedScope:a}=await Me(r,n,e.scope),d=e.affected===true,f=e.blastRadius===true,g=e.since?.trim()||"HEAD~1",p=d?await Oe(r,o,g):new Set(o),b,i="not-applicable",s=0,x="all";if(d&&f){let m=await Le(r,n,p);b=m.expanded,i=m.graphStatus,s=m.expansionDepth,x="affected+blast-radius";}else d?(b=p,x="affected"):(b=p,x="all");let j=e.stage==="init"?false:await _e(r,e.enforceGates),y=j?await Ue(r):[{gate:"doctor-workspace",status:"skipped",summary:"workspace run gates disabled"},{gate:"readiness",status:"skipped",summary:"workspace run gates disabled"}],c=y.find(m=>m.status==="fail"),l=o.filter(m=>b.has(m)),v=e.continueOnError===true||e.stage==="init",R=e.parallel===true,M=Ye(e.maxWorkers,l.length),$=l.length,N=0;e.json||console.log(S.gray(`Workspace run (${e.stage}) started: ${$} target(s), ${R?`parallel x${M}`:"sequential"}`));let h=new Map;for(let m of n){let k=o.includes(m),u=k&&b.has(m);h.set(m,{path:m,relativePath:A(w.relative(r,m)),selected:u,affected:u,status:"skipped",exitCode:null,durationMs:0,reason:u?void 0:k?"not affected":"outside scope",framework:void 0,runtimeDetected:void 0,executionCommand:void 0});}if(c)for(let m of l){let k=h.get(m);k&&(k.status="skipped",k.reason=`blocked by ${c.gate}`);}else {let m=async k=>{let u=h.get(k);if(!u)return;let I=A(w.relative(r,k));e.json||console.log(S.gray(`\u23F3 [${N}/${$}] ${e.stage} ${I}`)),u.selected=true,u.affected=true;let P=Date.now(),{runtime:E,framework:F,commandOverrides:be,environmentCommandVariants:xe,environment:ve}=await He(k);u.runtimeDetected=E,u.framework=F;let te=he(k,e.stage);if(!te.supported){u.status="skipped",u.reason=te.reason??`stage "${e.stage}" unsupported for project`,u.durationMs=Date.now()-P,u.exitCode=null,N+=1;return}let D=await ze(k,e.stage,E,F,be,xe,ve);if(u.executionCommand=D.command,u.errorCategory=D.errorCategory,u.healthStatus=D.healthStatus,u.durationMs=Date.now()-P,u.exitCode=D.exitCode,D.exitCode===0?(u.status="passed",u.reason=void 0):(u.status="failed",u.reason=D.message||"stage command failed",u.errorMessage=D.message),N+=1,!e.json){let Re=$>0?Math.round(N/$*100):100,je=u.status==="passed"?S.green("\u2705"):S.red("\u274C");if(console.log(S.gray(`${je} [${N}/${$}] (${Re}%) ${I} ${u.durationMs}ms`)),u.status==="failed"){u.reason&&console.log(S.red(` Reason: ${u.reason}`)),u.executionCommand&&console.log(S.gray(` Command: ${u.executionCommand}`));let re=Je(u.runtimeDetected);re&&u.errorCategory==="setup"&&console.log(S.gray(` Hint: ${re}`));}}};if(R&&l.length>1){let k=0,u=false,I=new Array(M).fill(null).map(async()=>{for(;k<l.length;){if(u&&!v)return;let P=k;k+=1;let E=l[P];await m(E),h.get(E)?.status==="failed"&&(u=true);}});if(await Promise.all(I),!v&&u){let P=false;for(let E of l){let F=h.get(E);if(F){if(F.status==="failed"){P=true;continue}P&&F.status==="skipped"&&(F.reason=F.reason||"stopped after failure");}}}}else for(let k of l){await m(k);let u=h.get(k);if(!v&&u?.status==="failed"){let I=l.slice(l.indexOf(k)+1);for(let P of I){let E=h.get(P);E&&(E.status="skipped",E.reason="stopped after failure");}break}}}let C=[];for(let m of n){let k=h.get(m);k&&C.push(k);}let Y=C.filter(m=>m.status==="passed").length,B=C.filter(m=>m.status==="failed").length,Q=C.filter(m=>m.status==="skipped").length,X=e.strict===true,we=B>0||X&&y.some(m=>m.status!=="pass")?1:0,Z={schemaVersion:"1.0",workspacePath:r,stage:e.stage,generatedAt:new Date().toISOString(),durationMs:Date.now()-t,options:{affected:d,blastRadius:f,since:d?g:null,parallel:R,maxWorkers:M,continueOnError:v,strict:X,enforceGates:j,scope:a},selection:{mode:x,since:d?g:null,scope:a,graphStatus:i,expansionDepth:s},gates:{enforced:j,results:y,blocked:!!c,blockingGate:c?.gate},summary:{projectCount:n.length,selectedCount:l.length,passed:Y,failed:B,skipped:Q,exitCode:we},projects:C},ee=w.join(r,".rapidkit","reports","workspace-run-last.json");return await De(ee,Z),e.json||(c&&(console.log(S.red(`\u274C Workspace run blocked by ${c.gate}`)),console.log(S.gray(` ${c.summary}`))),console.log(S.cyan(`Workspace run (${e.stage}) => passed: ${Y}, failed: ${B}, skipped: ${Q}`)),console.log(S.gray(`Report: ${ee}`))),Z}export{Rt as a};
1
+ import {n,q as q$1,g}from'./chunk-YBS2HGO3.js';import {h,i,f,e}from'./chunk-UZW5QFRW.js';import {a}from'./chunk-VKLL63TL.js';import I from'fs';import w from'path';import S from'chalk';import {execa}from'execa';function ue(e){return I.existsSync(w.join(e,"bun.lock"))||I.existsSync(w.join(e,"bunfig.toml"))?"bun":I.existsSync(w.join(e,"pnpm-lock.yaml"))?"pnpm":I.existsSync(w.join(e,"yarn.lock"))?"yarn":(I.existsSync(w.join(e,"package-lock.json")),"npm")}function de(e,t,r=ue(e)){return r==="npm"?`npm run ${t}`:`${r} run ${t}`}function le(e,t=ue(e)){return `${t} install`}var Ce={"python-fastapi":{runtime:"python",framework:"FastAPI",markers:["pyproject.toml","fastapi"],commands:{init:"python -m pip install -e .",test:"pytest",build:"python -m build",start:"uvicorn main:app --reload"},errorPatterns:{setup:["ModuleNotFoundError","No module named","pip: command not found"],"test-failure":["FAILED","ERROR","test session started"],dependency:["ImportError","missing.*dependency"],runtime:["TypeError","AttributeError","ValueError"],timeout:["timeout","Timeout","timed out"],unknown:[]},healthCheck:{stage:"start",type:"http",value:"http://localhost:8000/docs"},validation:{command:"python -m pip list | grep fastapi",error:"FastAPI not installed"}},"python-django":{runtime:"python",framework:"Django",markers:["manage.py","django"],commands:{init:"python manage.py migrate",test:"python manage.py test",build:"python manage.py collectstatic --noinput",start:"python manage.py runserver 0.0.0.0:8000"},errorPatterns:{setup:["ModuleNotFoundError","ProgrammingError.*migrate"],"test-failure":["FAILED","ERROR","Ran.*test"],dependency:["ImportError","missing.*dependency"],runtime:["DatabaseError","ImproperlyConfigured"],timeout:["timeout","Timeout"],unknown:[]},healthCheck:{stage:"start",type:"port",value:8e3},dependencies:["init"]},"node-nestjs":{runtime:"node",framework:"NestJS",markers:["package.json","@nestjs/core"],commands:{init:"npm install",test:"npm run test",build:"npm run build",start:"npm run start"},errorPatterns:{setup:["npm ERR!","ENOENT","not found"],"test-failure":["Tests.*failed","FAIL","fail.*test"],dependency:["Cannot find module","ERR_MODULE_NOT_FOUND"],runtime:["TypeError","Error: ","ReferenceError"],timeout:["timeout","TIMEOUT"],unknown:[]},healthCheck:{stage:"start",type:"port",value:3e3}},"node-express":{runtime:"node",framework:"Express",markers:["package.json","express"],commands:{init:"npm install",test:"npm run test",build:"npm run build",start:"npm start"},errorPatterns:{setup:["npm ERR!","ENOENT"],"test-failure":["failed","FAIL"],dependency:["Cannot find module"],runtime:["Error","TypeError"],timeout:["timeout"],unknown:[]}},"go-fiber":{runtime:"go",framework:"Fiber",markers:["go.mod","fiber"],commands:{init:"go mod download && go mod tidy",test:"go test ./...",build:"go build -o app .",start:"./app"},errorPatterns:{setup:["go: .*not found","cannot find","go mod tidy"],"test-failure":["FAIL","--- FAIL"],dependency:["missing.*module"],runtime:["panic","fatal","Error"],timeout:["timeout","context deadline"],unknown:[]},dependencies:["init"]},"go-gin":{runtime:"go",framework:"Gin",markers:["go.mod","gin-gonic"],commands:{init:"go mod download && go mod tidy",test:"go test ./...",build:"go build -o app .",start:"./app"},errorPatterns:{setup:["go: .*not found"],"test-failure":["FAIL"],dependency:["missing.*module"],runtime:["panic"],timeout:["timeout"],unknown:[]}},"java-springboot":{runtime:"java",framework:"Spring Boot",markers:["pom.xml","build.gradle","spring-boot"],commands:{init:"mvn dependency:go-offline",test:"mvn test",build:"mvn package -DskipTests",start:"mvn spring-boot:run"},errorPatterns:{setup:["\\[ERROR\\]","BUILD FAILURE","missing dependencies"],"test-failure":["\\[ERROR\\] Tests run:","BUILD FAILURE"],dependency:["missing.*dependency"],runtime:["Exception","Error","NullPointerException"],timeout:["timeout","Timeout"],unknown:[]},healthCheck:{stage:"start",type:"port",value:8080}},"php-laravel":{runtime:"php",framework:"Laravel",markers:["composer.json","artisan","app/Models"],commands:{init:"composer install && php artisan migrate:fresh --seed",test:"php artisan test",build:"php artisan config:cache && php artisan route:cache && php artisan view:cache",start:"php artisan serve --host=0.0.0.0 --port=8000"},errorPatterns:{setup:["Composer.*lock","Fatal error","Class.*not found"],"test-failure":["FAILED","Tests.*failed"],dependency:["Class.*not found","require.*failed"],runtime:["Fatal error","Exception","Error"],timeout:["timeout","Timeout"],unknown:[]},healthCheck:{stage:"start",type:"port",value:8e3},dependencies:["init"]},"php-symfony":{runtime:"php",framework:"Symfony",markers:["composer.json","symfony.lock","bin/console"],commands:{init:"composer install && php bin/console doctrine:database:create",test:"php bin/phpunit",build:"php bin/console cache:clear --env=prod",start:"symfony serve --no-tls"},errorPatterns:{setup:["Composer.*error","Fatal error"],"test-failure":["FAILED","failure"],dependency:["Class.*not found"],runtime:["Fatal error","Exception"],timeout:["timeout"],unknown:[]},dependencies:["init"]},"rust-actix":{runtime:"rust",framework:"Actix-web",markers:["Cargo.toml","actix"],commands:{init:"cargo fetch",test:"cargo test",build:"cargo build --release",start:"cargo run --release"},errorPatterns:{setup:["error: .*could not find","failed.*download"],"test-failure":["test result:","FAILED"],dependency:["can.t find.*crate"],runtime:["error\\[E","thread.*panicked"],timeout:["timeout"],unknown:[]},validation:{command:"cargo --version",error:"Rust/Cargo not installed"}},"rust-axum":{runtime:"rust",framework:"Axum",markers:["Cargo.toml","axum"],commands:{init:"cargo fetch",test:"cargo test",build:"cargo build --release",start:"cargo run --release"},errorPatterns:{setup:["error: .*could not find"],"test-failure":["test result:","FAILED"],dependency:["can.t find.*crate"],runtime:["error\\[E"],timeout:["timeout"],unknown:[]}},"rust-rocket":{runtime:"rust",framework:"Rocket",markers:["Cargo.toml","rocket"],commands:{init:"cargo fetch",test:"cargo test",build:"cargo build --release",start:"cargo run --release"},errorPatterns:{setup:["error: .*could not find"],"test-failure":["FAILED"],dependency:["can.t find"],runtime:["error\\[E"],timeout:["timeout"],unknown:[]}},"dotnet-aspnetcore":{runtime:"dotnet",framework:"ASP.NET Core",markers:[".csproj",".sln","Program.cs"],commands:{init:"dotnet restore",test:"dotnet test",build:"dotnet build -c Release",start:"dotnet run"},errorPatterns:{setup:["error CS","CSPROJ.*not found","NuGet.*restore"],"test-failure":["Failed:.*test","FAILED"],dependency:["error NU1101"],runtime:["error CS","Exception"],timeout:["timeout"],unknown:[]},healthCheck:{stage:"start",type:"port",value:5e3}},"elixir-phoenix":{runtime:"elixir",framework:"Phoenix",markers:["mix.exs","phoenix"],commands:{init:"mix setup",test:"mix test",build:"mix compile --all-warnings",start:"mix phx.server"},errorPatterns:{setup:["\\*\\* \\(.*Error\\)","Mix.InstallError"],"test-failure":["\\d+\\sfailed","FAILED"],dependency:["dependencies are not available"],runtime:["\\*\\* \\(","RuntimeError"],timeout:["timeout"],unknown:[]},healthCheck:{stage:"start",type:"port",value:4e3},dependencies:["init"]},"ruby-rails":{runtime:"ruby",framework:"Rails",markers:["Gemfile","config/application.rb","bin/rails"],commands:{init:"bundle install && rails db:prepare",test:"rails test",build:"rails assets:precompile",start:"rails server --binding=0.0.0.0 --port=3000"},errorPatterns:{setup:["Bundler::.*Error","Gem::.*Error"],"test-failure":["failures,","error,","FAILED"],dependency:["Could not find.*gem"],runtime:["Error","Exception","NoMethodError"],timeout:["timeout"],unknown:[]},healthCheck:{stage:"start",type:"port",value:3e3},dependencies:["init"]},"ruby-sinatra":{runtime:"ruby",framework:"Sinatra",markers:["Gemfile","app.rb","sinatra"],commands:{init:"bundle install",test:"rspec",build:`echo "Sinatra apps don't require build"`,start:"ruby app.rb"},errorPatterns:{setup:["Bundler.*Error","Gem.*Error"],"test-failure":["failure","FAILED"],dependency:["Could not find.*gem"],runtime:["Error","NoMethodError"],timeout:["timeout"],unknown:[]}}},Pe={init:{python:["pip install -e .","poetry install","pip install -r requirements.txt"],node:["npm install","pnpm install","yarn install"],go:["go mod download && go mod tidy","go get ./..."],java:["mvn dependency:go-offline","gradle dependencies"],php:["composer install"],rust:["cargo fetch"],dotnet:["dotnet restore"],elixir:["mix deps.get"],ruby:["bundle install"],"jvm-generic":["mvn dependency:go-offline","gradle dependencies"],unknown:[]},test:{python:["pytest","python -m unittest","python -m pytest"],node:["npm test","npm run test"],go:["go test ./...","make test"],java:["mvn test","gradle test"],php:["php artisan test","phpunit","pest"],rust:["cargo test"],dotnet:["dotnet test"],elixir:["mix test"],ruby:["rspec","ruby -m minitest"],"jvm-generic":["mvn test","gradle test"],unknown:[]},build:{python:["python -m build","python setup.py build"],node:["npm run build"],go:["go build -o app .","go build ./..."],java:["mvn package -DskipTests","gradle build -x test"],php:['echo "PHP build: typically no build step"'],rust:["cargo build --release"],dotnet:["dotnet build -c Release"],elixir:["mix compile"],ruby:["gem build *.gemspec"],"jvm-generic":["mvn package -DskipTests","gradle build"],unknown:[]},start:{python:["python app.py","python main.py","uvicorn main:app --reload"],node:["npm start","node index.js","node src/index.js"],go:["./app","go run main.go","go run ./..."],java:["mvn spring-boot:run","gradle bootRun","java -jar target/*.jar"],php:["php -S 0.0.0.0:8000","php artisan serve"],rust:["cargo run --release","./target/release/app"],dotnet:["dotnet run"],elixir:["mix phx.server","iex -S mix"],ruby:["rails server","ruby app.rb","bundle exec puma"],"jvm-generic":["java -jar *.jar","gradle run"],unknown:[]}};function pe(e$1,t,r){if(t){let o=t.trim().toLowerCase().replace(/[_.\s]+/g,"-"),a=e(t),g=`${e$1}-${a==="gofiber"?"fiber":a==="gogin"?"gin":a==="dotnet"?"aspnetcore":a!=="unknown"?a:o==="fiber"?"fiber":o==="aspnetcore"||o==="asp-net-core"?"aspnetcore":o}`,f=Ce[g];if(f&&f.commands[r])return f.commands[r]}let n=Pe[r]?.[e$1]??[];return n.length>0?n[0]:void 0}var Fe={test:"test",build:"build",start:"start"};function H(e){if(e.stage==="init")return e.runtime==="node"?le(e.projectPath):pe(e.runtime,e.framework,e.stage);if(e.runtime==="node"){let t=Fe[e.stage];if(t){let r=g(e.projectPath,t,{framework:e.framework});if(r)return de(e.projectPath,r.scriptName)}}return pe(e.runtime,e.framework,e.stage)}function Ae(e){let t=h(e).map(r=>r==="python"?"python":r==="node"||r==="bun"?"node":r==="go"?"go":r==="java"?"java":r==="php"?"php":r==="rust"?"rust":r==="dotnet"?"dotnet":r==="elixir"?"elixir":r==="ruby"?"ruby":r==="clojure"||r==="scala"||r==="kotlin"?"jvm-generic":null).filter(r=>r!==null).filter((r,n,o)=>o.indexOf(r)===n);return {primary:t.length>0?t[0]:"unknown",secondary:t.slice(1)}}function me(e){return Ae(e).primary}function fe(e,t){if(!e)return "unknown";t||(t={setup:["ModuleNotFoundError","npm ERR!","error:","not found"],"test-failure":["FAILED","FAIL","failed"],dependency:["cannot find module","import.*error"],runtime:["Exception","Error:","panic","TypeError"],timeout:["timeout","Timeout","deadline exceeded"],unknown:[]});for(let[r,n]of Object.entries(t))for(let o of n)if(new RegExp(o,"i").test(e))return r;return "unknown"}async function z(e){let t=e.split(/[&|;]\s*/)[0].trim().split(/\s+/)[0];if(["echo","cd","pwd","test","true","false","exit"].includes(t))return {valid:true};try{let n=process.platform==="win32"?"where":"which";if((await execa(n,[t],{reject:false})).exitCode===0)return {valid:true}}catch{}return {valid:false,reason:`Command '${t}' not found or not executable`}}function ge(e,t,r){if(!t)return e;let n=typeof t=="object"&&!Array.isArray(t)&&("dev"in t||"staging"in t||"prod"in t||"default"in t)&&!Object.keys(t).some(o=>["init","test","build","start"].includes(o))?t:{};return r&&typeof n[r]=="string"?n[r]:typeof n.default=="string"?n.default:e}var ye={init:"init",test:"test",build:"build",start:"start"};function Ne(e){return e in ye?ye[e]:null}function he(e,t,r=q$1(e)){let n=Ne(t);if(!n)return {supported:false,reason:`Workspace stage "${t}" is not part of the RapidKit fleet contract.`};if(!r.projectRoot)return {supported:false,reason:"No RapidKit project metadata was detected for this target."};let o=r.commandMap[n];return !o||o.status!=="supported"?{supported:false,reason:o?.reason??`Command "${n}" is not supported for this project runtime/framework.`}:{supported:true}}var ke="workspace-run-last.json",$e=new Set(["init","test","build","start"]),Te=new Set([".git","node_modules",".rapidkit",".venv","dist","build","coverage","htmlcov"]);async function W(e){try{return await I.promises.access(e,I.constants.F_OK),true}catch{return false}}async function q(e){let t=await I.promises.readFile(e,"utf-8");return JSON.parse(t)}async function De(e,t){await I.promises.mkdir(w.dirname(e),{recursive:true}),await I.promises.writeFile(e,`${JSON.stringify(t,null,2)}
2
+ `,"utf-8");}function A(e){return e.replace(/\\/g,"/")}function Ie(e){let t=e?.trim();return t?t.startsWith("project:")?t.slice(8).trim()||null:t:null}async function We(e){return a(e,{skipDirs:Te,includeHiddenDirs:false,descendIntoMatchedProjects:false,isProjectDir:async(t,r)=>await W(w.join(t,".rapidkit","context.json"))||await W(w.join(t,".rapidkit","project.json"))?true:w.resolve(t)===w.resolve(r)?false:h(t).length>0})}async function Me(e){for(let t of [w.join(".rapidkit","project.json"),w.join(".rapidkit","context.json")]){let r=w.join(e,t);if(await W(r))try{let n=await q(r),o=n.name??n.projectName??n.slug;if(typeof o=="string"&&o.trim())return o.trim()}catch{}}return null}async function Oe(e,t,r){let n=Ie(r);if(!n)return {projects:t,normalizedScope:null};let o=A(n).toLowerCase(),a=[];for(let d of t){let g=A(w.relative(e,d)),f=w.basename(d),m=await Me(d);[g,f,m].filter(i=>typeof i=="string"&&i.length>0).map(i=>A(i).toLowerCase()).includes(o)&&a.push(d);}if(a.length===0)throw new Error(`Workspace run scope did not match any project: ${r}`);return {projects:a,normalizedScope:n}}async function Le(e,t,r){let n=await execa("git",["diff","--name-only",`${r}...HEAD`],{cwd:e,reject:false});if(n.exitCode!==0)return new Set(t);let o=n.stdout.split(/\r?\n/).map(d=>d.trim()).filter(d=>d.length>0).map(d=>A(d));if(o.length===0)return new Set;let a=new Set;for(let d of t){let g=A(w.relative(e,d));if(!g||g===".")continue;let f=`${g}/`;o.some(m=>m===g||m.startsWith(f))&&a.add(d);}return a}async function Ge(e,t,r){let n=w.join(e,".rapidkit","workspace.contract.json");if(await W(n))try{let s=await _e(e,t,r,n);if(s.graphStatus!=="missing")return s}catch{return {expanded:r,graphStatus:"invalid",expansionDepth:0}}let o=w.join(e,".rapidkit","workspace-dependency-graph.json");if(!await W(o))return {expanded:r,graphStatus:"missing",expansionDepth:0};let a;try{a=await q(o);}catch{return {expanded:r,graphStatus:"invalid",expansionDepth:0}}let d=new Set(t.map(s=>w.resolve(s))),g=new Map;if(!a||typeof a!="object"||Array.isArray(a))return {expanded:r,graphStatus:"invalid",expansionDepth:0};let f=Array.isArray(a.projects)?a.projects:[];for(let s of f){if(!s||typeof s!="object"||Array.isArray(s))continue;let x=s,j=typeof x.path=="string"?x.path:"",y=w.resolve(e,j);if(!d.has(y))continue;let c=Array.isArray(x.dependsOn)?x.dependsOn.filter(l=>typeof l=="string"):[];for(let l of c){let v=w.resolve(e,l);d.has(v)&&(g.has(v)||g.set(v,new Set),g.get(v)?.add(y));}}let m=new Set(r),b=[...m],i=0;for(;b.length>0;){let s=b.shift();if(!s)continue;let x=g.get(s);if(x)for(let j of x)m.has(j)||(m.add(j),b.push(j),i+=1);}return {expanded:m,graphStatus:"loaded",expansionDepth:i}}async function _e(e,t,r,n){let o=await q(n);if(!o||typeof o!="object"||Array.isArray(o))return {expanded:r,graphStatus:"invalid",expansionDepth:0};let a=o,d=Array.isArray(a.projects)?a.projects:null;if(!d)return {expanded:r,graphStatus:"invalid",expansionDepth:0};let g=new Map,f=new Map;for(let y of t){let c=A(w.relative(e,y));f.set(c,w.resolve(y));}let m=new Map,b=new Map,i=new Map;for(let y of d){if(!y||typeof y!="object"||Array.isArray(y))continue;let c=y,l=typeof c.slug=="string"?c.slug:"",v=typeof c.relativePath=="string"?A(c.relativePath):l,R=f.get(v);!l||!R||g.set(l,R);}for(let y of d){if(!y||typeof y!="object"||Array.isArray(y))continue;let c=y,l=typeof c.slug=="string"?c.slug:"",v=g.get(l);if(!v)continue;let R=c.contracts&&typeof c.contracts=="object"&&!Array.isArray(c.contracts)?c.contracts:{},M=Array.isArray(R.dependsOn)?R.dependsOn.filter(h=>typeof h=="string"):[],N=Array.isArray(R.publishes)?R.publishes.filter(h=>typeof h=="string"):[],$=Array.isArray(R.consumes)?R.consumes.filter(h=>typeof h=="string"):[];for(let h of M){let C=g.get(h);C&&(i.has(C)||i.set(C,new Set),i.get(C)?.add(v));}for(let h of N)m.has(h)||m.set(h,new Set),m.get(h)?.add(v);for(let h of $)b.has(h)||b.set(h,new Set),b.get(h)?.add(v);}for(let[y,c]of m.entries()){let l=b.get(y);if(l)for(let v of c){i.has(v)||i.set(v,new Set);for(let R of l)R!==v&&i.get(v)?.add(R);}}let s=new Set(r),x=[...s],j=0;for(;x.length>0;){let y=x.shift();if(!y)continue;let c=i.get(y);if(c)for(let l of c)s.has(l)||(s.add(l),x.push(l),j+=1);}return {expanded:s,graphStatus:"loaded",expansionDepth:j}}async function Be(e,t){if(typeof t=="boolean")return t;let r=w.join(e,".rapidkit","policies.yml");if(!await W(r))return true;let n="";try{n=await I.promises.readFile(r,"utf-8");}catch{return true}let o=n.match(/^[\t ]*rules\.enforce_workspace_run_gates:\s*(true|false)\s*(?:#.*)?$/m);return o?o[1]==="true":true}async function J(e,t){let r=process.argv[1];if(!r)return {exitCode:1,stdout:"",stderr:"RapidKit entrypoint is unavailable for nested workspace-run execution."};let n=await execa(process.execPath,[r,...e],{cwd:t,reject:false,env:{...process.env,RAPIDKIT_WORKSPACE_RUN_CHILD:"1"}});return {exitCode:Number(n.exitCode??1),stdout:n.stdout,stderr:n.stderr}}function Ke(e){return e==="node"||e==="go"||e==="java"||e==="python"||e==="dotnet"}function Ve(){return process.env.VITEST==="true"||process.env.VITEST==="1"||process.env.NODE_ENV==="test"}async function He(e){let t=process.cwd();try{process.chdir(e);let{handleInitCommand:r}=await import('./index.js');return {exitCode:await r(["init"]),stdout:"",stderr:""}}finally{process.chdir(t);}}async function ze(e$1){let t=i=>{let s=f(i);return s==="node"||s==="bun"?"node":s==="python"?"python":s==="go"?"go":s==="java"?"java":s==="php"?"php":s==="ruby"?"ruby":s==="rust"?"rust":s==="dotnet"?"dotnet":s==="elixir"?"elixir":s==="clojure"||s==="scala"||s==="kotlin"?"jvm-generic":me(e$1)},r=i=>{if(!i)return;let s=e(i);if(new Set(["fastapi","django","flask","nestjs","express","fastify","koa","gofiber","gogin","echo","springboot","laravel","symfony","rails","sinatra","dotnet","actix","axum","rocket","phoenix"]).has(s))return s},n$1=n(e$1),o=n$1?.detection??i(e$1,n$1?.projectJson??null),a=n$1?.contextJson,d=t(o.runtime),g=r(o.key),f$1={},m=new Set(["init","test","build","start"]);if(a?.commands&&typeof a.commands=="object")for(let[i,s]of Object.entries(a.commands))typeof s=="string"&&m.has(i)&&(f$1[i]=s);let b;if(a?.commandEnvironments&&typeof a.commandEnvironments=="object"){let i=a.commandEnvironments;b={dev:typeof i.dev=="string"?i.dev:void 0,staging:typeof i.staging=="string"?i.staging:void 0,prod:typeof i.prod=="string"?i.prod:void 0,default:typeof i.default=="string"?i.default:void 0};}return {runtime:d,framework:g,commandOverrides:Object.keys(f$1).length>0?f$1:void 0,environmentCommandVariants:b,environment:typeof a?.environment=="string"?a.environment:void 0}}async function Je(e,t,r,n,o,a,d){let g=!o?.[t]&&Ke(r),f;if(o&&o[t]?f=o[t]:g?f=`rapidkit ${t}`:f=H({projectPath:e,runtime:r,framework:n,stage:t}),!f)return {exitCode:127,command:`<stage not supported for ${r}>`,message:`No stage command found for runtime '${r}' and framework '${n||"unknown"}'`,errorCategory:"runtime"};let m=ge(f,a,d);if(!m)return {exitCode:127,command:f,message:"Failed to resolve stage command",errorCategory:"runtime"};let b=H({projectPath:e,runtime:r,framework:n,stage:t});if(g){if(b){let c=await z(b);if(!c.valid)return {exitCode:127,command:m,message:c.reason||"Command not available",errorCategory:"setup"}}}else {let c=await z(m);if(!c.valid)return {exitCode:127,command:m,message:c.reason||"Command not available",errorCategory:"setup"}}let i=0,s="",x="",j;try{let c=g?t==="init"&&Ve()?await He(e):await J([t],e):await execa(m,[],{cwd:e,reject:false,shell:true});if(i=Number(c.exitCode??0),s=c.stdout,x=c.stderr,i!==0){let l=`${s}
3
+ ${x}`;j=fe(l);}}catch(c){return {exitCode:1,command:m,message:c instanceof Error?c.message:"Command execution failed",errorCategory:"runtime"}}return {exitCode:i,command:m,errorCategory:j,healthStatus:void 0,message:i!==0?`Stage failed with exit code ${i}`:void 0}}function we(e){try{return JSON.parse(e)}catch{return null}}function Ue(e){switch(e){case "dotnet":return "Install .NET 8+ SDK, then rerun `npx rapidkit setup dotnet` or `npx rapidkit init`.";case "go":return "Install Go 1.21+, then rerun `npx rapidkit setup go` or `npx rapidkit init`.";case "java":case "jvm-generic":return "Install Java 21+ and Maven/Gradle, then rerun `npx rapidkit setup java` or `npx rapidkit init`.";case "node":return "Install Node.js LTS and npm/pnpm/yarn, then rerun `npx rapidkit setup node` or `npx rapidkit init`.";case "python":return "Install Python 3.10+ and pip/Poetry, then rerun `npx rapidkit setup python` or `npx rapidkit init`.";default:return null}}async function qe(e){let t=[],r=await J(["doctor","workspace","--json"],e);if(r.exitCode!==0)t.push({gate:"doctor-workspace",status:"fail",summary:"doctor workspace command failed"});else {let a=we(r.stdout)?.healthScore,d=Number(a?.errors??0);Number.isFinite(d)&&d>0?t.push({gate:"doctor-workspace",status:"fail",summary:`doctor workspace reports ${d} error(s)`}):t.push({gate:"doctor-workspace",status:"pass",summary:"doctor workspace passed"});}let n=await J(["readiness","--json"],e);if(n.exitCode!==0)t.push({gate:"readiness",status:"fail",summary:"readiness command failed"});else {let o=we(n.stdout),a=String(o?.overallStatus??"").toLowerCase();a==="fail"?t.push({gate:"readiness",status:"fail",summary:"readiness overall status is fail"}):a==="warn"?t.push({gate:"readiness",status:"warn",summary:"readiness overall status is warn"}):t.push({gate:"readiness",status:"pass",summary:"readiness overall status is pass"});}return t}function Ye(e){return $e.has(e)}function Qe(e,t){let r=Math.max(1,Math.min(4,t)),n=Number(e??r);return Number.isFinite(n)?Math.max(1,Math.min(16,Math.trunc(n))):r}async function jt(e){if(!Ye(e.stage))throw new Error(`Unsupported workspace run stage: ${e.stage}`);let t=Date.now(),r=w.resolve(e.workspacePath),n=await We(r),{projects:o,normalizedScope:a}=await Oe(r,n,e.scope),d=e.affected===true,g=e.blastRadius===true,f=e.since?.trim()||"HEAD~1",m=d?await Le(r,o,f):new Set(o),b,i="not-applicable",s=0,x="all";if(d&&g){let p=await Ge(r,n,m);b=p.expanded,i=p.graphStatus,s=p.expansionDepth,x="affected+blast-radius";}else d?(b=m,x="affected"):(b=m,x="all");let j=e.stage==="init"?false:await Be(r,e.enforceGates),y=j?await qe(r):[{gate:"doctor-workspace",status:"skipped",summary:"workspace run gates disabled"},{gate:"readiness",status:"skipped",summary:"workspace run gates disabled"}],c=y.find(p=>p.status==="fail"),l=o.filter(p=>b.has(p)),v=e.continueOnError===true||e.stage==="init",R=e.parallel===true,M=Qe(e.maxWorkers,l.length),N=l.length,$=0;e.json||console.log(S.gray(`Workspace run (${e.stage}) started: ${N} target(s), ${R?`parallel x${M}`:"sequential"}`));let h=new Map;for(let p of n){let k=o.includes(p),u=k&&b.has(p);h.set(p,{path:p,relativePath:A(w.relative(r,p)),selected:u,affected:u,status:"skipped",exitCode:null,durationMs:0,reason:u?void 0:k?"not affected":"outside scope",framework:void 0,runtimeDetected:void 0,executionCommand:void 0});}if(c)for(let p of l){let k=h.get(p);k&&(k.status="skipped",k.reason=`blocked by ${c.gate}`);}else {let p=async k=>{let u=h.get(k);if(!u)return;let D=A(w.relative(r,k));e.json||console.log(S.gray(`\u23F3 [${$}/${N}] ${e.stage} ${D}`)),u.selected=true,u.affected=true;let P=Date.now(),{runtime:E,framework:F,commandOverrides:xe,environmentCommandVariants:ve,environment:Re}=await ze(k);u.runtimeDetected=E,u.framework=F;let te=he(k,e.stage);if(!te.supported){u.status="skipped",u.reason=te.reason??`stage "${e.stage}" unsupported for project`,u.durationMs=Date.now()-P,u.exitCode=null,$+=1;return}let T=await Je(k,e.stage,E,F,xe,ve,Re);if(u.executionCommand=T.command,u.errorCategory=T.errorCategory,u.healthStatus=T.healthStatus,u.durationMs=Date.now()-P,u.exitCode=T.exitCode,T.exitCode===0?(u.status="passed",u.reason=void 0):(u.status="failed",u.reason=T.message||"stage command failed",u.errorMessage=T.message),$+=1,!e.json){let je=N>0?Math.round($/N*100):100,Se=u.status==="passed"?S.green("\u2705"):S.red("\u274C");if(console.log(S.gray(`${Se} [${$}/${N}] (${je}%) ${D} ${u.durationMs}ms`)),u.status==="failed"){u.reason&&console.log(S.red(` Reason: ${u.reason}`)),u.executionCommand&&console.log(S.gray(` Command: ${u.executionCommand}`));let re=Ue(u.runtimeDetected);re&&u.errorCategory==="setup"&&console.log(S.gray(` Hint: ${re}`));}}};if(R&&l.length>1){let k=0,u=false,D=new Array(M).fill(null).map(async()=>{for(;k<l.length;){if(u&&!v)return;let P=k;k+=1;let E=l[P];await p(E),h.get(E)?.status==="failed"&&(u=true);}});if(await Promise.all(D),!v&&u){let P=false;for(let E of l){let F=h.get(E);if(F){if(F.status==="failed"){P=true;continue}P&&F.status==="skipped"&&(F.reason=F.reason||"stopped after failure");}}}}else for(let k of l){await p(k);let u=h.get(k);if(!v&&u?.status==="failed"){let D=l.slice(l.indexOf(k)+1);for(let P of D){let E=h.get(P);E&&(E.status="skipped",E.reason="stopped after failure");}break}}}let C=[];for(let p of n){let k=h.get(p);k&&C.push(k);}let Y=C.filter(p=>p.status==="passed").length,B=C.filter(p=>p.status==="failed").length,Q=C.filter(p=>p.status==="skipped").length,X=e.strict===true,be=B>0||X&&y.some(p=>p.status==="fail"||p.status==="warn")?1:0,Z={schemaVersion:"1.0",workspacePath:r,stage:e.stage,generatedAt:new Date().toISOString(),durationMs:Date.now()-t,options:{affected:d,blastRadius:g,since:d?f:null,parallel:R,maxWorkers:M,continueOnError:v,strict:X,enforceGates:j,scope:a},selection:{mode:x,since:d?f:null,scope:a,graphStatus:i,expansionDepth:s},gates:{enforced:j,results:y,blocked:!!c,blockingGate:c?.gate},summary:{projectCount:n.length,selectedCount:l.length,passed:Y,failed:B,skipped:Q,exitCode:be},projects:C,enterpriseControls:{jsonReady:true,evidencePath:`.rapidkit/reports/${ke}`}},ee=w.join(r,".rapidkit","reports",ke);return await De(ee,Z),e.json||(c&&(console.log(S.red(`\u274C Workspace run blocked by ${c.gate}`)),console.log(S.gray(` ${c.summary}`))),console.log(S.cyan(`Workspace run (${e.stage}) => passed: ${Y}, failed: ${B}, skipped: ${Q}`)),console.log(S.gray(`Report: ${ee}`))),Z}export{ke as a,jt as b};
@@ -0,0 +1,7 @@
1
+ import {b as b$1}from'./chunk-KIB4KHBF.js';import {a}from'./chunk-KMUWWZRT.js';import l from'chalk';import q from'fs';import k from'path';import {execa}from'execa';var Q="autopilot-release-last-run.json",X="autopilot-release.json";function C(t){try{return JSON.parse(t)}catch{return null}}function ue(t){let r=k.resolve(t),a$1=a(r);if(!a$1)throw new Error("No RapidKit workspace found in current directory or parents");return a$1}async function b(t,r){let a=process.argv[1];if(!a)return {exitCode:1,stdout:"",stderr:"RapidKit entrypoint is unavailable for autopilot execution.",crashed:true};try{let o=await execa(process.execPath,[a,...t],{cwd:r,reject:false,env:{...process.env,RAPIDKIT_AUTOPILOT_CHILD:"1"}});return {exitCode:Number(o.exitCode??1),stdout:o.stdout,stderr:o.stderr,crashed:false}}catch(o){return {exitCode:1,stdout:"",stderr:o instanceof Error?o.message:String(o),crashed:true}}}function Y(t){let r=t.toLowerCase();return r==="pass"?"pass":r==="warn"?"warn":r==="fail"?"fail":"warn"}function Z(t){return t.summary.failed>0?"fail":t.gates.results.some(r=>r.status==="warn")?"warn":"pass"}function fe(t){let r=t.filter(o=>o.status!=="skipped");if(r.length===0)return 100;let a=r.reduce((o,e)=>e.status==="pass"?o+1:e.status==="warn"?o+.6:o,0);return Math.round(a/r.length*100)}function me(t){return t.executionError?["Re-run: npx rapidkit autopilot release --mode audit --json","Inspect .rapidkit/reports/autopilot-release-last-run.json for execution failure details"]:t.blockers.length>0?["Run: npx rapidkit doctor workspace --plan","Run: npx rapidkit readiness --json --strict","Run: npx rapidkit workspace run test --affected --strict"]:t.hasWarnings&&t.mode!=="enforce"?["Review warning-level findings in autopilot report","Optionally run: npx rapidkit autopilot release --mode safe-fix"]:["Workspace is release-ready based on current autopilot policy"]}async function D(t,r){await q.promises.mkdir(k.dirname(t),{recursive:true}),await q.promises.writeFile(t,`${JSON.stringify(r,null,2)}
2
+ `,"utf-8");}async function xe(t){let r=ue(t.workspacePath),a=t.mode,o=[],e=[],F,U,I,T,J=0,f=false,L=0,_=0,E=-1,N=-1,c="skipped",d="skipped",ee=a==="enforce"?["doctor","workspace","--json","--strict"]:["doctor","workspace","--json","--ci"];if(t.skipPipelineStages)o.push({name:"doctor-workspace",status:"skipped",durationMs:0,summary:"doctor stage skipped (pipeline already executed)"},{name:"analyze",status:"skipped",durationMs:0,summary:"analyze stage skipped (pipeline already executed)"},{name:"readiness",status:"skipped",durationMs:0,summary:"readiness stage skipped (pipeline already executed)"});else {let s=Date.now(),i=await b([...ee],r),m=Date.now()-s;if(c="pass",i.crashed)c="fail",f=true,e.push(`doctor workspace execution error: ${i.stderr||"unknown error"}`);else if(i.exitCode===1)c="fail",e.push("doctor workspace command failed or reported errors");else if(i.exitCode===2)c="warn",e.push("doctor workspace reported warnings");else if(i.exitCode!==0)c="fail",e.push("doctor workspace command failed");else {let p=C(i.stdout),j=p&&p.healthScore&&typeof p.healthScore=="object"?p.healthScore:{},y=Number(j.errors??0),$=Number(j.warnings??0);Number.isFinite(y)&&y>0?(c="fail",e.push(`doctor workspace reports ${y} error(s)`)):Number.isFinite($)&&$>0&&(c="warn");}E=o.push({name:"doctor-workspace",status:c,durationMs:m,summary:c==="pass"?"doctor workspace passed":c==="warn"?"doctor workspace reported warnings":"doctor workspace reported errors"})-1,a==="enforce"&&c==="warn"&&e.push("doctor workspace reported warnings under enforce mode");let g=Date.now(),w=await b(["analyze","--json"],r),v=Date.now()-g;U=k.join(r,".rapidkit","reports","analyze-last-run.json");let n="pass";if(w.crashed)n="fail",f=true,e.push(`analyze execution error: ${w.stderr||"unknown error"}`);else if(w.exitCode!==0)n=w.exitCode===2?"warn":"fail",e.push(w.exitCode===2?"analyze reported needs-attention verdict":"analyze command failed or reported blocked verdict");else {let p=C(w.stdout),j=p&&p.summary&&typeof p.summary=="object"?p.summary:{},y=String(j.verdict??"ready");y==="blocked"?(n="fail",e.push("analyze reported blocked verdict")):y==="needs-attention"&&(n="warn");}o.push({name:"analyze",status:n,durationMs:v,summary:n==="pass"?"analyze passed":n==="warn"?"analyze reported needs-attention":"analyze reported blocked verdict"}),a==="enforce"&&n==="warn"&&e.push("analyze reported warnings under enforce mode");let P=Date.now(),h=await b(["readiness","--json"],r),R=Date.now()-P;if(d="fail",h.crashed)d="fail",f=true,e.push(`readiness execution error: ${h.stderr||"unknown error"}`);else if(h.exitCode!==0)d="fail",e.push("readiness command failed");else {let p=C(h.stdout),j=String(p?.overallStatus??"fail");if(d=Y(j),typeof p?.evidencePath=="string"&&p.evidencePath.trim().length>0&&(F=p.evidencePath),d==="fail"){let y=Array.isArray(p?.blockingReasons)?p?.blockingReasons.filter($=>typeof $=="string"):[];y.length>0?e.push(...y.map($=>`readiness: ${$}`)):e.push("readiness overall status is fail");}}N=o.push({name:"readiness",status:d,durationMs:R,summary:`readiness overall status is ${d}`})-1,a==="enforce"&&d==="warn"&&e.push("readiness reported warnings under enforce mode");}let te=Date.now(),z=await b(["doctor","workspace","--plan","--json"],r),se=Date.now()-te,S="warn";if(z.crashed)S="fail",f=true,e.push(`doctor remediation plan execution error: ${z.stderr||"unknown error"}`);else if(z.exitCode!==0)S="fail",e.push("doctor remediation plan command failed");else {let s=C(z.stdout),i=s&&s.remediationPlan&&typeof s.remediationPlan=="object"?s.remediationPlan:null,m=Number(i?.totalSteps??0),g=Number(i?.executableSteps??0);Number.isFinite(m)&&m>0&&(L=m),Number.isFinite(g)&&g>0&&(_=g),Number.isFinite(m)&&m===0?S="pass":S="warn";}if(o.push({name:"remediation-plan",status:S,durationMs:se,summary:S==="pass"?"no remediation steps required":"remediation steps available"}),a==="enforce"&&S==="warn"&&e.push("remediation plan has pending steps under enforce mode"),a==="safe-fix"){let s=Date.now(),i=await b(["doctor","workspace","--apply"],r),m=Date.now()-s,g=i.crashed||i.exitCode!==0?"fail":"pass";if(i.crashed)f=true,e.push(`doctor remediation apply execution error: ${i.stderr||"unknown error"}`);else if(g==="fail")e.push("doctor remediation apply failed");else {J=_>0?_:L>0?L:1;let w=await b(["doctor","workspace","--json"],r);if(w.crashed)c="fail",f=true,e.push(`post-apply doctor execution error: ${w.stderr||"unknown error"}`);else if(w.exitCode!==0)c="fail",e.push("post-apply doctor workspace command failed");else {let n=C(w.stdout),P=n&&n.healthScore&&typeof n.healthScore=="object"?n.healthScore:{},h=Number(P.errors??0),R=Number(P.warnings??0);Number.isFinite(h)&&h>0?(c="fail",e.push(`post-apply doctor reports ${h} error(s)`)):Number.isFinite(R)&&R>0?c="warn":c="pass";}E>=0&&(o[E].status=c,o[E].summary=`doctor workspace post-apply status is ${c}`);let v=await b(["readiness","--json"],r);if(v.crashed)d="fail",f=true,e.push(`post-apply readiness execution error: ${v.stderr||"unknown error"}`);else if(v.exitCode!==0)d="fail",e.push("post-apply readiness command failed");else {let n=C(v.stdout),P=String(n?.overallStatus??"fail");if(d=Y(P),typeof n?.evidencePath=="string"&&n.evidencePath.trim().length>0&&(F=n.evidencePath),d==="fail"){let h=Array.isArray(n?.blockingReasons)?n?.blockingReasons.filter(R=>typeof R=="string"):[];h.length>0?e.push(...h.map(R=>`post-apply readiness: ${R}`)):e.push("post-apply readiness overall status is fail");}}N>=0&&(o[N].status=d,o[N].summary=`readiness post-apply overall status is ${d}`);}o.push({name:"remediation-apply",status:g,durationMs:m,summary:g==="pass"?"safe remediation apply completed":"safe remediation apply failed"});}else o.push({name:"remediation-apply",status:"skipped",durationMs:0,summary:"remediation apply is skipped for this mode"});let re=Date.now(),x="pass",A="workspace test/build completed for selected projects";try{let s=await b$1({workspacePath:r,stage:"test",affected:true,since:t.since,parallel:t.parallel,maxWorkers:t.maxWorkers,strict:true,json:true,enforceGates:false});I=k.join(r,".rapidkit","reports","autopilot-workspace-run-test.json"),await D(I,s);let i=Z(s);if(i==="fail")x="fail",A="workspace test stage failed for selected projects",e.push("workspace run test failed for selected projects");else {i==="warn"&&(x="warn",A="workspace test stage completed with warnings",a==="enforce"&&e.push("workspace run test reported warnings under enforce mode"));let m=await b$1({workspacePath:r,stage:"build",affected:true,since:t.since,parallel:t.parallel,maxWorkers:t.maxWorkers,strict:true,json:true,enforceGates:false});T=k.join(r,".rapidkit","reports","autopilot-workspace-run-build.json"),await D(T,m);let g=Z(m);g==="fail"?(x="fail",A="workspace build stage failed for selected projects",e.push("workspace run build failed for selected projects")):g==="warn"&&(x="warn",A="workspace test/build completed with warnings",a==="enforce"&&e.push("workspace run test/build reported warnings under enforce mode"));}}catch(s){x="fail",A="workspace test/build orchestration failed",f=true,e.push(`workspace run orchestration error: ${s instanceof Error?s.message:String(s)}`);}let oe=Date.now()-re;o.push({name:"workspace-run-test-build",status:x,durationMs:oe,summary:A});let M=o.filter(s=>s.status==="warn").length,ae=o.filter(s=>s.status==="fail").length,B=a==="enforce"?o.some(s=>s.status==="warn"||s.status==="fail"):ae>0,W=[...new Set(e)],ne=f||B?Math.max(1,W.length):0,ie=fe(o),le=f||B?"blocked":M>0?"partial":"approved",ce=f?3:B?1:M>0?2:0,pe=me({mode:a,executionError:f,blockers:W,hasWarnings:M>0}),G=k.join(r,".rapidkit","reports"),O=k.join(G,Q),V=k.join(G,X),u={schemaVersion:"autopilot-release-v1",generatedAt:new Date().toISOString(),workspacePath:r,mode:a,summary:{releaseScore:ie,verdict:le,blockers:ne,warnings:M,safeFixesApplied:J,manualActions:W.length,exitCode:ce},stages:o,blockingReasons:W,nextActions:pe,artifacts:{reportPath:O,aliasEvidencePath:V,analyzeEvidencePath:U,readinessEvidencePath:F,workspaceRunTestPath:I,workspaceRunBuildPath:T},enterpriseControls:{jsonReady:true,evidencePath:`.rapidkit/reports/${Q}`,aliasEvidencePath:`.rapidkit/reports/${X}`}};if(await D(O,u),await D(V,u),t.output&&await D(k.resolve(t.output),u),!t.json){console.log(l.bold.cyan(`
3
+ \u{1F680} RapidKit Autopilot Release
4
+ `)),console.log(l.bold(`Workspace: ${l.cyan(k.basename(r))}`)),console.log(l.gray(`Path: ${r}`)),console.log(l.white(`Mode: ${a}`)),console.log(l.white(`Verdict: ${u.summary.verdict==="approved"?l.green("approved"):u.summary.verdict==="partial"?l.yellow("partial"):l.red("blocked")}`)),console.log(l.white(`Release score: ${u.summary.releaseScore}`));for(let s of u.stages){let i=s.status==="pass"?l.green("PASS"):s.status==="warn"?l.yellow("WARN"):s.status==="skipped"?l.gray("SKIP"):l.red("FAIL");console.log(` - ${s.name}: ${i} ${s.summary} (${s.durationMs}ms)`);}if(u.blockingReasons.length>0){console.log(l.bold.red(`
5
+ Blocking reasons:`));for(let s of u.blockingReasons)console.log(l.red(` - ${s}`));}if(u.nextActions.length>0){console.log(l.bold(`
6
+ Next actions:`));for(let s of u.nextActions)console.log(l.gray(` - ${s}`));}console.log(l.gray(`
7
+ Report: ${u.artifacts.reportPath}`));}return u}export{Q as a,X as b,xe as c};
@@ -0,0 +1,9 @@
1
+ import {a,b as b$1}from'./chunk-KMUWWZRT.js';import {h as h$1,i}from'./chunk-UZW5QFRW.js';import {a as a$1}from'./chunk-VKLL63TL.js';import h from'fs';import o from'path';import s from'chalk';var I=new Set([".git",".rapidkit",".venv","node_modules","dist","build","target","coverage","htmlcov",".next"]);async function y(e){try{return await h.promises.access(e,h.constants.F_OK),true}catch{return false}}async function v(e){try{let t=JSON.parse(await h.promises.readFile(e,"utf-8"));return t&&typeof t=="object"&&!Array.isArray(t)?t:null}catch{return null}}async function G(e){try{return await h.promises.readFile(e,"utf-8")}catch{return ""}}function E(e){return a(e)}async function S(e,t){return await y(o.join(e,".rapidkit","project.json"))||await y(o.join(e,".rapidkit","context.json"))?true:b$1(e)?false:o.resolve(e)===o.resolve(t)?h$1(e).length>0:h$1(e).length>0}async function T(e){let t=await a$1(e,{skipDirs:I,includeHiddenDirs:false,descendIntoMatchedProjects:false,isProjectDir:S});return t.length>0?t:b$1(e)?[]:h$1(e).length>0?[e]:[]}function N(e,t){return o.relative(e,t).replace(/\\/g,"/")||"."}async function b(e,t){for(let n of t)if(await y(o.join(e,n)))return true;return false}async function K(e){return b(e,["health","health.ts","health.js","health.py","health.go","health.kt","health.rb","health.php","healthcheck","health-check","src/health.ts","src/health.js","src/health.py","src/health.go","src/health.kt","src/health.rb","src/health.php","src/healthcheck.ts","src/healthcheck.js","src/liveness.ts","src/readiness.ts","src/ping.ts"])}async function O(e){if(await b(e,["tests","test","__tests__","src/__tests__","pytest.ini","vitest.config.ts","jest.config.ts"]))return true;let n=await v(o.join(e,"package.json")),i=n?.scripts&&typeof n.scripts=="object"?n.scripts:{};return typeof i.test=="string"&&i.test.trim().length>0}async function _(e){let t=await v(o.join(e,"package.json")),n=t?.scripts&&typeof t.scripts=="object"?t.scripts:{};return Object.keys(n).sort()}function f(e,t,n,i,r,c){return {id:e,severity:t,target:n,title:i,detail:r,remediation:c}}function J(e){let t=e.reduce((n,i)=>i.severity==="fail"?n+28:i.severity==="warn"?n+12:n+3,0);return Math.max(0,100-t)}async function M(e,t){let n=await v(o.join(t,".rapidkit","project.json")),i$1=i(t,n),r=h$1(t),c=i$1.runtime==="unknown"?r[0]||"unknown":i$1.runtime,a=N(e,t),d=a,m=await _(t),u=await y(o.join(t,".rapidkit","project.json"))||await y(o.join(t,".rapidkit","context.json")),g=await O(t),k=await b(t,["Dockerfile","dockerfile"]),w=await b(t,[".env.example","env.example","config/env.example"]),A=await b(t,[".github/workflows/ci.yml",".github/workflows/ci.yaml",".github/workflows/main.yml",".github/workflows/build.yml",".github/workflows/test.yml",".github/workflows/deploy.yml",".gitlab-ci.yml",".circleci/config.yml","azure-pipelines.yml","bitbucket-pipelines.yml","cloudbuild.yaml"]),z=await K(t),l=[];return i$1.key==="unknown"&&l.push(f("project.stack.unknown","fail",d,"Project stack is unknown","RapidKit cannot confidently classify this backend project.","Add .rapidkit/project.json metadata or import the project with `rapidkit import`.")),u||l.push(f("project.marker.missing","warn",d,"RapidKit marker is missing","The project can be detected by files, but it is not registered with RapidKit metadata.","Run `rapidkit import <path>` from a workspace or create the project through RapidKit.")),g||l.push(f("project.tests.missing","warn",d,"Test entrypoint is missing","No common test folder, config, or package test script was found.","Add a test command so `rapidkit workspace run test --affected` can gate changes.")),w||l.push(f("project.env.example.missing","info",d,"Environment example is missing","No .env.example or env.example file was found.","Add an env example for onboarding and CI secret documentation.")),A||l.push(f("project.ci.missing","warn",d,"Continuous integration is missing","No recognized CI/CD configuration file was detected for this project.","Add CI configuration so tests and checks run automatically for every change.")),z||l.push(f("project.health.missing","info",d,"Health or readiness probe is missing","The project has no obvious health or readiness endpoint to support automated deployment and runtime checks.","Add a simple health endpoint and document it for readiness gates and observability.")),k||l.push(f("project.container.missing","info",d,"Container recipe is missing","No Dockerfile was found for this project.","Add a Dockerfile when the service is intended for containerized deployment.")),{name:o.basename(t),path:t,relativePath:a,runtime:c,framework:i$1.key,confidence:i$1.confidence,supportTier:i$1.supportTier,hasRapidKitMarker:u,hasTests:g,hasDockerfile:k,hasEnvExample:w,hasCiConfig:A,hasHealthEndpoint:z,scripts:m,findings:l,score:J(l)}}function W(e){return e.name.toLowerCase()}async function H(e){let t=new Map(e.map(r=>[W(r),r])),n=[];for(let r of e){let c=await v(o.join(r.path,"package.json")),a={...c?.dependencies??{},...c?.devDependencies??{},...c?.peerDependencies??{}};for(let m of Object.keys(a)){let u=m.replace(/^@[^/]+\//,"").toLowerCase(),g=t.get(u);g&&g.relativePath!==r.relativePath&&n.push({from:r.relativePath,to:g.relativePath,kind:"package"});}let d=await G(o.join(r.path,"pyproject.toml"));for(let m of e)m.relativePath!==r.relativePath&&d.includes(m.name)&&n.push({from:r.relativePath,to:m.relativePath,kind:"workspace-reference"});}let i=new Set;return n.filter(r=>{let c=`${r.from}\0${r.to}\0${r.kind}`;return i.has(c)?false:(i.add(c),true)})}function B(e,t){let n=new Map;for(let i of e)n.set(i.relativePath,{project:i.relativePath,directDependents:0,directDependencies:0});for(let i of t){let r=n.get(i.from),c=n.get(i.to);r&&(r.directDependencies+=1),c&&(c.directDependents+=1);}return Array.from(n.values()).sort((i,r)=>r.directDependents-i.directDependents||r.directDependencies-i.directDependencies)}async function U(e){let t=await v(o.join(e,".rapidkit","workspace.json"));return typeof t?.profile=="string"?t.profile:null}function V(e){return {fail:e.filter(t=>t.severity==="fail").length,warn:e.filter(t=>t.severity==="warn").length,info:e.filter(t=>t.severity==="info").length}}function L(e){if(e.projectCount===0)return e.workspaceDetected?["Add your first project: npx rapidkit create project <name> --kit <kit>","Import an existing service: npx rapidkit import <path>"]:["Create a RapidKit workspace: npx rapidkit create workspace my-workspace --profile polyglot","Import an existing service: npx rapidkit import ../service"];let t=[];return e.findings.some(n=>n.id==="workspace.marker.missing")&&t.push("Initialize workspace metadata with `rapidkit bootstrap --profile polyglot`."),e.findings.some(n=>n.id==="project.marker.missing")&&t.push("Register detected projects with `rapidkit import <path>` or recreate them via `rapidkit create project`."),e.findings.some(n=>n.id==="project.tests.missing")&&t.push("Add test entrypoints, then gate changes with `rapidkit workspace run test --affected --strict`."),e.findings.some(n=>n.id==="project.ci.missing")&&t.push("Add CI/CD configuration to catch regressions early and make workspace health checks actionable."),e.findings.some(n=>n.id==="project.health.missing")&&t.push("Add a health/readiness endpoint so runtime probes and deployment checks can verify service health."),e.hasGraph||t.push("Create `.rapidkit/workspace-dependency-graph.json` or use analyze output as the first graph seed."),t.push("Run `rapidkit autopilot release --mode audit --json` before release."),Array.from(new Set(t))}async function ie(e={}){let t=o.resolve(e.workspacePath||process.cwd());if(!await y(t))throw new Error(`Workspace path does not exist: ${t}`);let n=E(t)??t,i=await y(o.join(n,".rapidkit-workspace"))||await y(o.join(n,".rapidkit","workspace.json")),r=await U(n),c=await T(n),a=await Promise.all(c.map(p=>M(n,p))),d=await H(a),m=B(a,d),u=[];i||u.push(f("workspace.marker.missing","warn",".","Workspace metadata is missing","The directory can be analyzed, but it is not a registered RapidKit workspace.","Run `rapidkit create workspace` or `rapidkit bootstrap --profile polyglot` in a workspace root.")),a.length===0&&u.push(f("workspace.projects.missing","warn",".","No backend projects detected","RapidKit did not find runtime markers or project metadata under this root.","Create a project with `rapidkit create project` or import one with `rapidkit import <path>`."));let g=[...u,...a.flatMap(p=>p.findings)],k=V(g),w={};for(let p of a)w[p.runtime]=(w[p.runtime]||0)+1;let A=a.length>0?Math.round(a.reduce((p,P)=>p+P.score,0)/a.length):0,z=u.reduce((p,P)=>p+(P.severity==="fail"?20:P.severity==="warn"?8:2),0),l=Math.max(0,A-z),F=k.fail>0||e.strict&&k.warn>0?"blocked":k.warn>0?"needs-attention":"ready",D={schemaVersion:"rapidkit-analyze-v1",generatedAt:new Date().toISOString(),workspacePath:n,workspaceDetected:i,profile:r,summary:{score:l,verdict:F,projectCount:a.length,runtimeCount:Object.keys(w).length,findings:k},runtimes:w,projects:a,dependencyGraph:{status:d.length>0?"generated":"empty",edges:d,topImpactedProjects:m.slice(0,5)},findings:g,nextActions:L({findings:g,projectCount:a.length,hasGraph:d.length>0,workspaceDetected:i}),enterpriseControls:{jsonReady:true,ciGateCommand:"rapidkit analyze --json --strict",releaseGateCommand:"rapidkit autopilot release --mode enforce --json",evidencePath:".rapidkit/reports/analyze-last-run.json"}};if(e.output&&(await h.promises.mkdir(o.dirname(o.resolve(e.output)),{recursive:true}),await h.promises.writeFile(o.resolve(e.output),`${JSON.stringify(D,null,2)}
2
+ `)),!e.output&&i){let p=o.join(n,".rapidkit","reports","analyze-last-run.json");await h.promises.mkdir(o.dirname(p),{recursive:true}),await h.promises.writeFile(p,`${JSON.stringify(D,null,2)}
3
+ `);}return D}function re(e){let t=e.summary.verdict==="ready"?s.green:e.summary.verdict==="needs-attention"?s.yellow:s.red;if(console.log(s.bold(`
4
+ RapidKit Workspace Analysis
5
+ `)),console.log(s.cyan("Workspace:"),e.workspacePath),console.log(s.cyan("Profile:"),e.profile||"not configured"),console.log(s.cyan("Score:"),`${e.summary.score}/100`),console.log(s.cyan("Verdict:"),t(e.summary.verdict)),console.log(s.gray(`Projects: ${e.summary.projectCount}, runtimes: ${e.summary.runtimeCount}, findings: ${e.summary.findings.fail} fail / ${e.summary.findings.warn} warn / ${e.summary.findings.info} info`)),e.projects.length>0){console.log(s.bold(`
6
+ Projects`));for(let n of e.projects){let i=n.score>=85?s.green("pass"):n.score>=65?s.yellow("watch"):s.red("risk");console.log(` ${n.relativePath} ${s.gray(`${n.runtime}/${n.framework}`)} ${i} ${n.score}/100`);}}if(e.dependencyGraph.status==="generated"&&(console.log(s.bold(`
7
+ Dependency Graph`)),console.log(s.gray(` edges: ${e.dependencyGraph.edges.length}`)),e.dependencyGraph.topImpactedProjects.length>0)){console.log(s.gray(" Top impacted projects:"));for(let n of e.dependencyGraph.topImpactedProjects.slice(0,3))console.log(` ${n.project} (${n.directDependents} dependents, ${n.directDependencies} dependencies)`);}if(e.findings.length>0){console.log(s.bold(`
8
+ Top Findings`));for(let n of e.findings.slice(0,8)){let i=n.severity==="fail"?s.red:n.severity==="warn"?s.yellow:s.gray;console.log(` ${i(n.severity.toUpperCase())} ${n.target}: ${n.title}`),console.log(s.gray(` ${n.remediation}`));}}console.log(s.bold(`
9
+ Next Actions`));for(let n of e.nextActions.slice(0,5))console.log(s.gray(` - ${n}`));console.log();}export{ie as a,re as b};
@@ -0,0 +1 @@
1
+ export{c as PYTHON_FREE_WORKSPACE_PROFILES,a as buildWorkspaceManifest,f as createProject,g as registerWorkspaceAtPath,d as resolvePythonFreeFallbackProfile,b as syncWorkspaceFoundationFiles,e as writeWorkspaceLauncher}from'./chunk-HUQ5WRUF.js';