@cognite/cli 1.0.0 → 1.1.0-alpha.48

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
@@ -83,7 +83,7 @@ To test against your own app instead of the fixture:
83
83
 
84
84
  ```bash
85
85
  cd apps/my-app
86
- COGNITE_TOKEN=test-token COGNITE_BASE_URL=http://localhost:9090 pnpm exec dune apps deploy --skip-build
86
+ COGNITE_TOKEN=test-token COGNITE_BASE_URL=http://localhost:9090 pnpm exec cognite apps deploy --skip-build
87
87
  ```
88
88
 
89
89
  #### Simulating error scenarios
@@ -0,0 +1,11 @@
1
+ ---
2
+ to: '<%= useCurrentDir ? "" : ((directoryName || name) + "/") %>.mcp.json'
3
+ ---
4
+ {
5
+ "mcpServers": {
6
+ "cognite-docs": {
7
+ "type": "http",
8
+ "url": "https://docs.cognite.com/mcp"
9
+ }
10
+ }
11
+ }
@@ -0,0 +1,10 @@
1
+ ---
2
+ to: '<%= useCurrentDir ? "" : ((directoryName || name) + "/") %>.cursor/mcp.json'
3
+ ---
4
+ {
5
+ "mcpServers": {
6
+ "cognite-docs": {
7
+ "url": "https://docs.cognite.com/mcp"
8
+ }
9
+ }
10
+ }
@@ -3,7 +3,7 @@ export default [
3
3
  type: 'input',
4
4
  name: 'name',
5
5
  message: 'What is the app name? (use kebab-case, e.g., my-awesome-app)',
6
- initial: 'my-dune-app',
6
+ initial: 'my-flows-app',
7
7
  validate: (input) =>
8
8
  /^[a-z][a-z0-9-]*$/.test(input)
9
9
  ? true
@@ -13,13 +13,13 @@ export default [
13
13
  type: 'input',
14
14
  name: 'displayName',
15
15
  message: 'What is the display name? (e.g., My Awesome App)',
16
- initial: 'My Dune app',
16
+ initial: 'My Flows app',
17
17
  },
18
18
  {
19
19
  type: 'input',
20
20
  name: 'description',
21
21
  message: 'What is the app description?',
22
- initial: 'A Dune application',
22
+ initial: 'A Flows application',
23
23
  },
24
24
  {
25
25
  type: 'input',
@@ -2,3 +2,4 @@
2
2
  to: '<%= useCurrentDir ? "" : ((directoryName || name) + "/") %>.npmrc'
3
3
  ---
4
4
  engine-strict=true
5
+ min-release-age=2
@@ -22,7 +22,13 @@ This app uses [github/spec-kit](https://github.com/github/spec-kit) for spec-dri
22
22
 
23
23
  ---
24
24
 
25
- ## 1. Dependency Injection
25
+ ## 1. UI Components
26
+
27
+ Always check `@cognite/aura/components` before reaching for a raw HTML element or custom CSS/Tailwind solution. If Aura has a component that covers the need, use it. Only fall back to custom solutions when Aura genuinely doesn't cover the use case.
28
+
29
+ ---
30
+
31
+ ## 2. Dependency Injection
26
32
 
27
33
  Inject dependencies via React context (hooks/components) or factory-override pattern (plain functions). Never hard-code dependencies.
28
34
 
@@ -51,7 +57,7 @@ export const doWork = async (props: Props, overrides?: Partial<Deps>) => {
51
57
 
52
58
  ---
53
59
 
54
- ## 2. Interface-Based Services
60
+ ## 3. Interface-Based Services
55
61
 
56
62
  Define an interface; implement with a class. Never reference the concrete class outside its own file.
57
63
 
@@ -68,7 +74,7 @@ export class ApiDataService implements DataService {
68
74
 
69
75
  ---
70
76
 
71
- ## 3. ViewModel Pattern
77
+ ## 4. ViewModel Pattern
72
78
 
73
79
  Business logic lives in `use<Name>ViewModel`. Components only render.
74
80
 
@@ -91,7 +97,7 @@ export const TodoView = () => {
91
97
 
92
98
  ---
93
99
 
94
- ## 4. Test-First Development
100
+ ## 5. Test-First Development
95
101
 
96
102
  Write tests before implementation for all non-trivial behavior changes.
97
103
 
@@ -187,7 +193,7 @@ Place reusable factories in `src/__mocks__/`. Use `.test` TLD for fake URLs (RFC
187
193
 
188
194
  ---
189
195
 
190
- ## 5. TypeScript Rules
196
+ ## 6. TypeScript Rules
191
197
 
192
198
  - Never use `any`; prefer `unknown` or explicit strong types
193
199
  - Never use `as unknown as T`; for partial test doubles use `{ ...defaults, ...overrides } as T`
@@ -201,7 +207,7 @@ function createMockWindow(overrides: Partial<Window> = {}): Window {
201
207
 
202
208
  ---
203
209
 
204
- ## 6. Commits and pull requests
210
+ ## 7. Commits and pull requests
205
211
 
206
212
  Use [Conventional Commits v1.0.0](https://www.conventionalcommits.org/en/v1.0.0/).
207
213
 
@@ -20,8 +20,8 @@ to: '<%= useCurrentDir ? "" : ((directoryName || name) + "/") %>package.json'
20
20
  "test:ui": "vitest --ui",
21
21
  "lint": "eslint . --ext .js,.mjs,.cjs,.ts,.tsx",
22
22
  "lint:fix": "eslint . --fix --ext .js,.mjs,.cjs,.ts,.tsx",
23
- "deploy": "npx @cognite/cli@latest apps deploy --interactive --published",
24
- "deploy-preview": "npx @cognite/cli@latest apps deploy --interactive"
23
+ "deploy": "npx @cognite/cli@latest apps deploy --interactive",
24
+ "activate": "npx @cognite/cli@latest apps activate --interactive"
25
25
  },
26
26
  "dependencies": {
27
27
  "@cognite/aura": "^0.1.7",
@@ -0,0 +1,11 @@
1
+ ---
2
+ to: '<%= useCurrentDir ? "" : ((directoryName || name) + "/") %>.vscode/mcp.json'
3
+ ---
4
+ {
5
+ "servers": {
6
+ "cognite-docs": {
7
+ "type": "http",
8
+ "url": "https://docs.cognite.com/mcp"
9
+ }
10
+ }
11
+ }
@@ -4,25 +4,25 @@ Selected, generated files from [github/spec-kit](https://github.com/github/spec-
4
4
 
5
5
  ## Why this exists
6
6
 
7
- Dune app authors should not need Python, `uv`, or network access just because they pass `dune create --spec-kit`.
7
+ Flows app authors should not need Python, `uv`, or network access just because they pass `cognite create --spec-kit`.
8
8
 
9
- Instead, Dune maintainers refresh spec-kit inside this monorepo, commit the selected generated files here, and let `dune create` copy them into new apps. That keeps end-user scaffolding fast and JS/TS-only while still letting us track upstream spec-kit intentionally.
9
+ Instead, Flows builder app maintainers refresh spec-kit inside this monorepo, commit the selected generated files here, and let `cognite create` copy them into new apps. That keeps end-user scaffolding fast and JS/TS-only while still letting us track upstream spec-kit intentionally.
10
10
 
11
11
  ## Maintainer-only refresh
12
12
 
13
- The refresh script is for Dune monorepo maintainers only:
13
+ The refresh script is for Flows app maintainers only:
14
14
 
15
15
  ```sh
16
16
  pnpm --filter @cognite/cli refresh-spec-kit <tag>
17
17
  ```
18
18
 
19
- It requires `uv` locally, which provides `uvx`. That is acceptable for maintainers; it must not become a requirement for generated Dune apps.
19
+ It requires `uv` locally, which provides `uvx`. That is acceptable for maintainers; it must not become a requirement for generated Flows apps.
20
20
 
21
21
  The script runs spec-kit's own `specify init` for the requested tag, stages the selected output in a temporary directory, and swaps it into `_vendor/spec-kit` only after all copies succeed.
22
22
 
23
23
  ## What we vendor
24
24
 
25
- We vendor the parts Dune uses:
25
+ We vendor the parts Flows apps uses:
26
26
 
27
27
  - generated `commands/speckit.{specify,clarify,plan,tasks,implement,analyze,checklist}.md`
28
28
  - `templates/{spec,plan,tasks,checklist}-template.md`
@@ -30,10 +30,10 @@ We vendor the parts Dune uses:
30
30
 
31
31
  Deliberately excluded:
32
32
 
33
- - spec-kit's `AGENTS.md`, constitution command, and constitution template, because Dune uses the app's `AGENTS.md` as the constitution
33
+ - spec-kit's `AGENTS.md`, constitution command, and constitution template, because Flows apps uses the app's `AGENTS.md` as the constitution
34
34
  - integration metadata/workflows generated by `specify init`
35
35
  - optional commands such as taskstoissues
36
- - PowerShell scripts, until Dune chooses to support a PowerShell command set
36
+ - PowerShell scripts, until Flows apps chooses to support a PowerShell command set
37
37
  - spec-kit's Python CLI, tests, and docs
38
38
 
39
- **Cadence:** refresh at least once per Dune CLI minor release, sooner if upstream ships a fix we depend on.
39
+ **Cadence:** refresh at least once per cognite CLI minor release, sooner if upstream ships a fix we depend on.
@@ -0,0 +1,9 @@
1
+ var W=Object.defineProperty;var s=(e,t)=>W(e,"name",{value:t,configurable:!0});import Y from"fs";import gt from"path";var F="https://docs.cognite.com/cdf/access/";function m(e){return e!==null&&typeof e=="object"}s(m,"isRecord");function P(e){return e instanceof Error&&"status"in e&&typeof e.status=="number"}s(P,"isHttpError");function Z(e){switch(e){case 401:return`Your credentials are invalid or expired. Check your client ID and secret.
2
+ See: ${F}`;case 403:return`You don't have the required CDF capabilities. Please contact your CDF admin.
3
+ See: ${F}`;default:return}}s(Z,"httpStatusHint");function A(e){let t=e instanceof Error?e:new Error(String(e));if(!P(t))return null;let n=Z(t.status);return n?Object.assign(new Error(`${t.message}
4
+ ${n}`),{cause:t}):null}s(A,"enrichedHttpError");function X(e){if(!m(e))return null;let t=e.missing;if(Array.isArray(t))return t;let n=e.data;if(m(n)){let r=n.error;if(m(r)&&Array.isArray(r.missing))return r.missing;if(Array.isArray(n.missing))return n.missing}return null}s(X,"findMissingArray");function Q(e,t){if(!P(e)||e.status!==400)return!1;let n=X(e);return n?n.some(r=>m(r)&&typeof r.externalId=="string"&&t.includes(r.externalId)):!1}s(Q,"isMissingExternalIdError");function $(e,t){return P(e)&&e.status===404||Q(e,t)}s($,"isNotFoundError");var M=["DRAFT","PUBLISHED","DEPRECATED","ARCHIVED"],J=["ACTIVE","PREVIEW"],I=class I extends Error{constructor(t,n){super(`Version ${n} of app ${t} not found`),this.name="AppVersionNotFoundError",this.appExternalId=t,this.version=n}};s(I,"AppVersionNotFoundError");var k=I;function q(e,t){return e.includes(t)}s(q,"includesValue");function tt(e){return q(M,e)}s(tt,"isAppVersionLifecycleState");function et(e){return q(J,e)}s(et,"isAppVersionAlias");function nt(e){return typeof e.version=="string"&&tt(e.lifecycleState)&&typeof e.entrypoint=="string"&&typeof e.createdTime=="number"&&typeof e.createdBy=="string"&&typeof e.appExternalId=="string"&&(e.alias===void 0||et(e.alias))&&(e.comment===void 0||typeof e.comment=="string")}s(nt,"isAppVersion");function H(e){if(!m(e))throw new Error("Invalid version response: not an object");if(!nt(e))throw new Error("Invalid version response: missing or malformed fields");return e}s(H,"parseAppVersion");var T=class T{constructor(t){this.client=t}get appsBasePath(){return`/api/v1/projects/${encodeURIComponent(this.client.project)}/apphosting/apps`}async createApp(t,n,r){try{await this.client.post(this.appsBasePath,{data:{items:[{externalId:t,name:n,description:r}]}})}catch(o){throw A(o)??o}}async uploadVersion(t,n,r,o,i="index.html"){console.log(`\u{1F4E4} Uploading version ${n}...`);let a=new FormData;a.append("file",new Blob([new Uint8Array(r)]),o),a.append("version",n),a.append("entryPath",i);let l=encodeURIComponent(t),c=`${this.appsBasePath}/${l}/versions`,p=await this.client.authenticate(),g=`${this.client.getBaseUrl()}${c}`,u=new AbortController,G=setTimeout(()=>u.abort(),300*1e3),h;try{h=await fetch(g,{method:"POST",headers:{Authorization:`Bearer ${p}`},body:a,signal:u.signal})}catch(f){throw f instanceof Error&&f.name==="AbortError"?new Error("Upload timed out after 5 minutes"):f}finally{clearTimeout(G)}if(!h.ok){let f=await h.text(),V=f;try{let x=JSON.parse(f);if(m(x)){let w=x.error;if(typeof w=="string")V=w;else if(m(w)){let E=w.message,B=w.code;V=typeof E=="string"?E:B!=null?`Unknown error (code: ${B})`:f}else{let E=x.message;V=typeof E=="string"?E:f}}}catch{}let j=h.headers.get("x-request-id"),K=j?` | X-Request-ID: ${j}`:"",N=Object.assign(new Error(`Upload failed: ${h.status} \u2014 ${V}${K}`),{status:h.status});throw A(N)??N}console.log(`\u2705 Version ${n} uploaded`)}async getVersion(t,n){let r=encodeURIComponent(t),o=encodeURIComponent(n),i=`${this.appsBasePath}/${r}/versions/${o}`;try{let a=await this.client.get(i);return H(a.data)}catch(a){throw $(a,[t,n])?new k(t,n):A(a)??a}}async getActiveVersion(t){let n=encodeURIComponent(t),r=`${this.appsBasePath}/${n}/active`;try{let o=await this.client.get(r);return H(o.data)}catch(o){if($(o,[t]))return null;throw A(o)??o}}async updateVersions(t,n){let r=encodeURIComponent(t),o=`${this.appsBasePath}/${r}/versions/update`;try{await this.client.post(o,{data:{items:n}})}catch(i){throw A(i)??i}}};s(T,"AppHostingApi");var v=T;var b=class b{constructor(t){this.api=new v(t)}getVersion(t,n){return this.api.getVersion(t,n)}uploadVersion(t,n,r,o,i){return this.api.uploadVersion(t,n,r,o,i)}async ensureApp(t,n,r){console.log("\u{1F50D} Ensuring app exists...");try{await this.api.createApp(t,n,r),console.log(`\u2705 App '${t}' created`)}catch(o){if(P(o)&&o.status===409){console.log(`\u2705 App '${t}' already exists`);return}throw o}}async publishVersion(t,n){await this.api.updateVersions(t,[{version:n,update:{lifecycleState:{set:"PUBLISHED"}}}])}async publishAndActivate(t,n){console.log(`\u{1F680} Publishing and activating version ${n}...`),await this.api.updateVersions(t,[{version:n,update:{lifecycleState:{set:"PUBLISHED"},alias:{set:"ACTIVE"}}}]),console.log(`\u2705 Version ${n} is now PUBLISHED and ACTIVE`)}getActiveVersion(t){return this.api.getActiveVersion(t)}async deactivateVersion(t,n){await this.api.updateVersions(t,[{version:n,update:{alias:{setNull:!0}}}])}async activateVersion(t,n){let r=null;try{r=await this.api.getActiveVersion(t)}catch{r=null}let o=r&&r.version!==n?r.version:void 0;return await this.api.updateVersions(t,[{version:n,update:{alias:{set:"ACTIVE"}}}]),{supersededVersion:o}}async deploy(t,n,r,o,i,a,l=!1){console.log(`
5
+ \u{1F680} Deploying application via App Hosting API...
6
+ `);try{await this.ensureApp(t,n,r),await this.uploadVersion(t,o,i,a),l&&await this.publishAndActivate(t,o),console.log(`
7
+ \u2705 Deployment successful!`)}catch(c){let p=c instanceof Error?c.message:String(c);throw Object.assign(new Error(`Deployment failed: ${p}`),{cause:c})}}};s(b,"AppHostingClient");var S=b;import y from"fs";import d from"path";import{parseAndValidateManifestConfig as rt}from"@cognite/app-sdk/vite";import{BlobReader as ot,Uint8ArrayWriter as st,ZipWriter as it}from"@zip.js/zip.js";var R="package.json",D="package-lock.json",z="manifest.json",_=".cognite",L=class L{constructor(t="dist"){this.distPath=d.isAbsolute(t)?t:d.join(process.cwd(),t),this.appRoot=d.dirname(this.distPath)}validateBuildDirectory(){if(!y.existsSync(this.distPath))throw new Error(`Build directory "${this.distPath}" not found. Run build first.`);let t=d.join(this.appRoot,R);if(!y.existsSync(t))throw new Error(`"${t}" not found. It is required for deployment.`);let n=d.join(this.appRoot,D);if(!y.existsSync(n))throw new Error(`"${n}" not found. It is required for deployment.`)}async createZip(t="app.zip",n=!1){this.validateBuildDirectory(),console.log("\u{1F4E6} Packaging application...");let r=new it(new st,{level:9}),o=s(async(c,p)=>{await r.add(p,new ot(await y.openAsBlob(c))),n&&console.log(` \u{1F4C4} ${p}`)},"addFile"),i=s(async c=>{let p=await y.promises.readdir(c,{withFileTypes:!0});for(let g of p){let u=d.join(c,g.name);g.isDirectory()?await i(u):await o(u,d.relative(this.distPath,u).replace(/\\/g,"/"))}},"addDir"),a;try{await i(this.distPath);let c=d.join(this.appRoot,R);await o(c,d.posix.join(_,R));let p=d.join(this.appRoot,z);if(y.existsSync(p)){let u=y.readFileSync(p,"utf-8");rt(u,p),await o(p,d.posix.join(_,z))}let g=d.join(this.appRoot,D);await o(g,d.posix.join(_,D)),a=await r.close()}catch(c){let p=c instanceof Error?c.message:String(c);throw new Error(`Failed to create zip: ${p}`)}await y.promises.writeFile(t,a);let l=(a.byteLength/1024/1024).toFixed(2);return console.log(`\u2705 App packaged: ${t} (${l} MB)`),t}};s(L,"ApplicationPackager");var C=L;import{CogniteClient as ut}from"@cognite/sdk";var at=s(()=>{let e=process.env.DEPLOYMENT_SECRETS;if(!e)return{};try{let t=JSON.parse(e),n={};for(let[r,o]of Object.entries(t))if(typeof o=="string"){let i=r.toLowerCase().replace(/_/g,"-");n[i]=o}return n}catch(t){return console.error("Error parsing DEPLOYMENT_SECRETS:",t),{}}},"loadSecretsFromEnv"),ct=s(e=>{let t;if(process.env.DEPLOYMENT_SECRET&&(t=process.env.DEPLOYMENT_SECRET),t||(t=at()[e]),t||(t=process.env[e]),!t)throw new Error(`Secret not found in environment: ${e}`);return t},"getSecretFromEnv"),pt=s(e=>{if(!e)return"";try{return new URL(e).hostname.replace(/\.cognitedata\.com$/,"")}catch{let t=e.replace(/^https?:\/\//,"");return t=t.split("/")[0],t=t.split(":")[0],t=t.replace(/\.cognitedata\.com$/,""),t}},"extractClusterFromUrl"),lt=s(async(e,t)=>{let n=`Basic ${btoa(`${e}:${t}`)}`,r=await fetch("https://auth.cognite.com/oauth2/token",{method:"POST",headers:{Authorization:n,"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"client_credentials"})});if(!r.ok){let i=await r.text();throw new Error(`Failed to get token from CDF: ${r.status} ${r.statusText}
8
+ ${i}`)}let o=await r.json();if(!o.access_token)throw new Error("No access token returned from CDF authentication");return o.access_token},"getTokenCdf"),dt=s(async(e,t,n,r)=>{if(!r)throw new Error("Entra ID authentication requires 'baseUrl' to be set in deployment configuration");let o=pt(r);if(!o)throw new Error(`Entra ID authentication requires 'baseUrl' to be a valid CDF URL (e.g., https://cluster.cognitedata.com), got: ${r}`);let i=`https://login.microsoftonline.com/${n}/oauth2/v2.0/token`,a=`https://${o}.cognitedata.com/.default`,l=await fetch(i,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({client_id:e,client_secret:t,scope:a,grant_type:"client_credentials"})});if(!l.ok){let p=await l.text();throw new Error(`Failed to get token from Entra ID: ${l.status} ${l.statusText}
9
+ ${p}`)}let c=await l.json();if(!c.access_token)throw new Error("No access token returned from Entra ID authentication");return c.access_token},"getTokenEntra"),O=s(async(e,t=process.env)=>{if(t.COGNITE_TOKEN)return t.COGNITE_TOKEN;let{deployClientId:n,deploySecretName:r,idpType:o="cdf",tenantId:i,baseUrl:a}=e,l=ct(r);if(o==="entra_id"){if(!i)throw new Error("Entra ID authentication requires 'tenantId' in deployment configuration");return dt(n,l,i,a)}return lt(n,l)},"getToken");async function U(e,t,n=process.env,r){let o=await O(e,n),i=n.COGNITE_BASE_URL??e.baseUrl,a=(r??(l=>new ut(l)))({appId:t,project:e.project,baseUrl:i,oidcTokenProvider:s(async()=>o,"oidcTokenProvider")});return await a.authenticate(),a}s(U,"getSdk");var ft=s(async(e,t,n)=>{let r=await new C(`${n}/dist`).createZip("app.zip",!0);try{let{externalId:o,name:i,description:a,versionTag:l}=t,c=await U(e,n),p=new S(c),g=Y.readFileSync(r),u=gt.basename(r);await p.deploy(o,i,a,l,g,u,e.published)}finally{try{Y.unlinkSync(r)}catch{}}},"deploy");export{S as a,C as b,O as c,U as d,ft as e};
package/dist/cli/cli.js CHANGED
@@ -1,13 +1,13 @@
1
1
  #!/usr/bin/env node
2
- import{a as o,e as Se}from"../chunk-A5ASLC6T.js";import{writeSync as Kr}from"fs";import{Command as Gr}from"commander";var ke="https://docs.cognite.com/cdf/access/";function P(e){return e!==null&&typeof e=="object"}o(P,"isRecord");function B(e){return e instanceof Error&&"status"in e&&typeof e.status=="number"}o(B,"isHttpError");function Rt(e){switch(e){case 401:return`Your credentials are invalid or expired. Check your client ID and secret.
3
- See: ${ke}`;case 403:return`You don't have the required CDF capabilities. Please contact your CDF admin.
4
- See: ${ke}`;default:return}}o(Rt,"httpStatusHint");function N(e){let t=e instanceof Error?e:new Error(String(e));if(!B(t))return null;let n=Rt(t.status);return n?Object.assign(new Error(`${t.message}
5
- ${n}`),{cause:t}):null}o(N,"enrichedHttpError");function Lt(e){if(!P(e))return null;let t=e.missing;if(Array.isArray(t))return t;let n=e.data;if(P(n)){let r=n.error;if(P(r)&&Array.isArray(r.missing))return r.missing;if(Array.isArray(n.missing))return n.missing}return null}o(Lt,"findMissingArray");function Vt(e,t){if(!B(e)||e.status!==400)return!1;let n=Lt(e);return n?n.some(r=>P(r)&&typeof r.externalId=="string"&&t.includes(r.externalId)):!1}o(Vt,"isMissingExternalIdError");function ee(e,t){return B(e)&&e.status===404||Vt(e,t)}o(ee,"isNotFoundError");var Pe=["DRAFT","PUBLISHED","DEPRECATED","ARCHIVED"],Te=["ACTIVE","PREVIEW"],te=class te extends Error{constructor(t,n){super(`Version ${n} of app ${t} not found`),this.name="AppVersionNotFoundError",this.appExternalId=t,this.version=n}};o(te,"AppVersionNotFoundError");var w=te;function De(e,t){return e.includes(t)}o(De,"includesValue");function _t(e){return De(Pe,e)}o(_t,"isAppVersionLifecycleState");function Nt(e){return De(Te,e)}o(Nt,"isAppVersionAlias");function Ht(e){return typeof e.version=="string"&&_t(e.lifecycleState)&&typeof e.entrypoint=="string"&&typeof e.createdTime=="number"&&typeof e.createdBy=="string"&&typeof e.appExternalId=="string"&&(e.alias===void 0||Nt(e.alias))&&(e.comment===void 0||typeof e.comment=="string")}o(Ht,"isAppVersion");function xe(e){if(!P(e))throw new Error("Invalid version response: not an object");if(!Ht(e))throw new Error("Invalid version response: missing or malformed fields");return e}o(xe,"parseAppVersion");var ne=class ne{constructor(t){this.client=t}get appsBasePath(){return`/api/v1/projects/${encodeURIComponent(this.client.project)}/apphosting/apps`}async createApp(t,n,r){try{await this.client.post(this.appsBasePath,{data:{items:[{externalId:t,name:n,description:r}]}})}catch(i){throw N(i)??i}}async uploadVersion(t,n,r,i,s="index.html"){console.log(`\u{1F4E4} Uploading version ${n}...`);let a=new FormData;a.append("file",new Blob([new Uint8Array(r)]),i),a.append("version",n),a.append("entryPath",s);let p=encodeURIComponent(t),c=`${this.appsBasePath}/${p}/versions`,l=await this.client.authenticate(),d=`${this.client.getBaseUrl()}${c}`,m=new AbortController,u=setTimeout(()=>m.abort(),300*1e3),h;try{h=await fetch(d,{method:"POST",headers:{Authorization:`Bearer ${l}`},body:a,signal:m.signal})}catch(f){throw f instanceof Error&&f.name==="AbortError"?new Error("Upload timed out after 5 minutes"):f}finally{clearTimeout(u)}if(!h.ok){let f=await h.text(),k=f;try{let j=JSON.parse(f);if(P(j)){let A=j.error;if(typeof A=="string")k=A;else if(P(A)){let x=A.message,g=A.code;k=typeof x=="string"?x:g!=null?`Unknown error (code: ${g})`:f}else{let x=j.message;k=typeof x=="string"?x:f}}}catch{}let E=h.headers.get("x-request-id"),Y=E?` | X-Request-ID: ${E}`:"",_=Object.assign(new Error(`Upload failed: ${h.status} \u2014 ${k}${Y}`),{status:h.status});throw N(_)??_}console.log(`\u2705 Version ${n} uploaded`)}async getVersion(t,n){let r=encodeURIComponent(t),i=encodeURIComponent(n),s=`${this.appsBasePath}/${r}/versions/${i}`;try{let a=await this.client.get(s);return xe(a.data)}catch(a){throw ee(a,[t,n])?new w(t,n):N(a)??a}}async getActiveVersion(t){let n=encodeURIComponent(t),r=`${this.appsBasePath}/${n}/active`;try{let i=await this.client.get(r);return xe(i.data)}catch(i){if(ee(i,[t]))return null;throw N(i)??i}}async updateVersions(t,n){let r=encodeURIComponent(t),i=`${this.appsBasePath}/${r}/versions/update`;try{await this.client.post(i,{data:{items:n}})}catch(s){throw N(s)??s}}};o(ne,"AppHostingApi");var J=ne;var re=class re{constructor(t){this.api=new J(t)}getVersion(t,n){return this.api.getVersion(t,n)}uploadVersion(t,n,r,i,s){return this.api.uploadVersion(t,n,r,i,s)}async ensureApp(t,n,r){console.log("\u{1F50D} Ensuring app exists...");try{await this.api.createApp(t,n,r),console.log(`\u2705 App '${t}' created`)}catch(i){if(B(i)&&i.status===409){console.log(`\u2705 App '${t}' already exists`);return}throw i}}async publishVersion(t,n){await this.api.updateVersions(t,[{version:n,update:{lifecycleState:{set:"PUBLISHED"}}}])}async publishAndActivate(t,n){console.log(`\u{1F680} Publishing and activating version ${n}...`),await this.api.updateVersions(t,[{version:n,update:{lifecycleState:{set:"PUBLISHED"},alias:{set:"ACTIVE"}}}]),console.log(`\u2705 Version ${n} is now PUBLISHED and ACTIVE`)}async activateVersion(t,n){let r=null;try{r=await this.api.getActiveVersion(t)}catch{r=null}let i=r&&r.version!==n?r.version:void 0;return await this.api.updateVersions(t,[{version:n,update:{alias:{set:"ACTIVE"}}}]),{supersededVersion:i}}async deploy(t,n,r,i,s,a,p=!1){console.log(`
2
+ import{a as o,e as Ge}from"../chunk-A5ASLC6T.js";import{writeSync as Bi}from"fs";import{Command as Yi}from"commander";var Be="https://docs.cognite.com/cdf/access/";function F(e){return e!==null&&typeof e=="object"}o(F,"isRecord");function B(e){return e instanceof Error&&"status"in e&&typeof e.status=="number"}o(B,"isHttpError");function Un(e){switch(e){case 401:return`Your credentials are invalid or expired. Check your client ID and secret.
3
+ See: ${Be}`;case 403:return`You don't have the required CDF capabilities. Please contact your CDF admin.
4
+ See: ${Be}`;default:return}}o(Un,"httpStatusHint");function V(e){let t=e instanceof Error?e:new Error(String(e));if(!B(t))return null;let n=Un(t.status);return n?Object.assign(new Error(`${t.message}
5
+ ${n}`),{cause:t}):null}o(V,"enrichedHttpError");function Ln(e){if(!F(e))return null;let t=e.missing;if(Array.isArray(t))return t;let n=e.data;if(F(n)){let r=n.error;if(F(r)&&Array.isArray(r.missing))return r.missing;if(Array.isArray(n.missing))return n.missing}return null}o(Ln,"findMissingArray");function Nn(e,t){if(!B(e)||e.status!==400)return!1;let n=Ln(e);return n?n.some(r=>F(r)&&typeof r.externalId=="string"&&t.includes(r.externalId)):!1}o(Nn,"isMissingExternalIdError");function pe(e,t){return B(e)&&e.status===404||Nn(e,t)}o(pe,"isNotFoundError");var Je=["DRAFT","PUBLISHED","DEPRECATED","ARCHIVED"],Xe=["ACTIVE","PREVIEW"],le=class le extends Error{constructor(t,n){super(`Version ${n} of app ${t} not found`),this.name="AppVersionNotFoundError",this.appExternalId=t,this.version=n}};o(le,"AppVersionNotFoundError");var E=le;function ze(e,t){return e.includes(t)}o(ze,"includesValue");function jn(e){return ze(Je,e)}o(jn,"isAppVersionLifecycleState");function Kn(e){return ze(Xe,e)}o(Kn,"isAppVersionAlias");function Mn(e){return typeof e.version=="string"&&jn(e.lifecycleState)&&typeof e.entrypoint=="string"&&typeof e.createdTime=="number"&&typeof e.createdBy=="string"&&typeof e.appExternalId=="string"&&(e.alias===void 0||Kn(e.alias))&&(e.comment===void 0||typeof e.comment=="string")}o(Mn,"isAppVersion");function Ye(e){if(!F(e))throw new Error("Invalid version response: not an object");if(!Mn(e))throw new Error("Invalid version response: missing or malformed fields");return e}o(Ye,"parseAppVersion");var me=class me{constructor(t){this.client=t}get appsBasePath(){return`/api/v1/projects/${encodeURIComponent(this.client.project)}/apphosting/apps`}async createApp(t,n,r){try{await this.client.post(this.appsBasePath,{data:{items:[{externalId:t,name:n,description:r}]}})}catch(i){throw V(i)??i}}async uploadVersion(t,n,r,i,s="index.html"){console.log(`\u{1F4E4} Uploading version ${n}...`);let a=new FormData;a.append("file",new Blob([new Uint8Array(r)]),i),a.append("version",n),a.append("entryPath",s);let c=encodeURIComponent(t),p=`${this.appsBasePath}/${c}/versions`,l=await this.client.authenticate(),m=`${this.client.getBaseUrl()}${p}`,d=new AbortController,u=setTimeout(()=>d.abort(),300*1e3),f;try{f=await fetch(m,{method:"POST",headers:{Authorization:`Bearer ${l}`},body:a,signal:d.signal})}catch(g){throw g instanceof Error&&g.name==="AbortError"?new Error("Upload timed out after 5 minutes"):g}finally{clearTimeout(u)}if(!f.ok){let g=await f.text(),T=g;try{let _=JSON.parse(g);if(F(_)){let I=_.error;if(typeof I=="string")T=I;else if(F(I)){let $=I.message,y=I.code;T=typeof $=="string"?$:y!=null?`Unknown error (code: ${y})`:g}else{let $=_.message;T=typeof $=="string"?$:g}}}catch{}let D=f.headers.get("x-request-id"),Z=D?` | X-Request-ID: ${D}`:"",M=Object.assign(new Error(`Upload failed: ${f.status} \u2014 ${T}${Z}`),{status:f.status});throw V(M)??M}console.log(`\u2705 Version ${n} uploaded`)}async getVersion(t,n){let r=encodeURIComponent(t),i=encodeURIComponent(n),s=`${this.appsBasePath}/${r}/versions/${i}`;try{let a=await this.client.get(s);return Ye(a.data)}catch(a){throw pe(a,[t,n])?new E(t,n):V(a)??a}}async getActiveVersion(t){let n=encodeURIComponent(t),r=`${this.appsBasePath}/${n}/active`;try{let i=await this.client.get(r);return Ye(i.data)}catch(i){if(pe(i,[t]))return null;throw V(i)??i}}async updateVersions(t,n){let r=encodeURIComponent(t),i=`${this.appsBasePath}/${r}/versions/update`;try{await this.client.post(i,{data:{items:n}})}catch(s){throw V(s)??s}}};o(me,"AppHostingApi");var ee=me;var de=class de{constructor(t){this.api=new ee(t)}getVersion(t,n){return this.api.getVersion(t,n)}uploadVersion(t,n,r,i,s){return this.api.uploadVersion(t,n,r,i,s)}async ensureApp(t,n,r){console.log("\u{1F50D} Ensuring app exists...");try{await this.api.createApp(t,n,r),console.log(`\u2705 App '${t}' created`)}catch(i){if(B(i)&&i.status===409){console.log(`\u2705 App '${t}' already exists`);return}throw i}}async publishVersion(t,n){await this.api.updateVersions(t,[{version:n,update:{lifecycleState:{set:"PUBLISHED"}}}])}async publishAndActivate(t,n){console.log(`\u{1F680} Publishing and activating version ${n}...`),await this.api.updateVersions(t,[{version:n,update:{lifecycleState:{set:"PUBLISHED"},alias:{set:"ACTIVE"}}}]),console.log(`\u2705 Version ${n} is now PUBLISHED and ACTIVE`)}getActiveVersion(t){return this.api.getActiveVersion(t)}async deactivateVersion(t,n){await this.api.updateVersions(t,[{version:n,update:{alias:{setNull:!0}}}])}async activateVersion(t,n){let r=null;try{r=await this.api.getActiveVersion(t)}catch{r=null}let i=r&&r.version!==n?r.version:void 0;return await this.api.updateVersions(t,[{version:n,update:{alias:{set:"ACTIVE"}}}]),{supersededVersion:i}}async deploy(t,n,r,i,s,a,c=!1){console.log(`
6
6
  \u{1F680} Deploying application via App Hosting API...
7
- `);try{await this.ensureApp(t,n,r),await this.uploadVersion(t,i,s,a),p&&await this.publishAndActivate(t,i),console.log(`
8
- \u2705 Deployment successful!`)}catch(c){let l=c instanceof Error?c.message:String(c);throw Object.assign(new Error(`Deployment failed: ${l}`),{cause:c})}}};o(re,"AppHostingClient");var y=re;import{existsSync as Zt,readFileSync as Xt}from"fs";import{resolve as en}from"path";import{array as Bt,boolean as Mt,check as Ie,forward as $e,literal as Kt,maxLength as Gt,minLength as zt,nonEmpty as H,object as Oe,optional as R,picklist as qt,pipe as T,safeParse as Yt,string as v,url as Jt}from"valibot";var oe=T(v(),H("must not be empty")),ie=T(v(),H("must not be empty"),Gt(256,"must be 256 characters or fewer")),se=T(v(),H("must not be empty"),Jt("must be a valid URL")),ae=T(v(),H("must not be empty")),pe=T(v(),H("must not be empty")),Wt=T(Oe({org:ae,project:pe,baseUrl:se,deployClientId:R(v(),""),deploySecretName:R(v(),""),published:R(Mt(),!1),idpType:R(qt(["cdf","entra_id"]),"cdf"),tenantId:R(v())}),$e(Ie(e=>e.idpType!=="entra_id"||!!e.tenantId,'must be set when idpType is "entra_id"'),["tenantId"]),$e(Ie(e=>!e.deployClientId||!!e.deploySecretName,"must be set when deployClientId is set"),["deploySecretName"])),Qt=Oe({name:oe,externalId:ie,versionTag:T(v(),H("must not be empty")),description:R(v(),""),deployments:T(Bt(Wt),zt(1,"must contain at least one deployment")),infra:R(Kt("appsApi"))});function ce(e){let t=Yt(Qt,e);if(t.success)return t.output;let n=t.issues[0],r=n.path?.map(s=>s.key).join(".")??"",i=r?`"${r}" `:"";throw new Error(`app.json: ${i}${n.message}`)}o(ce,"validateAppConfig");function C(e,t={}){let{validator:n=ce,existsSync:r=Zt,readFileSync:i=Xt}=t,s=en(e,"app.json");if(!r(s))throw new Error("No app.json found in current directory. Make sure you're running this command from your app's root directory.");let a=i(s,"utf-8"),p;try{p=JSON.parse(a)}catch{throw new Error("Failed to parse app.json \u2014 check that it contains valid JSON.")}return n(p)}o(C,"loadAppConfig");import{CogniteClient as kn}from"@cognite/sdk";import{CogniteClient as an}from"@cognite/sdk";var tn=o(()=>{let e=process.env.DEPLOYMENT_SECRETS;if(!e)return{};try{let t=JSON.parse(e),n={};for(let[r,i]of Object.entries(t))if(typeof i=="string"){let s=r.toLowerCase().replace(/_/g,"-");n[s]=i}return n}catch(t){return console.error("Error parsing DEPLOYMENT_SECRETS:",t),{}}},"loadSecretsFromEnv"),nn=o(e=>{let t;if(process.env.DEPLOYMENT_SECRET&&(t=process.env.DEPLOYMENT_SECRET),t||(t=tn()[e]),t||(t=process.env[e]),!t)throw new Error(`Secret not found in environment: ${e}`);return t},"getSecretFromEnv"),rn=o(e=>{if(!e)return"";try{return new URL(e).hostname.replace(/\.cognitedata\.com$/,"")}catch{let t=e.replace(/^https?:\/\//,"");return t=t.split("/")[0],t=t.split(":")[0],t=t.replace(/\.cognitedata\.com$/,""),t}},"extractClusterFromUrl"),on=o(async(e,t)=>{let n=`Basic ${btoa(`${e}:${t}`)}`,r=await fetch("https://auth.cognite.com/oauth2/token",{method:"POST",headers:{Authorization:n,"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"client_credentials"})});if(!r.ok){let s=await r.text();throw new Error(`Failed to get token from CDF: ${r.status} ${r.statusText}
9
- ${s}`)}let i=await r.json();if(!i.access_token)throw new Error("No access token returned from CDF authentication");return i.access_token},"getTokenCdf"),sn=o(async(e,t,n,r)=>{if(!r)throw new Error("Entra ID authentication requires 'baseUrl' to be set in deployment configuration");let i=rn(r);if(!i)throw new Error(`Entra ID authentication requires 'baseUrl' to be a valid CDF URL (e.g., https://cluster.cognitedata.com), got: ${r}`);let s=`https://login.microsoftonline.com/${n}/oauth2/v2.0/token`,a=`https://${i}.cognitedata.com/.default`,p=await fetch(s,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({client_id:e,client_secret:t,scope:a,grant_type:"client_credentials"})});if(!p.ok){let l=await p.text();throw new Error(`Failed to get token from Entra ID: ${p.status} ${p.statusText}
10
- ${l}`)}let c=await p.json();if(!c.access_token)throw new Error("No access token returned from Entra ID authentication");return c.access_token},"getTokenEntra"),le=o(async(e,t=process.env)=>{if(t.COGNITE_TOKEN)return t.COGNITE_TOKEN;let{deployClientId:n,deploySecretName:r,idpType:i="cdf",tenantId:s,baseUrl:a}=e,p=nn(r);if(i==="entra_id"){if(!s)throw new Error("Entra ID authentication requires 'tenantId' in deployment configuration");return sn(n,p,s,a)}return on(n,p)},"getToken");var M=o(async(e,t,n=process.env)=>{let r=await le(e,n),i=n.COGNITE_BASE_URL??e.baseUrl,s=new an({appId:t,project:e.project,baseUrl:i,oidcTokenProvider:o(async()=>r,"oidcTokenProvider")});return await s.authenticate(),s},"getSdk");import fn from"os";import gn from"path";import yn from"open";import{buildAuthorizationUrl as hn,calculatePKCECodeChallenge as Cn,discovery as wn,None as vn,randomPKCECodeVerifier as bn,randomState as En}from"openid-client";import pn from"https";import{authorizationCodeGrant as cn}from"openid-client";function Ue(e){return e.replace(/[&<>"']/g,t=>({"&":"&amp;","<":"&lt;",">":"&gt;",'"':"&quot;","'":"&#39;"})[t]??t)}o(Ue,"escapeHtml");function de(e,t,n){let r=Ue(t),i=Ue(n);return`<html><body style="font-family: system-ui; padding: 40px; text-align: center;">
7
+ `);try{await this.ensureApp(t,n,r),await this.uploadVersion(t,i,s,a),c&&await this.publishAndActivate(t,i),console.log(`
8
+ \u2705 Deployment successful!`)}catch(p){let l=p instanceof Error?p.message:String(p);throw Object.assign(new Error(`Deployment failed: ${l}`),{cause:p})}}};o(de,"AppHostingClient");var h=de;import{existsSync as Qn,readFileSync as Zn}from"fs";import{resolve as er}from"path";import{array as Vn,boolean as Hn,check as We,forward as qe,literal as Gn,maxLength as Bn,minLength as Yn,nonEmpty as H,object as Qe,optional as U,picklist as Jn,pipe as O,safeParse as Xn,string as v,url as zn}from"valibot";var ue=O(v(),H("must not be empty")),ge=O(v(),H("must not be empty"),Bn(256,"must be 256 characters or fewer")),fe=O(v(),H("must not be empty"),zn("must be a valid URL")),ye=O(v(),H("must not be empty")),he=O(v(),H("must not be empty")),Wn=O(Qe({org:ye,project:he,baseUrl:fe,deployClientId:U(v(),""),deploySecretName:U(v(),""),published:U(Hn(),!1),idpType:U(Jn(["cdf","entra_id"]),"cdf"),tenantId:U(v())}),qe(We(e=>e.idpType!=="entra_id"||!!e.tenantId,'must be set when idpType is "entra_id"'),["tenantId"]),qe(We(e=>!e.deployClientId||!!e.deploySecretName,"must be set when deployClientId is set"),["deploySecretName"])),qn=Qe({name:ue,externalId:ge,versionTag:O(v(),H("must not be empty")),description:U(v(),""),deployments:O(Vn(Wn),Yn(1,"must contain at least one deployment")),infra:U(Gn("appsApi"))});function Ce(e){let t=Xn(qn,e);if(t.success)return t.output;let n=t.issues[0],r=n.path?.map(s=>s.key).join(".")??"",i=r?`"${r}" `:"";throw new Error(`app.json: ${i}${n.message}`)}o(Ce,"validateAppConfig");function C(e,t={}){let{validator:n=Ce,existsSync:r=Qn,readFileSync:i=Zn}=t,s=er(e,"app.json");if(!r(s))throw new Error("No app.json found in current directory. Make sure you're running this command from your app's root directory.");let a=i(s,"utf-8"),c;try{c=JSON.parse(a)}catch{throw new Error("Failed to parse app.json \u2014 check that it contains valid JSON.")}return n(c)}o(C,"loadAppConfig");import{CogniteClient as br}from"@cognite/sdk";import{CogniteClient as sr}from"@cognite/sdk";var tr=o(()=>{let e=process.env.DEPLOYMENT_SECRETS;if(!e)return{};try{let t=JSON.parse(e),n={};for(let[r,i]of Object.entries(t))if(typeof i=="string"){let s=r.toLowerCase().replace(/_/g,"-");n[s]=i}return n}catch(t){return console.error("Error parsing DEPLOYMENT_SECRETS:",t),{}}},"loadSecretsFromEnv"),nr=o(e=>{let t;if(process.env.DEPLOYMENT_SECRET&&(t=process.env.DEPLOYMENT_SECRET),t||(t=tr()[e]),t||(t=process.env[e]),!t)throw new Error(`Secret not found in environment: ${e}`);return t},"getSecretFromEnv"),rr=o(e=>{if(!e)return"";try{return new URL(e).hostname.replace(/\.cognitedata\.com$/,"")}catch{let t=e.replace(/^https?:\/\//,"");return t=t.split("/")[0],t=t.split(":")[0],t=t.replace(/\.cognitedata\.com$/,""),t}},"extractClusterFromUrl"),or=o(async(e,t)=>{let n=`Basic ${btoa(`${e}:${t}`)}`,r=await fetch("https://auth.cognite.com/oauth2/token",{method:"POST",headers:{Authorization:n,"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"client_credentials"})});if(!r.ok){let s=await r.text();throw new Error(`Failed to get token from CDF: ${r.status} ${r.statusText}
9
+ ${s}`)}let i=await r.json();if(!i.access_token)throw new Error("No access token returned from CDF authentication");return i.access_token},"getTokenCdf"),ir=o(async(e,t,n,r)=>{if(!r)throw new Error("Entra ID authentication requires 'baseUrl' to be set in deployment configuration");let i=rr(r);if(!i)throw new Error(`Entra ID authentication requires 'baseUrl' to be a valid CDF URL (e.g., https://cluster.cognitedata.com), got: ${r}`);let s=`https://login.microsoftonline.com/${n}/oauth2/v2.0/token`,a=`https://${i}.cognitedata.com/.default`,c=await fetch(s,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({client_id:e,client_secret:t,scope:a,grant_type:"client_credentials"})});if(!c.ok){let l=await c.text();throw new Error(`Failed to get token from Entra ID: ${c.status} ${c.statusText}
10
+ ${l}`)}let p=await c.json();if(!p.access_token)throw new Error("No access token returned from Entra ID authentication");return p.access_token},"getTokenEntra"),we=o(async(e,t=process.env)=>{if(t.COGNITE_TOKEN)return t.COGNITE_TOKEN;let{deployClientId:n,deploySecretName:r,idpType:i="cdf",tenantId:s,baseUrl:a}=e,c=nr(r);if(i==="entra_id"){if(!s)throw new Error("Entra ID authentication requires 'tenantId' in deployment configuration");return ir(n,c,s,a)}return or(n,c)},"getToken");async function Y(e,t,n=process.env,r){let i=await we(e,n),s=n.COGNITE_BASE_URL??e.baseUrl,a=(r??(c=>new sr(c)))({appId:t,project:e.project,baseUrl:s,oidcTokenProvider:o(async()=>i,"oidcTokenProvider")});return await a.authenticate(),a}o(Y,"getSdk");import ur from"os";import gr from"path";import fr from"open";import{buildAuthorizationUrl as yr,calculatePKCECodeChallenge as hr,discovery as Cr,None as wr,randomPKCECodeVerifier as Er,randomState as Sr}from"openid-client";import ar from"https";import{authorizationCodeGrant as cr}from"openid-client";function Ze(e){return e.replace(/[&<>"']/g,t=>({"&":"&amp;","<":"&lt;",">":"&gt;",'"':"&quot;","'":"&#39;"})[t]??t)}o(Ze,"escapeHtml");function Ee(e,t,n){let r=Ze(t),i=Ze(n);return`<html><body style="font-family: system-ui; padding: 40px; text-align: center;">
11
11
  <h1>${r}</h1><p>${i}</p><p>You can close this window.</p>${e==="success"?`<style>
12
12
  @keyframes checkmark {
13
13
  0% { transform: scale(0); }
@@ -16,31 +16,31 @@ ${l}`)}let c=await p.json();if(!c.access_token)throw new Error("No access token
16
16
  }
17
17
  h1 { animation: checkmark 0.5s ease-out; }
18
18
  </style>`:""}
19
- </body></html>`}o(de,"generateHtml");async function ln(e,t,n,r,i,s){let a=new URL(e.url??"/",`https://${e.headers.host??"localhost"}`);if(a.pathname!=="/")return t.writeHead(404),t.end("Not found"),{shouldClose:!1};try{console.log("\u{1F504} Exchanging authorization code for tokens...");let p=await s.authorizationCodeGrant(n,a,{pkceCodeVerifier:r,expectedState:i});return t.writeHead(200,{"Content-Type":"text/html"}),t.end(de("success","Login Successful!","You can close this window and return to the terminal.")),{shouldClose:!0,tokens:p}}catch(p){let c=p instanceof Error?p:new Error(String(p));return t.writeHead(400,{"Content-Type":"text/html"}),t.end(de("error","Authentication Error",c.message)),{shouldClose:!0,error:c}}}o(ln,"handleCallback");function dn(e){let t=e/6e4,n=Math.round(t*10)/10;return`${n} ${n===1?"minute":"minutes"}`}o(dn,"formatTimeoutMinutes");function Fe(e,t,n,r,i,s={createServer:pn.createServer,setTimeout:globalThis.setTimeout,clearTimeout:globalThis.clearTimeout,authorizationCodeGrant:cn}){return new Promise((a,p)=>{let c,l=s.setTimeout(()=>{c?.close(),p(new Error(`Login timeout - no response received within ${dn(e.loginTimeout)}`))},e.loginTimeout);c=s.createServer(t,async(d,m)=>{try{let u=await ln(d,m,n,r,i,s);u.shouldClose&&(s.clearTimeout(l),c?.close(),u.error?p(u.error):u.tokens?a(u.tokens):p(new Error("No tokens received")))}catch(u){s.clearTimeout(l),c?.close(),p(u instanceof Error?u:new Error(String(u)))}}),c.on("error",d=>{s.clearTimeout(l),d.code==="EADDRINUSE"?console.error(`\u274C Port ${e.port} is already in use.`):console.error(`\u274C Server error: ${d.message}`),p(d)}),c.listen(e.port,"127.0.0.1",()=>{console.log(`\u{1F310} Local HTTPS server started on https://localhost:${e.port}`)})})}o(Fe,"startCallbackServer");import{execFileSync as mn}from"child_process";import me from"fs";import je from"path";function Re(e,t,n){return{key:n.readFileSync(e),cert:n.readFileSync(t)}}o(Re,"loadCertificates");function un(e,t,n,r){console.log("\u{1F510} Generating self-signed certificate for HTTPS..."),r.existsSync(e)||r.mkdirSync(e,{recursive:!0});try{return r.execFileSync("openssl",["req","-x509","-newkey","rsa:2048","-nodes","-sha256","-subj","/CN=localhost","-keyout",t,"-out",n,"-days","365"],{stdio:["ignore","pipe","ignore"]}),console.log("\u2705 Certificate generated and saved locally"),Re(t,n,r)}catch{throw new Error(`Failed to generate self-signed certificate. Make sure openssl is installed.
19
+ </body></html>`}o(Ee,"generateHtml");async function pr(e,t,n,r,i,s){let a=new URL(e.url??"/",`https://${e.headers.host??"localhost"}`);if(a.pathname!=="/")return t.writeHead(404),t.end("Not found"),{shouldClose:!1};try{console.log("\u{1F504} Exchanging authorization code for tokens...");let c=await s.authorizationCodeGrant(n,a,{pkceCodeVerifier:r,expectedState:i});return t.writeHead(200,{"Content-Type":"text/html"}),t.end(Ee("success","Login Successful!","You can close this window and return to the terminal.")),{shouldClose:!0,tokens:c}}catch(c){let p=c instanceof Error?c:new Error(String(c));return t.writeHead(400,{"Content-Type":"text/html"}),t.end(Ee("error","Authentication Error",p.message)),{shouldClose:!0,error:p}}}o(pr,"handleCallback");function lr(e){let t=e/6e4,n=Math.round(t*10)/10;return`${n} ${n===1?"minute":"minutes"}`}o(lr,"formatTimeoutMinutes");function et(e,t,n,r,i,s={createServer:ar.createServer,setTimeout:globalThis.setTimeout,clearTimeout:globalThis.clearTimeout,authorizationCodeGrant:cr}){return new Promise((a,c)=>{let p,l=s.setTimeout(()=>{p?.close(),c(new Error(`Login timeout - no response received within ${lr(e.loginTimeout)}`))},e.loginTimeout);p=s.createServer(t,async(m,d)=>{try{let u=await pr(m,d,n,r,i,s);u.shouldClose&&(s.clearTimeout(l),p?.close(),u.error?c(u.error):u.tokens?a(u.tokens):c(new Error("No tokens received")))}catch(u){s.clearTimeout(l),p?.close(),c(u instanceof Error?u:new Error(String(u)))}}),p.on("error",m=>{s.clearTimeout(l),m.code==="EADDRINUSE"?console.error(`\u274C Port ${e.port} is already in use.`):console.error(`\u274C Server error: ${m.message}`),c(m)}),p.listen(e.port,"127.0.0.1",()=>{console.log(`\u{1F310} Local HTTPS server started on https://localhost:${e.port}`)})})}o(et,"startCallbackServer");import{execFileSync as mr}from"child_process";import Se from"fs";import tt from"path";function nt(e,t,n){return{key:n.readFileSync(e),cert:n.readFileSync(t)}}o(nt,"loadCertificates");function dr(e,t,n,r){console.log("\u{1F510} Generating self-signed certificate for HTTPS..."),r.existsSync(e)||r.mkdirSync(e,{recursive:!0});try{return r.execFileSync("openssl",["req","-x509","-newkey","rsa:2048","-nodes","-sha256","-subj","/CN=localhost","-keyout",t,"-out",n,"-days","365"],{stdio:["ignore","pipe","ignore"]}),console.log("\u2705 Certificate generated and saved locally"),nt(t,n,r)}catch{throw new Error(`Failed to generate self-signed certificate. Make sure openssl is installed.
20
20
  On macOS: openssl is pre-installed
21
21
  On Linux: sudo apt-get install openssl
22
- On Windows: Install OpenSSL or use WSL`)}}o(un,"generateCertificate");function Le(e,t={existsSync:me.existsSync,readFileSync:o(n=>me.readFileSync(n),"readFileSync"),mkdirSync:o((n,r)=>{me.mkdirSync(n,r)},"mkdirSync"),execFileSync:mn}){let n=je.join(e,"localhost-key.pem"),r=je.join(e,"localhost-cert.pem");return t.existsSync(n)&&t.existsSync(r)?Re(n,r,t):un(e,n,r,t)}o(Le,"getOrCreateCertificates");var An={authority:"https://auth.cognite.com",clientId:"0404baaa-0a90-43a2-aba7-a110b53fb41c",redirectUri:"https://localhost:3000/",port:3e3,loginTimeout:300*1e3,certDir:gn.join(fn.homedir(),".cdf-login")},Sn={open:yn,getOrCreateCertificates:Le,startCallbackServer:Fe,discovery:wn,buildAuthorizationUrl:hn,randomPKCECodeVerifier:bn,calculatePKCECodeChallenge:Cn,randomState:En,logger:console};async function _e(e,t=An,n){return n===void 0?Ve(e,t,Sn):Ve(e,t,n)}o(_e,"login");async function Ve(e,t,n){n.logger.log(`\u{1F510} Starting CDF login flow...
23
- `),n.logger.log(`\u{1F4E1} Fetching OpenID configuration from ${t.authority}...`);let r=await n.discovery(new URL(t.authority),t.clientId,void 0,vn()),i=n.randomPKCECodeVerifier(),s=await n.calculatePKCECodeChallenge(i),a=n.randomState(),p={redirect_uri:t.redirectUri,scope:"openid profile email",code_challenge:s,code_challenge_method:"S256",state:a};e&&(p.organization_hint=e);let c=n.buildAuthorizationUrl(r,p).toString(),l=n.getOrCreateCertificates(t.certDir);e&&n.logger.log(`\u{1F3E2} Organization: ${e}`),n.logger.log(`\u{1F680} Opening browser for authentication...
24
- `);try{await n.open(c)}catch(d){let m=d instanceof Error?d.message:String(d);n.logger.error("\u274C Failed to open browser automatically."),n.logger.error(` Reason: ${m}`),n.logger.error(`Please open this URL manually:
25
- `),n.logger.error(c),n.logger.error("")}return n.startCallbackServer(t,l,r,i,a)}o(Ve,"loginImpl");async function D(e,t,n={}){let{login:r=_e,getSdk:i=M,createClient:s=o(a=>new kn(a),"createClient")}=n;if(t.interactive){let a=t.orgHint||e.org||void 0,p=await r(a),c=s({appId:t.appId,project:e.project,baseUrl:e.baseUrl,getToken:o(async()=>p.access_token,"getToken")});return await c.authenticate(),c}return i(e,t.appId)}o(D,"getClientForDeployment");import{existsSync as xn}from"fs";import{resolve as Pn}from"path";import{config as Tn}from"dotenv";function I(e,t={existsSync:xn,config:Tn}){let n=Pn(e,".env");t.existsSync(n)&&(console.log(`Loading environment variables from ${n}`),t.config({path:n}))}o(I,"loadEnvFile");import Ne from"enquirer";var He="Enter custom target...";function Be(e,t){let n=t.map((r,i)=>` ${i}: ${r.org}/${r.project}`).join(`
22
+ On Windows: Install OpenSSL or use WSL`)}}o(dr,"generateCertificate");function rt(e,t={existsSync:Se.existsSync,readFileSync:o(n=>Se.readFileSync(n),"readFileSync"),mkdirSync:o((n,r)=>{Se.mkdirSync(n,r)},"mkdirSync"),execFileSync:mr}){let n=tt.join(e,"localhost-key.pem"),r=tt.join(e,"localhost-cert.pem");return t.existsSync(n)&&t.existsSync(r)?nt(n,r,t):dr(e,n,r,t)}o(rt,"getOrCreateCertificates");var vr={authority:"https://auth.cognite.com",clientId:"0404baaa-0a90-43a2-aba7-a110b53fb41c",redirectUri:"https://localhost:3000/",port:3e3,loginTimeout:300*1e3,certDir:gr.join(ur.homedir(),".cdf-login")},xr={open:fr,getOrCreateCertificates:rt,startCallbackServer:et,discovery:Cr,buildAuthorizationUrl:yr,randomPKCECodeVerifier:Er,calculatePKCECodeChallenge:hr,randomState:Sr,logger:console};async function it(e,t=vr,n){return n===void 0?ot(e,t,xr):ot(e,t,n)}o(it,"login");async function ot(e,t,n){n.logger.log(`\u{1F510} Starting CDF login flow...
23
+ `),n.logger.log(`\u{1F4E1} Fetching OpenID configuration from ${t.authority}...`);let r=await n.discovery(new URL(t.authority),t.clientId,void 0,wr()),i=n.randomPKCECodeVerifier(),s=await n.calculatePKCECodeChallenge(i),a=n.randomState(),c={redirect_uri:t.redirectUri,scope:"openid profile email",code_challenge:s,code_challenge_method:"S256",state:a};e&&(c.organization_hint=e);let p=n.buildAuthorizationUrl(r,c).toString(),l=n.getOrCreateCertificates(t.certDir);e&&n.logger.log(`\u{1F3E2} Organization: ${e}`),n.logger.log(`\u{1F680} Opening browser for authentication...
24
+ `);try{await n.open(p)}catch(m){let d=m instanceof Error?m.message:String(m);n.logger.error("\u274C Failed to open browser automatically."),n.logger.error(` Reason: ${d}`),n.logger.error(`Please open this URL manually:
25
+ `),n.logger.error(p),n.logger.error("")}return n.startCallbackServer(t,l,r,i,a)}o(ot,"loginImpl");async function x(e,t,n={}){let{login:r=it,getSdk:i=Y,createClient:s=o(a=>new br(a),"createClient")}=n;if(t.interactive){let a=t.orgHint||e.org||void 0,c=await r(a),p=s({appId:t.appId,project:e.project,baseUrl:e.baseUrl,getToken:o(async()=>c.access_token,"getToken")});return await p.authenticate(),p}return i(e,t.appId)}o(x,"getClientForDeployment");import st from"enquirer";var at="Enter custom target...";function ct(e,t){let n=t.map((r,i)=>` ${i}: ${r.org}/${r.project}`).join(`
26
26
  `);throw new Error(`Deployment "${e}" not found. Available deployments:
27
- ${n}`)}o(Be,"deploymentNotFoundError");function S(e,t){if(e.length===0)throw new Error("No deployments configured in app.json");if(t===void 0)return e[0];if(/^\d+$/.test(t)){let r=e[Number.parseInt(t)];if(r)return r;Be(t,e)}let n=e.find(r=>r.project===t||`${r.org}/${r.project}`===t);if(n)return n;Be(t,e)}o(S,"findDeployment");function $(e){let t=[];return e.deployClientId||t.push("deployClientId"),e.deploySecretName||t.push("deploySecretName"),t}o($,"getMissingCredentials");async function O(e,t){if(t.baseUrl&&t.project)return{org:t.org??"",project:t.project,baseUrl:t.baseUrl,deployClientId:"",deploySecretName:"",published:!1,idpType:"cdf"};if(t.deployment!==void 0)return S(e.deployments,t.deployment);let n=[...e.deployments.map(s=>`${s.org}/${s.project}`),He],{selected:r}=await Ne.prompt({type:"select",name:"selected",message:"Select deployment target",choices:n});if(r!==He){let s=e.deployments.find(a=>`${a.org}/${a.project}`===r);if(s)return s;throw new Error(`Deployment "${r}" could not be resolved from app.json.`)}let i=await Ne.prompt([{type:"input",name:"baseUrl",message:"CDF Base URL",initial:"https://api.cognitedata.com"},{type:"input",name:"project",message:"CDF Project",validate:o(s=>s?!0:"Project is required","validate")},{type:"input",name:"org",message:"Organization (for login hint)",initial:""}]);return{org:i.org||"",project:i.project,baseUrl:i.baseUrl,deployClientId:"",deploySecretName:"",published:!1,idpType:"cdf"}}o(O,"resolveDeployment");function U(e){e.infra!=="appsApi"&&(console.error(`
27
+ ${n}`)}o(ct,"deploymentNotFoundError");function S(e,t){if(e.length===0)throw new Error("No deployments configured in app.json");if(t===void 0)return e[0];if(/^\d+$/.test(t)){let r=e[Number.parseInt(t)];if(r)return r;ct(t,e)}let n=e.find(r=>r.project===t||`${r.org}/${r.project}`===t);if(n)return n;ct(t,e)}o(S,"findDeployment");function b(e){let t=[];return e.deployClientId||t.push("deployClientId"),e.deploySecretName||t.push("deploySecretName"),t}o(b,"getMissingCredentials");async function P(e,t){if(t.baseUrl&&t.project)return{org:t.org??"",project:t.project,baseUrl:t.baseUrl,deployClientId:"",deploySecretName:"",published:!1,idpType:"cdf"};if(t.deployment!==void 0)return S(e.deployments,t.deployment);let n=[...e.deployments.map(s=>`${s.org}/${s.project}`),at],{selected:r}=await st.prompt({type:"select",name:"selected",message:"Select deployment target",choices:n});if(r!==at){let s=e.deployments.find(a=>`${a.org}/${a.project}`===r);if(s)return s;throw new Error(`Deployment "${r}" could not be resolved from app.json.`)}let i=await st.prompt([{type:"input",name:"baseUrl",message:"CDF Base URL",initial:"https://api.cognitedata.com"},{type:"input",name:"project",message:"CDF Project",validate:o(s=>s?!0:"Project is required","validate")},{type:"input",name:"org",message:"Organization (for login hint)",initial:""}]);return{org:i.org||"",project:i.project,baseUrl:i.baseUrl,deployClientId:"",deploySecretName:"",published:!1,idpType:"cdf"}}o(P,"resolveDeployment");import{existsSync as Pr}from"fs";import{resolve as Ar}from"path";import{config as kr}from"dotenv";function A(e,t={existsSync:Pr,config:kr}){let n=Ar(e,".env");t.existsSync(n)&&(console.log(`Loading environment variables from ${n}`),t.config({path:n}))}o(A,"loadEnvFile");function k(e){e.infra!=="appsApi"&&(console.error(`
28
28
  \u26A0\uFE0F Legacy infrastructure is no longer supported.
29
29
 
30
30
  Your app.json is missing \`"infra": "appsApi"\`, which means it was created for
31
31
  the old CDF Application Registry. This deploy path has been removed.
32
32
 
33
33
  To migrate: add \`"infra": "appsApi"\` to your app.json, wire up the correct authentication and re-deploy.
34
- `),process.exit(1))}o(U,"assertAppHostingInfra");async function Dn(e){let t=process.cwd();I(t);let n=C(t);U(n);let r=e.interactive?await O(n,e):S(n.deployments,e.deployment);if(!e.interactive){let d=$(r);if(d.length>0)throw new Error(`Deployment ${r.org}/${r.project} is missing ${d.join(" and ")} in app.json. Use \`dune apps activate --interactive\` for browser-based authentication instead.`)}let i=await D(r,{interactive:e.interactive,appId:n.externalId,orgHint:e.org}),s=new y(i),{externalId:a,versionTag:p}=n,c;try{c=await s.getVersion(a,p)}catch(d){throw d instanceof w?new Error(`Version ${p} of ${a} has not been deployed yet. Run \`npx @cognite/cli apps deploy\` first.`):d}if(c.alias==="ACTIVE"){console.log(` ${a} @ ${p} is already ACTIVE \u2014 nothing to do.`);return}if(c.lifecycleState==="DEPRECATED"||c.lifecycleState==="ARCHIVED")throw new Error(`Cannot activate ${a} @ ${p}: version is ${c.lifecycleState} (terminal).`);c.lifecycleState==="DRAFT"&&(await s.publishVersion(a,p),console.log(`\u2713 Published ${a} @ ${p} is now PUBLISHED`));let{supersededVersion:l}=await s.activateVersion(a,p);console.log(`\u2713 Activated ${a} @ ${p} is now ACTIVE`),l&&console.log(` Superseded ${l} \u2192 PUBLISHED`)}o(Dn,"handleActivate");function Me(e){return e.command("activate").description("Activate the current app version (publish if needed, then set ACTIVE alias)").argument("[path]","Path to the app folder (only `.` is currently supported)",".").option("-d, --deployment <target>","Deployment target from app.json (index or name)").option("--interactive","Use browser-based authentication instead of env-var credentials",!1).option("--base-url <url>","CDF base URL (only with --interactive)").option("--project <project>","CDF project name (only with --interactive)").option("--org <org>","Organization hint for login (only with --interactive)").addHelpText("after",`
34
+ `),process.exit(1))}o(k,"assertAppHostingInfra");async function Dr(e){let t=process.cwd();A(t);let n=C(t);k(n);let r=e.interactive?await P(n,e):S(n.deployments,e.deployment);if(!e.interactive){let m=b(r);if(m.length>0)throw new Error(`Deployment ${r.org}/${r.project} is missing ${m.join(" and ")} in app.json. Use \`npx @cognite/cli@latest apps activate --interactive\` for browser-based authentication instead.`)}let i=await x(r,{interactive:e.interactive,appId:n.externalId,orgHint:e.org}),s=new h(i),{externalId:a,versionTag:c}=n,p;try{p=await s.getVersion(a,c)}catch(m){throw m instanceof E?new Error(`Version ${c} of ${a} has not been deployed yet. Run \`npx @cognite/cli apps deploy\` first.`):m}if(p.alias==="ACTIVE"){console.log(` ${a} @ ${c} is already ACTIVE \u2014 nothing to do.`);return}if(p.lifecycleState==="DEPRECATED"||p.lifecycleState==="ARCHIVED")throw new Error(`Cannot activate ${a} @ ${c}: version is ${p.lifecycleState} (terminal).`);p.lifecycleState==="DRAFT"&&(await s.publishVersion(a,c),console.log(`\u2713 Published ${a} @ ${c} is now PUBLISHED`));let{supersededVersion:l}=await s.activateVersion(a,c);console.log(`\u2713 Activated ${a} @ ${c} is now ACTIVE`),l&&console.log(` Superseded ${l} \u2192 PUBLISHED`)}o(Dr,"handleActivate");function pt(e){return e.command("activate").description("Activate the current app version (publish if needed, then set ACTIVE alias)").argument("[path]","Path to the app folder (only `.` is currently supported)",".").option("-d, --deployment <target>","Deployment target from app.json (index or name)").option("--interactive","Use browser-based authentication instead of env-var credentials",!1).option("--base-url <url>","CDF base URL (only with --interactive)").option("--project <project>","CDF project name (only with --interactive)").option("--org <org>","Organization hint for login (only with --interactive)").addHelpText("after",`
35
35
  Examples:
36
36
  npx @cognite/cli apps activate . Activate using env-var auth
37
- npx @cognite/cli apps activate . --interactive Activate using browser auth (no secrets needed)`).action((t,n)=>Dn(n))}o(Me,"registerActivateCommand");import{readdirSync as Bn}from"fs";import{basename as Xe,dirname as Mn,normalize as Kn,resolve as G}from"path";import{fileURLToPath as Gn,pathToFileURL as zn}from"url";import{Logger as qn,runner as Yn}from"hygen";import{safeParse as In}from"valibot";function K(e,t){return n=>{let r=In(t,n);return r.success?!0:`${e} ${r.issues[0].message}`}}o(K,"toPromptValidator");var Ke={name:K("App name",ie),displayName:K("Display name",oe),baseUrl:K("Base URL",se),org:K("Org",ae),project:K("Project",pe)};function $n(e,t){return e?async n=>{let r=t(n);return r===!0?e(n):r}:t}o($n,"composeValidators");function W(e){return e.map(t=>{if(!(t.name in Ke))return t;let n=Ke[t.name];return{...t,validate:$n(t.validate,n)}})}o(W,"applySchemaValidators");import{basename as ze}from"path";import qe from"enquirer";function Ge(e){return e.replace(/[A-Z]/g,(t,n)=>n===0?t.toLowerCase():`-${t.toLowerCase()}`)}o(Ge,"kebabCase");var On={type:"confirm",name:"useSpecKit",message:["Enable spec-driven development?"," Adds the github/spec-kit slash commands (/speckit.specify, .clarify, .plan, .tasks, .implement)"," to your app for use in Claude Code or Cursor. They walk you through writing SPEC.md and"," generating a plan, tasks, and implementation."].join(`
38
- `),initial:!1};async function Un(e){return!!(await e([On])).useSpecKit}o(Un,"promptForSpecKit");async function Fn(e,t,n){return e!==void 0?e:t?Un(n):!1}o(Fn,"resolveSpecKit");function Ye({isCurrentDir:e,dirName:t,onAppName:n,onUseSpecKit:r,presets:i={},specKit:s,prompt:a=qe.prompt.bind(qe)}){return()=>({prompt:o(async p=>{if(!Array.isArray(p))return a([p]);let c=Object.fromEntries(Object.entries(i).filter(g=>g[1]!==void 0)),l=Object.keys(c).length>0,d=e?ze(process.cwd()):t?ze(t):null,m=l&&d!==null,u=!m&&d?p.map(g=>g.name==="name"?{...g,initial:d}:g):p,h=W(u),f=m?{...c,name:d}:c,k=new Set(Object.keys(f)),E=h.filter(g=>!k.has(g.name)),Y=E.findIndex(g=>g.name==="baseUrl"),_;if(Y!==-1){let g=E.filter(jt=>jt.name!=="baseUrl"),X=g.length>0?await a(g):{},It=typeof X.cluster=="string"?X.cluster:"",$t=typeof f.cluster=="string"?f.cluster:"",Ot=`https://${(It||$t).trim().replace(/\/+$/,"")||"api"}.cognitedata.com`,Ut=E[Y],Ft=await a([{...Ut,initial:Ot}]);_={...X,...Ft}}else _=E.length>0?await a(E):{};let j={...f,..._},A=typeof j.name=="string"?j.name:"";A&&n(A);let x=await Fn(s,E.length>0,a);return r?.(x),{...j,name:A,useCurrentDir:e,directoryName:e?void 0:t??void 0,useSpecKit:x}},"prompt")})}o(Ye,"createAppPrompter");async function Je(e,t,n){let r=[];Object.values(t).some(s=>s!==void 0)&&n!==null&&r.push({key:"name",value:n,label:"directory"});for(let[s,a]of Object.entries(t))a!==void 0&&r.push({key:s,value:a,label:`--${Ge(s)}`});for(let{key:s,value:a,label:p}of r){let c=e.find(d=>d.name===s)?.validate;if(!c)continue;let l=await c(a);if(l!==!0)throw new Error(`Invalid ${p}: ${l}`)}}o(Je,"validatePresets");import{cpSync as Rn,mkdirSync as We,writeFileSync as Ln}from"fs";import{dirname as Qe,resolve as L}from"path";import{fileURLToPath as Vn}from"url";import{symlinkSync as jn}from"fs";function Q({target:e,linkPath:t,label:n,symlink:r=jn}){try{return r(e,t),!0}catch(i){if(i instanceof Error&&"code"in i&&i.code==="EEXIST")return!0;let s=i instanceof Error?i.message:String(i);return console.warn(`\u26A0\uFE0F Could not create ${n} symlink:`,s),!1}}o(Q,"symlinkOrWarn");var _n=L(Qe(Vn(import.meta.url)),"..","..","_vendor","spec-kit"),Nn={branch_numbering:"sequential"},Hn=[{from:"templates",to:".specify/templates"},{from:"scripts/bash",to:".specify/scripts/bash"},{from:"commands",to:".claude/commands"},{from:"commands",to:".cursor/commands"}];function Ze({appDir:e,vendorDir:t=_n}){let n=L(e,".specify"),r=L(n,"memory"),i=`prepare spec-kit install for appDir=${e}`;try{for(let{from:s,to:a}of Hn){let p=L(e,a);i=`copy ${s} to ${a}`,We(Qe(p),{recursive:!0}),Rn(L(t,s),p,{recursive:!0})}i=`write init-options.json under specifyDir=${n}`,Ln(L(n,"init-options.json"),`${JSON.stringify(Nn,null,2)}
39
- `),i=`link .specify/memory/constitution.md in specifyDir=${n}`,We(r,{recursive:!0}),Q({target:"../../AGENTS.md",linkPath:L(r,"constitution.md"),label:".specify/memory/constitution.md"})}catch(s){let a=s instanceof Error?s.message:String(s);throw new Error(`installSpecKit failed while ${i} (appDir=${e}, vendorDir=${t}): ${a}`,{cause:s})}}o(Ze,"installSpecKit");var et=G(Mn(Gn(import.meta.url)),"..","..","_templates");async function Jn(){let e=G(et,"app","new","prompt.js");return(await import(zn(e).href)).default}o(Jn,"loadPromptDefs");function Wn(e,t){return!e||t?null:Kn(e)}o(Wn,"resolveDirName");function Qn(e,t,n){if(e)return{cwd:process.cwd(),display:"."};let r=t??n;if(!r)throw new Error("App creation completed without a target directory or name.");return{cwd:G(process.cwd(),r),display:r}}o(Qn,"resolveAppLocation");function Zn(e,t,n){let r=` npm install
37
+ npx @cognite/cli apps activate . --interactive Activate using browser auth (no secrets needed)`).action((t,n)=>Dr(n))}o(pt,"registerActivateCommand");import{readdirSync as Mr}from"fs";import{basename as xt,dirname as Vr,normalize as Hr,resolve as X}from"path";import{fileURLToPath as Gr,pathToFileURL as Br}from"url";import{Logger as Yr,runner as Jr}from"hygen";import{safeParse as Ir}from"valibot";function J(e,t){return n=>{let r=Ir(t,n);return r.success?!0:`${e} ${r.issues[0].message}`}}o(J,"toPromptValidator");var lt={name:J("App name",ge),displayName:J("Display name",ue),baseUrl:J("Base URL",fe),org:J("Org",ye),project:J("Project",he)};function Tr(e,t){return e?async n=>{let r=t(n);return r===!0?e(n):r}:t}o(Tr,"composeValidators");function te(e){return e.map(t=>{if(!(t.name in lt))return t;let n=lt[t.name];return{...t,validate:Tr(t.validate,n)}})}o(te,"applySchemaValidators");import{execFileSync as ne}from"child_process";function mt(e={}){let{execFileSync:t=ne}=e;try{return t("git",["--version"],{stdio:"ignore"}),!0}catch{return!1}}o(mt,"isGitInstalled");function dt(e,t={}){let{execFileSync:n=ne}=t;try{return n("git",["-C",e,"status"],{stdio:"ignore"}),!0}catch{return!1}}o(dt,"isInsideGitRepo");function ut(e,t={}){let{execFileSync:n=ne}=t;n("git",["-C",e,"init"],{stdio:"pipe"}),n("git",["-C",e,"add","."],{stdio:"pipe"}),n("git",["-C",e,"commit","-m","Initial commit","--no-gpg-sign","--no-verify"],{stdio:"pipe"})}o(ut,"gitInitAndCommit");function gt(e={}){let{execFileSync:t=ne}=e;try{return String(t("git",["config","--get","user.email"],{encoding:"utf-8",stdio:["ignore","pipe","ignore"]})).trim()||void 0}catch{return}}o(gt,"gitUserEmail");import{basename as yt}from"path";import ht from"enquirer";function ft(e){return e.replace(/[A-Z]/g,(t,n)=>n===0?t.toLowerCase():`-${t.toLowerCase()}`)}o(ft,"kebabCase");var $r={type:"confirm",name:"useSpecKit",message:["Enable spec-driven development?"," Adds the github/spec-kit slash commands (/speckit.specify, .clarify, .plan, .tasks, .implement)"," to your app for use in Claude Code or Cursor. They walk you through writing SPEC.md and"," generating a plan, tasks, and implementation."].join(`
38
+ `),initial:!1};async function Fr(e){return!!(await e([$r])).useSpecKit}o(Fr,"promptForSpecKit");async function Or(e,t,n){return e!==void 0?e:t?Fr(n):!1}o(Or,"resolveSpecKit");function Ct({isCurrentDir:e,dirName:t,onAppName:n,onUseSpecKit:r,presets:i={},specKit:s,prompt:a=ht.prompt.bind(ht)}){return()=>({prompt:o(async c=>{if(!Array.isArray(c))return a([c]);let p=Object.fromEntries(Object.entries(i).filter(y=>y[1]!==void 0)),l=Object.keys(p).length>0,m=e?yt(process.cwd()):t?yt(t):null,d=l&&m!==null,u=!d&&m?c.map(y=>y.name==="name"?{...y,initial:m}:y):c,f=te(u),g=d?{...p,name:m}:p,T=new Set(Object.keys(g)),D=f.filter(y=>!T.has(y.name)),Z=D.findIndex(y=>y.name==="baseUrl"),M;if(Z!==-1){let y=D.filter(_n=>_n.name!=="baseUrl"),ce=y.length>0?await a(y):{},Tn=typeof ce.cluster=="string"?ce.cluster:"",$n=typeof g.cluster=="string"?g.cluster:"",Fn=`https://${(Tn||$n).trim().replace(/\/+$/,"")||"api"}.cognitedata.com`,On=D[Z],Rn=await a([{...On,initial:Fn}]);M={...ce,...Rn}}else M=D.length>0?await a(D):{};let _={...g,...M},I=typeof _.name=="string"?_.name:"";I&&n(I);let $=await Or(s,D.length>0,a);return r?.($),{..._,name:I,useCurrentDir:e,directoryName:e?void 0:t??void 0,useSpecKit:$}},"prompt")})}o(Ct,"createAppPrompter");async function wt(e,t,n){let r=[];Object.values(t).some(s=>s!==void 0)&&n!==null&&r.push({key:"name",value:n,label:"directory"});for(let[s,a]of Object.entries(t))a!==void 0&&r.push({key:s,value:a,label:`--${ft(s)}`});for(let{key:s,value:a,label:c}of r){let p=e.find(m=>m.name===s)?.validate;if(!p)continue;let l=await p(a);if(l!==!0)throw new Error(`Invalid ${c}: ${l}`)}}o(wt,"validatePresets");import{cpSync as _r,mkdirSync as Et,writeFileSync as Ur}from"fs";import{dirname as St,resolve as L}from"path";import{fileURLToPath as Lr}from"url";import{symlinkSync as Rr}from"fs";function re({target:e,linkPath:t,label:n,symlink:r=Rr}){try{return r(e,t),!0}catch(i){if(i instanceof Error&&"code"in i&&i.code==="EEXIST")return!0;let s=i instanceof Error?i.message:String(i);return console.warn(`\u26A0\uFE0F Could not create ${n} symlink:`,s),!1}}o(re,"symlinkOrWarn");var Nr=L(St(Lr(import.meta.url)),"..","..","_vendor","spec-kit"),jr={branch_numbering:"sequential"},Kr=[{from:"templates",to:".specify/templates"},{from:"scripts/bash",to:".specify/scripts/bash"},{from:"commands",to:".claude/commands"},{from:"commands",to:".cursor/commands"}];function vt({appDir:e,vendorDir:t=Nr}){let n=L(e,".specify"),r=L(n,"memory"),i=`prepare spec-kit install for appDir=${e}`;try{for(let{from:s,to:a}of Kr){let c=L(e,a);i=`copy ${s} to ${a}`,Et(St(c),{recursive:!0}),_r(L(t,s),c,{recursive:!0})}i=`write init-options.json under specifyDir=${n}`,Ur(L(n,"init-options.json"),`${JSON.stringify(jr,null,2)}
39
+ `),i=`link .specify/memory/constitution.md in specifyDir=${n}`,Et(r,{recursive:!0}),re({target:"../../AGENTS.md",linkPath:L(r,"constitution.md"),label:".specify/memory/constitution.md"})}catch(s){let a=s instanceof Error?s.message:String(s);throw new Error(`installSpecKit failed while ${i} (appDir=${e}, vendorDir=${t}): ${a}`,{cause:s})}}o(vt,"installSpecKit");var bt=X(Vr(Gr(import.meta.url)),"..","..","_templates");async function Xr(){let e=X(bt,"app","new","prompt.js");return(await import(Br(e).href)).default}o(Xr,"loadPromptDefs");function zr(e,t){return!e||t?null:Hr(e)}o(zr,"resolveDirName");function Wr(e,t,n){if(e)return{cwd:process.cwd(),display:"."};let r=t??n;if(!r)throw new Error("App creation completed without a target directory or name.");return{cwd:X(process.cwd(),r),display:r}}o(Wr,"resolveAppLocation");function qr(e,t,n){let r=` npm install
40
40
  npm run dev`,i="To deploy your app:",s="npx @cognite/cli apps deploy --interactive",a=n?`
41
41
  To start spec-driven development:
42
42
  Run /speckit.specify in Claude Code or Cursor and describe your app.
43
- `:"",p=` # Or fully non-interactive (deploys first target from app.json):
43
+ `:"",c=` # Or fully non-interactive (deploys first target from app.json):
44
44
  npx @cognite/cli apps deploy`;if(e){console.log(`
45
45
  \u2705 App created successfully in current directory!
46
46
 
@@ -49,7 +49,7 @@ ${r}
49
49
  ${a}
50
50
  ${i}
51
51
  ${s}
52
- ${p}
52
+ ${c}
53
53
  `);return}console.log(`
54
54
  \u2705 App created successfully!
55
55
 
@@ -62,9 +62,9 @@ ${a}
62
62
  ${i}
63
63
  cd "${t}"
64
64
  ${s}
65
- ${p}
66
- `)}o(Zn,"printSuccessMessage");async function Xn(e){try{let{execSkillsCli:t,pullAllArgs:n}=await import("../skills-GQ5TZKCM.js");console.log("\u{1F9E0} Pulling skills into your app..."),t(n(),{cwd:e,timeout:3e4,stdio:["pipe","pipe","inherit"]});let r=G(e,".agents","skills"),i=0;try{i=Bn(r).length}catch{console.warn(`Skills directory not found after pull \u2014 no skills may have been installed (expected: ${r})`)}let s=i>0?`${i} skills`:"skills";console.log(`\u2705 Installed ${s} successfully to
67
- ${r}`)}catch(t){let n=t instanceof Error?t.message:String(t);console.warn("\u26A0\uFE0F Could not pull skills:",n)}}o(Xn,"pullSkillsInto");async function er(e,t){let n=e==="."||e==="./",r=Wn(e,n),i=null,s=!1,a={displayName:t.displayName,description:t.description,org:t.org,project:t.project,cluster:t.cluster,baseUrl:t.baseUrl},p=await Jn(),c=W(p),l=n?Xe(process.cwd()):r?Xe(r):null;await Je(c,a,l);let d=Ye({isCurrentDir:n,dirName:r,onAppName:o(u=>{i=u},"onAppName"),onUseSpecKit:o(u=>{s=u},"onUseSpecKit"),presets:a,specKit:t.specKit});await Yn(["app","new"],{templates:et,cwd:process.cwd(),logger:new qn(console.log.bind(console)),createPrompter:d,debug:!!process.env.DEBUG});let m=Qn(n,r,i);Q({target:"AGENTS.md",linkPath:G(m.cwd,"CLAUDE.md"),label:"CLAUDE.md"}),s&&Ze({appDir:m.cwd}),Zn(n,m.display,s),await Xn(m.cwd)}o(er,"handleCreate");function tt(e){return e.command("create").description("Create a new application.").argument("[directory]","Target directory (. for current, or subdirectory name)").option("--display-name <name>","App display name (skips the prompt)").option("--description <description>","App description (skips the prompt)").option("--org <org>","Deployment org (skips the prompt)").option("--project <project>","Deployment project (skips the prompt)").option("--cluster <cluster>","CDF cluster, e.g. greenfield (skips the prompt)").option("--base-url <url>","CDF base URL, e.g. https://greenfield.cognitedata.com (skips the prompt; defaults to cluster-derived URL when omitted)").option("--spec-kit","Install spec-kit slash commands (skips the prompt)").option("--no-spec-kit","Skip spec-kit installation (skips the prompt)").addHelpText("after",`
65
+ ${c}
66
+ `)}o(qr,"printSuccessMessage");async function Qr(e){try{let{execSkillsCli:t,pullAllArgs:n}=await import("../skills-GQ5TZKCM.js");console.log("\u{1F9E0} Pulling skills into your app..."),t(n(),{cwd:e,timeout:3e4,stdio:["pipe","pipe","inherit"]});let r=X(e,".agents","skills"),i=0;try{i=Mr(r).length}catch{console.warn(`Skills directory not found after pull \u2014 no skills may have been installed (expected: ${r})`)}let s=i>0?`${i} skills`:"skills";console.log(`\u2705 Installed ${s} successfully to
67
+ ${r}`)}catch(t){let n=t instanceof Error?t.message:String(t);console.warn("\u26A0\uFE0F Could not pull skills:",n)}}o(Qr,"pullSkillsInto");function Zr(e,t={}){let{isGitInstalled:n=mt,isInsideGitRepo:r=dt,gitInitAndCommit:i=ut}=t;if(!n()){console.warn("git not found \u2014 skipping git repository initialisation");return}if(!r(e)){console.log("Initialising git repository...");try{i(e)}catch(s){let c=(s&&typeof s=="object"&&"stderr"in s&&s.stderr?String(s.stderr).trim():"")||(s instanceof Error?s.message:String(s));console.warn("Could not initialise git repository:",c)}}}o(Zr,"maybeInitGit");async function eo(e,t){let n=e==="."||e==="./",r=zr(e,n),i=null,s=!1,a={displayName:t.displayName,description:t.description,org:t.org,project:t.project,cluster:t.cluster,baseUrl:t.baseUrl},c=await Xr(),p=te(c),l=n?xt(process.cwd()):r?xt(r):null;await wt(p,a,l);let m=Ct({isCurrentDir:n,dirName:r,onAppName:o(u=>{i=u},"onAppName"),onUseSpecKit:o(u=>{s=u},"onUseSpecKit"),presets:a,specKit:t.specKit});await Jr(["app","new"],{templates:bt,cwd:process.cwd(),logger:new Yr(console.log.bind(console)),createPrompter:m,debug:!!process.env.DEBUG});let d=Wr(n,r,i);re({target:"AGENTS.md",linkPath:X(d.cwd,"CLAUDE.md"),label:"CLAUDE.md"}),s&&vt({appDir:d.cwd}),await Qr(d.cwd),Zr(d.cwd),qr(n,d.display,s)}o(eo,"handleCreate");function Pt(e){return e.command("create").description("Create a new application.").argument("[directory]","Target directory (. for current, or subdirectory name)").option("--display-name <name>","App display name (skips the prompt)").option("--description <description>","App description (skips the prompt)").option("--org <org>","Deployment org (skips the prompt)").option("--project <project>","Deployment project (skips the prompt)").option("--cluster <cluster>","CDF cluster, e.g. greenfield (skips the prompt)").option("--base-url <url>","CDF base URL, e.g. https://greenfield.cognitedata.com (skips the prompt; defaults to cluster-derived URL when omitted)").option("--spec-kit","Install spec-kit slash commands (skips the prompt)").option("--no-spec-kit","Skip spec-kit installation (skips the prompt)").addHelpText("after",`
68
68
  Non-interactive use (CI, scripts, AI agents):
69
69
  Pass [directory] plus --display-name, --description, --org, --project, --cluster, --base-url
70
70
  to skip every prompt. Missing flags fall back to the interactive prompt.
@@ -77,14 +77,17 @@ Examples:
77
77
  --display-name "My App" --description "My app" \\
78
78
  --org cog-atlas --project atlas-greenfield --cluster greenfield \\
79
79
  --base-url https://greenfield.cognitedata.com
80
- Fully non-interactive`).action(er)}o(tt,"registerCreateCommand");import{readFile as ar,unlink as pr}from"fs/promises";import{basename as cr}from"path";import rt from"fs";import ir from"path";import F from"fs";import b from"path";import{parseAndValidateManifestConfig as tr}from"@cognite/app-sdk/vite";import{BlobReader as nr,Uint8ArrayWriter as rr,ZipWriter as or}from"@zip.js/zip.js";var ue="package.json",fe="package-lock.json",nt="manifest.json",ge=class ge{constructor(t="dist",n={}){this.distPath=b.isAbsolute(t)?t:b.join(process.cwd(),t),this.appRoot=b.dirname(this.distPath),this.requireLockFile=n.requireLockFile??!1}validateBuildDirectory(){if(!F.existsSync(this.distPath))throw new Error(`Build directory "${this.distPath}" not found. Run build first.`);let t=b.join(this.appRoot,ue);if(!F.existsSync(t))throw new Error(`"${t}" not found. It is required for deployment.`);if(this.requireLockFile){let n=b.join(this.appRoot,fe);if(!F.existsSync(n))throw new Error(`"${n}" not found. It is required for deployment.`)}}async createZip(t="app.zip",n=!1){this.validateBuildDirectory(),console.log("\u{1F4E6} Packaging application...");let r=new or(new rr,{level:9}),i=o(async(c,l)=>{await r.add(l,new nr(await F.openAsBlob(c))),n&&console.log(` \u{1F4C4} ${l}`)},"addFile"),s=o(async c=>{let l=await F.promises.readdir(c,{withFileTypes:!0});for(let d of l){let m=b.join(c,d.name);d.isDirectory()?await s(m):await i(m,b.relative(this.distPath,m).replace(/\\/g,"/"))}},"addDir"),a;try{await s(this.distPath),await i(b.join(this.appRoot,ue),ue);let c=b.join(this.appRoot,nt);if(F.existsSync(c)){let l=F.readFileSync(c,"utf-8");tr(l,c),await i(c,nt)}this.requireLockFile&&await i(b.join(this.appRoot,fe),fe),a=await r.close()}catch(c){let l=c instanceof Error?c.message:String(c);throw new Error(`Failed to create zip: ${l}`)}await F.promises.writeFile(t,a);let p=(a.byteLength/1024/1024).toFixed(2);return console.log(`\u2705 App packaged: ${t} (${p} MB)`),t}};o(ge,"ApplicationPackager");var V=ge;var ye=o(async(e,t,n)=>{let r=await new V(`${n}/dist`,{requireLockFile:!0}).createZip("app.zip",!0);try{let{externalId:i,name:s,description:a,versionTag:p}=t,c=await M(e,n),l=new y(c),d=rt.readFileSync(r),m=ir.basename(r);await l.deploy(i,s,a,p,d,m,e.published)}finally{try{rt.unlinkSync(r)}catch{}}},"deploy");import{execSync as sr}from"child_process";function he(e,t=!0,n={execSync:sr}){console.log("\u{1F4E6} Building app with npm..."),n.execSync("npm run build",{cwd:e,stdio:t?"inherit":"pipe"}),console.log("\u2705 Build successful")}o(he,"buildApp");function ot(e,t){let{org:n,project:r,baseUrl:i}=e,s;try{s=new URL(i).hostname}catch{return null}let{externalId:a,versionTag:p}=t,c=new URLSearchParams({cluster:s,customAppVersion:p,workspace:"industrial-tools"});return`https://${n}.fusion.cognite.com/${r}/flows-apps/app/${encodeURIComponent(a)}?${c}`}o(ot,"generateFusionUrl");function it(e,t,n){let r=n?"\u{1F680} Deploy (Interactive)":"\u{1F680} Deploy",i=n?`${t.project} @ ${t.baseUrl}`:`${t.org}/${t.project}`;console.log(["",r,"=".repeat(r.length),`App: ${e.name} (${e.externalId})`,`Version: ${e.versionTag}`,`Target: ${i}`,""].join(`
81
- `))}o(it,"printDeployInfo");function st(e,t){console.log(`
80
+ Fully non-interactive`).action(eo)}o(Pt,"registerCreateCommand");async function to(e){let t=process.cwd();A(t);let n=C(t);k(n);let r=e.interactive?await P(n,e):S(n.deployments,e.deployment);if(!e.interactive){let l=b(r);if(l.length>0)throw new Error(`Deployment ${r.org}/${r.project} is missing ${l.join(" and ")} in app.json. Use \`npx @cognite/cli@latest apps deactivate --interactive\` for browser-based authentication instead.`)}let i=await x(r,{interactive:e.interactive,appId:n.externalId,orgHint:e.org}),s=new h(i),{externalId:a,versionTag:c}=n,p;try{p=await s.getVersion(a,c)}catch(l){if(l instanceof E){console.log(` ${a} @ ${c} has not been deployed yet \u2014 nothing to deactivate.`);return}throw l}if(p.alias!=="ACTIVE"){console.log(` ${a} @ ${c} is not active (status: ${p.lifecycleState}) \u2014 nothing to deactivate.`);return}await s.deactivateVersion(a,c),console.log(`\u2713 Deactivated ${a} @ ${c} \u2014 active alias removed`)}o(to,"handleDeactivate");function At(e){return e.command("deactivate").description("Deactivate the app by removing its active version from service").argument("[path]","Path to the app folder (only `.` is currently supported)",".").option("-d, --deployment <target>","Deployment target from app.json (index or name)").option("--interactive","Use browser-based authentication instead of env-var credentials",!1).option("--base-url <url>","CDF base URL (only with --interactive)").option("--project <project>","CDF project name (only with --interactive)").option("--org <org>","Organization hint for login (only with --interactive)").addHelpText("after",`
81
+ Examples:
82
+ npx @cognite/cli apps deactivate . Deactivate using env-var auth
83
+ npx @cognite/cli apps deactivate . --interactive Deactivate using browser auth (no secrets needed)`).action((t,n)=>to(n))}o(At,"registerDeactivateCommand");import{readFile as co,unlink as po}from"fs/promises";import{basename as lo}from"path";import Dt from"fs";import so from"path";import R from"fs";import w from"path";import{parseAndValidateManifestConfig as no}from"@cognite/app-sdk/vite";import{BlobReader as ro,Uint8ArrayWriter as oo,ZipWriter as io}from"@zip.js/zip.js";var ve="package.json",xe="package-lock.json",kt="manifest.json",be=".cognite",Pe=class Pe{constructor(t="dist"){this.distPath=w.isAbsolute(t)?t:w.join(process.cwd(),t),this.appRoot=w.dirname(this.distPath)}validateBuildDirectory(){if(!R.existsSync(this.distPath))throw new Error(`Build directory "${this.distPath}" not found. Run build first.`);let t=w.join(this.appRoot,ve);if(!R.existsSync(t))throw new Error(`"${t}" not found. It is required for deployment.`);let n=w.join(this.appRoot,xe);if(!R.existsSync(n))throw new Error(`"${n}" not found. It is required for deployment.`)}async createZip(t="app.zip",n=!1){this.validateBuildDirectory(),console.log("\u{1F4E6} Packaging application...");let r=new io(new oo,{level:9}),i=o(async(p,l)=>{await r.add(l,new ro(await R.openAsBlob(p))),n&&console.log(` \u{1F4C4} ${l}`)},"addFile"),s=o(async p=>{let l=await R.promises.readdir(p,{withFileTypes:!0});for(let m of l){let d=w.join(p,m.name);m.isDirectory()?await s(d):await i(d,w.relative(this.distPath,d).replace(/\\/g,"/"))}},"addDir"),a;try{await s(this.distPath);let p=w.join(this.appRoot,ve);await i(p,w.posix.join(be,ve));let l=w.join(this.appRoot,kt);if(R.existsSync(l)){let d=R.readFileSync(l,"utf-8");no(d,l),await i(l,w.posix.join(be,kt))}let m=w.join(this.appRoot,xe);await i(m,w.posix.join(be,xe)),a=await r.close()}catch(p){let l=p instanceof Error?p.message:String(p);throw new Error(`Failed to create zip: ${l}`)}await R.promises.writeFile(t,a);let c=(a.byteLength/1024/1024).toFixed(2);return console.log(`\u2705 App packaged: ${t} (${c} MB)`),t}};o(Pe,"ApplicationPackager");var N=Pe;var Ae=o(async(e,t,n)=>{let r=await new N(`${n}/dist`).createZip("app.zip",!0);try{let{externalId:i,name:s,description:a,versionTag:c}=t,p=await Y(e,n),l=new h(p),m=Dt.readFileSync(r),d=so.basename(r);await l.deploy(i,s,a,c,m,d,e.published)}finally{try{Dt.unlinkSync(r)}catch{}}},"deploy");import{execSync as ao}from"child_process";function ke(e,t=!0,n={execSync:ao}){console.log("\u{1F4E6} Building app with npm..."),n.execSync("npm run build",{cwd:e,stdio:t?"inherit":"pipe"}),console.log("\u2705 Build successful")}o(ke,"buildApp");function It(e,t){let{org:n,project:r,baseUrl:i}=e,s;try{s=new URL(i).hostname}catch{return null}let{externalId:a,versionTag:c}=t,p=new URLSearchParams({cluster:s,customAppVersion:c,workspace:"industrial-tools"});return`https://${n}.fusion.cognite.com/${r}/flows-apps/app/${encodeURIComponent(a)}?${p}`}o(It,"generateFusionUrl");function Tt(e,t,n){let r=n?"\u{1F680} Deploy (Interactive)":"\u{1F680} Deploy",i=n?`${t.project} @ ${t.baseUrl}`:`${t.org}/${t.project}`;console.log(["",r,"=".repeat(r.length),`App: ${e.name} (${e.externalId})`,`Version: ${e.versionTag}`,`Target: ${i}`,""].join(`
84
+ `))}o(Tt,"printDeployInfo");function $t(e,t){console.log(`
82
85
  \u2705 Successfully deployed ${e.name} version ${e.versionTag} to ${t.org?`${t.org}/`:""}${t.project}`),console.log("\u{1F512} App is deployed in draft mode");let n=e.deployments.length>1?` -d ${t.project}`:"";console.log(`
83
- To publish: npx @cognite/cli apps publish .${n}`),console.log(`To activate: npx @cognite/cli apps activate .${n}`);let r=ot(t,e);r&&console.log(`
86
+ To publish: npx @cognite/cli apps publish .${n}`),console.log(`To activate: npx @cognite/cli apps activate .${n}`);let r=It(t,e);r&&console.log(`
84
87
  \u{1F517} Open your app:
85
- ${r}`)}o(st,"printDeployResult");async function lr(e,t,n,r,i){let s=$(t);if(s.length>0)throw new Error(`Deployment ${t.org}/${t.project} is missing ${s.join(" and ")} in app.json. Use \`cognite apps deploy --interactive\` for browser-based authentication instead.`);it(e,t,!1),r.skipBuild||he(n),console.log(`
86
- \u{1F4E4} Deploying to ${t.org}/${t.project}...`),await i({...t,published:!1},{externalId:e.externalId,name:e.name,description:e.description,versionTag:e.versionTag},n),st(e,t)}o(lr,"handleDeployNonInteractive");async function dr(e,t,n,r){it(e,t,!0),r.skipBuild||he(n);let i=await D(t,{interactive:!0,appId:e.externalId,orgHint:r.org});console.log(`
87
- \u{1F4E4} Deploying to ${t.project}...`);let s=await new V(`${n}/dist`).createZip("app.zip",!0);try{let a=await ar(s);await new y(i).deploy(e.externalId,e.name,e.description,e.versionTag,a,cr(s),!1),st(e,t)}finally{await pr(s).catch(()=>{})}}o(dr,"handleDeployInteractive");async function mr(e,t=process.cwd(),n={}){let{loadEnvFile:r=I,loadAppConfig:i=C,deploy:s=ye}=n;r(t);let a=i(t);if(U(a),e.interactive){let c=await O(a,e);await dr(a,c,t,e);return}let p=S(a.deployments,e.deployment);await lr(a,p,t,e,s)}o(mr,"handleDeploy");function at(e){return e.command("deploy").description("Deploy your app to Cognite Data Fusion. Use --interactive for browser-based login (no env-var secrets required).").option("-d, --deployment <target>","Deployment target (index or project name)").option("--skip-build","Skip the build step",!1).option("--interactive","Use browser-based authentication instead of env-var credentials",!1).option("--base-url <url>","CDF base URL (only with --interactive)").option("--project <project>","CDF project name (only with --interactive)").option("--org <org>","Organization hint for login (only with --interactive)").addHelpText("after",`
88
+ ${r}`)}o($t,"printDeployResult");async function mo(e,t,n,r,i){let s=b(t);if(s.length>0)throw new Error(`Deployment ${t.org}/${t.project} is missing ${s.join(" and ")} in app.json. Use \`cognite apps deploy --interactive\` for browser-based authentication instead.`);Tt(e,t,!1),r.skipBuild||ke(n),console.log(`
89
+ \u{1F4E4} Deploying to ${t.org}/${t.project}...`),await i({...t,published:!1},{externalId:e.externalId,name:e.name,description:e.description,versionTag:e.versionTag},n),$t(e,t)}o(mo,"handleDeployNonInteractive");async function uo(e,t,n,r){Tt(e,t,!0),r.skipBuild||ke(n);let i=await x(t,{interactive:!0,appId:e.externalId,orgHint:r.org});console.log(`
90
+ \u{1F4E4} Deploying to ${t.project}...`);let s=await new N(`${n}/dist`).createZip("app.zip",!0);try{let a=await co(s);await new h(i).deploy(e.externalId,e.name,e.description,e.versionTag,a,lo(s),!1),$t(e,t)}finally{await po(s).catch(()=>{})}}o(uo,"handleDeployInteractive");async function go(e,t=process.cwd(),n={}){let{loadEnvFile:r=A,loadAppConfig:i=C,deploy:s=Ae}=n;r(t);let a=i(t);if(k(a),e.interactive){let p=await P(a,e);await uo(a,p,t,e);return}let c=S(a.deployments,e.deployment);await mo(a,c,t,e,s)}o(go,"handleDeploy");function Ft(e){return e.command("deploy").description("Deploy your app to Cognite Data Fusion. Use --interactive for browser-based login (no env-var secrets required).").option("-d, --deployment <target>","Deployment target (index or project name)").option("--skip-build","Skip the build step",!1).option("--interactive","Use browser-based authentication instead of env-var credentials",!1).option("--base-url <url>","CDF base URL (only with --interactive)").option("--project <project>","CDF project name (only with --interactive)").option("--org <org>","Organization hint for login (only with --interactive)").addHelpText("after",`
88
91
  Environment (non-interactive):
89
92
  deployClientId and deploySecretName are configured per deployment in app.json.
90
93
  deploySecretName is the name of the environment variable that holds the client
@@ -98,19 +101,42 @@ Examples:
98
101
  npx @cognite/cli apps deploy -d my-project Deploy to project by name
99
102
  npx @cognite/cli apps deploy --skip-build Deploy without rebuilding
100
103
  npx @cognite/cli apps deploy --interactive Browser auth, prompts for target
101
- npx @cognite/cli apps deploy --interactive -d 0 Browser auth, target chosen non-interactively`).action(t=>mr(t))}o(at,"registerDeployCommand");async function ur(e){let t=process.cwd();I(t);let n=C(t);U(n);let r=e.interactive?await O(n,e):S(n.deployments,e.deployment);if(!e.interactive){let l=$(r);if(l.length>0)throw new Error(`Deployment ${r.org}/${r.project} is missing ${l.join(" and ")} in app.json. Use \`cognite apps publish --interactive\` for browser-based authentication instead.`)}let i=await D(r,{interactive:e.interactive,appId:n.externalId,orgHint:e.org}),s=new y(i),{externalId:a,versionTag:p}=n,c;try{c=await s.getVersion(a,p)}catch(l){throw l instanceof w?new Error(`Version ${p} of ${a} has not been deployed yet. Run \`npx @cognite/cli apps deploy\` first.`):l}if(c.alias==="ACTIVE"){console.log(` ${a} @ ${p} is already ACTIVE \u2014 nothing to do.`);return}if(c.lifecycleState==="PUBLISHED"){console.log(` ${a} @ ${p} is already PUBLISHED \u2014 nothing to do.`);return}if(c.lifecycleState==="DEPRECATED"||c.lifecycleState==="ARCHIVED")throw new Error(`Cannot publish ${a} @ ${p}: version is ${c.lifecycleState} (terminal).`);await s.publishVersion(a,p),console.log(`\u2713 Published ${a} @ ${p} is now PUBLISHED`),console.log(""),console.log("Run `npx @cognite/cli apps activate .` to make it active.")}o(ur,"handlePublish");function pt(e){return e.command("publish").description("Publish the current app version (transition DRAFT \u2192 PUBLISHED)").argument("[path]","Path to the app folder (only `.` is currently supported)",".").option("-d, --deployment <target>","Deployment target from app.json (index or name)").option("--interactive","Use browser-based authentication instead of env-var credentials",!1).option("--base-url <url>","CDF base URL (only with --interactive)").option("--project <project>","CDF project name (only with --interactive)").option("--org <org>","Organization hint for login (only with --interactive)").addHelpText("after",`
104
+ npx @cognite/cli apps deploy --interactive -d 0 Browser auth, target chosen non-interactively`).action(t=>go(t))}o(Ft,"registerDeployCommand");async function fo(e){let t=process.cwd();A(t);let n=C(t);k(n);let r=e.interactive?await P(n,e):S(n.deployments,e.deployment);if(!e.interactive){let l=b(r);if(l.length>0)throw new Error(`Deployment ${r.org}/${r.project} is missing ${l.join(" and ")} in app.json. Use \`cognite apps publish --interactive\` for browser-based authentication instead.`)}let i=await x(r,{interactive:e.interactive,appId:n.externalId,orgHint:e.org}),s=new h(i),{externalId:a,versionTag:c}=n,p;try{p=await s.getVersion(a,c)}catch(l){throw l instanceof E?new Error(`Version ${c} of ${a} has not been deployed yet. Run \`npx @cognite/cli apps deploy\` first.`):l}if(p.alias==="ACTIVE"){console.log(` ${a} @ ${c} is already ACTIVE \u2014 nothing to do.`);return}if(p.lifecycleState==="PUBLISHED"){console.log(` ${a} @ ${c} is already PUBLISHED \u2014 nothing to do.`);return}if(p.lifecycleState==="DEPRECATED"||p.lifecycleState==="ARCHIVED")throw new Error(`Cannot publish ${a} @ ${c}: version is ${p.lifecycleState} (terminal).`);await s.publishVersion(a,c),console.log(`\u2713 Published ${a} @ ${c} is now PUBLISHED`),console.log(""),console.log("Run `npx @cognite/cli apps activate .` to make it active.")}o(fo,"handlePublish");function Ot(e){return e.command("publish").description("Publish the current app version (transition DRAFT \u2192 PUBLISHED)").argument("[path]","Path to the app folder (only `.` is currently supported)",".").option("-d, --deployment <target>","Deployment target from app.json (index or name)").option("--interactive","Use browser-based authentication instead of env-var credentials",!1).option("--base-url <url>","CDF base URL (only with --interactive)").option("--project <project>","CDF project name (only with --interactive)").option("--org <org>","Organization hint for login (only with --interactive)").addHelpText("after",`
102
105
  Examples:
103
106
  npx @cognite/cli apps publish . Publish using env-var auth
104
- npx @cognite/cli apps publish . --interactive Publish using browser auth (no secrets needed)`).action((t,n)=>ur(n))}o(pt,"registerPublishCommand");function fr(e){return e.alias==="ACTIVE"?"ACTIVE":e.lifecycleState}o(fr,"describeStatus");async function gr(e){let t=process.cwd();I(t);let n=C(t);U(n);let r=e.interactive?await O(n,e):S(n.deployments,e.deployment);if(!e.interactive){let a=$(r);if(a.length>0)throw new Error(`Deployment ${r.org}/${r.project} is missing ${a.join(" and ")} in app.json. Use \`cognite apps status --interactive\` for browser-based authentication instead.`)}let i=await D(r,{interactive:e.interactive,appId:n.externalId,orgHint:e.org}),s=new y(i);console.log(""),console.log(`App: ${n.name} (${n.externalId})`),console.log(`Version: ${n.versionTag} (local)`);try{let a=await s.getVersion(n.externalId,n.versionTag),p=fr(a);console.log(`Status: ${p}`),a.lifecycleState==="DRAFT"&&(console.log(""),console.log("Run `npx @cognite/cli apps publish .` to publish this version."))}catch(a){if(a instanceof w){console.log("Status: not deployed yet"),console.log(""),console.log("Run `npx @cognite/cli apps deploy` to upload this version.");return}throw a}}o(gr,"handleStatus");function ct(e){return e.command("status").description("Show the deployment status of the current app version").argument("[path]","Path to the app folder (only `.` is currently supported)",".").option("-d, --deployment <target>","Deployment target from app.json (index or name)").option("--interactive","Use browser-based authentication instead of env-var credentials",!1).option("--base-url <url>","CDF base URL (only with --interactive)").option("--project <project>","CDF project name (only with --interactive)").option("--org <org>","Organization hint for login (only with --interactive)").addHelpText("after",`
107
+ npx @cognite/cli apps publish . --interactive Publish using browser auth (no secrets needed)`).action((t,n)=>fo(n))}o(Ot,"registerPublishCommand");function yo(e){return e.alias==="ACTIVE"?"ACTIVE":e.lifecycleState}o(yo,"describeStatus");async function ho(e){let t=process.cwd();A(t);let n=C(t);k(n);let r=e.interactive?await P(n,e):S(n.deployments,e.deployment);if(!e.interactive){let a=b(r);if(a.length>0)throw new Error(`Deployment ${r.org}/${r.project} is missing ${a.join(" and ")} in app.json. Use \`cognite apps status --interactive\` for browser-based authentication instead.`)}let i=await x(r,{interactive:e.interactive,appId:n.externalId,orgHint:e.org}),s=new h(i);console.log(""),console.log(`App: ${n.name} (${n.externalId})`),console.log(`Version: ${n.versionTag} (local)`);try{let a=await s.getVersion(n.externalId,n.versionTag),c=yo(a);console.log(`Status: ${c}`),a.lifecycleState==="DRAFT"&&(console.log(""),console.log("Run `npx @cognite/cli apps publish .` to publish this version."))}catch(a){if(a instanceof E){console.log("Status: not deployed yet"),console.log(""),console.log("Run `npx @cognite/cli apps deploy` to upload this version.");return}throw a}}o(ho,"handleStatus");function Rt(e){return e.command("status").description("Show the deployment status of the current app version").argument("[path]","Path to the app folder (only `.` is currently supported)",".").option("-d, --deployment <target>","Deployment target from app.json (index or name)").option("--interactive","Use browser-based authentication instead of env-var credentials",!1).option("--base-url <url>","CDF base URL (only with --interactive)").option("--project <project>","CDF project name (only with --interactive)").option("--org <org>","Organization hint for login (only with --interactive)").addHelpText("after",`
105
108
  Examples:
106
109
  npx @cognite/cli apps status . Status using env-var auth
107
- npx @cognite/cli apps status . --interactive Status using browser auth (no secrets needed)`).action((t,n)=>gr(n))}o(ct,"registerStatusCommand");function lt(e){let t=e.command("apps").description("Manage Fusion Custom Apps \u2014 create, deploy, and manage version lifecycle");return tt(t),at(t),ct(t),pt(t),Me(t),Se(t),t}o(lt,"registerAppsCommand");var dt=1e3,yr=new Set(["baseUrl","url","project","deployment","source","path","name","displayName","description"]);function hr(e){return Object.fromEntries(Object.entries(e).map(([t,n])=>typeof n=="boolean"?[t,n]:yr.has(t)?[t,n]:[t,"[REDACTED]"]))}o(hr,"sanitize");function Cr(e){let t=[],n=e;for(;n;)n.parent&&t.unshift(n.name()),n=n.parent;return t.join(" ")}o(Cr,"getCommandPath");function mt(e){try{let t=e(process.cwd());return{appExternalId:t.externalId,appVersionTag:t.versionTag}}catch{return{}}}o(mt,"tryLoadAppConfig");function Ce(e){return e.filter(t=>!t.startsWith("-")).join(" ")||"unknown"}o(Ce,"commandFromArgv");function ut(e,t,n=C){e.hook("postAction",async(r,i)=>{try{let s={command:Cr(i),options:hr(i.opts()),success:!0,...mt(n)};t.track("Flows.CLI.Command",s),await t.flush(dt)}catch{}})}o(ut,"instrument");async function ft(e,t,n=C){try{let r={command:Ce(t),options:{},success:!1,...mt(n)};e.track("Flows.CLI.Command",r),await e.flush(dt)}catch{}}o(ft,"trackFailure");var wr="ERR_USE_AFTER_CLOSE";function yt(e){return e instanceof Error&&"code"in e&&e.code===wr}o(yt,"isReadlineClosedError");function vr(e){let t=Object.getPrototypeOf(e);return t===Object.prototype||t===null}o(vr,"isPlainObject");function we(e){return e==null||yt(e)?!0:e instanceof Error?!1:!!(typeof e=="object"&&e!==null&&vr(e)&&Object.keys(e).length===0)}o(we,"isPromptCancel");var gt=!1;function ht(){gt||(gt=!0,process.on("uncaughtException",e=>{yt(e)&&(console.error(`
108
- Cancelled.`),process.exit(130)),console.error(e),process.exit(1)}),process.on("unhandledRejection",e=>{we(e)&&(console.error(`
109
- Cancelled.`),process.exit(130)),console.error(e),process.exit(1)}))}o(ht,"installCancelHandler");import Ct from"mixpanel";var br="5c4d853e7c3b77b1eb4468d5329b278c",z="cognite-cli",Er=2e3,wt={env:process.env,init:Ct.init.bind(Ct)},Ar={track:o(()=>{},"track"),flush:o(async()=>{},"flush")};function ve(e=process.env){return e.COGNITE_TELEMETRY_DISABLED==="1"||e.DO_NOT_TRACK==="1"}o(ve,"isTelemetryDisabled");function Sr(e){return e.COGNITE_TELEMETRY_DEBUG==="1"}o(Sr,"isDebug");function vt(e={}){let t=e.env??wt.env,n=e.init??wt.init,r=e.packageName,i=e.cliVersion,s=Sr(t);if(ve(t))return s&&process.stderr.write(`[telemetry] disabled \u2014 noop tracker
110
- `),Ar;let a,p=new Set;function c(){if(a)return a;try{return a=n(br,{geolocate:!1,keepAlive:!1}),a}catch{return}}return o(c,"getClient"),{track(l,d={}){let m=c();if(!m)return;let u={...d,applicationId:z,...r&&{packageName:r},...i&&{cliVersion:i},nodeVersion:process.version,platform:process.platform};s&&process.stderr.write(`[telemetry] track ${l} ${JSON.stringify(u)}
111
- `);let h=o(()=>{},"finish"),f=new Promise(k=>{h=k});p.add(f);try{m.track(l,u,h)}catch{h()}f.finally(()=>p.delete(f))},async flush(l=Er){if(p.size===0)return;let d,m=new Promise(u=>{d=setTimeout(u,l),d.unref?.()});try{await Promise.race([Promise.allSettled([...p]),m])}finally{d&&clearTimeout(d)}s&&process.stderr.write(`[telemetry] flush done (${p.size} still pending)
112
- `)}}}o(vt,"createTelemetry");var kr=1e3,xr="https://0a118cb02e3be57b1838bcfb5783a2bf@o4508040730968064.ingest.de.sentry.io/4510719268290640",Pr={captureError:o(async()=>{},"captureError"),flush:o(async()=>{},"flush")};function Tr(e){return e.packageName&&e.cliVersion?`${e.packageName}@${e.cliVersion}`:e.cliVersion??"unknown"}o(Tr,"buildRelease");var Dr="192.0.2.0";function Ir(e){let t={...e.user,email:void 0,username:void 0,ip_address:Dr,id:void 0};return{...e,user:t,server_name:void 0}}o(Ir,"scrubPii");function bt(e={}){let t=e.env??process.env;if(ve(t))return Pr;let n=Tr(e),r="production",i=null,s=null;function a(){return{dsn:xr,release:n,environment:r,defaultIntegrations:!1,integrations:[],sendDefaultPii:!1,enableLogs:!1,initialScope:{tags:{component:"cli",applicationId:z},contexts:{cli:{applicationId:z,node:process.version,platform:process.platform}}},beforeSend:Ir}}o(a,"buildInitOptions");async function p(){return i||(s||(s=(async()=>{try{let c=e.sdk??await import("@sentry/node");return c.init(a()),i=c,c}catch{return null}})()),s)}return o(p,"ensureSdk"),{async captureError(c,l){try{let d=await p();if(!d)return;let m={level:"fatal"};l?.command&&(m.tags={command:l.command},m.contexts={cli:{applicationId:z,node:process.version,platform:process.platform,command:l.command}}),d.captureException(c,m)}catch{}},async flush(c=kr){try{if(!i)return;await i.flush(c)}catch{}}}}o(bt,"createErrorReporter");import{mkdirSync as $r,readFileSync as Or,writeFileSync as Ur}from"fs";import{homedir as Fr}from"os";import{resolve as Z}from"path";import{debuglog as jr}from"util";import{lt as Rr,parse as Et}from"semver";var Lr="https://registry.npmjs.org/@cognite/cli/latest",Vr=1500,At="upgrade-check.json",St=Z(process.env.XDG_CACHE_HOME||Z(Fr(),".cache"),"@cognite","cli"),be=jr("cognite-dune");function _r(e,t){return!e||!t||!Et(e)||!Et(t)?!1:Rr(e,t)}o(_r,"isOutdated");async function Nr({timeout:e=Vr,registryUrl:t=Lr,fetchImpl:n=globalThis.fetch}={}){if(typeof n!="function")return null;try{let r=await n(t,{signal:AbortSignal.timeout(e)});if(!r?.ok)return null;let i=await r.json();return typeof i?.version=="string"?i.version:null}catch(r){return be("fetchLatestVersion failed (%s): %O",t,r),null}}o(Nr,"fetchLatestVersion");function Hr(e=St,t=864e5){try{let n=Or(Z(e,At),"utf-8"),r=JSON.parse(n);return typeof r.latest!="string"||typeof r.fetchedAt!="number"||Date.now()-r.fetchedAt>t?null:{latest:r.latest,fetchedAt:r.fetchedAt}}catch(n){return be("readUpgradeCheckCache failed (%s): %O",e,n),null}}o(Hr,"readUpgradeCheckCache");function Br(e,t){try{$r(e,{recursive:!0});let n={latest:t,fetchedAt:Date.now()};Ur(Z(e,At),JSON.stringify(n))}catch(n){be("writeUpgradeCheckCache failed (%s): %O",e,n)}}o(Br,"writeUpgradeCheckCache");async function Mr({cacheDir:e=St,...t}={}){let n=await Nr(t);n&&Br(e,n)}o(Mr,"startBackgroundUpgradeCheck");function kt(e,{onOutdated:t,cacheDir:n,...r}={}){let i=Hr(n);if(i){_r(e,i.latest)&&t?.(e,i.latest);return}Mr({cacheDir:n,...r})}o(kt,"preActionUpgradeCheck");import{default as ua,chalkStderr as xt}from"chalk";function Pt(e,t){let n=[`\u26A0 Update available: ${e} -> ${t}`," Run npx @cognite/cli@latest"],r=Math.max(...n.map(p=>[...p].length))+2,i="\u2500".repeat(r),s=o(p=>`\u2502 ${p}${" ".repeat(r-1-[...p].length)}\u2502`,"pad"),a=[`\u250C${i}\u2510`,...n.map(s),`\u2514${i}\u2518`].join(`
113
- `);return xt.bold.yellow(a)}o(Pt,"formatUpgradeWarning");function zr(e){return e instanceof Error&&"code"in e&&typeof e.code=="string"&&e.code==="DEP0040"}o(zr,"isDep0040Warning");var Ae=process,qr=Ae.emit.bind(Ae);Ae.emit=function(e,...t){return e==="warning"&&zr(t[0])?!1:qr(e,...t)};ht();var q=new Gr;q.name("cognite").description("Build and deploy React apps to Cognite Data Fusion").version("1.0.0").showHelpAfterError().configureOutput({writeOut:o(e=>Kr(1,e),"writeOut")});q.hook("preAction",()=>{kt("1.0.0",{onOutdated:o((e,t)=>{console.warn(`
114
- ${Pt(e,t)}
115
- `)},"onOutdated")})});lt(q);var Dt=vt({packageName:"@cognite/cli",cliVersion:"1.0.0"}),Tt=bt({packageName:"@cognite/cli",cliVersion:"1.0.0"});ut(q,Dt);var Ee=process.argv.slice(2);q.parseAsync(Ee,{from:"user"}).catch(async e=>{await ft(Dt,Ee),we(e)&&(console.error(`
116
- Cancelled.`),process.exit(130)),await Tt.captureError(e,{command:Ce(Ee)}),await Tt.flush(),console.error(e instanceof Error?`\u274C ${e.message}`:e),process.exit(1)});
110
+ npx @cognite/cli apps status . --interactive Status using browser auth (no secrets needed)`).action((t,n)=>ho(n))}o(Rt,"registerStatusCommand");function _t(e){let t=e.command("apps").description("Manage Fusion Custom Apps \u2014 create, deploy, and manage version lifecycle");return Pt(t),Ft(t),Rt(t),Ot(t),pt(t),At(t),Ge(t),t}o(_t,"registerAppsCommand");import{existsSync as li,mkdirSync as mi,writeFileSync as di}from"fs";import{dirname as Ue,join as Le}from"path";import{execFile as wo}from"child_process";import{promisify as Eo}from"util";import{platform as Co}from"os";function j(e={}){let{platform:t=Co}=e;return t()==="darwin"}o(j,"isMacOS");var Ut="cognite-flows",So=Eo(wo),Lt=o((e,t)=>So(e,t),"defaultExecFile"),vo=-25300,xo=vo&255;function bo(e){if(!(e instanceof Error)||!("code"in e)||e.code!==xo)return!1;let t="stderr"in e?String(e.stderr):"";return/could not be found/i.test(t)||t===""}o(bo,"isKeychainNotFoundError");async function Nt(e,t,n={}){if(!j(n))throw new Error("Keychain storage is only supported on macOS");let{execFile:r=Lt}=n;await r("security",["add-generic-password","-a",e,"-s",Ut,"-w",Buffer.from(t,"utf-8").toString("base64"),"-U"])}o(Nt,"storeKeyInKeychain");async function jt(e,t={}){if(!j(t))return null;let{execFile:n=Lt}=t;try{let{stdout:r}=await n("security",["find-generic-password","-a",e,"-s",Ut,"-w"]);return Buffer.from(r.trim(),"base64").toString("utf-8")}catch(r){if(bo(r))return null;throw r}}o(jt,"readKeyFromKeychain");import{pbkdf2 as ko,randomBytes as Do}from"crypto";import{promisify as Io}from"util";import{CompactEncrypt as To,base64url as $o,compactDecrypt as Ep}from"jose";var Po=new TextEncoder,Ao=new TextDecoder,Kt={encode:o(e=>Po.encode(e),"encode"),decode:o(e=>Ao.decode(e),"decode")};var Fo=Io(ko),De=6e5,Oo="sha512",Ro="PBKDF2-HMAC-SHA512",_o=16,Uo="A256GCM",Lo=32,Mt=2e6;async function No(e,t,n){return await Fo(e,t,n,Lo,Oo)}o(No,"deriveKey");async function Vt(e,t,n=De){if(!Number.isInteger(n)||n<1||n>Mt)throw new Error(`Invalid iterations: must be an integer between 1 and ${Mt}`);let r=Do(_o),i=await No(t,r,n);return await new To(Kt.encode(e)).setProtectedHeader({alg:"dir",enc:Uo,kdf:Ro,kdf_iter:n,kdf_salt:$o.encode(r)}).encrypt(i)}o(Vt,"encryptStringAsJwe");import{calculateJwkThumbprint as jo,exportJWK as Ko,exportPKCS8 as Mo,exportSPKI as Vo,generateKeyPair as Ho}from"jose";async function Ht(){let{publicKey:e,privateKey:t}=await Ho("EdDSA",{extractable:!0}),n=await Mo(t),r=await Vo(e),i=await Ko(e),s=await jo(i);return{privateKeyPem:n,publicKeyPem:r,kid:s}}o(Ht,"generateSigningKeyPair");import{existsSync as Bo,readdirSync as Yo,readFileSync as Jo}from"fs";import{join as oe}from"path";import{homedir as Go}from"os";import{join as Gt}from"path";function K(e={}){let{env:t=process.env,homedir:n=Go}=e,r=t.DUNE_HOME?.trim()||Gt(n(),".dune");return{home:r,keysDir:Gt(r,"keys")}}o(K,"getConfig");var ie=".pub.pem",Ie=".key.jwe",Xo=".pem",Te=".meta.json";function Bt(e){switch(e.kind){case"keychain":return"Keychain";case"encrypted-file":return e.path;case"legacy-unencrypted-file":return`${e.path} (unencrypted \u2014 rotate)`;case"public-only":return"public-only (private key missing)"}}o(Bt,"formatLocalKeySource");function zo(e){return{existsSync:e.existsSync??Bo,readdirSync:e.readdirSync??Yo,readFileSync:e.readFileSync??((t,n)=>Jo(t,n)),isMacOS:e.isMacOS??(()=>j()),readKeyFromKeychain:e.readKeyFromKeychain??(t=>jt(t))}}o(zo,"resolveDeps");function Wo(e){try{let t=JSON.parse(e);if(typeof t=="object"&&t!==null&&!Array.isArray(t)&&"email"in t&&typeof t.email=="string")return t.email}catch{}}o(Wo,"readEmailFromMeta");function qo(e,t){return t.existsSync(e)?t.readdirSync(e).filter(n=>n.endsWith(ie)):[]}o(qo,"publicKeyEntries");function Qo(e){return e.slice(0,-ie.length)}o(Qo,"kidFromPublicKeyFilename");async function Zo(e,t,n){if(n.isMacOS()&&await n.readKeyFromKeychain(e).catch(()=>null)!==null)return{kind:"keychain"};let r=oe(t,`${e}${Ie}`);if(n.existsSync(r))return{kind:"encrypted-file",path:r};let i=oe(t,`${e}${Xo}`);return n.existsSync(i)?{kind:"legacy-unencrypted-file",path:i}:{kind:"public-only"}}o(Zo,"resolveSource");async function Yt(e=K().keysDir,t={}){let n=zo(t),r=new Set,i=qo(e,n).flatMap(s=>{let a=Qo(s);return!a||r.has(a)?[]:(r.add(a),[{kid:a,entry:s}])});return Promise.all(i.map(async({kid:s,entry:a})=>{let c=await Zo(s,e,n),p=oe(e,`${s}${Te}`),l;try{l=Wo(n.readFileSync(p,"utf8"))}catch{}return{kid:s,source:c,publicKeyPath:oe(e,a),email:l}}))}o(Yt,"discoverLocalKeys");function Jt(e,t){let n=e.getUTCFullYear(),r=e.getUTCMonth()+t,i=new Date(Date.UTC(n,r+1,0)).getUTCDate(),s=Math.min(e.getUTCDate(),i);return new Date(Date.UTC(n,r,s))}o(Jt,"addMonthsClamped");function $e(e){return e.toISOString().slice(0,10)}o($e,"formatIsoDate");function Xt(e=new Date){return $e(e)}o(Xt,"todayIso");import ei,{Chalk as ti}from"chalk";var Fe=new ti({level:0});function zt(e){return e.isTTY?ei:Fe}o(zt,"chalkForStream");function ni(e){return e.replace(/-----BEGIN [^-]+-----/g,"").replace(/-----END [^-]+-----/g,"").replace(/\s+/g,"")}o(ni,"pemBodyOneLine");function Wt(e,t=Fe,n=new Date){let r=e.issuedAt??Xt(n),i=ni(e.publicKeyPem),s=" ",a=o((p,l)=>`${s}${t.cyan(p)}${t.dim(":")} ${l}
111
+ `,"kv"),c="";return c+=`
112
+ ${t.bold("Add this entry to")} ${t.magenta("services/app-hosting/config/signing-keys.yaml")} ${t.bold("under")} ${t.cyan("public_keys:")}
113
+
114
+ `,c+=`${t.dim("-")} ${t.cyan("kid")}${t.dim(":")} ${t.green(e.kid)}
115
+ `,c+=a("public_key",t.green(i)),c+=a("email",t.yellow(e.email)),c+=a("capabilities",`${t.dim("[")}${t.yellow("developer")}${t.dim("]")}`),c+=a("issued_at",t.green(r)),c+=a("expires",t.green(e.expires)),c+=a("revoked_at",t.dim("null")),c}o(Wt,"renderRegistryEntry");import{email as ri,pipe as oi,safeParse as ii,string as si}from"valibot";var ai=oi(si(),ri());function W(e,t="email"){let n=e.trim();if(!n)throw new Error(`${t} is required`);if(!ii(ai,n).success)throw new Error(`${t} must look like an email (user@example.com); got "${e}"`);return n}o(W,"parseEmail");function q(e,t="--expires"){let n=Number(e);if(!Number.isInteger(n)||n<1||n>12)throw new Error(`${t} must be an integer between 1 and 12 (months); got "${e}"`);return n}o(q,"parseExpiryMonths");import pi from"enquirer";var se=3,qt=`Key expiry in months (${1}-${12})`,Qt="Email address for the registry entry",Zt=`Passphrase for the encrypted private key (min ${15} chars)`,en="Confirm passphrase",tn=o(()=>`Passphrase must be at least ${15} characters`,"passphraseTooShortMsg"),nn=o(e=>`Passphrases do not match (attempt ${e}/${se}).
116
+ `,"passphraseMismatchMsg"),rn=`Passphrase confirmation failed after ${se} attempts`;async function _e(e){return pi.prompt(e)}o(_e,"defaultPrompt");function on(e){return t=>{try{return e(t),!0}catch(n){return n instanceof Error?n.message:"Invalid"}}}o(on,"parserAsValidator");async function sn(e={}){let{prompt:t=_e}=e,{months:n}=await t({type:"input",name:"months",message:qt,initial:String(6),validate:on(r=>q(r,"expiry"))});return q(n,"expiry")}o(sn,"promptExpiryMonths");async function an(e={}){let{prompt:t=_e,gitUserEmail:n=gt}=e,{email:r}=await t({type:"input",name:"email",message:Qt,initial:n(),validate:on(i=>W(i,"email"))});return W(r,"email")}o(an,"promptEmail");async function cn(e={}){let{prompt:t=_e,stderr:n=process.stderr}=e;for(let r=1;r<=se;r+=1){let{passphrase:i}=await t({type:"password",name:"passphrase",message:Zt,validate:o(a=>a.length>=15?!0:tn(),"validate")}),{confirm:s}=await t({type:"password",name:"confirm",message:en});if(i===s)return i;n.write(nn(r))}throw new Error(rn)}o(cn,"promptPassphrase");function ui(e){return{writeFileSync:e.writeFileSync??di,mkdirSync:e.mkdirSync??mi,existsSync:e.existsSync??li,generateSigningKeyPair:e.generateSigningKeyPair??Ht,encryptStringAsJwe:e.encryptStringAsJwe??Vt,storeKeyInKeychain:e.storeKeyInKeychain??Nt,isMacOS:e.isMacOS??j,promptExpiryMonths:e.promptExpiryMonths??sn,promptEmail:e.promptEmail??an,promptPassphrase:e.promptPassphrase??cn,discoverLocalKeys:e.discoverLocalKeys??(()=>Yt())}}o(ui,"resolveDeps");function ln(e,t={}){let n=ui(t),r=e.command("keys").description("Manage code signing keys");r.command("generate").description("Generate an Ed25519 keypair for code signing").option("-o, --output <path>","Encrypted private key output path (forces file storage even on macOS)").option("--no-keychain","Skip macOS Keychain and write a passphrase-encrypted private key under ~/.dune/keys/ instead").option("-e, --expires <months>",`Validity in months (${1}-${12}); skips the interactive prompt`).option("--email <address>","Email address for the registry entry; skips the interactive prompt").action(i=>yi(i,n)),r.command("list").description("List local signing identities and their storage location").action(()=>gi(n))}o(ln,"registerKeysCommand");async function gi(e){let t=await e.discoverLocalKeys();if(t.length===0){process.stdout.write(`No signing identities found.
117
+ `),process.stdout.write(`Run \`cognite keys generate\` to create one (storage: ${K().keysDir}).
118
+ `);return}let n=["KID","SOURCE","EMAIL"],r=t.map(a=>[a.kid,Bt(a.source),a.email??"\u2014"]),i=n.map((a,c)=>Math.max(a.length,...r.map(p=>p[c].length))),s=o(a=>a.map((c,p)=>c.padEnd(i[p])).join(" ").trimEnd(),"fmt");process.stdout.write(`${s(n)}
119
+ `);for(let a of r)process.stdout.write(`${s(a)}
120
+ `)}o(gi,"handleList");function pn(e,t,n){let r=Le(K().keysDir,`${e}${ie}`);return n.mkdirSync(Ue(r),{recursive:!0}),n.writeFileSync(r,t),r}o(pn,"writePublicKey");async function fi(e,t,n,r,i){let s=r??Le(K().keysDir,`${e}${Ie}`);if(i.mkdirSync(Ue(s),{recursive:!0}),i.existsSync(s))throw new Error(`Refusing to overwrite existing key at ${s}. Delete it first if you really want to regenerate: rm ${s}`);let a=await i.encryptStringAsJwe(t,n);return i.writeFileSync(s,a,{mode:384}),s}o(fi,"writeEncryptedPrivateKey");async function yi(e,t,n=new Date){let r=e.keychain!==!1&&t.isMacOS()&&!e.output,i=e.expires!==void 0?q(e.expires):await t.promptExpiryMonths(),s=$e(Jt(n,i)),a=e.email!==void 0?W(e.email,"--email"):await t.promptEmail(),c=r?null:await t.promptPassphrase();process.stderr.write(`
121
+ Generating Ed25519 keypair...
122
+
123
+ `);let{privateKeyPem:p,publicKeyPem:l,kid:m}=await t.generateSigningKeyPair();if(r){await t.storeKeyInKeychain(m,p);let f=pn(m,l,t);process.stderr.write(`Public key: ${f}
124
+ `),process.stderr.write(`Private key: macOS Keychain (service: cognite-dune, account: ${m})
125
+ `)}else{if(c===null)throw new Error("passphrase is required when not using Keychain");let f=await fi(m,p,c,e.output,t),g=pn(m,l,t);process.stderr.write(`Public key: ${g}
126
+ `),process.stderr.write(`Private key: ${f} (JWE, AES-256-GCM, PBKDF2-SHA512 x${De.toLocaleString()})
127
+ `),t.isMacOS()||process.stderr.write(` (macOS Keychain integration is the default on darwin; on this OS we use the file.)
128
+ `)}let d=Le(K().keysDir,`${m}${Te}`);t.mkdirSync(Ue(d),{recursive:!0}),t.writeFileSync(d,JSON.stringify({email:a}));let u=zt(process.stderr);process.stderr.write(`
129
+ Signing identity (kid): ${u.green(m)}
130
+ `),process.stderr.write(`Expires: ${s} (${i} month${i===1?"":"s"} from today)
131
+ `),process.stderr.write(Wt({kid:m,publicKeyPem:l,email:a,expires:s},u,n)),process.stderr.write(`
132
+ ${u.bold("Next:")} open a PR against the ${u.magenta("infrastructure")} repo with that block, then \`${u.cyan(`cognite sign -s ${m}`)}\`
133
+ `)}o(yi,"handleGenerate");var mn=1e3,hi=new Set(["baseUrl","url","project","deployment","source","path","name","displayName","description"]);function Ci(e){return Object.fromEntries(Object.entries(e).map(([t,n])=>typeof n=="boolean"?[t,n]:hi.has(t)?[t,n]:[t,"[REDACTED]"]))}o(Ci,"sanitize");function wi(e){let t=[],n=e;for(;n;)n.parent&&t.unshift(n.name()),n=n.parent;return t.join(" ")}o(wi,"getCommandPath");function dn(e){try{let t=e(process.cwd());return{appExternalId:t.externalId,appVersionTag:t.versionTag}}catch{return{}}}o(dn,"tryLoadAppConfig");function Ne(e){return e.filter(t=>!t.startsWith("-")).join(" ")||"unknown"}o(Ne,"commandFromArgv");function un(e,t,n=C){e.hook("postAction",async(r,i)=>{try{let s={command:wi(i),options:Ci(i.opts()),success:!0,...dn(n)};t.track("Flows.CLI.Command",s),await t.flush(mn)}catch{}})}o(un,"instrument");async function gn(e,t,n=C){try{let r={command:Ne(t),options:{},success:!1,...dn(n)};e.track("Flows.CLI.Command",r),await e.flush(mn)}catch{}}o(gn,"trackFailure");var Ei="ERR_USE_AFTER_CLOSE";function yn(e){return e instanceof Error&&"code"in e&&e.code===Ei}o(yn,"isReadlineClosedError");function Si(e){let t=Object.getPrototypeOf(e);return t===Object.prototype||t===null}o(Si,"isPlainObject");function je(e){return e==null||yn(e)?!0:e instanceof Error?!1:!!(typeof e=="object"&&e!==null&&Si(e)&&Object.keys(e).length===0)}o(je,"isPromptCancel");var fn=!1;function hn(){fn||(fn=!0,process.on("uncaughtException",e=>{yn(e)&&(console.error(`
134
+ Cancelled.`),process.exit(130)),console.error(e),process.exit(1)}),process.on("unhandledRejection",e=>{je(e)&&(console.error(`
135
+ Cancelled.`),process.exit(130)),console.error(e),process.exit(1)}))}o(hn,"installCancelHandler");import Cn from"mixpanel";var vi="5c4d853e7c3b77b1eb4468d5329b278c",Q="cognite-cli",xi=2e3,wn={env:process.env,init:Cn.init.bind(Cn)},bi={track:o(()=>{},"track"),flush:o(async()=>{},"flush")};function Ke(e=process.env){return e.COGNITE_TELEMETRY_DISABLED==="1"||e.DO_NOT_TRACK==="1"}o(Ke,"isTelemetryDisabled");function Pi(e){return e.COGNITE_TELEMETRY_DEBUG==="1"}o(Pi,"isDebug");function En(e={}){let t=e.env??wn.env,n=e.init??wn.init,r=e.packageName,i=e.cliVersion,s=Pi(t);if(Ke(t))return s&&process.stderr.write(`[telemetry] disabled \u2014 noop tracker
136
+ `),bi;let a,c=new Set;function p(){if(a)return a;try{return a=n(vi,{geolocate:!1,keepAlive:!1}),a}catch{return}}return o(p,"getClient"),{track(l,m={}){let d=p();if(!d)return;let u={...m,applicationId:Q,...r&&{packageName:r},...i&&{cliVersion:i},nodeVersion:process.version,platform:process.platform};s&&process.stderr.write(`[telemetry] track ${l} ${JSON.stringify(u)}
137
+ `);let f=o(()=>{},"finish"),g=new Promise(T=>{f=T});c.add(g);try{d.track(l,u,f)}catch{f()}g.finally(()=>c.delete(g))},async flush(l=xi){if(c.size===0)return;let m,d=new Promise(u=>{m=setTimeout(u,l),m.unref?.()});try{await Promise.race([Promise.allSettled([...c]),d])}finally{m&&clearTimeout(m)}s&&process.stderr.write(`[telemetry] flush done (${c.size} still pending)
138
+ `)}}}o(En,"createTelemetry");var Ai=1e3,ki="https://0a118cb02e3be57b1838bcfb5783a2bf@o4508040730968064.ingest.de.sentry.io/4510719268290640",Di={captureError:o(async()=>{},"captureError"),flush:o(async()=>{},"flush")};function Ii(e){return e.packageName&&e.cliVersion?`${e.packageName}@${e.cliVersion}`:e.cliVersion??"unknown"}o(Ii,"buildRelease");var Ti="192.0.2.0";function $i(e){let t={...e.user,email:void 0,username:void 0,ip_address:Ti,id:void 0};return{...e,user:t,server_name:void 0}}o($i,"scrubPii");function Sn(e={}){let t=e.env??process.env;if(Ke(t))return Di;let n=Ii(e),r="production",i=null,s=null;function a(){return{dsn:ki,release:n,environment:r,defaultIntegrations:!1,integrations:[],sendDefaultPii:!1,enableLogs:!1,initialScope:{tags:{component:"cli",applicationId:Q},contexts:{cli:{applicationId:Q,node:process.version,platform:process.platform}}},beforeSend:$i}}o(a,"buildInitOptions");async function c(){return i||(s||(s=(async()=>{try{let p=e.sdk??await import("@sentry/node");return p.init(a()),i=p,p}catch{return null}})()),s)}return o(c,"ensureSdk"),{async captureError(p,l){try{let m=await c();if(!m)return;let d={level:"fatal"};l?.command&&(d.tags={command:l.command},d.contexts={cli:{applicationId:Q,node:process.version,platform:process.platform,command:l.command}}),m.captureException(p,d)}catch{}},async flush(p=Ai){try{if(!i)return;await i.flush(p)}catch{}}}}o(Sn,"createErrorReporter");import{mkdirSync as Fi,readFileSync as Oi,writeFileSync as Ri}from"fs";import{homedir as _i}from"os";import{resolve as ae}from"path";import{debuglog as Ui}from"util";import{lt as Li,parse as vn}from"semver";var Ni="https://registry.npmjs.org/@cognite/cli/latest",ji=1500,xn="upgrade-check.json",bn=ae(process.env.XDG_CACHE_HOME||ae(_i(),".cache"),"@cognite","cli"),Me=Ui("cognite-flows");function Ki(e,t){return!e||!t||!vn(e)||!vn(t)?!1:Li(e,t)}o(Ki,"isOutdated");async function Mi({timeout:e=ji,registryUrl:t=Ni,fetchImpl:n=globalThis.fetch}={}){if(typeof n!="function")return null;try{let r=await n(t,{signal:AbortSignal.timeout(e)});if(!r?.ok)return null;let i=await r.json();return typeof i?.version=="string"?i.version:null}catch(r){return Me("fetchLatestVersion failed (%s): %O",t,r),null}}o(Mi,"fetchLatestVersion");function Vi(e=bn,t=864e5){try{let n=Oi(ae(e,xn),"utf-8"),r=JSON.parse(n);return typeof r.latest!="string"||typeof r.fetchedAt!="number"||Date.now()-r.fetchedAt>t?null:{latest:r.latest,fetchedAt:r.fetchedAt}}catch(n){return Me("readUpgradeCheckCache failed (%s): %O",e,n),null}}o(Vi,"readUpgradeCheckCache");function Hi(e,t){try{Fi(e,{recursive:!0});let n={latest:t,fetchedAt:Date.now()};Ri(ae(e,xn),JSON.stringify(n))}catch(n){Me("writeUpgradeCheckCache failed (%s): %O",e,n)}}o(Hi,"writeUpgradeCheckCache");async function Gi({cacheDir:e=bn,...t}={}){let n=await Mi(t);n&&Hi(e,n)}o(Gi,"startBackgroundUpgradeCheck");function Pn(e,{onOutdated:t,cacheDir:n,...r}={}){let i=Vi(n);if(i){Ki(e,i.latest)&&t?.(e,i.latest);return}Gi({cacheDir:n,...r})}o(Pn,"preActionUpgradeCheck");import{default as Jl,chalkStderr as An}from"chalk";function kn(e,t){let n=[`\u26A0 Update available: ${e} -> ${t}`," Run npx @cognite/cli@latest"],r=Math.max(...n.map(c=>[...c].length))+2,i="\u2500".repeat(r),s=o(c=>`\u2502 ${c}${" ".repeat(r-1-[...c].length)}\u2502`,"pad"),a=[`\u250C${i}\u2510`,...n.map(s),`\u2514${i}\u2518`].join(`
139
+ `);return An.bold.yellow(a)}o(kn,"formatUpgradeWarning");function Ji(e){return e instanceof Error&&"code"in e&&typeof e.code=="string"&&e.code==="DEP0040"}o(Ji,"isDep0040Warning");var He=process,Xi=He.emit.bind(He);He.emit=function(e,...t){return e==="warning"&&Ji(t[0])?!1:Xi(e,...t)};hn();var G=new Yi;G.name("cognite").description("Build and deploy React apps to Cognite Data Fusion").version("1.1.0-alpha.48").showHelpAfterError().configureOutput({writeOut:o(e=>Bi(1,e),"writeOut")});G.hook("preAction",()=>{Pn("1.1.0-alpha.48",{onOutdated:o((e,t)=>{console.warn(`
140
+ ${kn(e,t)}
141
+ `)},"onOutdated")})});_t(G);ln(G);var In=En({packageName:"@cognite/cli",cliVersion:"1.1.0-alpha.48"}),Dn=Sn({packageName:"@cognite/cli",cliVersion:"1.1.0-alpha.48"});un(G,In);var Ve=process.argv.slice(2);G.parseAsync(Ve,{from:"user"}).catch(async e=>{await gn(In,Ve),je(e)&&(console.error(`
142
+ Cancelled.`),process.exit(130)),await Dn.captureError(e,{command:Ne(Ve)}),await Dn.flush(),console.error(e instanceof Error?`\u274C ${e.message}`:e),process.exit(1)});
@@ -1,4 +1,4 @@
1
- import { CogniteClient } from '@cognite/sdk';
1
+ import { CogniteClient, ClientOptions } from '@cognite/sdk';
2
2
 
3
3
  type Deployment = {
4
4
  org: string;
@@ -60,6 +60,9 @@ declare class AppHostingClient {
60
60
  publishVersion(appExternalId: string, version: string): Promise<void>;
61
61
  /** Publish the version and immediately set it as the ACTIVE alias. */
62
62
  publishAndActivate(appExternalId: string, version: string): Promise<void>;
63
+ getActiveVersion(appExternalId: string): Promise<AppVersion | null>;
64
+ /** Remove the ACTIVE alias from a version, taking it out of service without changing its lifecycle state. */
65
+ deactivateVersion(appExternalId: string, version: string): Promise<void>;
63
66
  /**
64
67
  * Set the ACTIVE alias on a version. Returns the version that was
65
68
  * previously active (if any) so callers can surface "Superseded X"
@@ -87,19 +90,17 @@ declare class AppHostingClient {
87
90
  *
88
91
  * Handles packaging of build directories into deployment-ready zip files.
89
92
  */
90
- interface ApplicationPackagerOptions {
91
- requireLockFile?: boolean;
92
- }
93
93
  declare class ApplicationPackager {
94
94
  private distPath;
95
95
  private appRoot;
96
- private requireLockFile;
97
- constructor(distDirectory?: string, options?: ApplicationPackagerOptions);
96
+ constructor(distDirectory?: string);
98
97
  validateBuildDirectory(): void;
99
98
  createZip(outputFilename?: string, verbose?: boolean): Promise<string>;
100
99
  }
101
100
 
102
- declare const getSdk: (deployment: Deployment, folder: string, env?: NodeJS.ProcessEnv) => Promise<CogniteClient>;
101
+ type Authenticatable = Pick<CogniteClient, 'authenticate'>;
102
+ declare function getSdk(deployment: Deployment, folder: string, env?: NodeJS.ProcessEnv): Promise<CogniteClient>;
103
+ declare function getSdk<C extends Authenticatable>(deployment: Deployment, folder: string, env: NodeJS.ProcessEnv, createClient: (opts: ClientOptions) => C): Promise<C>;
103
104
 
104
105
  /**
105
106
  * Get access token for deployment using the appropriate identity provider.
@@ -1,9 +1 @@
1
- import{a as s}from"../chunk-EI7MMDWY.js";import J from"fs";import ut from"path";var j="https://docs.cognite.com/cdf/access/";function f(e){return e!==null&&typeof e=="object"}s(f,"isRecord");function S(e){return e instanceof Error&&"status"in e&&typeof e.status=="number"}s(S,"isHttpError");function K(e){switch(e){case 401:return`Your credentials are invalid or expired. Check your client ID and secret.
2
- See: ${j}`;case 403:return`You don't have the required CDF capabilities. Please contact your CDF admin.
3
- See: ${j}`;default:return}}s(K,"httpStatusHint");function w(e){let t=e instanceof Error?e:new Error(String(e));if(!S(t))return null;let n=K(t.status);return n?Object.assign(new Error(`${t.message}
4
- ${n}`),{cause:t}):null}s(w,"enrichedHttpError");function W(e){if(!f(e))return null;let t=e.missing;if(Array.isArray(t))return t;let n=e.data;if(f(n)){let r=n.error;if(f(r)&&Array.isArray(r.missing))return r.missing;if(Array.isArray(n.missing))return n.missing}return null}s(W,"findMissingArray");function Z(e,t){if(!S(e)||e.status!==400)return!1;let n=W(e);return n?n.some(r=>f(r)&&typeof r.externalId=="string"&&t.includes(r.externalId)):!1}s(Z,"isMissingExternalIdError");function x(e,t){return S(e)&&e.status===404||Z(e,t)}s(x,"isNotFoundError");var H=["DRAFT","PUBLISHED","DEPRECATED","ARCHIVED"],q=["ACTIVE","PREVIEW"],I=class I extends Error{constructor(t,n){super(`Version ${n} of app ${t} not found`),this.name="AppVersionNotFoundError",this.appExternalId=t,this.version=n}};s(I,"AppVersionNotFoundError");var C=I;function M(e,t){return e.includes(t)}s(M,"includesValue");function X(e){return M(H,e)}s(X,"isAppVersionLifecycleState");function Q(e){return M(q,e)}s(Q,"isAppVersionAlias");function tt(e){return typeof e.version=="string"&&X(e.lifecycleState)&&typeof e.entrypoint=="string"&&typeof e.createdTime=="number"&&typeof e.createdBy=="string"&&typeof e.appExternalId=="string"&&(e.alias===void 0||Q(e.alias))&&(e.comment===void 0||typeof e.comment=="string")}s(tt,"isAppVersion");function N(e){if(!f(e))throw new Error("Invalid version response: not an object");if(!tt(e))throw new Error("Invalid version response: missing or malformed fields");return e}s(N,"parseAppVersion");var T=class T{constructor(t){this.client=t}get appsBasePath(){return`/api/v1/projects/${encodeURIComponent(this.client.project)}/apphosting/apps`}async createApp(t,n,r){try{await this.client.post(this.appsBasePath,{data:{items:[{externalId:t,name:n,description:r}]}})}catch(o){throw w(o)??o}}async uploadVersion(t,n,r,o,i="index.html"){console.log(`\u{1F4E4} Uploading version ${n}...`);let c=new FormData;c.append("file",new Blob([new Uint8Array(r)]),o),c.append("version",n),c.append("entryPath",i);let p=encodeURIComponent(t),a=`${this.appsBasePath}/${p}/versions`,l=await this.client.authenticate(),h=`${this.client.getBaseUrl()}${a}`,d=new AbortController,Y=setTimeout(()=>d.abort(),300*1e3),y;try{y=await fetch(h,{method:"POST",headers:{Authorization:`Bearer ${l}`},body:c,signal:d.signal})}catch(g){throw g instanceof Error&&g.name==="AbortError"?new Error("Upload timed out after 5 minutes"):g}finally{clearTimeout(Y)}if(!y.ok){let g=await y.text(),V=g;try{let $=JSON.parse(g);if(f($)){let A=$.error;if(typeof A=="string")V=A;else if(f(A)){let E=A.message,B=A.code;V=typeof E=="string"?E:B!=null?`Unknown error (code: ${B})`:g}else{let E=$.message;V=typeof E=="string"?E:g}}}catch{}let O=y.headers.get("x-request-id"),G=O?` | X-Request-ID: ${O}`:"",U=Object.assign(new Error(`Upload failed: ${y.status} \u2014 ${V}${G}`),{status:y.status});throw w(U)??U}console.log(`\u2705 Version ${n} uploaded`)}async getVersion(t,n){let r=encodeURIComponent(t),o=encodeURIComponent(n),i=`${this.appsBasePath}/${r}/versions/${o}`;try{let c=await this.client.get(i);return N(c.data)}catch(c){throw x(c,[t,n])?new C(t,n):w(c)??c}}async getActiveVersion(t){let n=encodeURIComponent(t),r=`${this.appsBasePath}/${n}/active`;try{let o=await this.client.get(r);return N(o.data)}catch(o){if(x(o,[t]))return null;throw w(o)??o}}async updateVersions(t,n){let r=encodeURIComponent(t),o=`${this.appsBasePath}/${r}/versions/update`;try{await this.client.post(o,{data:{items:n}})}catch(i){throw w(i)??i}}};s(T,"AppHostingApi");var v=T;var b=class b{constructor(t){this.api=new v(t)}getVersion(t,n){return this.api.getVersion(t,n)}uploadVersion(t,n,r,o,i){return this.api.uploadVersion(t,n,r,o,i)}async ensureApp(t,n,r){console.log("\u{1F50D} Ensuring app exists...");try{await this.api.createApp(t,n,r),console.log(`\u2705 App '${t}' created`)}catch(o){if(S(o)&&o.status===409){console.log(`\u2705 App '${t}' already exists`);return}throw o}}async publishVersion(t,n){await this.api.updateVersions(t,[{version:n,update:{lifecycleState:{set:"PUBLISHED"}}}])}async publishAndActivate(t,n){console.log(`\u{1F680} Publishing and activating version ${n}...`),await this.api.updateVersions(t,[{version:n,update:{lifecycleState:{set:"PUBLISHED"},alias:{set:"ACTIVE"}}}]),console.log(`\u2705 Version ${n} is now PUBLISHED and ACTIVE`)}async activateVersion(t,n){let r=null;try{r=await this.api.getActiveVersion(t)}catch{r=null}let o=r&&r.version!==n?r.version:void 0;return await this.api.updateVersions(t,[{version:n,update:{alias:{set:"ACTIVE"}}}]),{supersededVersion:o}}async deploy(t,n,r,o,i,c,p=!1){console.log(`
5
- \u{1F680} Deploying application via App Hosting API...
6
- `);try{await this.ensureApp(t,n,r),await this.uploadVersion(t,o,i,c),p&&await this.publishAndActivate(t,o),console.log(`
7
- \u2705 Deployment successful!`)}catch(a){let l=a instanceof Error?a.message:String(a);throw Object.assign(new Error(`Deployment failed: ${l}`),{cause:a})}}};s(b,"AppHostingClient");var P=b;import m from"fs";import u from"path";import{parseAndValidateManifestConfig as et}from"@cognite/app-sdk/vite";import{BlobReader as nt,Uint8ArrayWriter as rt,ZipWriter as ot}from"@zip.js/zip.js";var R="package.json",L="package-lock.json",z="manifest.json",D=class D{constructor(t="dist",n={}){this.distPath=u.isAbsolute(t)?t:u.join(process.cwd(),t),this.appRoot=u.dirname(this.distPath),this.requireLockFile=n.requireLockFile??!1}validateBuildDirectory(){if(!m.existsSync(this.distPath))throw new Error(`Build directory "${this.distPath}" not found. Run build first.`);let t=u.join(this.appRoot,R);if(!m.existsSync(t))throw new Error(`"${t}" not found. It is required for deployment.`);if(this.requireLockFile){let n=u.join(this.appRoot,L);if(!m.existsSync(n))throw new Error(`"${n}" not found. It is required for deployment.`)}}async createZip(t="app.zip",n=!1){this.validateBuildDirectory(),console.log("\u{1F4E6} Packaging application...");let r=new ot(new rt,{level:9}),o=s(async(a,l)=>{await r.add(l,new nt(await m.openAsBlob(a))),n&&console.log(` \u{1F4C4} ${l}`)},"addFile"),i=s(async a=>{let l=await m.promises.readdir(a,{withFileTypes:!0});for(let h of l){let d=u.join(a,h.name);h.isDirectory()?await i(d):await o(d,u.relative(this.distPath,d).replace(/\\/g,"/"))}},"addDir"),c;try{await i(this.distPath),await o(u.join(this.appRoot,R),R);let a=u.join(this.appRoot,z);if(m.existsSync(a)){let l=m.readFileSync(a,"utf-8");et(l,a),await o(a,z)}this.requireLockFile&&await o(u.join(this.appRoot,L),L),c=await r.close()}catch(a){let l=a instanceof Error?a.message:String(a);throw new Error(`Failed to create zip: ${l}`)}await m.promises.writeFile(t,c);let p=(c.byteLength/1024/1024).toFixed(2);return console.log(`\u2705 App packaged: ${t} (${p} MB)`),t}};s(D,"ApplicationPackager");var k=D;import{CogniteClient as lt}from"@cognite/sdk";var st=s(()=>{let e=process.env.DEPLOYMENT_SECRETS;if(!e)return{};try{let t=JSON.parse(e),n={};for(let[r,o]of Object.entries(t))if(typeof o=="string"){let i=r.toLowerCase().replace(/_/g,"-");n[i]=o}return n}catch(t){return console.error("Error parsing DEPLOYMENT_SECRETS:",t),{}}},"loadSecretsFromEnv"),it=s(e=>{let t;if(process.env.DEPLOYMENT_SECRET&&(t=process.env.DEPLOYMENT_SECRET),t||(t=st()[e]),t||(t=process.env[e]),!t)throw new Error(`Secret not found in environment: ${e}`);return t},"getSecretFromEnv"),at=s(e=>{if(!e)return"";try{return new URL(e).hostname.replace(/\.cognitedata\.com$/,"")}catch{let t=e.replace(/^https?:\/\//,"");return t=t.split("/")[0],t=t.split(":")[0],t=t.replace(/\.cognitedata\.com$/,""),t}},"extractClusterFromUrl"),ct=s(async(e,t)=>{let n=`Basic ${btoa(`${e}:${t}`)}`,r=await fetch("https://auth.cognite.com/oauth2/token",{method:"POST",headers:{Authorization:n,"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"client_credentials"})});if(!r.ok){let i=await r.text();throw new Error(`Failed to get token from CDF: ${r.status} ${r.statusText}
8
- ${i}`)}let o=await r.json();if(!o.access_token)throw new Error("No access token returned from CDF authentication");return o.access_token},"getTokenCdf"),pt=s(async(e,t,n,r)=>{if(!r)throw new Error("Entra ID authentication requires 'baseUrl' to be set in deployment configuration");let o=at(r);if(!o)throw new Error(`Entra ID authentication requires 'baseUrl' to be a valid CDF URL (e.g., https://cluster.cognitedata.com), got: ${r}`);let i=`https://login.microsoftonline.com/${n}/oauth2/v2.0/token`,c=`https://${o}.cognitedata.com/.default`,p=await fetch(i,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({client_id:e,client_secret:t,scope:c,grant_type:"client_credentials"})});if(!p.ok){let l=await p.text();throw new Error(`Failed to get token from Entra ID: ${p.status} ${p.statusText}
9
- ${l}`)}let a=await p.json();if(!a.access_token)throw new Error("No access token returned from Entra ID authentication");return a.access_token},"getTokenEntra"),_=s(async(e,t=process.env)=>{if(t.COGNITE_TOKEN)return t.COGNITE_TOKEN;let{deployClientId:n,deploySecretName:r,idpType:o="cdf",tenantId:i,baseUrl:c}=e,p=it(r);if(o==="entra_id"){if(!i)throw new Error("Entra ID authentication requires 'tenantId' in deployment configuration");return pt(n,p,i,c)}return ct(n,p)},"getToken");var F=s(async(e,t,n=process.env)=>{let r=await _(e,n),o=n.COGNITE_BASE_URL??e.baseUrl,i=new lt({appId:t,project:e.project,baseUrl:o,oidcTokenProvider:s(async()=>r,"oidcTokenProvider")});return await i.authenticate(),i},"getSdk");var dt=s(async(e,t,n)=>{let r=await new k(`${n}/dist`,{requireLockFile:!0}).createZip("app.zip",!0);try{let{externalId:o,name:i,description:c,versionTag:p}=t,a=await F(e,n),l=new P(a),h=J.readFileSync(r),d=ut.basename(r);await l.deploy(o,i,c,p,h,d,e.published)}finally{try{J.unlinkSync(r)}catch{}}},"deploy");export{P as AppHostingClient,k as ApplicationPackager,dt as deploy,F as getSdk,_ as getToken};
1
+ import{a,b,c,d,e}from"../chunk-QOJVLP7E.js";export{a as AppHostingClient,b as ApplicationPackager,e as deploy,d as getSdk,c as getToken};
package/dist/index.d.ts CHANGED
@@ -1,4 +1,2 @@
1
- export { AppSdkAuthProvider, CDFConfig, DuneAuthProvider, DuneAuthProviderContext, DuneAuthProviderProps, DuneContextValue, EMPTY_SDK, createCDFSDK, getToken, useDune } from './auth/index.js';
2
- import 'react/jsx-runtime';
3
- import 'react';
1
+ export { App, AppHostingClient, ApplicationPackager, Deployment, deploy, getSdk, getToken } from './deploy/index.js';
4
2
  import '@cognite/sdk';
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- import{a as o,b as r,c as e,d as f,e as m,f as p,g as t}from"./chunk-QGJ3VKXY.js";import"./chunk-EI7MMDWY.js";export{p as AppSdkAuthProvider,m as DuneAuthProvider,f as DuneAuthProviderContext,e as EMPTY_SDK,r as createCDFSDK,o as getToken,t as useDune};
1
+ import{a as o,b as r,c as e,d as f,e as m}from"./chunk-QOJVLP7E.js";export{o as AppHostingClient,r as ApplicationPackager,m as deploy,f as getSdk,e as getToken};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cognite/cli",
3
- "version": "1.0.0",
3
+ "version": "1.1.0-alpha.48",
4
4
  "description": "CLI for Cognite Data Fusion",
5
5
  "license": "Apache-2.0",
6
6
  "author": "Cognite",
@@ -18,21 +18,10 @@
18
18
  "import": "./dist/index.js",
19
19
  "default": "./dist/index.js"
20
20
  },
21
- "./auth": {
22
- "types": "./dist/auth/index.d.ts",
23
- "import": "./dist/auth/index.js",
24
- "default": "./dist/auth/index.js"
25
- },
26
21
  "./deploy": {
27
22
  "types": "./dist/deploy/index.d.ts",
28
23
  "import": "./dist/deploy/index.js",
29
24
  "default": "./dist/deploy/index.js"
30
- },
31
- "./vite": {
32
- "types": "./dist/vite/index.d.ts",
33
- "development": "./src/vite/index.ts",
34
- "import": "./dist/vite/index.js",
35
- "default": "./dist/vite/index.js"
36
25
  }
37
26
  },
38
27
  "bin": {
@@ -100,7 +89,7 @@
100
89
  "react-dom": "^19.2.6",
101
90
  "tsup": "^8.4.0",
102
91
  "typescript": "^5.0.0",
103
- "vitest": "^2.1.8"
92
+ "vitest": "^3.2.4"
104
93
  },
105
94
  "engines": {
106
95
  "node": ">=20"
@@ -1,51 +0,0 @@
1
- import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import * as react from 'react';
3
- import { ReactNode } from 'react';
4
- import { CogniteClient } from '@cognite/sdk';
5
-
6
- interface AppSdkAuthProviderProps {
7
- children: ReactNode;
8
- loadingComponent?: ReactNode;
9
- errorComponent?: (error: string) => ReactNode;
10
- }
11
- /**
12
- * Auth provider for apps running in the new Fusion app host (dune-app-host).
13
- * Uses @cognite/app-sdk's Comlink handshake to connect to the host and obtain
14
- * tokens on-demand. Exposes the same DuneContextValue ({ sdk, isLoading,
15
- * error }) as DuneAuthProvider so useDune() works unchanged.
16
- */
17
- declare const AppSdkAuthProvider: ({ children, loadingComponent, errorComponent, }: AppSdkAuthProviderProps) => react_jsx_runtime.JSX.Element;
18
-
19
- interface DuneContextValue {
20
- sdk: CogniteClient;
21
- isLoading: boolean;
22
- error?: string;
23
- }
24
- declare const DuneAuthProviderContext: react.Context<DuneContextValue>;
25
- interface DuneAuthProviderProps {
26
- children: ReactNode;
27
- useIFrameAuthentication?: boolean;
28
- useLocalConfiguration?: {
29
- org: string;
30
- project: string;
31
- baseUrl: string;
32
- };
33
- loadingComponent?: ReactNode;
34
- errorComponent?: (error: string) => ReactNode;
35
- }
36
- declare const DuneAuthProvider: ({ children, loadingComponent, errorComponent, }: DuneAuthProviderProps) => react_jsx_runtime.JSX.Element;
37
-
38
- declare const useDune: () => DuneContextValue;
39
-
40
- interface CDFConfig {
41
- project: string;
42
- baseUrl: string;
43
- clientId: string;
44
- clientSecret: string;
45
- appId?: string;
46
- }
47
- declare const getToken: (clientId: string, clientSecret: string) => Promise<any>;
48
- declare const createCDFSDK: (config: CDFConfig) => Promise<CogniteClient>;
49
- declare const EMPTY_SDK: CogniteClient;
50
-
51
- export { AppSdkAuthProvider, type CDFConfig, DuneAuthProvider, DuneAuthProviderContext, type DuneAuthProviderProps, type DuneContextValue, EMPTY_SDK, createCDFSDK, getToken, useDune };
@@ -1 +0,0 @@
1
- import{a,b,c,d,e,f,g}from"../chunk-QGJ3VKXY.js";import"../chunk-EI7MMDWY.js";export{f as AppSdkAuthProvider,e as DuneAuthProvider,d as DuneAuthProviderContext,c as EMPTY_SDK,b as createCDFSDK,a as getToken,g as useDune};
@@ -1 +0,0 @@
1
- var c=Object.defineProperty;var d=(a,b)=>c(a,"name",{value:b,configurable:!0});export{d as a};
@@ -1 +0,0 @@
1
- import{a as t}from"./chunk-EI7MMDWY.js";import{connectToHostApp as b}from"@cognite/app-sdk";import{CogniteClient as U}from"@cognite/sdk";import{useEffect as N,useState as v}from"react";import{CogniteClient as R}from"@cognite/sdk";import{createContext as I,useEffect as L,useState as P}from"react";import{CogniteClient as A}from"@cognite/sdk";var D=t(async(n,e)=>{let o=`Basic ${btoa(`${n}:${e}`)}`;return(await(await fetch("https://auth.cognite.com/oauth2/token",{method:"POST",headers:{Authorization:o,"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"client_credentials"})})).json()).access_token},"getToken"),T=t(async n=>{let{project:e,baseUrl:o,clientId:r,clientSecret:d,appId:c="cdf-authentication-package"}=n;if(!e||!o||!r||!d)throw new Error("Missing required configuration. Please provide: project, baseUrl, clientId, clientSecret");let u=new A({appId:c,project:e,baseUrl:o,oidcTokenProvider:t(async()=>await D(r,d),"oidcTokenProvider")});return await u.authenticate(),u},"createCDFSDK"),p=new A({appId:"cdf-authentication-package",project:"",oidcTokenProvider:t(async()=>"","oidcTokenProvider")}),E=t(()=>{console.log("\u{1F511} Requesting credentials from parent..."),window.parent&&window.parent!==window&&window.parent.postMessage({type:"REQUEST_CREDENTIALS"},"*")},"requestCredentials"),S=t(n=>{if(n.data?.type==="PROVIDE_CREDENTIALS"&&n.data?.credentials){let e=n.data.credentials;if(e.token&&e.baseUrl&&e.project)return console.log("\u{1F389} useCredentials received credentials:",{hasToken:!!e.token,tokenLength:e.token?.length||0,project:e.project,baseUrl:e.baseUrl}),e}},"handleCredentialsResponse");import{Fragment as w,jsx as l,jsxs as x}from"react/jsx-runtime";var g=I({sdk:p,isLoading:!1}),y=t(({children:n,loadingComponent:e=l("div",{children:"Loading CDF authentication..."}),errorComponent:o=t(r=>x("div",{children:["Authentication error: ",r]}),"errorComponent")})=>l(_,{loadingComponent:e,errorComponent:o,children:n}),"DuneAuthProvider"),_=t(({children:n,loadingComponent:e=l("div",{children:"Loading CDF authentication..."}),errorComponent:o=t(r=>x("div",{children:["Authentication error: ",r]}),"errorComponent")})=>{let[r,d]=P(!0),[c,u]=P(p),[s]=P();return L(()=>{E();let f=t(async i=>{console.log("\u{1F50D} Handling message from Fusion");let a=S(i);if(!a)return;let h=new R({appId:"dune-app",project:a.project,baseUrl:a.baseUrl,oidcTokenProvider:t(async()=>a.token,"oidcTokenProvider")});await h.authenticate(),u(h),d(!1)},"handleMessage");return console.log("\u{1F50D} Adding message listener"),window.addEventListener("message",f),()=>window.removeEventListener("message",f)},[]),console.log("\u{1F50D} CDFIframeAuthenticationInnerProvider",c,r,s),s&&o?l(w,{children:o(s)}):r&&e?l(w,{children:e}):l(g.Provider,{value:{sdk:c,isLoading:r,error:s},children:n})},"FusionIframeAuthenticationInnerProvider");import{Fragment as k,jsx as C,jsxs as j}from"react/jsx-runtime";var F=t(({children:n,loadingComponent:e=C("div",{children:"Loading CDF authentication..."}),errorComponent:o=t(r=>j("div",{children:["Authentication error: ",r]}),"errorComponent")})=>{let[r,d]=v(p),[c,u]=v(!0),[s,f]=v();return N(()=>{b().then(async({api:i})=>{let[a,h]=await Promise.all([i.getProject(),i.getBaseUrl()]),m=new U({appId:"dune-app",project:a,baseUrl:h,oidcTokenProvider:t(async()=>i.getAccessToken(),"oidcTokenProvider")});await m.authenticate(),d(m),f(void 0)}).catch(i=>{let a=i instanceof Error?i.message:String(i);f(a)}).finally(()=>{u(!1)})},[]),s&&o?C(k,{children:o(s)}):c&&e?C(k,{children:e}):C(g.Provider,{value:{sdk:r,isLoading:c,error:s},children:n})},"AppSdkAuthProvider");import{useContext as M}from"react";var Y=t(()=>{let n=M(g);if(!n)throw new Error("useDune must be used within a DuneAuthProvider");return n},"useDune");export{D as a,T as b,p as c,g as d,y as e,F as f,Y as g};
@@ -1 +0,0 @@
1
- export { CspFetchDirective, MANIFEST_VERSION, ManifestConfig, NetworkAllowlistRule, buildFrameAncestors, buildHostedAppContentSecurityPolicy, fusionOpenPlugin, getManifestNetworkRules, loadManifestConfig, manifestCspPlugin, parseAndValidateManifestConfig, validateManifestConfig } from '@cognite/app-sdk/vite';
@@ -1 +0,0 @@
1
- import"../chunk-EI7MMDWY.js";import{fusionOpenPlugin as i,manifestCspPlugin as n,buildFrameAncestors as o,buildHostedAppContentSecurityPolicy as s,getManifestNetworkRules as a,loadManifestConfig as l,MANIFEST_VERSION as f,parseAndValidateManifestConfig as p,validateManifestConfig as r}from"@cognite/app-sdk/vite";export{f as MANIFEST_VERSION,o as buildFrameAncestors,s as buildHostedAppContentSecurityPolicy,i as fusionOpenPlugin,a as getManifestNetworkRules,l as loadManifestConfig,n as manifestCspPlugin,p as parseAndValidateManifestConfig,r as validateManifestConfig};