@kuadrant/kuadrant-backstage-plugin-frontend 0.0.2-dev-39963ad → 0.0.2-dev-8f2e157
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/ApiKeyManagementTab/ApiKeyManagementTab.esm.js +153 -39
- package/dist/components/ApiKeyManagementTab/ApiKeyManagementTab.esm.js.map +1 -1
- package/dist/components/ApiProductInfoCard/ApiProductInfoCard.esm.js +35 -4
- package/dist/components/ApiProductInfoCard/ApiProductInfoCard.esm.js.map +1 -1
- package/dist/components/ApprovalQueueCard/ApprovalQueueCard.esm.js +114 -32
- package/dist/components/ApprovalQueueCard/ApprovalQueueCard.esm.js.map +1 -1
- package/dist/components/EditAPIKeyRequestDialog/EditAPIKeyRequestDialog.esm.js +106 -0
- package/dist/components/EditAPIKeyRequestDialog/EditAPIKeyRequestDialog.esm.js.map +1 -0
- package/dist/components/EditAPIProductDialog/EditAPIProductDialog.esm.js +8 -2
- package/dist/components/EditAPIProductDialog/EditAPIProductDialog.esm.js.map +1 -1
- package/dist/components/KuadrantPage/KuadrantPage.esm.js +40 -9
- package/dist/components/KuadrantPage/KuadrantPage.esm.js.map +1 -1
- package/dist/components/MyApiKeysCard/MyApiKeysCard.esm.js +169 -11
- package/dist/components/MyApiKeysCard/MyApiKeysCard.esm.js.map +1 -1
- package/dist/index.d.ts +57 -7
- package/dist/index.esm.js +1 -1
- package/dist/permissions.esm.js +43 -13
- package/dist/permissions.esm.js.map +1 -1
- package/dist-scalprum/{internal.plugin-kuadrant.908832be3d1bbb2c9c5b.js → internal.plugin-kuadrant.86c50e4da6b961c623e9.js} +2 -2
- package/dist-scalprum/internal.plugin-kuadrant.86c50e4da6b961c623e9.js.map +1 -0
- package/dist-scalprum/plugin-manifest.json +2 -2
- package/dist-scalprum/static/2120.44884438.chunk.js +3 -0
- package/dist-scalprum/static/2120.44884438.chunk.js.LICENSE.txt +9 -0
- package/dist-scalprum/static/2120.44884438.chunk.js.map +1 -0
- package/dist-scalprum/static/4306.04dfa125.chunk.js +2 -0
- package/dist-scalprum/static/4306.04dfa125.chunk.js.map +1 -0
- package/dist-scalprum/static/4556.c6bedfc4.chunk.js +3 -0
- package/dist-scalprum/static/{4161.aa5fd28d.chunk.js.LICENSE.txt → 4556.c6bedfc4.chunk.js.LICENSE.txt} +0 -10
- package/dist-scalprum/static/4556.c6bedfc4.chunk.js.map +1 -0
- package/dist-scalprum/static/5453.ee6fb9af.chunk.js +2 -0
- package/dist-scalprum/static/5453.ee6fb9af.chunk.js.map +1 -0
- package/dist-scalprum/static/6281.14f57b13.chunk.js +2 -0
- package/dist-scalprum/static/6281.14f57b13.chunk.js.map +1 -0
- package/dist-scalprum/static/7632.646001ce.chunk.js +2 -0
- package/dist-scalprum/static/7632.646001ce.chunk.js.map +1 -0
- package/dist-scalprum/static/9555.59e77806.chunk.js +2 -0
- package/dist-scalprum/static/9555.59e77806.chunk.js.map +1 -0
- package/dist-scalprum/static/exposed-PluginRoot.9522bcfa.chunk.js +2 -0
- package/dist-scalprum/static/{exposed-PluginRoot.50e173c2.chunk.js.map → exposed-PluginRoot.9522bcfa.chunk.js.map} +1 -1
- package/package.json +1 -1
- package/dist-scalprum/internal.plugin-kuadrant.908832be3d1bbb2c9c5b.js.map +0 -1
- package/dist-scalprum/static/4161.aa5fd28d.chunk.js +0 -3
- package/dist-scalprum/static/4161.aa5fd28d.chunk.js.map +0 -1
- package/dist-scalprum/static/4306.133aa342.chunk.js +0 -2
- package/dist-scalprum/static/4306.133aa342.chunk.js.map +0 -1
- package/dist-scalprum/static/5453.d8d305e9.chunk.js +0 -2
- package/dist-scalprum/static/5453.d8d305e9.chunk.js.map +0 -1
- package/dist-scalprum/static/6281.29f4549b.chunk.js +0 -2
- package/dist-scalprum/static/6281.29f4549b.chunk.js.map +0 -1
- package/dist-scalprum/static/7632.26afde62.chunk.js +0 -2
- package/dist-scalprum/static/7632.26afde62.chunk.js.map +0 -1
- package/dist-scalprum/static/8617.d1dc70a8.chunk.js +0 -2
- package/dist-scalprum/static/8617.d1dc70a8.chunk.js.map +0 -1
- package/dist-scalprum/static/exposed-PluginRoot.50e173c2.chunk.js +0 -2
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";(self.webpackChunkinternal_plugin_kuadrant=self.webpackChunkinternal_plugin_kuadrant||[]).push([[4306],{16400:(e,t,a)=>{a.d(t,{tN:()=>r}),a(31085),a(26659);var n=a(64218);function r(){const e=(0,n.useVersionedContext)("entity-context");if(!e)throw new Error("Entity context is not available");const t=e.atVersion(1);if(!t)throw new Error("EntityContext v1 not available");if(!t.entity)throw new Error("useEntity hook is being called outside of an EntityLayout where the entity has not been loaded. If this is intentional, please use useAsyncEntity instead.");return{entity:t.entity}}(0,n.createVersionedContext)("entity-context")},18466:(e,t,a)=>{var n=a(4293),r=a(78920);t.A=void 0;var i=r(a(95478)),s=(0,n(a(74044)).default)(i.createElement("path",{d:"M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z"}),"Add");t.A=s},32269:(e,t,a)=>{var n=a(4293),r=a(78920);t.A=void 0;var i=r(a(95478)),s=(0,n(a(74044)).default)(i.createElement("path",{d:"M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5zM12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5zm0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3z"}),"Visibility");t.A=s},34955:(e,t,a)=>{a.d(t,{FL:()=>i,H4:()=>u,J:()=>r,KN:()=>d,TE:()=>c,ib:()=>s,jH:()=>h,qC:()=>o,uL:()=>p,vs:()=>l});var n=a(83572);(0,n.i)({name:"kuadrant.planpolicy.create",attributes:{action:"create"}}),(0,n.i)({name:"kuadrant.planpolicy.read",attributes:{action:"read"}}),(0,n.i)({name:"kuadrant.planpolicy.update",attributes:{action:"update"}}),(0,n.i)({name:"kuadrant.planpolicy.delete",attributes:{action:"delete"}});const r=(0,n.i)({name:"kuadrant.planpolicy.list",attributes:{action:"read"}}),i=(0,n.i)({name:"kuadrant.apiproduct.create",attributes:{action:"create"}}),s=((0,n.i)({name:"kuadrant.apiproduct.read",attributes:{action:"read"}}),(0,n.i)({name:"kuadrant.apiproduct.update",attributes:{action:"update"}})),o=(0,n.i)({name:"kuadrant.apiproduct.delete",attributes:{action:"delete"}}),l=(0,n.i)({name:"kuadrant.apiproduct.list",attributes:{action:"read"}}),d=(0,n.i)({name:"kuadrant.apikeyrequest.create",attributes:{action:"create"},resourceType:"apiproduct"}),c=((0,n.i)({name:"kuadrant.apikeyrequest.read.own",attributes:{action:"read"}}),(0,n.i)({name:"kuadrant.apikeyrequest.read.all",attributes:{action:"read"}})),u=(0,n.i)({name:"kuadrant.apikeyrequest.update",attributes:{action:"update"}}),p=((0,n.i)({name:"kuadrant.apikeyrequest.list",attributes:{action:"read"}}),(0,n.i)({name:"kuadrant.apikey.read.own",attributes:{action:"read"}}),(0,n.i)({name:"kuadrant.apikey.read.all",attributes:{action:"read"}}),(0,n.i)({name:"kuadrant.apikey.delete.own",attributes:{action:"delete"}})),h=(0,n.i)({name:"kuadrant.apikey.delete.all",attributes:{action:"delete"}})},39590:(e,t,a)=>{var n=a(4293),r=a(78920);t.A=void 0;var i=r(a(95478)),s=(0,n(a(74044)).default)(i.createElement("path",{d:"M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z"}),"Delete");t.A=s},46205:(e,t,a)=>{a.d(t,{W:()=>i,l:()=>r});var n=a(87421);function r(e,t){const a="resourceType"in e?{permission:e,resourceRef:t}:{permission:e},r=(0,n.J)(a);return{allowed:r.allowed,loading:r.loading,error:r.error}}function i(e,t,a,n){return!!n||!(!a||e!==t)}},54306:(e,t,a)=>{a.r(t),a.d(t,{ApiKeyManagementTab:()=>K});var n=a(31085),r=a(95478),i=a(35015),s=a(26648),o=a(86687),l=a(42367),d=a(25010),c=a(10394),u=a(72501),p=a(31653),h=a(38605),m=a(67720),v=a(29365),y=a(42899),A=a(64947),x=a(76891),g=a(61477),j=a(46805),f=a(95061),k=a(48543),b=a(81215),w=a(26343),C=a(16249),q=a(93453),P=a(22097),E=a(16400),S=a(32269),z=a(61524),T=a(39590),$=a(93246),R=a(92399),I=a(18466),N=a(34955),D=a(46205);const K=({namespace:e})=>{var t,a,K;const{entity:B}=(0,E.tN)(),H=(0,P.useApi)(P.configApiRef),L=(0,P.useApi)(P.identityApiRef),V=(0,P.useApi)(P.fetchApiRef),M=H.getString("backend.baseUrl"),[_,U]=(0,r.useState)(new Set),[W,G]=(0,r.useState)(0),[O,X]=(0,r.useState)("guest"),[J,F]=(0,r.useState)(""),[Y,Q]=(0,r.useState)(!1),[Z,ee]=(0,r.useState)(""),[te,ae]=(0,r.useState)(""),[ne,re]=(0,r.useState)(!1),[ie,se]=(0,r.useState)(null),[oe,le]=(0,r.useState)(!1),[de,ce]=(0,r.useState)(null),[ue,pe]=(0,r.useState)(!1),he=(null===(t=B.metadata.annotations)||void 0===t?void 0:t["kuadrant.io/apiproduct"])||B.metadata.name,me=(null===(a=B.metadata.annotations)||void 0===a?void 0:a["kuadrant.io/namespace"])||e||"default";(0,i.A)(async()=>{const e=await L.getBackstageIdentity(),t=await L.getProfileInfo();X(e.userEntityRef.split("/")[1]||"guest"),F(t.email||"")},[L]);const{value:ve,loading:ye,error:Ae}=(0,i.A)(async()=>{const e=await V.fetch(`${M}/api/kuadrant/requests/my?namespace=${me}`);if(!e.ok)throw new Error("failed to fetch requests");return((await e.json()).items||[]).filter(e=>e.spec.apiName===he&&e.spec.apiNamespace===me)},[he,me,W,V,M]),{value:xe,loading:ge,error:je}=(0,i.A)(async()=>{var e;const t=await V.fetch(`${M}/api/kuadrant/apiproducts`);if(!t.ok)throw new Error("failed to fetch api products");return null===(e=(await t.json()).items)||void 0===e?void 0:e.find(e=>e.metadata.namespace===me&&e.metadata.name===he)},[me,he,V]),fe=xe?`apiproduct:${xe.metadata.namespace}/${xe.metadata.name}`:void 0,{allowed:ke,loading:be,error:we}=(0,D.l)(N.KN,fe),{allowed:Ce,loading:qe,error:Pe}=(0,D.l)(N.uL),{allowed:Ee,loading:Se,error:ze}=(0,D.l)(N.jH),Te=(e,t)=>{ce({name:e,displayName:t}),le(!0)},$e=()=>{le(!1),ce(null)},Re=(0,r.useMemo)(()=>[{render:e=>{var t;const a=e.rowData;return(null==a||null===(t=a.metadata)||void 0===t?void 0:t.name)?(0,n.jsx)(Ie,{request:a,apiName:he}):(0,n.jsx)(c.A,{})}}],[he]),Ie=({request:e,apiName:t})=>{var a,i,o,l,d;const[m,v]=(0,r.useState)(0),y=(null===(a=e.status)||void 0===a?void 0:a.apiHostname)||`${t}.apps.example.com`;return(0,n.jsxs)(c.A,{p:3,bgcolor:"background.default",onClick:e=>e.stopPropagation(),children:[(0,n.jsx)(u.A,{variant:"h6",gutterBottom:!0,children:"Usage Examples"}),(0,n.jsxs)(u.A,{variant:"body2",paragraph:!0,children:["Use these code examples to test the API with your ",e.spec.planTier," tier key."]}),(0,n.jsx)(c.A,{onClick:e=>e.stopPropagation(),children:(0,n.jsxs)(p.A,{value:m,onChange:(e,t)=>{e.stopPropagation(),v(t)},indicatorColor:"primary",children:[(0,n.jsx)(h.A,{label:"cURL",onClick:e=>e.stopPropagation()}),(0,n.jsx)(h.A,{label:"Node.js",onClick:e=>e.stopPropagation()}),(0,n.jsx)(h.A,{label:"Python",onClick:e=>e.stopPropagation()}),(0,n.jsx)(h.A,{label:"Go",onClick:e=>e.stopPropagation()})]})}),(0,n.jsxs)(c.A,{mt:2,children:[0===m&&(0,n.jsx)(s.z,{text:`curl -X GET https://${y}/api/v1/endpoint \\\n -H "Authorization: Bearer ${null===(i=e.status)||void 0===i?void 0:i.apiKey}"`,language:"bash",showCopyCodeButton:!0}),1===m&&(0,n.jsx)(s.z,{text:`const fetch = require('node-fetch');\n\nconst apiKey = '${null===(o=e.status)||void 0===o?void 0:o.apiKey}';\nconst endpoint = 'https://${y}/api/v1/endpoint';\n\nfetch(endpoint, {\n method: 'GET',\n headers: {\n 'Authorization': \`Bearer \${apiKey}\`\n }\n})\n .then(response => response.json())\n .then(data => console.log(data))\n .catch(error => console.error('Error:', error));`,language:"javascript",showCopyCodeButton:!0}),2===m&&(0,n.jsx)(s.z,{text:`import requests\n\napi_key = '${null===(l=e.status)||void 0===l?void 0:l.apiKey}'\nendpoint = 'https://${y}/api/v1/endpoint'\n\nheaders = {\n 'Authorization': f'Bearer {api_key}'\n}\n\nresponse = requests.get(endpoint, headers=headers)\nprint(response.json())`,language:"python",showCopyCodeButton:!0}),3===m&&(0,n.jsx)(s.z,{text:`package main\n\nimport (\n "fmt"\n "net/http"\n "io"\n)\n\nfunc main() {\n apiKey := "${null===(d=e.status)||void 0===d?void 0:d.apiKey}"\n endpoint := "https://${y}/api/v1/endpoint"\n\n client := &http.Client{}\n req, _ := http.NewRequest("GET", endpoint, nil)\n req.Header.Add("Authorization", "Bearer " + apiKey)\n\n resp, err := client.Do(req)\n if err != nil {\n fmt.Println("Error:", err)\n return\n }\n defer resp.Body.Close()\n\n body, _ := io.ReadAll(resp.Body)\n fmt.Println(string(body))\n}`,language:"go",showCopyCodeButton:!0})]})]})},Ne=Ae||je,De=we||Pe||ze;if(ye||ge||be||qe||Se)return(0,n.jsx)(o.k,{});if(Ne)return(0,n.jsx)(l._,{error:Ne});if(De){const e=we?"kuadrant.apikeyrequest.create":Pe?"kuadrant.apikey.delete.own":ze?"kuadrant.apikey.delete.all":"unknown";return(0,n.jsxs)(c.A,{p:2,children:[(0,n.jsxs)(u.A,{color:"error",children:["Unable to check permissions: ",De.message]}),(0,n.jsxs)(u.A,{variant:"body2",color:"textSecondary",children:["Permission: ",e]}),(0,n.jsx)(u.A,{variant:"body2",color:"textSecondary",children:"Please try again or contact your administrator"})]})}const Ke=ve||[],Be=(null==xe||null===(K=xe.spec)||void 0===K?void 0:K.plans)||[],He=Ke.filter(e=>{var t;return!(null===(t=e.status)||void 0===t?void 0:t.phase)||"Pending"===e.status.phase}),Le=Ke.filter(e=>{var t;return"Approved"===(null===(t=e.status)||void 0===t?void 0:t.phase)}),Ve=Ke.filter(e=>{var t;return"Rejected"===(null===(t=e.status)||void 0===t?void 0:t.phase)}),Me=[{title:"Plan Tier",field:"spec.planTier",render:e=>(0,n.jsx)(m.A,{label:e.spec.planTier,color:"primary",size:"small"})},{title:"Approved",field:"status.reviewedAt",render:e=>{var t;return(0,n.jsx)(u.A,{variant:"body2",children:(null===(t=e.status)||void 0===t?void 0:t.reviewedAt)?new Date(e.status.reviewedAt).toLocaleDateString():"-"})}},{title:"API Key",field:"status.apiKey",searchable:!1,render:e=>{var t;const a=_.has(e.metadata.name),r=(null===(t=e.status)||void 0===t?void 0:t.apiKey)||"N/A";return(0,n.jsxs)(c.A,{display:"flex",alignItems:"center",children:[(0,n.jsx)(u.A,{variant:"body2",style:{fontFamily:"monospace",marginRight:8},children:a?r:"••••••••••••••••"}),(0,n.jsx)(v.A,{size:"small",onClick:()=>{return t=e.metadata.name,void U(e=>{const a=new Set(e);return a.has(t)?a.delete(t):a.add(t),a});var t},children:a?(0,n.jsx)(z.A,{}):(0,n.jsx)(S.A,{})})]})}},{title:"Actions",field:"actions",searchable:!1,render:e=>{const t=e.spec.requestedBy.userId;return(0,D.W)(t,O,Ce,Ee)?(0,n.jsx)(v.A,{size:"small",onClick:()=>Te(e.metadata.name,he),color:"secondary",title:"Revoke access and delete key",children:(0,n.jsx)(T.A,{})}):null}}],_e=[{title:"Status",field:"status.phase",render:e=>{var t;const a=(null===(t=e.status)||void 0===t?void 0:t.phase)||"Pending",r="Pending"===a;return(0,n.jsx)(m.A,{label:a,size:"small",icon:r?(0,n.jsx)($.A,{}):(0,n.jsx)(R.A,{}),color:r?"default":"secondary"})}},{title:"Plan Tier",field:"spec.planTier",render:e=>(0,n.jsx)(m.A,{label:e.spec.planTier,color:"primary",size:"small"})},{title:"Use Case",field:"spec.useCase",render:e=>(0,n.jsx)(u.A,{variant:"body2",children:e.spec.useCase||"-"})},{title:"Requested",field:"spec.requestedAt",render:e=>(0,n.jsx)(u.A,{variant:"body2",children:e.spec.requestedAt?new Date(e.spec.requestedAt).toLocaleDateString():"-"})},{title:"Reviewed",field:"status.reviewedAt",render:e=>{var t;return(null===(t=e.status)||void 0===t?void 0:t.reviewedAt)?(0,n.jsx)(u.A,{variant:"body2",children:new Date(e.status.reviewedAt).toLocaleDateString()}):(0,n.jsx)(u.A,{variant:"body2",children:"-"})}},{title:"Reason",field:"status.reason",render:e=>{var t;return(0,n.jsx)(u.A,{variant:"body2",children:(null===(t=e.status)||void 0===t?void 0:t.reason)||"-"})}},{title:"Actions",field:"actions",searchable:!1,render:e=>{var t;const a=!(null===(t=e.status)||void 0===t?void 0:t.phase)||"Pending"===e.status.phase,r=e.spec.requestedBy.userId,i=(0,D.W)(r,O,Ce,Ee);return a&&i?(0,n.jsx)(v.A,{size:"small",onClick:()=>Te(e.metadata.name,he),color:"secondary",children:(0,n.jsx)(T.A,{})}):null}}];return(0,n.jsxs)(c.A,{p:2,children:[(0,n.jsxs)(y.A,{container:!0,spacing:3,direction:"column",children:[ke&&(0,n.jsx)(y.A,{item:!0,children:(0,n.jsxs)(c.A,{display:"flex",flexDirection:"column",alignItems:"flex-end",mb:2,children:[(0,n.jsx)(A.A,{variant:"contained",color:"primary",startIcon:(0,n.jsx)(I.A,{}),onClick:()=>Q(!0),disabled:0===Be.length,children:"Request API Access"}),0===Be.length&&(0,n.jsx)(u.A,{variant:"caption",color:"textSecondary",style:{marginTop:4},children:xe?"No plans available":"API product not found"})]})}),0===He.length&&0===Ve.length&&0===Le.length&&(0,n.jsx)(y.A,{item:!0,children:(0,n.jsx)(c.A,{p:3,textAlign:"center",children:(0,n.jsx)(u.A,{variant:"body1",color:"textSecondary",children:"No API keys yet. Request access to get started."})})}),He.length>0&&(0,n.jsx)(y.A,{item:!0,children:(0,n.jsx)(d.X,{title:"Pending Requests",options:{paging:!1,search:!1},columns:_e,data:He})}),Ve.length>0&&(0,n.jsx)(y.A,{item:!0,children:(0,n.jsx)(d.X,{title:"Rejected Requests",options:{paging:!1,search:!1},columns:_e,data:Ve})}),Le.length>0&&(0,n.jsx)(y.A,{item:!0,children:(0,n.jsx)(d.X,{title:"API Keys",options:{paging:!1,search:!1},columns:Me,data:Le,detailPanel:Re},"api-keys-table")})]}),(0,n.jsxs)(x.A,{open:Y,onClose:()=>Q(!1),maxWidth:"sm",fullWidth:!0,children:[(0,n.jsx)(g.A,{children:"Request API Access"}),(0,n.jsxs)(j.A,{children:[ie&&(0,n.jsx)(c.A,{mb:2,p:2,bgcolor:"error.main",color:"error.contrastText",borderRadius:1,children:(0,n.jsx)(u.A,{variant:"body2",children:ie})}),(0,n.jsxs)(f.A,{fullWidth:!0,margin:"normal",children:[(0,n.jsx)(k.A,{children:"Select Plan Tier"}),(0,n.jsx)(b.A,{value:Z,onChange:e=>ee(e.target.value),children:Be.map(e=>{const t=Object.entries(e.limits||{}).map(([e,t])=>`${t} per ${e}`).join(", ");return(0,n.jsxs)(w.A,{value:e.tier,children:[e.tier," ",t?`(${t})`:""]},e.tier)})})]}),(0,n.jsx)(C.A,{label:"Use Case (optional)",placeholder:"Describe how you plan to use this API",multiline:!0,rows:3,fullWidth:!0,margin:"normal",value:te,onChange:e=>ae(e.target.value),helperText:"Explain your intended use of this API for admin review"})]}),(0,n.jsxs)(q.A,{children:[(0,n.jsx)(A.A,{onClick:()=>Q(!1),children:"Cancel"}),(0,n.jsx)(A.A,{onClick:async()=>{if(Z){re(!0),se(null);try{const e=await V.fetch(`${M}/api/kuadrant/requests`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({apiName:he,apiNamespace:me,userId:O,userEmail:J,planTier:Z,useCase:te.trim()||"",namespace:me})});if(!e.ok){const t=await e.json().catch(()=>({}));throw new Error(t.error||`failed to create request: ${e.status}`)}Q(!1),ee(""),ae(""),G(e=>e+1)}catch(e){console.error("error creating api key request:",e),se(e instanceof Error?e.message:"unknown error occurred")}finally{re(!1)}}},color:"primary",disabled:!Z||ne,children:ne?"Submitting...":"Submit Request"})]})]}),(0,n.jsxs)(x.A,{open:oe,onClose:$e,children:[(0,n.jsx)(g.A,{children:"Confirm Delete"}),(0,n.jsxs)(j.A,{children:[(0,n.jsxs)(u.A,{children:["Are you sure you want to revoke access and delete your API key for ",(0,n.jsx)("strong",{children:null==de?void 0:de.displayName}),"?"]}),(0,n.jsx)(u.A,{variant:"body2",color:"textSecondary",style:{marginTop:8},children:"This action cannot be undone. You will need to request access again if you want to use this API in the future."})]}),(0,n.jsxs)(q.A,{children:[(0,n.jsx)(A.A,{onClick:$e,color:"primary",children:"Cancel"}),(0,n.jsx)(A.A,{onClick:async()=>{if(de){pe(!0);try{if(!(await V.fetch(`${M}/api/kuadrant/requests/${me}/${de.name}`,{method:"DELETE"})).ok)throw new Error("failed to delete request");G(e=>e+1),le(!1),ce(null)}catch(e){console.error("error deleting request:",e)}finally{pe(!1)}}},color:"secondary",disabled:ue,children:ue?"Deleting...":"Delete"})]})]})]})}},61524:(e,t,a)=>{var n=a(4293),r=a(78920);t.A=void 0;var i=r(a(95478)),s=(0,n(a(74044)).default)(i.createElement("path",{d:"M12 7c2.76 0 5 2.24 5 5 0 .65-.13 1.26-.36 1.83l2.92 2.92c1.51-1.26 2.7-2.89 3.43-4.75-1.73-4.39-6-7.5-11-7.5-1.4 0-2.74.25-3.98.7l2.16 2.16C10.74 7.13 11.35 7 12 7zM2 4.27l2.28 2.28.46.46C3.08 8.3 1.78 10.02 1 12c1.73 4.39 6 7.5 11 7.5 1.55 0 3.03-.3 4.38-.84l.42.42L19.73 22 21 20.73 3.27 3 2 4.27zM7.53 9.8l1.55 1.55c-.05.21-.08.43-.08.65 0 1.66 1.34 3 3 3 .22 0 .44-.03.65-.08l1.55 1.55c-.67.33-1.41.53-2.2.53-2.76 0-5-2.24-5-5 0-.79.2-1.53.53-2.2zm4.31-.78l3.15 3.15.02-.16c0-1.66-1.34-3-3-3l-.17.01z"}),"VisibilityOff");t.A=s},93246:(e,t,a)=>{var n=a(4293),r=a(78920);t.A=void 0;var i=r(a(95478)),s=(0,n(a(74044)).default)(i.createElement("path",{d:"M6 2v6h.01L6 8.01 10 12l-4 4 .01.01H6V22h12v-5.99h-.01L18 16l-4-4 4-3.99-.01-.01H18V2H6zm10 14.5V20H8v-3.5l4-4 4 4zm-4-5l-4-4V4h8v3.5l-4 4z"}),"HourglassEmpty");t.A=s}}]);
|
|
2
|
-
//# sourceMappingURL=4306.133aa342.chunk.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"static/4306.133aa342.chunk.js","mappings":"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","sources":["webpack://internal.plugin-kuadrant/../../node_modules/@backstage/plugin-catalog-react/dist/hooks/useEntity.esm.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/icons/Add.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/icons/Visibility.js","webpack://internal.plugin-kuadrant/./src/permissions.ts","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/icons/Delete.js","webpack://internal.plugin-kuadrant/./src/utils/permissions.ts","webpack://internal.plugin-kuadrant/./src/components/ApiKeyManagementTab/ApiKeyManagementTab.tsx","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/icons/VisibilityOff.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/icons/HourglassEmpty.js"],"sourcesContent":["import { jsx } from 'react/jsx-runtime';\nimport { stringifyEntityRef } from '@backstage/catalog-model';\nimport { AnalyticsContext } from '@backstage/core-plugin-api';\nimport { createVersionedContext, useVersionedContext, createVersionedValueMap } from '@backstage/version-bridge';\n\nconst NewEntityContext = createVersionedContext(\n \"entity-context\"\n);\nconst AsyncEntityProvider = (props) => {\n const { children, entity, loading, error, refresh } = props;\n const value = { entity, loading, error, refresh };\n return /* @__PURE__ */ jsx(NewEntityContext.Provider, { value: createVersionedValueMap({ 1: value }), children: /* @__PURE__ */ jsx(\n AnalyticsContext,\n {\n attributes: {\n ...entity ? { entityRef: stringifyEntityRef(entity) } : void 0\n },\n children\n }\n ) });\n};\nconst EntityProvider = (props) => /* @__PURE__ */ jsx(\n AsyncEntityProvider,\n {\n entity: props.entity,\n loading: !Boolean(props.entity),\n error: void 0,\n refresh: void 0,\n children: props.children\n }\n);\nfunction useEntity() {\n const versionedHolder = useVersionedContext(\n \"entity-context\"\n );\n if (!versionedHolder) {\n throw new Error(\"Entity context is not available\");\n }\n const value = versionedHolder.atVersion(1);\n if (!value) {\n throw new Error(\"EntityContext v1 not available\");\n }\n if (!value.entity) {\n throw new Error(\n \"useEntity hook is being called outside of an EntityLayout where the entity has not been loaded. If this is intentional, please use useAsyncEntity instead.\"\n );\n }\n return { entity: value.entity };\n}\nfunction useAsyncEntity() {\n const versionedHolder = useVersionedContext(\n \"entity-context\"\n );\n if (!versionedHolder) {\n throw new Error(\"Entity context is not available\");\n }\n const value = versionedHolder.atVersion(1);\n if (!value) {\n throw new Error(\"EntityContext v1 not available\");\n }\n const { entity, loading, error, refresh } = value;\n return { entity, loading, error, refresh };\n}\n\nexport { AsyncEntityProvider, EntityProvider, useAsyncEntity, useEntity };\n//# sourceMappingURL=useEntity.esm.js.map\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _interopRequireWildcard = require(\"@babel/runtime/helpers/interopRequireWildcard\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z\"\n}), 'Add');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _interopRequireWildcard = require(\"@babel/runtime/helpers/interopRequireWildcard\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5zM12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5zm0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3z\"\n}), 'Visibility');\n\nexports.default = _default;","import { createPermission } from '@backstage/plugin-permission-common';\n\n/**\n * permission definitions for the kuadrant plugin\n *\n * these permissions control access to kuadrant resources and operations.\n * they must match the permissions defined in the backend plugin.\n *\n * permission types:\n * - BasicPermission: standard permission that applies globally\n * - ResourcePermission: permission scoped to specific resource types (e.g., apiproduct)\n *\n * permission patterns:\n * - `.create` - create new resources\n * - `.read` - read resource details\n * - `.read.own` - read only resources owned by the user\n * - `.read.all` - read all resources regardless of ownership\n * - `.update` - modify existing resources\n * - `.delete` - delete resources\n * - `.delete.own` - delete only resources owned by the user\n * - `.delete.all` - delete any resource regardless of ownership\n * - `.list` - list/view collections of resources\n */\n\n// planpolicy permissions\nexport const kuadrantPlanPolicyCreatePermission = createPermission({\n name: 'kuadrant.planpolicy.create',\n attributes: { action: 'create' },\n});\n\nexport const kuadrantPlanPolicyReadPermission = createPermission({\n name: 'kuadrant.planpolicy.read',\n attributes: { action: 'read' },\n});\n\nexport const kuadrantPlanPolicyUpdatePermission = createPermission({\n name: 'kuadrant.planpolicy.update',\n attributes: { action: 'update' },\n});\n\nexport const kuadrantPlanPolicyDeletePermission = createPermission({\n name: 'kuadrant.planpolicy.delete',\n attributes: { action: 'delete' },\n});\n\nexport const kuadrantPlanPolicyListPermission = createPermission({\n name: 'kuadrant.planpolicy.list',\n attributes: { action: 'read' },\n});\n\n// apiproduct permissions\nexport const kuadrantApiProductCreatePermission = createPermission({\n name: 'kuadrant.apiproduct.create',\n attributes: { action: 'create' },\n});\n\nexport const kuadrantApiProductReadPermission = createPermission({\n name: 'kuadrant.apiproduct.read',\n attributes: { action: 'read' },\n});\n\nexport const kuadrantApiProductUpdatePermission = createPermission({\n name: 'kuadrant.apiproduct.update',\n attributes: { action: 'update' },\n});\n\nexport const kuadrantApiProductDeletePermission = createPermission({\n name: 'kuadrant.apiproduct.delete',\n attributes: { action: 'delete' },\n});\n\nexport const kuadrantApiProductListPermission = createPermission({\n name: 'kuadrant.apiproduct.list',\n attributes: { action: 'read' },\n});\n\n// apikeyrequest permissions\n\n/**\n * permission to create API key requests\n *\n * this is a ResourcePermission scoped to 'apiproduct', allowing\n * fine-grained control over which API products users can request access to.\n *\n * use in frontend: useKuadrantPermission(kuadrantApiKeyRequestCreatePermission)\n * use in backend with resource: { permission, resourceRef: 'apiproduct:namespace/name' }\n */\nexport const kuadrantApiKeyRequestCreatePermission = createPermission({\n name: 'kuadrant.apikeyrequest.create',\n attributes: { action: 'create' },\n resourceType: 'apiproduct',\n});\n\n/**\n * permission to read API key requests created by the current user\n * use this for allowing users to see their own request history\n */\nexport const kuadrantApiKeyRequestReadOwnPermission = createPermission({\n name: 'kuadrant.apikeyrequest.read.own',\n attributes: { action: 'read' },\n});\n\n/**\n * permission to read all API key requests regardless of who created them\n * use this for platform engineers/admins who need to view the approval queue\n */\nexport const kuadrantApiKeyRequestReadAllPermission = createPermission({\n name: 'kuadrant.apikeyrequest.read.all',\n attributes: { action: 'read' },\n});\n\n/**\n * permission to approve or reject API key requests\n * typically granted to API owners and platform engineers\n */\nexport const kuadrantApiKeyRequestUpdatePermission = createPermission({\n name: 'kuadrant.apikeyrequest.update',\n attributes: { action: 'update' },\n});\n\nexport const kuadrantApiKeyRequestListPermission = createPermission({\n name: 'kuadrant.apikeyrequest.list',\n attributes: { action: 'read' },\n});\n\n// api key permissions\n\n/**\n * permission to read API keys owned by the current user\n * allows users to view their own active API keys\n */\nexport const kuadrantApiKeyReadOwnPermission = createPermission({\n name: 'kuadrant.apikey.read.own',\n attributes: { action: 'read' },\n});\n\n/**\n * permission to read all API keys regardless of ownership\n * for platform engineers/admins who need to audit keys\n */\nexport const kuadrantApiKeyReadAllPermission = createPermission({\n name: 'kuadrant.apikey.read.all',\n attributes: { action: 'read' },\n});\n\n/**\n * permission to delete API keys owned by the current user\n * allows users to revoke their own access\n */\nexport const kuadrantApiKeyDeleteOwnPermission = createPermission({\n name: 'kuadrant.apikey.delete.own',\n attributes: { action: 'delete' },\n});\n\n/**\n * permission to delete any API key regardless of ownership\n * for platform engineers/admins who need to revoke access\n */\nexport const kuadrantApiKeyDeleteAllPermission = createPermission({\n name: 'kuadrant.apikey.delete.all',\n attributes: { action: 'delete' },\n});\n\nexport const kuadrantPermissions = [\n kuadrantPlanPolicyCreatePermission,\n kuadrantPlanPolicyReadPermission,\n kuadrantPlanPolicyUpdatePermission,\n kuadrantPlanPolicyDeletePermission,\n kuadrantPlanPolicyListPermission,\n kuadrantApiProductCreatePermission,\n kuadrantApiProductReadPermission,\n kuadrantApiProductUpdatePermission,\n kuadrantApiProductDeletePermission,\n kuadrantApiProductListPermission,\n kuadrantApiKeyRequestCreatePermission,\n kuadrantApiKeyRequestReadOwnPermission,\n kuadrantApiKeyRequestReadAllPermission,\n kuadrantApiKeyRequestUpdatePermission,\n kuadrantApiKeyRequestListPermission,\n kuadrantApiKeyReadOwnPermission,\n kuadrantApiKeyReadAllPermission,\n kuadrantApiKeyDeleteOwnPermission,\n kuadrantApiKeyDeleteAllPermission,\n];\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _interopRequireWildcard = require(\"@babel/runtime/helpers/interopRequireWildcard\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z\"\n}), 'Delete');\n\nexports.default = _default;","import { usePermission } from '@backstage/plugin-permission-react';\nimport { Permission, ResourcePermission } from '@backstage/plugin-permission-common';\n\n/**\n * result of a permission check including error state\n */\nexport interface PermissionCheckResult {\n allowed: boolean;\n loading: boolean;\n error?: Error;\n}\n\n/**\n * custom hook for checking kuadrant permissions that handles both\n * BasicPermission and ResourcePermission types without type bypasses\n *\n * @param permission - the permission to check\n * @param resourceRef - optional resource reference for ResourcePermissions\n * @returns permission check result with error handling\n *\n * @example\n * // basic permission\n * const { allowed, loading, error } = useKuadrantPermission(\n * kuadrantApiProductListPermission\n * );\n *\n * @example\n * // resource permission\n * const { allowed, loading, error } = useKuadrantPermission(\n * kuadrantApiKeyRequestCreatePermission,\n * 'apiproduct:namespace/name'\n * );\n */\nexport function useKuadrantPermission(\n permission: Permission,\n resourceRef?: string,\n): PermissionCheckResult {\n // construct the permission request based on whether it's a ResourcePermission\n const permissionRequest = 'resourceType' in permission\n ? { permission: permission as ResourcePermission, resourceRef }\n : { permission };\n\n const result = usePermission(permissionRequest as any);\n\n return {\n allowed: result.allowed,\n loading: result.loading,\n error: result.error,\n };\n}\n\n/**\n * helper to determine if a user can delete a specific API key or request\n *\n * @param ownerId - the user id who owns the key/request\n * @param currentUserId - the current user's id\n * @param canDeleteOwn - whether user has permission to delete their own keys\n * @param canDeleteAll - whether user has permission to delete all keys\n * @returns true if user can delete this specific key/request\n */\nexport function canDeleteResource(\n ownerId: string,\n currentUserId: string,\n canDeleteOwn: boolean,\n canDeleteAll: boolean,\n): boolean {\n if (canDeleteAll) return true;\n if (canDeleteOwn && ownerId === currentUserId) return true;\n return false;\n}\n","import React, { useState, useMemo } from 'react';\nimport { useAsync } from 'react-use';\nimport {\n Table,\n TableColumn,\n Progress,\n ResponseErrorPanel,\n CodeSnippet,\n} from '@backstage/core-components';\nimport {\n IconButton,\n Typography,\n Box,\n Chip,\n Grid,\n Button,\n Dialog,\n DialogTitle,\n DialogContent,\n DialogActions,\n TextField,\n Select,\n MenuItem,\n FormControl,\n InputLabel,\n Tabs,\n Tab,\n} from '@material-ui/core';\nimport { useApi, configApiRef, identityApiRef, fetchApiRef } from '@backstage/core-plugin-api';\nimport { useEntity } from '@backstage/plugin-catalog-react';\nimport VisibilityIcon from '@material-ui/icons/Visibility';\nimport VisibilityOffIcon from '@material-ui/icons/VisibilityOff';\nimport DeleteIcon from '@material-ui/icons/Delete';\nimport HourglassEmptyIcon from '@material-ui/icons/HourglassEmpty';\nimport CancelIcon from '@material-ui/icons/Cancel';\nimport AddIcon from '@material-ui/icons/Add';\nimport { APIKeyRequest } from '../../types/api-management';\nimport {\n kuadrantApiKeyRequestCreatePermission,\n kuadrantApiKeyDeleteOwnPermission,\n kuadrantApiKeyDeleteAllPermission,\n} from '../../permissions';\nimport { useKuadrantPermission, canDeleteResource } from '../../utils/permissions';\n\ninterface APIProduct {\n metadata: {\n name: string;\n namespace: string;\n };\n spec: {\n plans?: Array<{\n tier: string;\n description?: string;\n limits?: any;\n }>;\n };\n}\n\ninterface Plan {\n tier: string;\n limits: any;\n}\n\nexport interface ApiKeyManagementTabProps {\n namespace?: string;\n}\n\nexport const ApiKeyManagementTab = ({ namespace: propNamespace }: ApiKeyManagementTabProps) => {\n const { entity } = useEntity();\n const config = useApi(configApiRef);\n const identityApi = useApi(identityApiRef);\n const fetchApi = useApi(fetchApiRef);\n const backendUrl = config.getString('backend.baseUrl');\n const [visibleKeys, setVisibleKeys] = useState<Set<string>>(new Set());\n const [refresh, setRefresh] = useState(0);\n const [userId, setUserId] = useState<string>('guest');\n const [userEmail, setUserEmail] = useState<string>('');\n const [open, setOpen] = useState(false);\n const [selectedPlan, setSelectedPlan] = useState('');\n const [useCase, setUseCase] = useState('');\n const [creating, setCreating] = useState(false);\n const [createError, setCreateError] = useState<string | null>(null);\n const [deleteDialogOpen, setDeleteDialogOpen] = useState(false);\n const [requestToDelete, setRequestToDelete] = useState<{ name: string; displayName: string } | null>(null);\n const [deleting, setDeleting] = useState(false);\n\n // get apiproduct name from entity annotation (set by entity provider)\n const apiProductName = entity.metadata.annotations?.['kuadrant.io/apiproduct'] || entity.metadata.name;\n const namespace = entity.metadata.annotations?.['kuadrant.io/namespace'] || propNamespace || 'default';\n\n useAsync(async () => {\n const identity = await identityApi.getBackstageIdentity();\n const profile = await identityApi.getProfileInfo();\n setUserId(identity.userEntityRef.split('/')[1] || 'guest');\n setUserEmail(profile.email || '');\n }, [identityApi]);\n\n const { value: requests, loading: requestsLoading, error: requestsError } = useAsync(async () => {\n const response = await fetchApi.fetch(\n `${backendUrl}/api/kuadrant/requests/my?namespace=${namespace}`\n );\n if (!response.ok) {\n throw new Error('failed to fetch requests');\n }\n const data = await response.json();\n // filter by apiproduct name, not httproute name\n return (data.items || []).filter(\n (r: APIKeyRequest) => r.spec.apiName === apiProductName && r.spec.apiNamespace === namespace\n );\n }, [apiProductName, namespace, refresh, fetchApi, backendUrl]);\n\n const { value: apiProduct, loading: plansLoading, error: plansError } = useAsync(async () => {\n const response = await fetchApi.fetch(`${backendUrl}/api/kuadrant/apiproducts`);\n if (!response.ok) {\n throw new Error('failed to fetch api products');\n }\n const data = await response.json();\n\n const product = data.items?.find((p: APIProduct) =>\n p.metadata.namespace === namespace &&\n p.metadata.name === apiProductName\n );\n\n return product;\n }, [namespace, apiProductName, fetchApi]);\n\n // check permissions with resource reference once we have the apiproduct\n const resourceRef = apiProduct ? `apiproduct:${apiProduct.metadata.namespace}/${apiProduct.metadata.name}` : undefined;\n\n const {\n allowed: canCreateRequest,\n loading: createRequestPermissionLoading,\n error: createRequestPermissionError,\n } = useKuadrantPermission(kuadrantApiKeyRequestCreatePermission, resourceRef);\n\n const {\n allowed: canDeleteOwnKey,\n loading: deleteOwnPermissionLoading,\n error: deleteOwnPermissionError,\n } = useKuadrantPermission(kuadrantApiKeyDeleteOwnPermission);\n\n const {\n allowed: canDeleteAllKeys,\n loading: deleteAllPermissionLoading,\n error: deleteAllPermissionError,\n } = useKuadrantPermission(kuadrantApiKeyDeleteAllPermission);\n\n const handleDeleteClick = (name: string, displayName: string) => {\n setRequestToDelete({ name, displayName });\n setDeleteDialogOpen(true);\n };\n\n const handleDeleteConfirm = async () => {\n if (!requestToDelete) return;\n\n setDeleting(true);\n try {\n const response = await fetchApi.fetch(\n `${backendUrl}/api/kuadrant/requests/${namespace}/${requestToDelete.name}`,\n { method: 'DELETE' }\n );\n if (!response.ok) {\n throw new Error('failed to delete request');\n }\n setRefresh(r => r + 1);\n setDeleteDialogOpen(false);\n setRequestToDelete(null);\n } catch (err) {\n console.error('error deleting request:', err);\n } finally {\n setDeleting(false);\n }\n };\n\n const handleDeleteCancel = () => {\n setDeleteDialogOpen(false);\n setRequestToDelete(null);\n };\n\n const toggleVisibility = (keyName: string) => {\n setVisibleKeys(prev => {\n const newSet = new Set(prev);\n if (newSet.has(keyName)) {\n newSet.delete(keyName);\n } else {\n newSet.add(keyName);\n }\n return newSet;\n });\n };\n\n const handleRequestAccess = async () => {\n if (!selectedPlan) return;\n\n setCreating(true);\n setCreateError(null);\n try {\n const response = await fetchApi.fetch(`${backendUrl}/api/kuadrant/requests`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n apiName: apiProductName,\n apiNamespace: namespace,\n userId,\n userEmail,\n planTier: selectedPlan,\n useCase: useCase.trim() || '',\n namespace,\n }),\n });\n\n if (!response.ok) {\n const errorData = await response.json().catch(() => ({}));\n throw new Error(errorData.error || `failed to create request: ${response.status}`);\n }\n\n setOpen(false);\n setSelectedPlan('');\n setUseCase('');\n setRefresh(r => r + 1);\n } catch (err) {\n console.error('error creating api key request:', err);\n setCreateError(err instanceof Error ? err.message : 'unknown error occurred');\n } finally {\n setCreating(false);\n }\n };\n\n const detailPanelConfig = useMemo(() => [\n {\n render: (data: any) => {\n // backstage Table wraps the data in { rowData: actualData }\n const request = data.rowData as APIKeyRequest;\n if (!request?.metadata?.name) {\n return <Box />;\n }\n\n return <DetailPanelContent request={request} apiName={apiProductName} />;\n },\n },\n ], [apiProductName]);\n\n // separate component to isolate state\n const DetailPanelContent = ({ request, apiName: api }: { request: APIKeyRequest; apiName: string }) => {\n const [selectedLanguage, setSelectedLanguage] = useState(0);\n const hostname = request.status?.apiHostname || `${api}.apps.example.com`;\n\n return (\n <Box p={3} bgcolor=\"background.default\" onClick={(e) => e.stopPropagation()}>\n <Typography variant=\"h6\" gutterBottom>\n Usage Examples\n </Typography>\n <Typography variant=\"body2\" paragraph>\n Use these code examples to test the API with your {request.spec.planTier} tier key.\n </Typography>\n <Box onClick={(e) => e.stopPropagation()}>\n <Tabs\n value={selectedLanguage}\n onChange={(e, newValue) => {\n e.stopPropagation();\n setSelectedLanguage(newValue);\n }}\n indicatorColor=\"primary\"\n >\n <Tab label=\"cURL\" onClick={(e) => e.stopPropagation()} />\n <Tab label=\"Node.js\" onClick={(e) => e.stopPropagation()} />\n <Tab label=\"Python\" onClick={(e) => e.stopPropagation()} />\n <Tab label=\"Go\" onClick={(e) => e.stopPropagation()} />\n </Tabs>\n </Box>\n <Box mt={2}>\n {selectedLanguage === 0 && (\n <CodeSnippet\n text={`curl -X GET https://${hostname}/api/v1/endpoint \\\\\n -H \"Authorization: Bearer ${request.status?.apiKey}\"`}\n language=\"bash\"\n showCopyCodeButton\n />\n )}\n {selectedLanguage === 1 && (\n <CodeSnippet\n text={`const fetch = require('node-fetch');\n\nconst apiKey = '${request.status?.apiKey}';\nconst endpoint = 'https://${hostname}/api/v1/endpoint';\n\nfetch(endpoint, {\n method: 'GET',\n headers: {\n 'Authorization': \\`Bearer \\${apiKey}\\`\n }\n})\n .then(response => response.json())\n .then(data => console.log(data))\n .catch(error => console.error('Error:', error));`}\n language=\"javascript\"\n showCopyCodeButton\n />\n )}\n {selectedLanguage === 2 && (\n <CodeSnippet\n text={`import requests\n\napi_key = '${request.status?.apiKey}'\nendpoint = 'https://${hostname}/api/v1/endpoint'\n\nheaders = {\n 'Authorization': f'Bearer {api_key}'\n}\n\nresponse = requests.get(endpoint, headers=headers)\nprint(response.json())`}\n language=\"python\"\n showCopyCodeButton\n />\n )}\n {selectedLanguage === 3 && (\n <CodeSnippet\n text={`package main\n\nimport (\n \"fmt\"\n \"net/http\"\n \"io\"\n)\n\nfunc main() {\n apiKey := \"${request.status?.apiKey}\"\n endpoint := \"https://${hostname}/api/v1/endpoint\"\n\n client := &http.Client{}\n req, _ := http.NewRequest(\"GET\", endpoint, nil)\n req.Header.Add(\"Authorization\", \"Bearer \" + apiKey)\n\n resp, err := client.Do(req)\n if err != nil {\n fmt.Println(\"Error:\", err)\n return\n }\n defer resp.Body.Close()\n\n body, _ := io.ReadAll(resp.Body)\n fmt.Println(string(body))\n}`}\n language=\"go\"\n showCopyCodeButton\n />\n )}\n </Box>\n </Box>\n );\n };\n\n const loading = requestsLoading || plansLoading || createRequestPermissionLoading || deleteOwnPermissionLoading || deleteAllPermissionLoading;\n const error = requestsError || plansError;\n const permissionError = createRequestPermissionError || deleteOwnPermissionError || deleteAllPermissionError;\n\n if (loading) {\n return <Progress />;\n }\n\n if (error) {\n return <ResponseErrorPanel error={error} />;\n }\n\n if (permissionError) {\n const failedPermission = createRequestPermissionError ? 'kuadrant.apikeyrequest.create' :\n deleteOwnPermissionError ? 'kuadrant.apikey.delete.own' :\n deleteAllPermissionError ? 'kuadrant.apikey.delete.all' : 'unknown';\n return (\n <Box p={2}>\n <Typography color=\"error\">\n Unable to check permissions: {permissionError.message}\n </Typography>\n <Typography variant=\"body2\" color=\"textSecondary\">\n Permission: {failedPermission}\n </Typography>\n <Typography variant=\"body2\" color=\"textSecondary\">\n Please try again or contact your administrator\n </Typography>\n </Box>\n );\n }\n\n const myRequests = (requests || []) as APIKeyRequest[];\n const plans = (apiProduct?.spec?.plans || []) as Plan[];\n\n const pendingRequests = myRequests.filter(r => !r.status?.phase || r.status.phase === 'Pending');\n const approvedRequests = myRequests.filter(r => r.status?.phase === 'Approved');\n const rejectedRequests = myRequests.filter(r => r.status?.phase === 'Rejected');\n\n const approvedColumns: TableColumn<APIKeyRequest>[] = [\n {\n title: 'Plan Tier',\n field: 'spec.planTier',\n render: (row: APIKeyRequest) => (\n <Chip label={row.spec.planTier} color=\"primary\" size=\"small\" />\n ),\n },\n {\n title: 'Approved',\n field: 'status.reviewedAt',\n render: (row: APIKeyRequest) => (\n <Typography variant=\"body2\">\n {row.status?.reviewedAt ? new Date(row.status.reviewedAt).toLocaleDateString() : '-'}\n </Typography>\n ),\n },\n {\n title: 'API Key',\n field: 'status.apiKey',\n searchable: false,\n render: (row: APIKeyRequest) => {\n const isVisible = visibleKeys.has(row.metadata.name);\n const apiKey = row.status?.apiKey || 'N/A';\n\n return (\n <Box display=\"flex\" alignItems=\"center\">\n <Typography\n variant=\"body2\"\n style={{\n fontFamily: 'monospace',\n marginRight: 8,\n }}\n >\n {isVisible ? apiKey : '••••••••••••••••'}\n </Typography>\n <IconButton\n size=\"small\"\n onClick={() => toggleVisibility(row.metadata.name)}\n >\n {isVisible ? <VisibilityOffIcon /> : <VisibilityIcon />}\n </IconButton>\n </Box>\n );\n },\n },\n {\n title: 'Actions',\n field: 'actions',\n searchable: false,\n render: (row: APIKeyRequest) => {\n const ownerId = row.spec.requestedBy.userId;\n const canDelete = canDeleteResource(ownerId, userId, canDeleteOwnKey, canDeleteAllKeys);\n if (!canDelete) return null;\n return (\n <IconButton\n size=\"small\"\n onClick={() => handleDeleteClick(row.metadata.name, apiProductName)}\n color=\"secondary\"\n title=\"Revoke access and delete key\"\n >\n <DeleteIcon />\n </IconButton>\n );\n },\n },\n ];\n\n const requestColumns: TableColumn<APIKeyRequest>[] = [\n {\n title: 'Status',\n field: 'status.phase',\n render: (row: APIKeyRequest) => {\n const phase = row.status?.phase || 'Pending';\n const isPending = phase === 'Pending';\n return (\n <Chip\n label={phase}\n size=\"small\"\n icon={isPending ? <HourglassEmptyIcon /> : <CancelIcon />}\n color={isPending ? 'default' : 'secondary'}\n />\n );\n },\n },\n {\n title: 'Plan Tier',\n field: 'spec.planTier',\n render: (row: APIKeyRequest) => (\n <Chip label={row.spec.planTier} color=\"primary\" size=\"small\" />\n ),\n },\n {\n title: 'Use Case',\n field: 'spec.useCase',\n render: (row: APIKeyRequest) => (\n <Typography variant=\"body2\">{row.spec.useCase || '-'}</Typography>\n ),\n },\n {\n title: 'Requested',\n field: 'spec.requestedAt',\n render: (row: APIKeyRequest) => (\n <Typography variant=\"body2\">\n {row.spec.requestedAt ? new Date(row.spec.requestedAt).toLocaleDateString() : '-'}\n </Typography>\n ),\n },\n {\n title: 'Reviewed',\n field: 'status.reviewedAt',\n render: (row: APIKeyRequest) => {\n if (!row.status?.reviewedAt) return <Typography variant=\"body2\">-</Typography>;\n return (\n <Typography variant=\"body2\">\n {new Date(row.status.reviewedAt).toLocaleDateString()}\n </Typography>\n );\n },\n },\n {\n title: 'Reason',\n field: 'status.reason',\n render: (row: APIKeyRequest) => (\n <Typography variant=\"body2\">{row.status?.reason || '-'}</Typography>\n ),\n },\n {\n title: 'Actions',\n field: 'actions',\n searchable: false,\n render: (row: APIKeyRequest) => {\n const isPending = !row.status?.phase || row.status.phase === 'Pending';\n const ownerId = row.spec.requestedBy.userId;\n const canDelete = canDeleteResource(ownerId, userId, canDeleteOwnKey, canDeleteAllKeys);\n if (!isPending || !canDelete) return null;\n return (\n <IconButton\n size=\"small\"\n onClick={() => handleDeleteClick(row.metadata.name, apiProductName)}\n color=\"secondary\"\n >\n <DeleteIcon />\n </IconButton>\n );\n },\n },\n ];\n\n return (\n <Box p={2}>\n <Grid container spacing={3} direction=\"column\">\n {canCreateRequest && (\n <Grid item>\n <Box display=\"flex\" flexDirection=\"column\" alignItems=\"flex-end\" mb={2}>\n <Button\n variant=\"contained\"\n color=\"primary\"\n startIcon={<AddIcon />}\n onClick={() => setOpen(true)}\n disabled={plans.length === 0}\n >\n Request API Access\n </Button>\n {plans.length === 0 && (\n <Typography variant=\"caption\" color=\"textSecondary\" style={{ marginTop: 4 }}>\n {!apiProduct ? 'API product not found' : 'No plans available'}\n </Typography>\n )}\n </Box>\n </Grid>\n )}\n {pendingRequests.length === 0 && rejectedRequests.length === 0 && approvedRequests.length === 0 && (\n <Grid item>\n <Box p={3} textAlign=\"center\">\n <Typography variant=\"body1\" color=\"textSecondary\">\n No API keys yet. Request access to get started.\n </Typography>\n </Box>\n </Grid>\n )}\n {pendingRequests.length > 0 && (\n <Grid item>\n <Table\n title=\"Pending Requests\"\n options={{\n paging: false,\n search: false,\n }}\n columns={requestColumns}\n data={pendingRequests}\n />\n </Grid>\n )}\n {rejectedRequests.length > 0 && (\n <Grid item>\n <Table\n title=\"Rejected Requests\"\n options={{\n paging: false,\n search: false,\n }}\n columns={requestColumns}\n data={rejectedRequests}\n />\n </Grid>\n )}\n {approvedRequests.length > 0 && (\n <Grid item>\n <Table\n key=\"api-keys-table\"\n title=\"API Keys\"\n options={{\n paging: false,\n search: false,\n }}\n columns={approvedColumns}\n data={approvedRequests}\n detailPanel={detailPanelConfig}\n />\n </Grid>\n )}\n </Grid>\n\n <Dialog open={open} onClose={() => setOpen(false)} maxWidth=\"sm\" fullWidth>\n <DialogTitle>Request API Access</DialogTitle>\n <DialogContent>\n {createError && (\n <Box mb={2} p={2} bgcolor=\"error.main\" color=\"error.contrastText\" borderRadius={1}>\n <Typography variant=\"body2\">{createError}</Typography>\n </Box>\n )}\n <FormControl fullWidth margin=\"normal\">\n <InputLabel>Select Plan Tier</InputLabel>\n <Select\n value={selectedPlan}\n onChange={(e) => setSelectedPlan(e.target.value as string)}\n >\n {plans.map((plan: Plan) => {\n const limitDesc = Object.entries(plan.limits || {})\n .map(([key, val]) => `${val} per ${key}`)\n .join(', ');\n return (\n <MenuItem key={plan.tier} value={plan.tier}>\n {plan.tier} {limitDesc ? `(${limitDesc})` : ''}\n </MenuItem>\n );\n })}\n </Select>\n </FormControl>\n <TextField\n label=\"Use Case (optional)\"\n placeholder=\"Describe how you plan to use this API\"\n multiline\n rows={3}\n fullWidth\n margin=\"normal\"\n value={useCase}\n onChange={(e) => setUseCase(e.target.value)}\n helperText=\"Explain your intended use of this API for admin review\"\n />\n </DialogContent>\n <DialogActions>\n <Button onClick={() => setOpen(false)}>Cancel</Button>\n <Button\n onClick={handleRequestAccess}\n color=\"primary\"\n disabled={!selectedPlan || creating}\n >\n {creating ? 'Submitting...' : 'Submit Request'}\n </Button>\n </DialogActions>\n </Dialog>\n\n <Dialog open={deleteDialogOpen} onClose={handleDeleteCancel}>\n <DialogTitle>Confirm Delete</DialogTitle>\n <DialogContent>\n <Typography>\n Are you sure you want to revoke access and delete your API key for <strong>{requestToDelete?.displayName}</strong>?\n </Typography>\n <Typography variant=\"body2\" color=\"textSecondary\" style={{ marginTop: 8 }}>\n This action cannot be undone. You will need to request access again if you want to use this API in the future.\n </Typography>\n </DialogContent>\n <DialogActions>\n <Button onClick={handleDeleteCancel} color=\"primary\">\n Cancel\n </Button>\n <Button onClick={handleDeleteConfirm} color=\"secondary\" disabled={deleting}>\n {deleting ? 'Deleting...' : 'Delete'}\n </Button>\n </DialogActions>\n </Dialog>\n </Box>\n );\n};\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _interopRequireWildcard = require(\"@babel/runtime/helpers/interopRequireWildcard\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M12 7c2.76 0 5 2.24 5 5 0 .65-.13 1.26-.36 1.83l2.92 2.92c1.51-1.26 2.7-2.89 3.43-4.75-1.73-4.39-6-7.5-11-7.5-1.4 0-2.74.25-3.98.7l2.16 2.16C10.74 7.13 11.35 7 12 7zM2 4.27l2.28 2.28.46.46C3.08 8.3 1.78 10.02 1 12c1.73 4.39 6 7.5 11 7.5 1.55 0 3.03-.3 4.38-.84l.42.42L19.73 22 21 20.73 3.27 3 2 4.27zM7.53 9.8l1.55 1.55c-.05.21-.08.43-.08.65 0 1.66 1.34 3 3 3 .22 0 .44-.03.65-.08l1.55 1.55c-.67.33-1.41.53-2.2.53-2.76 0-5-2.24-5-5 0-.79.2-1.53.53-2.2zm4.31-.78l3.15 3.15.02-.16c0-1.66-1.34-3-3-3l-.17.01z\"\n}), 'VisibilityOff');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _interopRequireWildcard = require(\"@babel/runtime/helpers/interopRequireWildcard\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M6 2v6h.01L6 8.01 10 12l-4 4 .01.01H6V22h12v-5.99h-.01L18 16l-4-4 4-3.99-.01-.01H18V2H6zm10 14.5V20H8v-3.5l4-4 4 4zm-4-5l-4-4V4h8v3.5l-4 4z\"\n}), 'HourglassEmpty');\n\nexports.default = _default;"],"names":["useEntity","versionedHolder","useVersionedContext","Error","value","atVersion","entity","createVersionedContext","_interopRequireDefault","_interopRequireWildcard","exports","React","_default","default","createElement","d","createPermission","name","attributes","action","kuadrantPlanPolicyListPermission","kuadrantApiProductCreatePermission","kuadrantApiProductUpdatePermission","kuadrantApiProductDeletePermission","kuadrantApiProductListPermission","kuadrantApiKeyRequestCreatePermission","resourceType","kuadrantApiKeyRequestReadAllPermission","kuadrantApiKeyRequestUpdatePermission","kuadrantApiKeyDeleteOwnPermission","kuadrantApiKeyDeleteAllPermission","useKuadrantPermission","permission","resourceRef","permissionRequest","result","usePermission","allowed","loading","error","canDeleteResource","ownerId","currentUserId","canDeleteOwn","canDeleteAll","ApiKeyManagementTab","namespace","propNamespace","apiProduct","config","useApi","configApiRef","identityApi","identityApiRef","fetchApi","fetchApiRef","backendUrl","getString","visibleKeys","setVisibleKeys","useState","Set","refresh","setRefresh","userId","setUserId","userEmail","setUserEmail","open","setOpen","selectedPlan","setSelectedPlan","useCase","setUseCase","creating","setCreating","createError","setCreateError","deleteDialogOpen","setDeleteDialogOpen","requestToDelete","setRequestToDelete","deleting","setDeleting","apiProductName","metadata","annotations","useAsync","async","identity","getBackstageIdentity","profile","getProfileInfo","userEntityRef","split","email","requests","requestsLoading","requestsError","response","fetch","ok","json","items","filter","r","spec","apiName","apiNamespace","plansLoading","plansError","data","find","p","undefined","canCreateRequest","createRequestPermissionLoading","createRequestPermissionError","canDeleteOwnKey","deleteOwnPermissionLoading","deleteOwnPermissionError","canDeleteAllKeys","deleteAllPermissionLoading","deleteAllPermissionError","handleDeleteClick","displayName","handleDeleteCancel","detailPanelConfig","useMemo","render","request","rowData","DetailPanelContent","Box","api","selectedLanguage","setSelectedLanguage","hostname","status","apiHostname","bgcolor","onClick","e","stopPropagation","Typography","variant","gutterBottom","paragraph","planTier","Tabs","onChange","newValue","indicatorColor","Tab","label","mt","CodeSnippet","text","apiKey","language","showCopyCodeButton","permissionError","Progress","ResponseErrorPanel","failedPermission","color","message","myRequests","plans","pendingRequests","phase","approvedRequests","rejectedRequests","approvedColumns","title","field","row","Chip","size","reviewedAt","Date","toLocaleDateString","searchable","isVisible","has","display","alignItems","style","fontFamily","marginRight","IconButton","toggleVisibility","keyName","prev","newSet","delete","add","VisibilityOffIcon","VisibilityIcon","requestedBy","DeleteIcon","requestColumns","isPending","icon","HourglassEmptyIcon","CancelIcon","requestedAt","reason","canDelete","Grid","container","spacing","direction","item","flexDirection","mb","Button","startIcon","AddIcon","disabled","length","marginTop","textAlign","Table","options","paging","search","columns","detailPanel","Dialog","onClose","maxWidth","fullWidth","DialogTitle","DialogContent","borderRadius","FormControl","margin","InputLabel","Select","target","map","plan","limitDesc","Object","entries","limits","key","val","join","MenuItem","tier","TextField","placeholder","multiline","rows","helperText","DialogActions","method","headers","body","JSON","stringify","trim","errorData","catch","err","console","strong"],"sourceRoot":""}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";(self.webpackChunkinternal_plugin_kuadrant=self.webpackChunkinternal_plugin_kuadrant||[]).push([[5453],{5030:(e,t,n)=>{Object.defineProperty(t,"__esModule",{value:!0});var a=n(85608),r=n(95478),i=a.__importDefault(n(10009));t.default=function(e,t,n){void 0===t&&(t=[]),void 0===n&&(n={loading:!1});var o=r.useRef(0),s=i.default(),l=r.useState(n),c=l[0],d=l[1],p=r.useCallback(function(){for(var t=[],n=0;n<arguments.length;n++)t[n]=arguments[n];var r=++o.current;return c.loading||d(function(e){return a.__assign(a.__assign({},e),{loading:!0})}),e.apply(void 0,t).then(function(e){return s()&&r===o.current&&d({value:e,loading:!1}),e},function(e){return s()&&r===o.current&&d({error:e,loading:!1}),e})},t);return[c,p]}},9719:(e,t,n)=>{n.d(t,{A:()=>p});var a=n(89575),r=n(39850),i=n(95478),o=n(36274),s=n(7031),l=n(75614),c=n(268),d=i.forwardRef(function(e,t){var n=e.classes,s=e.className,c=e.component,d=void 0===c?"tr":c,p=e.hover,h=void 0!==p&&p,u=e.selected,x=void 0!==u&&u,m=(0,r.A)(e,["classes","className","component","hover","selected"]),g=i.useContext(l.A);return i.createElement(d,(0,a.A)({ref:t,className:(0,o.A)(n.root,s,g&&{head:n.head,footer:n.footer}[g.variant],h&&n.hover,x&&n.selected),role:"tr"===d?null:"row"},m))});const p=(0,s.A)(function(e){return{root:{color:"inherit",display:"table-row",verticalAlign:"middle",outline:0,"&$hover:hover":{backgroundColor:e.palette.action.hover},"&$selected, &$selected:hover":{backgroundColor:(0,c.X4)(e.palette.secondary.main,e.palette.action.selectedOpacity)}},selected:{},hover:{},head:{},footer:{}}},{name:"MuiTableRow"})(d)},10009:(e,t,n)=>{Object.defineProperty(t,"__esModule",{value:!0});var a=n(95478);t.default=function(){var e=a.useRef(!1),t=a.useCallback(function(){return e.current},[]);return a.useEffect(function(){return e.current=!0,function(){e.current=!1}},[]),t}},13677:(e,t,n)=>{n.d(t,{A:()=>h});var a=n(89575),r=n(39850),i=n(95478),o=n(36274),s=n(7031),l=n(75614),c={variant:"body"},d="tbody",p=i.forwardRef(function(e,t){var n=e.classes,s=e.className,p=e.component,h=void 0===p?d:p,u=(0,r.A)(e,["classes","className","component"]);return i.createElement(l.A.Provider,{value:c},i.createElement(h,(0,a.A)({className:(0,o.A)(n.root,s),ref:t,role:h===d?null:"rowgroup"},u)))});const h=(0,s.A)({root:{display:"table-row-group"}},{name:"MuiTableBody"})(p)},16400:(e,t,n)=>{n.d(t,{tN:()=>r}),n(31085),n(26659);var a=n(64218);function r(){const e=(0,a.useVersionedContext)("entity-context");if(!e)throw new Error("Entity context is not available");const t=e.atVersion(1);if(!t)throw new Error("EntityContext v1 not available");if(!t.entity)throw new Error("useEntity hook is being called outside of an EntityLayout where the entity has not been loaded. If this is intentional, please use useAsyncEntity instead.");return{entity:t.entity}}(0,a.createVersionedContext)("entity-context")},37725:(e,t,n)=>{n.d(t,{N_:()=>y});var a=n(31085),r=n(22097),i=n(49203),o=n(37976),s=n(72501),l=n(53373),c=n.n(l),d=n(45250),p=n(95478),h=n(42469),u=n(39330);const x=(0,o.makeStyles)(e=>({visuallyHidden:{clip:"rect(0 0 0 0)",clipPath:"inset(50%)",overflow:"hidden",position:"absolute",userSelect:"none",whiteSpace:"nowrap",height:1,width:1},externalLink:{position:"relative"},externalLinkIcon:{verticalAlign:"bottom",marginLeft:e.spacing(.5)}}),{name:"Link"}),m=()=>{const e=(0,r.useApp)().getSystemIcon("externalLink")||u.A,t=x();return(0,a.jsx)(e,{className:t.externalLinkIcon})},g=e=>/^([a-z+.-]+):/.test(e),f=/^[\u0000-\u001F ]*j[\r\n\t]*a[\r\n\t]*v[\r\n\t]*a[\r\n\t]*s[\r\n\t]*c[\r\n\t]*r[\r\n\t]*i[\r\n\t]*p[\r\n\t]*t[\r\n\t]*\:/i,A=window.open;if(A&&!A.__backstage){const e=function(...e){const t=String(e[0]);if(f.test(t))throw new Error("Rejected window.open() with a javascript: URL as a security precaution");return A.apply(this,e)};e.__backstage=!0,window.open=e}const v=e=>e instanceof Array?e.map(v).join(" ").trim():"object"==typeof e&&e?v(e?.props?.children):["string","number"].includes(typeof e)?String(e):"",y=(0,p.forwardRef)(({onClick:e,noTrack:t,externalLinkIcon:n,...o},l)=>{const p=x(),u=(0,r.useAnalytics)(),A=function(){const[e]=(0,h.createRoutesFromChildren)((0,a.jsx)(h.Route,{index:!0,element:(0,a.jsx)("div",{})}));return!e.index}()?(e=>{let t=String(e);const n=(()=>{const e=(()=>{try{return(0,r.useApi)(r.configApiRef).getOptionalString("app.baseUrl")}catch{return}})()??"/",{pathname:t}=new URL(e,"http://sample.dev");return(0,d.trimEnd)(t,"/")})(),a=g(t),i=t.startsWith(n);return a||i||(t=n.concat(t)),t})(o.to):o.to,y=v(o.children)||A,j=g(A),b=j&&!!/^https?:/.exec(A);if(f.test(A))throw new Error("Link component rejected javascript: URL as a security precaution");const k=n=>{e?.(n),t||u.captureEvent("click",y,{attributes:{to:A}})};return j?(0,a.jsxs)(i.A,{...b?{target:"_blank",rel:"noopener"}:{},...o,...o["aria-label"]?{"aria-label":`${o["aria-label"]}, Opens in a new window`}:{},ref:l,href:A,onClick:k,className:c()(p.externalLink,o.className),children:[o.children,n&&(0,a.jsx)(m,{}),(0,a.jsx)(s.A,{component:"span",className:p.visuallyHidden,children:", Opens in a new window"})]}):(0,a.jsx)(i.A,{...o,ref:l,component:h.Link,to:A,onClick:k})})},39330:(e,t,n)=>{var a=n(4293),r=n(78920);t.A=void 0;var i=r(n(95478)),o=(0,a(n(74044)).default)(i.createElement("path",{d:"M19 19H5V5h7V3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2v-7h-2v7zM14 3v2h3.59l-9.83 9.83 1.41 1.41L19 6.41V10h2V3h-7z"}),"OpenInNew");t.A=o},47625:(e,t,n)=>{n.d(t,{A:()=>h});var a=n(89575),r=n(39850),i=n(95478),o=n(36274),s=n(7031),l=n(75614),c={variant:"head"},d="thead",p=i.forwardRef(function(e,t){var n=e.classes,s=e.className,p=e.component,h=void 0===p?d:p,u=(0,r.A)(e,["classes","className","component"]);return i.createElement(l.A.Provider,{value:c},i.createElement(h,(0,a.A)({className:(0,o.A)(n.root,s),ref:t,role:h===d?null:"rowgroup"},u)))});const h=(0,s.A)({root:{display:"table-header-group"}},{name:"MuiTableHead"})(p)},52235:(e,t,n)=>{var a=n(4293),r=n(78920);t.A=void 0;var i=r(n(95478)),o=(0,a(n(74044)).default)(i.createElement("path",{d:"M12 4l-1.41 1.41L16.17 11H4v2h12.17l-5.58 5.59L12 20l8-8z"}),"ArrowForward");t.A=o},54801:(e,t,n)=>{n.d(t,{A:()=>u});var a=n(39850),r=n(89575),i=n(95478),o=n(36274),s=n(7031),l=n(11192),c=n(268),d=n(98394),p=n(75614),h=i.forwardRef(function(e,t){var n,s,c=e.align,h=void 0===c?"inherit":c,u=e.classes,x=e.className,m=e.component,g=e.padding,f=e.scope,A=e.size,v=e.sortDirection,y=e.variant,j=(0,a.A)(e,["align","classes","className","component","padding","scope","size","sortDirection","variant"]),b=i.useContext(d.A),k=i.useContext(p.A),w=k&&"head"===k.variant;m?(s=m,n=w?"columnheader":"cell"):s=w?"th":"td";var C=f;!C&&w&&(C="col");var N=g||(b&&b.padding?b.padding:"normal"),P=A||(b&&b.size?b.size:"medium"),I=y||k&&k.variant,R=null;return v&&(R="asc"===v?"ascending":"descending"),i.createElement(s,(0,r.A)({ref:t,className:(0,o.A)(u.root,u[I],x,"inherit"!==h&&u["align".concat((0,l.A)(h))],"normal"!==N&&u["padding".concat((0,l.A)(N))],"medium"!==P&&u["size".concat((0,l.A)(P))],"head"===I&&b&&b.stickyHeader&&u.stickyHeader),"aria-sort":R,role:n,scope:C},j))});const u=(0,s.A)(function(e){return{root:(0,r.A)({},e.typography.body2,{display:"table-cell",verticalAlign:"inherit",borderBottom:"1px solid\n ".concat("light"===e.palette.type?(0,c.a)((0,c.X4)(e.palette.divider,1),.88):(0,c.e$)((0,c.X4)(e.palette.divider,1),.68)),textAlign:"left",padding:16}),head:{color:e.palette.text.primary,lineHeight:e.typography.pxToRem(24),fontWeight:e.typography.fontWeightMedium},body:{color:e.palette.text.primary},footer:{color:e.palette.text.secondary,lineHeight:e.typography.pxToRem(21),fontSize:e.typography.pxToRem(12)},sizeSmall:{padding:"6px 24px 6px 16px","&:last-child":{paddingRight:16},"&$paddingCheckbox":{width:24,padding:"0 12px 0 16px","&:last-child":{paddingLeft:12,paddingRight:16},"& > *":{padding:0}}},paddingCheckbox:{width:48,padding:"0 0 0 4px","&:last-child":{paddingLeft:0,paddingRight:4}},paddingNone:{padding:0,"&:last-child":{padding:0}},alignLeft:{textAlign:"left"},alignCenter:{textAlign:"center"},alignRight:{textAlign:"right",flexDirection:"row-reverse"},alignJustify:{textAlign:"justify"},stickyHeader:{position:"sticky",top:0,left:0,zIndex:2,backgroundColor:e.palette.background.default}}},{name:"MuiTableCell"})(h)},61009:(e,t,n)=>{n.d(t,{A:()=>p});var a=n(39850),r=n(89575),i=n(95478),o=n(36274),s=n(7031),l=n(98394),c="table",d=i.forwardRef(function(e,t){var n=e.classes,s=e.className,d=e.component,p=void 0===d?c:d,h=e.padding,u=void 0===h?"normal":h,x=e.size,m=void 0===x?"medium":x,g=e.stickyHeader,f=void 0!==g&&g,A=(0,a.A)(e,["classes","className","component","padding","size","stickyHeader"]),v=i.useMemo(function(){return{padding:u,size:m,stickyHeader:f}},[u,m,f]);return i.createElement(l.A.Provider,{value:v},i.createElement(p,(0,r.A)({role:p===c?null:"table",ref:t,className:(0,o.A)(n.root,s,f&&n.stickyHeader)},A)))});const p=(0,s.A)(function(e){return{root:{display:"table",width:"100%",borderCollapse:"collapse",borderSpacing:0,"& caption":(0,r.A)({},e.typography.body2,{padding:e.spacing(2),color:e.palette.text.secondary,textAlign:"left",captionSide:"bottom"})},stickyHeader:{borderCollapse:"separate"}}},{name:"MuiTable"})(d)},75453:(e,t,n)=>{n.r(t),n.d(t,{ApiProductInfoCard:()=>y});var a=n(31085),r=(n(95478),n(16400)),i=n(22097),o=n(96040),s=n(86687),l=n(42367),c=n(37725),d=n(72501),p=n(42899),h=n(10394),u=n(67720),x=n(61009),m=n(47625),g=n(9719),f=n(54801),A=n(13677),v=n(91638);const y=()=>{var e,t;const{entity:n}=(0,r.tN)(),y=(0,i.useApi)(i.configApiRef),j=(0,i.useApi)(i.fetchApiRef),b=y.getString("backend.baseUrl"),k=null===(e=n.metadata.annotations)||void 0===e?void 0:e["kuadrant.io/namespace"],w=null===(t=n.metadata.annotations)||void 0===t?void 0:t["kuadrant.io/apiproduct"],{value:C,loading:N,error:P}=(0,v.A)(async()=>{if(!k||!w)return null;const e=await j.fetch(`${b}/api/kuadrant/apiproducts/${k}/${w}`);return await e.json()},[b,j,k,w]);if(!k||!w)return(0,a.jsx)(o.n,{title:"API Product Information",children:(0,a.jsx)(d.A,{children:"No APIProduct linked to this API entity"})});if(N)return(0,a.jsx)(o.n,{title:"API Product Information",children:(0,a.jsx)(s.k,{})});if(P)return(0,a.jsx)(o.n,{title:"API Product Information",children:(0,a.jsx)(l._,{error:P})});if(!C)return(0,a.jsx)(o.n,{title:"API Product Information",children:(0,a.jsx)(d.A,{children:"APIProduct not found"})});const{spec:I}=C;return(0,a.jsxs)(p.A,{container:!0,spacing:3,children:[(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsx)(o.n,{title:"API Product Details",children:(0,a.jsxs)(h.A,{p:2,children:[(0,a.jsx)(d.A,{variant:"h6",gutterBottom:!0,children:I.displayName||w}),(0,a.jsx)(d.A,{variant:"body2",color:"textSecondary",paragraph:!0,children:I.description}),(0,a.jsxs)(h.A,{display:"flex",alignItems:"center",flexWrap:"wrap",style:{gap:8},children:[(0,a.jsxs)(d.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:"Version:"})," ",I.version||"v1"]}),I.tags&&I.tags.length>0&&(0,a.jsx)(h.A,{display:"flex",ml:2,style:{gap:4},children:I.tags.map(e=>(0,a.jsx)(u.A,{label:e,size:"small"},e))})]})]})})}),I.plans&&I.plans.length>0&&(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsxs)(o.n,{title:"Available Plans",children:[(0,a.jsxs)(x.A,{size:"small",children:[(0,a.jsx)(m.A,{children:(0,a.jsxs)(g.A,{children:[(0,a.jsx)(f.A,{children:"Tier"}),(0,a.jsx)(f.A,{children:"Description"}),(0,a.jsx)(f.A,{children:"Rate Limits"})]})}),(0,a.jsx)(A.A,{children:I.plans.map(e=>(0,a.jsxs)(g.A,{children:[(0,a.jsx)(f.A,{children:(0,a.jsx)(u.A,{label:e.tier,size:"small"})}),(0,a.jsx)(f.A,{children:e.description||"-"}),(0,a.jsx)(f.A,{children:e.limits&&Object.entries(e.limits).map(([e,t])=>(0,a.jsxs)(d.A,{variant:"body2",children:[String(t)," per ",e]},e))})]},e.tier))})]}),I.planPolicyRef&&(0,a.jsx)(h.A,{mt:2,children:(0,a.jsxs)(d.A,{variant:"caption",color:"textSecondary",children:["Managed by PlanPolicy: ",(0,a.jsx)("strong",{children:I.planPolicyRef.name})," (",I.planPolicyRef.namespace,")"]})})]})}),(0,a.jsx)(p.A,{item:!0,xs:12,md:6,children:(0,a.jsx)(o.n,{title:"Contact Information",children:I.contact?(0,a.jsx)(h.A,{p:2,children:(0,a.jsxs)(p.A,{container:!0,spacing:2,children:[I.contact.team&&(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsxs)(d.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:"Team:"})," ",I.contact.team]})}),I.contact.email&&(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsxs)(d.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:"Email:"})," ",(0,a.jsx)(c.N_,{to:`mailto:${I.contact.email}`,children:I.contact.email})]})}),I.contact.slack&&(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsxs)(d.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:"Slack:"})," ",I.contact.slack]})})]})}):(0,a.jsx)(h.A,{p:2,children:(0,a.jsx)(d.A,{variant:"body2",color:"textSecondary",children:"No contact information available"})})})}),(0,a.jsx)(p.A,{item:!0,xs:12,md:6,children:(0,a.jsx)(o.n,{title:"Documentation",children:I.documentation?(0,a.jsx)(h.A,{p:2,children:(0,a.jsxs)(p.A,{container:!0,spacing:2,children:[I.documentation.docsURL&&(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsxs)(d.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:"Documentation:"})," ",(0,a.jsx)(c.N_,{to:I.documentation.docsURL,target:"_blank",children:"View Docs"})]})}),I.documentation.openAPISpec&&(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsxs)(d.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:"OpenAPI Spec:"})," ",(0,a.jsx)(c.N_,{to:I.documentation.openAPISpec,target:"_blank",children:"View Spec"})]})})]})}):(0,a.jsx)(h.A,{p:2,children:(0,a.jsx)(d.A,{variant:"body2",color:"textSecondary",children:"No documentation links available"})})})})]})}},75614:(e,t,n)=>{n.d(t,{A:()=>a});const a=n(95478).createContext()},91638:(e,t,n)=>{var a=n(85608),r=n(95478),i=a.__importDefault(n(5030));t.A=function(e,t){void 0===t&&(t=[]);var n=i.default(e,t,{loading:!0}),a=n[0],o=n[1];return r.useEffect(function(){o()},[o]),a}},96040:(e,t,n)=>{n.d(t,{n:()=>S});var a=n(31085),r=n(40703),i=n(59469),o=n(48653),s=n(45685),l=n(37197),c=n(37976),d=n(53373),p=n.n(d),h=n(10394),u=n(72501),x=n(52235),m=n(37725);const g=(0,c.makeStyles)(e=>({root:{maxWidth:"fit-content",padding:e.spacing(2,2,2,2.5)},boxTitle:{margin:0,color:e.palette.textSubtle},arrow:{color:e.palette.textSubtle}}),{name:"BackstageBottomLink"});function f(e){const{link:t,title:n,onClick:r}=e,i=g();return(0,a.jsxs)(h.A,{children:[(0,a.jsx)(l.A,{}),(0,a.jsx)(m.N_,{to:t,onClick:r,underline:"none",children:(0,a.jsxs)(h.A,{display:"flex",alignItems:"center",className:i.root,children:[(0,a.jsx)(h.A,{className:i.boxTitle,fontWeight:"fontWeightBold",m:1,children:(0,a.jsx)(u.A,{children:(0,a.jsx)("strong",{children:n})})}),(0,a.jsx)(x.A,{className:i.arrow})]})})]})}var A=n(95478),v=n(64947);const y=(0,A.forwardRef)((e,t)=>(0,a.jsx)(m.N_,{ref:t,...e,color:"initial"})),j=(0,A.forwardRef)((e,t)=>(0,a.jsx)(v.A,{ref:t,component:y,...e}));var b=n(34169),k=n(16098),w=n(67550);const C=e=>{const{slackChannel:t}=e,{t:n}=(0,w.i)(k.O);return t?"string"==typeof t?(0,a.jsx)(u.A,{children:n("errorBoundary.title",{slackChannel:t})}):t.href?(0,a.jsx)(j,{to:t.href,variant:"contained",children:t.name}):(0,a.jsx)(u.A,{children:n("errorBoundary.title",{slackChannel:t.name})}):null},N=class extends A.Component{constructor(e){super(e),this.state={error:void 0,errorInfo:void 0}}componentDidCatch(e,t){console.error(`ErrorBoundary, error: ${e}`,{error:e,errorInfo:t}),this.setState({error:e,errorInfo:t})}render(){const{slackChannel:e,children:t}=this.props,{error:n}=this.state;return n?(0,a.jsx)(b.b,{title:"Something Went Wrong",error:n,children:(0,a.jsx)(C,{slackChannel:e})}):t}},P=(0,c.makeStyles)(e=>({noPadding:{padding:0,"&:last-child":{paddingBottom:0}},contentAlignBottom:{display:"flex",alignItems:"self-end"},header:{padding:e.spacing(2,2,2,2.5)},headerTitle:{fontWeight:e.typography.fontWeightBold},headerSubheader:{paddingTop:e.spacing(1)},headerAvatar:{},headerAction:{},headerContent:{},subheader:{display:"flex"}}),{name:"BackstageInfoCard"}),I=(0,c.withStyles)(e=>({root:{display:"inline-block",padding:e.spacing(8,8,0,0),float:"right"}}),{name:"BackstageInfoCardCardActionsTopRight"})(i.A),R={card:{flex:{display:"flex",flexDirection:"column"},fullHeight:{display:"flex",flexDirection:"column",height:"100%"},gridItem:{display:"flex",flexDirection:"column",height:"calc(100% - 10px)",marginBottom:"10px",breakInside:"avoid-page","@media print":{height:"auto"}}},cardContent:{fullHeight:{flex:1},gridItem:{flex:1}}};function S(e){const{title:t,subheader:n,divider:c=!0,deepLink:d,slackChannel:h,errorBoundaryProps:u,variant:x,alignContent:m="normal",children:g,headerStyle:A,headerProps:v,icon:y,action:j,actionsClassName:b,actions:k,cardClassName:w,actionsTopRight:C,className:S,noPadding:_,titleTypographyProps:E,subheaderTypographyProps:L}=e,T=P();let z={},H={};x&&x.split(/[\s]+/g).forEach(e=>{z={...z,...R.card[e]},H={...H,...R.cardContent[e]}});const B=u||(h?{slackChannel:h}:{});return(0,a.jsx)(r.A,{style:z,className:S,children:(0,a.jsxs)(N,{...B,children:[t&&(0,a.jsx)(s.A,{classes:{root:p()(T.header),title:T.headerTitle,subheader:T.headerSubheader,avatar:T.headerAvatar,action:T.headerAction,content:T.headerContent},title:t,subheader:n||y?(0,a.jsxs)("div",{"data-testid":"info-card-subheader",children:[n&&(0,a.jsx)("div",{className:T.subheader,children:n}),y]}):null,action:j,style:{...A},titleTypographyProps:E,subheaderTypographyProps:L,...v}),C&&(0,a.jsx)(I,{children:C}),c&&(0,a.jsx)(l.A,{}),(0,a.jsx)(o.A,{className:p()(w,{[T.noPadding]:_,[T.contentAlignBottom]:"bottom"===m}),style:H,children:g}),k&&(0,a.jsx)(i.A,{className:b,children:k}),d&&(0,a.jsx)(f,{...d})]})})}},98394:(e,t,n)=>{n.d(t,{A:()=>a});const a=n(95478).createContext()}}]);
|
|
2
|
-
//# sourceMappingURL=5453.d8d305e9.chunk.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"static/5453.d8d305e9.chunk.js","mappings":"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","sources":["webpack://internal.plugin-kuadrant/../../node_modules/react-use/lib/useAsyncFn.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/TableRow/TableRow.js","webpack://internal.plugin-kuadrant/../../node_modules/react-use/lib/useMountedState.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/TableBody/TableBody.js","webpack://internal.plugin-kuadrant/../../node_modules/@backstage/plugin-catalog-react/dist/hooks/useEntity.esm.js","webpack://internal.plugin-kuadrant/./node_modules/@backstage/core-components/dist/components/Link/Link.esm.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/icons/OpenInNew.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/TableHead/TableHead.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/icons/ArrowForward.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/TableCell/TableCell.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/Table/Table.js","webpack://internal.plugin-kuadrant/./src/components/ApiProductInfoCard/ApiProductInfoCard.tsx","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/Table/Tablelvl2Context.js","webpack://internal.plugin-kuadrant/../../node_modules/react-use/lib/useAsync.js","webpack://internal.plugin-kuadrant/./node_modules/@backstage/core-components/dist/layout/BottomLink/BottomLink.esm.js","webpack://internal.plugin-kuadrant/./node_modules/@backstage/core-components/dist/components/LinkButton/LinkButton.esm.js","webpack://internal.plugin-kuadrant/./node_modules/@backstage/core-components/dist/layout/ErrorBoundary/ErrorBoundary.esm.js","webpack://internal.plugin-kuadrant/./node_modules/@backstage/core-components/dist/layout/InfoCard/InfoCard.esm.js","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/core/esm/Table/TableContext.js"],"sourcesContent":["\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar react_1 = require(\"react\");\nvar useMountedState_1 = tslib_1.__importDefault(require(\"./useMountedState\"));\nfunction useAsyncFn(fn, deps, initialState) {\n if (deps === void 0) { deps = []; }\n if (initialState === void 0) { initialState = { loading: false }; }\n var lastCallId = react_1.useRef(0);\n var isMounted = useMountedState_1.default();\n var _a = react_1.useState(initialState), state = _a[0], set = _a[1];\n var callback = react_1.useCallback(function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var callId = ++lastCallId.current;\n if (!state.loading) {\n set(function (prevState) { return (tslib_1.__assign(tslib_1.__assign({}, prevState), { loading: true })); });\n }\n return fn.apply(void 0, args).then(function (value) {\n isMounted() && callId === lastCallId.current && set({ value: value, loading: false });\n return value;\n }, function (error) {\n isMounted() && callId === lastCallId.current && set({ error: error, loading: false });\n return error;\n });\n }, deps);\n return [state, callback];\n}\nexports.default = useAsyncFn;\n","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport Tablelvl2Context from '../Table/Tablelvl2Context';\nimport { alpha } from '../styles/colorManipulator';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n color: 'inherit',\n display: 'table-row',\n verticalAlign: 'middle',\n // We disable the focus ring for mouse, touch and keyboard users.\n outline: 0,\n '&$hover:hover': {\n backgroundColor: theme.palette.action.hover\n },\n '&$selected, &$selected:hover': {\n backgroundColor: alpha(theme.palette.secondary.main, theme.palette.action.selectedOpacity)\n }\n },\n\n /* Pseudo-class applied to the root element if `selected={true}`. */\n selected: {},\n\n /* Pseudo-class applied to the root element if `hover={true}`. */\n hover: {},\n\n /* Styles applied to the root element if table variant=\"head\". */\n head: {},\n\n /* Styles applied to the root element if table variant=\"footer\". */\n footer: {}\n };\n};\nvar defaultComponent = 'tr';\n/**\n * Will automatically set dynamic row height\n * based on the material table element parent (head, body, etc).\n */\n\nvar TableRow = /*#__PURE__*/React.forwardRef(function TableRow(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? defaultComponent : _props$component,\n _props$hover = props.hover,\n hover = _props$hover === void 0 ? false : _props$hover,\n _props$selected = props.selected,\n selected = _props$selected === void 0 ? false : _props$selected,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"component\", \"hover\", \"selected\"]);\n\n var tablelvl2 = React.useContext(Tablelvl2Context);\n return /*#__PURE__*/React.createElement(Component, _extends({\n ref: ref,\n className: clsx(classes.root, className, tablelvl2 && {\n 'head': classes.head,\n 'footer': classes.footer\n }[tablelvl2.variant], hover && classes.hover, selected && classes.selected),\n role: Component === defaultComponent ? null : 'row'\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? TableRow.propTypes = {\n /**\n * Should be valid <tr> children such as `TableCell`.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes\n /* @typescript-to-proptypes-ignore */\n .elementType,\n\n /**\n * If `true`, the table row will shade on hover.\n */\n hover: PropTypes.bool,\n\n /**\n * If `true`, the table row will have the selected shading.\n */\n selected: PropTypes.bool\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTableRow'\n})(TableRow);","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar react_1 = require(\"react\");\nfunction useMountedState() {\n var mountedRef = react_1.useRef(false);\n var get = react_1.useCallback(function () { return mountedRef.current; }, []);\n react_1.useEffect(function () {\n mountedRef.current = true;\n return function () {\n mountedRef.current = false;\n };\n }, []);\n return get;\n}\nexports.default = useMountedState;\n","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport Tablelvl2Context from '../Table/Tablelvl2Context';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n display: 'table-row-group'\n }\n};\nvar tablelvl2 = {\n variant: 'body'\n};\nvar defaultComponent = 'tbody';\nvar TableBody = /*#__PURE__*/React.forwardRef(function TableBody(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? defaultComponent : _props$component,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"component\"]);\n\n return /*#__PURE__*/React.createElement(Tablelvl2Context.Provider, {\n value: tablelvl2\n }, /*#__PURE__*/React.createElement(Component, _extends({\n className: clsx(classes.root, className),\n ref: ref,\n role: Component === defaultComponent ? null : 'rowgroup'\n }, other)));\n});\nprocess.env.NODE_ENV !== \"production\" ? TableBody.propTypes = {\n /**\n * The content of the component, normally `TableRow`.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes\n /* @typescript-to-proptypes-ignore */\n .elementType\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTableBody'\n})(TableBody);","import { jsx } from 'react/jsx-runtime';\nimport { stringifyEntityRef } from '@backstage/catalog-model';\nimport { AnalyticsContext } from '@backstage/core-plugin-api';\nimport { createVersionedContext, useVersionedContext, createVersionedValueMap } from '@backstage/version-bridge';\n\nconst NewEntityContext = createVersionedContext(\n \"entity-context\"\n);\nconst AsyncEntityProvider = (props) => {\n const { children, entity, loading, error, refresh } = props;\n const value = { entity, loading, error, refresh };\n return /* @__PURE__ */ jsx(NewEntityContext.Provider, { value: createVersionedValueMap({ 1: value }), children: /* @__PURE__ */ jsx(\n AnalyticsContext,\n {\n attributes: {\n ...entity ? { entityRef: stringifyEntityRef(entity) } : void 0\n },\n children\n }\n ) });\n};\nconst EntityProvider = (props) => /* @__PURE__ */ jsx(\n AsyncEntityProvider,\n {\n entity: props.entity,\n loading: !Boolean(props.entity),\n error: void 0,\n refresh: void 0,\n children: props.children\n }\n);\nfunction useEntity() {\n const versionedHolder = useVersionedContext(\n \"entity-context\"\n );\n if (!versionedHolder) {\n throw new Error(\"Entity context is not available\");\n }\n const value = versionedHolder.atVersion(1);\n if (!value) {\n throw new Error(\"EntityContext v1 not available\");\n }\n if (!value.entity) {\n throw new Error(\n \"useEntity hook is being called outside of an EntityLayout where the entity has not been loaded. If this is intentional, please use useAsyncEntity instead.\"\n );\n }\n return { entity: value.entity };\n}\nfunction useAsyncEntity() {\n const versionedHolder = useVersionedContext(\n \"entity-context\"\n );\n if (!versionedHolder) {\n throw new Error(\"Entity context is not available\");\n }\n const value = versionedHolder.atVersion(1);\n if (!value) {\n throw new Error(\"EntityContext v1 not available\");\n }\n const { entity, loading, error, refresh } = value;\n return { entity, loading, error, refresh };\n}\n\nexport { AsyncEntityProvider, EntityProvider, useAsyncEntity, useEntity };\n//# sourceMappingURL=useEntity.esm.js.map\n","import { jsxs, jsx } from 'react/jsx-runtime';\nimport { useAnalytics, useApp, useApi, configApiRef } from '@backstage/core-plugin-api';\nimport MaterialLink from '@material-ui/core/Link';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Typography from '@material-ui/core/Typography';\nimport classNames from 'classnames';\nimport { trimEnd } from 'lodash';\nimport { forwardRef } from 'react';\nimport { Link as Link$1, createRoutesFromChildren, Route } from 'react-router-dom';\nimport OpenInNew from '@material-ui/icons/OpenInNew';\n\nfunction isReactRouterBeta() {\n const [obj] = createRoutesFromChildren(/* @__PURE__ */ jsx(Route, { index: true, element: /* @__PURE__ */ jsx(\"div\", {}) }));\n return !obj.index;\n}\nconst useStyles = makeStyles(\n (theme) => ({\n visuallyHidden: {\n clip: \"rect(0 0 0 0)\",\n clipPath: \"inset(50%)\",\n overflow: \"hidden\",\n position: \"absolute\",\n userSelect: \"none\",\n whiteSpace: \"nowrap\",\n height: 1,\n width: 1\n },\n externalLink: {\n position: \"relative\"\n },\n externalLinkIcon: {\n verticalAlign: \"bottom\",\n marginLeft: theme.spacing(0.5)\n }\n }),\n { name: \"Link\" }\n);\nconst ExternalLinkIcon = () => {\n const app = useApp();\n const Icon = app.getSystemIcon(\"externalLink\") || OpenInNew;\n const classes = useStyles();\n return /* @__PURE__ */ jsx(Icon, { className: classes.externalLinkIcon });\n};\nconst isExternalUri = (uri) => /^([a-z+.-]+):/.test(uri);\nconst scriptProtocolPattern = (\n // eslint-disable-next-line no-control-regex\n /^[\\u0000-\\u001F ]*j[\\r\\n\\t]*a[\\r\\n\\t]*v[\\r\\n\\t]*a[\\r\\n\\t]*s[\\r\\n\\t]*c[\\r\\n\\t]*r[\\r\\n\\t]*i[\\r\\n\\t]*p[\\r\\n\\t]*t[\\r\\n\\t]*\\:/i\n);\nconst originalWindowOpen = window.open;\nif (originalWindowOpen && !originalWindowOpen.__backstage) {\n const newOpen = function open(...args) {\n const url = String(args[0]);\n if (scriptProtocolPattern.test(url)) {\n throw new Error(\n \"Rejected window.open() with a javascript: URL as a security precaution\"\n );\n }\n return originalWindowOpen.apply(this, args);\n };\n newOpen.__backstage = true;\n window.open = newOpen;\n}\nconst useBaseUrl = () => {\n try {\n const config = useApi(configApiRef);\n return config.getOptionalString(\"app.baseUrl\");\n } catch {\n return void 0;\n }\n};\nconst useBasePath = () => {\n const base = \"http://sample.dev\";\n const url = useBaseUrl() ?? \"/\";\n const { pathname } = new URL(url, base);\n return trimEnd(pathname, \"/\");\n};\nconst useResolvedPath = (uri) => {\n let resolvedPath = String(uri);\n const basePath = useBasePath();\n const external = isExternalUri(resolvedPath);\n const startsWithBasePath = resolvedPath.startsWith(basePath);\n if (!external && !startsWithBasePath) {\n resolvedPath = basePath.concat(resolvedPath);\n }\n return resolvedPath;\n};\nconst getNodeText = (node) => {\n if (node instanceof Array) {\n return node.map(getNodeText).join(\" \").trim();\n }\n if (typeof node === \"object\" && node) {\n return getNodeText(node?.props?.children);\n }\n if ([\"string\", \"number\"].includes(typeof node)) {\n return String(node);\n }\n return \"\";\n};\nconst Link = forwardRef(\n ({ onClick, noTrack, externalLinkIcon, ...props }, ref) => {\n const classes = useStyles();\n const analytics = useAnalytics();\n const to = isReactRouterBeta() ? useResolvedPath(props.to) : props.to;\n const linkText = getNodeText(props.children) || to;\n const external = isExternalUri(to);\n const newWindow = external && !!/^https?:/.exec(to);\n if (scriptProtocolPattern.test(to)) {\n throw new Error(\n \"Link component rejected javascript: URL as a security precaution\"\n );\n }\n const handleClick = (event) => {\n onClick?.(event);\n if (!noTrack) {\n analytics.captureEvent(\"click\", linkText, { attributes: { to } });\n }\n };\n return external ? (\n // External links\n /* @__PURE__ */ jsxs(\n MaterialLink,\n {\n ...newWindow ? { target: \"_blank\", rel: \"noopener\" } : {},\n ...props,\n ...props[\"aria-label\"] ? { \"aria-label\": `${props[\"aria-label\"]}, Opens in a new window` } : {},\n ref,\n href: to,\n onClick: handleClick,\n className: classNames(classes.externalLink, props.className),\n children: [\n props.children,\n externalLinkIcon && /* @__PURE__ */ jsx(ExternalLinkIcon, {}),\n /* @__PURE__ */ jsx(Typography, { component: \"span\", className: classes.visuallyHidden, children: \", Opens in a new window\" })\n ]\n }\n )\n ) : (\n // Interact with React Router for internal links\n /* @__PURE__ */ jsx(\n MaterialLink,\n {\n ...props,\n ref,\n component: Link$1,\n to,\n onClick: handleClick\n }\n )\n );\n }\n);\n\nexport { Link, isExternalUri, isReactRouterBeta, useResolvedPath };\n//# sourceMappingURL=Link.esm.js.map\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _interopRequireWildcard = require(\"@babel/runtime/helpers/interopRequireWildcard\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M19 19H5V5h7V3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2v-7h-2v7zM14 3v2h3.59l-9.83 9.83 1.41 1.41L19 6.41V10h2V3h-7z\"\n}), 'OpenInNew');\n\nexports.default = _default;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport Tablelvl2Context from '../Table/Tablelvl2Context';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n display: 'table-header-group'\n }\n};\nvar tablelvl2 = {\n variant: 'head'\n};\nvar defaultComponent = 'thead';\nvar TableHead = /*#__PURE__*/React.forwardRef(function TableHead(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? defaultComponent : _props$component,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"component\"]);\n\n return /*#__PURE__*/React.createElement(Tablelvl2Context.Provider, {\n value: tablelvl2\n }, /*#__PURE__*/React.createElement(Component, _extends({\n className: clsx(classes.root, className),\n ref: ref,\n role: Component === defaultComponent ? null : 'rowgroup'\n }, other)));\n});\nprocess.env.NODE_ENV !== \"production\" ? TableHead.propTypes = {\n /**\n * The content of the component, normally `TableRow`.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes\n /* @typescript-to-proptypes-ignore */\n .elementType\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTableHead'\n})(TableHead);","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _interopRequireWildcard = require(\"@babel/runtime/helpers/interopRequireWildcard\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M12 4l-1.41 1.41L16.17 11H4v2h12.17l-5.58 5.59L12 20l8-8z\"\n}), 'ArrowForward');\n\nexports.default = _default;","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { chainPropTypes } from '@material-ui/utils';\nimport withStyles from '../styles/withStyles';\nimport capitalize from '../utils/capitalize';\nimport { darken, alpha, lighten } from '../styles/colorManipulator';\nimport TableContext from '../Table/TableContext';\nimport Tablelvl2Context from '../Table/Tablelvl2Context';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: _extends({}, theme.typography.body2, {\n display: 'table-cell',\n verticalAlign: 'inherit',\n // Workaround for a rendering bug with spanned columns in Chrome 62.0.\n // Removes the alpha (sets it to 1), and lightens or darkens the theme color.\n borderBottom: \"1px solid\\n \".concat(theme.palette.type === 'light' ? lighten(alpha(theme.palette.divider, 1), 0.88) : darken(alpha(theme.palette.divider, 1), 0.68)),\n textAlign: 'left',\n padding: 16\n }),\n\n /* Styles applied to the root element if `variant=\"head\"` or `context.table.head`. */\n head: {\n color: theme.palette.text.primary,\n lineHeight: theme.typography.pxToRem(24),\n fontWeight: theme.typography.fontWeightMedium\n },\n\n /* Styles applied to the root element if `variant=\"body\"` or `context.table.body`. */\n body: {\n color: theme.palette.text.primary\n },\n\n /* Styles applied to the root element if `variant=\"footer\"` or `context.table.footer`. */\n footer: {\n color: theme.palette.text.secondary,\n lineHeight: theme.typography.pxToRem(21),\n fontSize: theme.typography.pxToRem(12)\n },\n\n /* Styles applied to the root element if `size=\"small\"`. */\n sizeSmall: {\n padding: '6px 24px 6px 16px',\n '&:last-child': {\n paddingRight: 16\n },\n '&$paddingCheckbox': {\n width: 24,\n // prevent the checkbox column from growing\n padding: '0 12px 0 16px',\n '&:last-child': {\n paddingLeft: 12,\n paddingRight: 16\n },\n '& > *': {\n padding: 0\n }\n }\n },\n\n /* Styles applied to the root element if `padding=\"checkbox\"`. */\n paddingCheckbox: {\n width: 48,\n // prevent the checkbox column from growing\n padding: '0 0 0 4px',\n '&:last-child': {\n paddingLeft: 0,\n paddingRight: 4\n }\n },\n\n /* Styles applied to the root element if `padding=\"none\"`. */\n paddingNone: {\n padding: 0,\n '&:last-child': {\n padding: 0\n }\n },\n\n /* Styles applied to the root element if `align=\"left\"`. */\n alignLeft: {\n textAlign: 'left'\n },\n\n /* Styles applied to the root element if `align=\"center\"`. */\n alignCenter: {\n textAlign: 'center'\n },\n\n /* Styles applied to the root element if `align=\"right\"`. */\n alignRight: {\n textAlign: 'right',\n flexDirection: 'row-reverse'\n },\n\n /* Styles applied to the root element if `align=\"justify\"`. */\n alignJustify: {\n textAlign: 'justify'\n },\n\n /* Styles applied to the root element if `context.table.stickyHeader={true}`. */\n stickyHeader: {\n position: 'sticky',\n top: 0,\n left: 0,\n zIndex: 2,\n backgroundColor: theme.palette.background.default\n }\n };\n};\n/**\n * The component renders a `<th>` element when the parent context is a header\n * or otherwise a `<td>` element.\n */\n\nvar TableCell = /*#__PURE__*/React.forwardRef(function TableCell(props, ref) {\n var _props$align = props.align,\n align = _props$align === void 0 ? 'inherit' : _props$align,\n classes = props.classes,\n className = props.className,\n component = props.component,\n paddingProp = props.padding,\n scopeProp = props.scope,\n sizeProp = props.size,\n sortDirection = props.sortDirection,\n variantProp = props.variant,\n other = _objectWithoutProperties(props, [\"align\", \"classes\", \"className\", \"component\", \"padding\", \"scope\", \"size\", \"sortDirection\", \"variant\"]);\n\n var table = React.useContext(TableContext);\n var tablelvl2 = React.useContext(Tablelvl2Context);\n var isHeadCell = tablelvl2 && tablelvl2.variant === 'head';\n var role;\n var Component;\n\n if (component) {\n Component = component;\n role = isHeadCell ? 'columnheader' : 'cell';\n } else {\n Component = isHeadCell ? 'th' : 'td';\n }\n\n var scope = scopeProp;\n\n if (!scope && isHeadCell) {\n scope = 'col';\n }\n\n var padding = paddingProp || (table && table.padding ? table.padding : 'normal');\n var size = sizeProp || (table && table.size ? table.size : 'medium');\n var variant = variantProp || tablelvl2 && tablelvl2.variant;\n var ariaSort = null;\n\n if (sortDirection) {\n ariaSort = sortDirection === 'asc' ? 'ascending' : 'descending';\n }\n\n return /*#__PURE__*/React.createElement(Component, _extends({\n ref: ref,\n className: clsx(classes.root, classes[variant], className, align !== 'inherit' && classes[\"align\".concat(capitalize(align))], padding !== 'normal' && classes[\"padding\".concat(capitalize(padding))], size !== 'medium' && classes[\"size\".concat(capitalize(size))], variant === 'head' && table && table.stickyHeader && classes.stickyHeader),\n \"aria-sort\": ariaSort,\n role: role,\n scope: scope\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? TableCell.propTypes = {\n /**\n * Set the text-align on the table cell content.\n *\n * Monetary or generally number fields **should be right aligned** as that allows\n * you to add them up quickly in your head without having to worry about decimals.\n */\n align: PropTypes.oneOf(['center', 'inherit', 'justify', 'left', 'right']),\n\n /**\n * The table cell contents.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes\n /* @typescript-to-proptypes-ignore */\n .elementType,\n\n /**\n * Sets the padding applied to the cell.\n * By default, the Table parent component set the value (`normal`).\n * `default` is deprecated, use `normal` instead.\n */\n padding: chainPropTypes(PropTypes.oneOf(['normal', 'checkbox', 'none', 'default']), function (props) {\n if (props.padding === 'default') {\n return new Error('Material-UI: padding=\"default\" was renamed to padding=\"normal\" for consistency.');\n }\n\n return null;\n }),\n\n /**\n * Set scope attribute.\n */\n scope: PropTypes.string,\n\n /**\n * Specify the size of the cell.\n * By default, the Table parent component set the value (`medium`).\n */\n size: PropTypes.oneOf(['medium', 'small']),\n\n /**\n * Set aria-sort direction.\n */\n sortDirection: PropTypes.oneOf(['asc', 'desc', false]),\n\n /**\n * Specify the cell type.\n * By default, the TableHead, TableBody or TableFooter parent component set the value.\n */\n variant: PropTypes.oneOf(['body', 'footer', 'head'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTableCell'\n})(TableCell);","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { chainPropTypes } from '@material-ui/utils';\nimport withStyles from '../styles/withStyles';\nimport TableContext from './TableContext';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n display: 'table',\n width: '100%',\n borderCollapse: 'collapse',\n borderSpacing: 0,\n '& caption': _extends({}, theme.typography.body2, {\n padding: theme.spacing(2),\n color: theme.palette.text.secondary,\n textAlign: 'left',\n captionSide: 'bottom'\n })\n },\n\n /* Styles applied to the root element if `stickyHeader={true}`. */\n stickyHeader: {\n borderCollapse: 'separate'\n }\n };\n};\nvar defaultComponent = 'table';\nvar Table = /*#__PURE__*/React.forwardRef(function Table(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? defaultComponent : _props$component,\n _props$padding = props.padding,\n padding = _props$padding === void 0 ? 'normal' : _props$padding,\n _props$size = props.size,\n size = _props$size === void 0 ? 'medium' : _props$size,\n _props$stickyHeader = props.stickyHeader,\n stickyHeader = _props$stickyHeader === void 0 ? false : _props$stickyHeader,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"component\", \"padding\", \"size\", \"stickyHeader\"]);\n\n var table = React.useMemo(function () {\n return {\n padding: padding,\n size: size,\n stickyHeader: stickyHeader\n };\n }, [padding, size, stickyHeader]);\n return /*#__PURE__*/React.createElement(TableContext.Provider, {\n value: table\n }, /*#__PURE__*/React.createElement(Component, _extends({\n role: Component === defaultComponent ? null : 'table',\n ref: ref,\n className: clsx(classes.root, className, stickyHeader && classes.stickyHeader)\n }, other)));\n});\nprocess.env.NODE_ENV !== \"production\" ? Table.propTypes = {\n /**\n * The content of the table, normally `TableHead` and `TableBody`.\n */\n children: PropTypes.node.isRequired,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes\n /* @typescript-to-proptypes-ignore */\n .elementType,\n\n /**\n * Allows TableCells to inherit padding of the Table.\n * `default` is deprecated, use `normal` instead.\n */\n padding: chainPropTypes(PropTypes.oneOf(['normal', 'checkbox', 'none', 'default']), function (props) {\n if (props.padding === 'default') {\n return new Error('Material-UI: padding=\"default\" was renamed to padding=\"normal\" for consistency.');\n }\n\n return null;\n }),\n\n /**\n * Allows TableCells to inherit size of the Table.\n */\n size: PropTypes.oneOf(['small', 'medium']),\n\n /**\n * Set the header sticky.\n *\n * ⚠️ It doesn't work with IE 11.\n */\n stickyHeader: PropTypes.bool\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTable'\n})(Table);","import React from 'react';\nimport { useEntity } from '@backstage/plugin-catalog-react';\nimport { useApi, configApiRef, fetchApiRef } from '@backstage/core-plugin-api';\nimport { InfoCard, Link, Progress, ResponseErrorPanel } from '@backstage/core-components';\nimport { Grid, Chip, Typography, Box, Table, TableBody, TableCell, TableHead, TableRow } from '@material-ui/core';\nimport useAsync from 'react-use/lib/useAsync';\n\nexport const ApiProductInfoCard = () => {\n const { entity } = useEntity();\n const config = useApi(configApiRef);\n const fetchApi = useApi(fetchApiRef);\n const backendUrl = config.getString('backend.baseUrl');\n\n const namespace = entity.metadata.annotations?.['kuadrant.io/namespace'];\n const apiProductName = entity.metadata.annotations?.['kuadrant.io/apiproduct'];\n\n const { value: apiProduct, loading, error } = useAsync(async () => {\n if (!namespace || !apiProductName) {\n return null;\n }\n\n const response = await fetchApi.fetch(\n `${backendUrl}/api/kuadrant/apiproducts/${namespace}/${apiProductName}`\n );\n return await response.json();\n }, [backendUrl, fetchApi, namespace, apiProductName]);\n\n if (!namespace || !apiProductName) {\n return (\n <InfoCard title=\"API Product Information\">\n <Typography>No APIProduct linked to this API entity</Typography>\n </InfoCard>\n );\n }\n\n if (loading) {\n return (\n <InfoCard title=\"API Product Information\">\n <Progress />\n </InfoCard>\n );\n }\n\n if (error) {\n return (\n <InfoCard title=\"API Product Information\">\n <ResponseErrorPanel error={error} />\n </InfoCard>\n );\n }\n\n if (!apiProduct) {\n return (\n <InfoCard title=\"API Product Information\">\n <Typography>APIProduct not found</Typography>\n </InfoCard>\n );\n }\n\n const { spec } = apiProduct;\n\n return (\n <Grid container spacing={3}>\n <Grid item xs={12}>\n <InfoCard title=\"API Product Details\">\n <Box p={2}>\n <Typography variant=\"h6\" gutterBottom>\n {spec.displayName || apiProductName}\n </Typography>\n <Typography variant=\"body2\" color=\"textSecondary\" paragraph>\n {spec.description}\n </Typography>\n <Box display=\"flex\" alignItems=\"center\" flexWrap=\"wrap\" style={{ gap: 8 }}>\n <Typography variant=\"body2\">\n <strong>Version:</strong> {spec.version || 'v1'}\n </Typography>\n {spec.tags && spec.tags.length > 0 && (\n <Box display=\"flex\" ml={2} style={{ gap: 4 }}>\n {spec.tags.map((tag: string) => (\n <Chip key={tag} label={tag} size=\"small\" />\n ))}\n </Box>\n )}\n </Box>\n </Box>\n </InfoCard>\n </Grid>\n\n {spec.plans && spec.plans.length > 0 && (\n <Grid item xs={12}>\n <InfoCard title=\"Available Plans\">\n <Table size=\"small\">\n <TableHead>\n <TableRow>\n <TableCell>Tier</TableCell>\n <TableCell>Description</TableCell>\n <TableCell>Rate Limits</TableCell>\n </TableRow>\n </TableHead>\n <TableBody>\n {spec.plans.map((plan: any) => (\n <TableRow key={plan.tier}>\n <TableCell>\n <Chip\n label={plan.tier}\n size=\"small\"\n />\n </TableCell>\n <TableCell>{plan.description || '-'}</TableCell>\n <TableCell>\n {plan.limits && Object.entries(plan.limits).map(([key, value]) => (\n <Typography key={key} variant=\"body2\">\n {String(value)} per {key}\n </Typography>\n ))}\n </TableCell>\n </TableRow>\n ))}\n </TableBody>\n </Table>\n {spec.planPolicyRef && (\n <Box mt={2}>\n <Typography variant=\"caption\" color=\"textSecondary\">\n Managed by PlanPolicy: <strong>{spec.planPolicyRef.name}</strong> ({spec.planPolicyRef.namespace})\n </Typography>\n </Box>\n )}\n </InfoCard>\n </Grid>\n )}\n\n <Grid item xs={12} md={6}>\n <InfoCard title=\"Contact Information\">\n {spec.contact ? (\n <Box p={2}>\n <Grid container spacing={2}>\n {spec.contact.team && (\n <Grid item xs={12}>\n <Typography variant=\"body2\">\n <strong>Team:</strong> {spec.contact.team}\n </Typography>\n </Grid>\n )}\n {spec.contact.email && (\n <Grid item xs={12}>\n <Typography variant=\"body2\">\n <strong>Email:</strong> <Link to={`mailto:${spec.contact.email}`}>{spec.contact.email}</Link>\n </Typography>\n </Grid>\n )}\n {spec.contact.slack && (\n <Grid item xs={12}>\n <Typography variant=\"body2\">\n <strong>Slack:</strong> {spec.contact.slack}\n </Typography>\n </Grid>\n )}\n </Grid>\n </Box>\n ) : (\n <Box p={2}>\n <Typography variant=\"body2\" color=\"textSecondary\">\n No contact information available\n </Typography>\n </Box>\n )}\n </InfoCard>\n </Grid>\n\n <Grid item xs={12} md={6}>\n <InfoCard title=\"Documentation\">\n {spec.documentation ? (\n <Box p={2}>\n <Grid container spacing={2}>\n {spec.documentation.docsURL && (\n <Grid item xs={12}>\n <Typography variant=\"body2\">\n <strong>Documentation:</strong>{' '}\n <Link to={spec.documentation.docsURL} target=\"_blank\">\n View Docs\n </Link>\n </Typography>\n </Grid>\n )}\n {spec.documentation.openAPISpec && (\n <Grid item xs={12}>\n <Typography variant=\"body2\">\n <strong>OpenAPI Spec:</strong>{' '}\n <Link to={spec.documentation.openAPISpec} target=\"_blank\">\n View Spec\n </Link>\n </Typography>\n </Grid>\n )}\n </Grid>\n </Box>\n ) : (\n <Box p={2}>\n <Typography variant=\"body2\" color=\"textSecondary\">\n No documentation links available\n </Typography>\n </Box>\n )}\n </InfoCard>\n </Grid>\n </Grid>\n );\n};\n","import * as React from 'react';\n/**\n * @ignore - internal component.\n */\n\nvar Tablelvl2Context = React.createContext();\n\nif (process.env.NODE_ENV !== 'production') {\n Tablelvl2Context.displayName = 'Tablelvl2Context';\n}\n\nexport default Tablelvl2Context;","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar react_1 = require(\"react\");\nvar useAsyncFn_1 = tslib_1.__importDefault(require(\"./useAsyncFn\"));\nfunction useAsync(fn, deps) {\n if (deps === void 0) { deps = []; }\n var _a = useAsyncFn_1.default(fn, deps, {\n loading: true,\n }), state = _a[0], callback = _a[1];\n react_1.useEffect(function () {\n callback();\n }, [callback]);\n return state;\n}\nexports.default = useAsync;\n","import { jsxs, jsx } from 'react/jsx-runtime';\nimport Box from '@material-ui/core/Box';\nimport Divider from '@material-ui/core/Divider';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Typography from '@material-ui/core/Typography';\nimport ArrowIcon from '@material-ui/icons/ArrowForward';\nimport { Link } from '../../components/Link/Link.esm.js';\n\nconst useStyles = makeStyles(\n (theme) => ({\n root: {\n maxWidth: \"fit-content\",\n padding: theme.spacing(2, 2, 2, 2.5)\n },\n boxTitle: {\n margin: 0,\n color: theme.palette.textSubtle\n },\n arrow: {\n color: theme.palette.textSubtle\n }\n }),\n { name: \"BackstageBottomLink\" }\n);\nfunction BottomLink(props) {\n const { link, title, onClick } = props;\n const classes = useStyles();\n return /* @__PURE__ */ jsxs(Box, { children: [\n /* @__PURE__ */ jsx(Divider, {}),\n /* @__PURE__ */ jsx(Link, { to: link, onClick, underline: \"none\", children: /* @__PURE__ */ jsxs(Box, { display: \"flex\", alignItems: \"center\", className: classes.root, children: [\n /* @__PURE__ */ jsx(Box, { className: classes.boxTitle, fontWeight: \"fontWeightBold\", m: 1, children: /* @__PURE__ */ jsx(Typography, { children: /* @__PURE__ */ jsx(\"strong\", { children: title }) }) }),\n /* @__PURE__ */ jsx(ArrowIcon, { className: classes.arrow })\n ] }) })\n ] });\n}\n\nexport { BottomLink };\n//# sourceMappingURL=BottomLink.esm.js.map\n","import { jsx } from 'react/jsx-runtime';\nimport Button$1 from '@material-ui/core/Button';\nimport { forwardRef } from 'react';\nimport { Link } from '../Link/Link.esm.js';\n\nconst LinkWrapper = forwardRef((props, ref) => /* @__PURE__ */ jsx(Link, { ref, ...props, color: \"initial\" }));\nconst LinkButton = forwardRef((props, ref) => /* @__PURE__ */ jsx(Button$1, { ref, component: LinkWrapper, ...props }));\nconst Button = LinkButton;\n\nexport { Button, LinkButton };\n//# sourceMappingURL=LinkButton.esm.js.map\n","import { jsx } from 'react/jsx-runtime';\nimport Typography from '@material-ui/core/Typography';\nimport { Component } from 'react';\nimport { LinkButton } from '../../components/LinkButton/LinkButton.esm.js';\nimport { ErrorPanel } from '../../components/ErrorPanel/ErrorPanel.esm.js';\nimport { coreComponentsTranslationRef } from '../../translation.esm.js';\nimport { useTranslationRef } from '@backstage/core-plugin-api/alpha';\n\nconst SlackLink = (props) => {\n const { slackChannel } = props;\n const { t } = useTranslationRef(coreComponentsTranslationRef);\n if (!slackChannel) {\n return null;\n } else if (typeof slackChannel === \"string\") {\n return /* @__PURE__ */ jsx(Typography, { children: t(\"errorBoundary.title\", { slackChannel }) });\n } else if (!slackChannel.href) {\n return /* @__PURE__ */ jsx(Typography, { children: t(\"errorBoundary.title\", {\n slackChannel: slackChannel.name\n }) });\n }\n return /* @__PURE__ */ jsx(LinkButton, { to: slackChannel.href, variant: \"contained\", children: slackChannel.name });\n};\nconst ErrorBoundary = class ErrorBoundary2 extends Component {\n constructor(props) {\n super(props);\n this.state = {\n error: void 0,\n errorInfo: void 0\n };\n }\n componentDidCatch(error, errorInfo) {\n console.error(`ErrorBoundary, error: ${error}`, { error, errorInfo });\n this.setState({ error, errorInfo });\n }\n render() {\n const { slackChannel, children } = this.props;\n const { error } = this.state;\n if (!error) {\n return children;\n }\n return /* @__PURE__ */ jsx(ErrorPanel, { title: \"Something Went Wrong\", error, children: /* @__PURE__ */ jsx(SlackLink, { slackChannel }) });\n }\n};\n\nexport { ErrorBoundary };\n//# sourceMappingURL=ErrorBoundary.esm.js.map\n","import { jsx, jsxs } from 'react/jsx-runtime';\nimport Card from '@material-ui/core/Card';\nimport CardActions from '@material-ui/core/CardActions';\nimport CardContent from '@material-ui/core/CardContent';\nimport CardHeader from '@material-ui/core/CardHeader';\nimport Divider from '@material-ui/core/Divider';\nimport { makeStyles, withStyles } from '@material-ui/core/styles';\nimport classNames from 'classnames';\nimport { BottomLink } from '../BottomLink/BottomLink.esm.js';\nimport { ErrorBoundary } from '../ErrorBoundary/ErrorBoundary.esm.js';\n\nconst useStyles = makeStyles(\n (theme) => ({\n noPadding: {\n padding: 0,\n \"&:last-child\": {\n paddingBottom: 0\n }\n },\n contentAlignBottom: {\n display: \"flex\",\n alignItems: \"self-end\"\n },\n header: {\n padding: theme.spacing(2, 2, 2, 2.5)\n },\n headerTitle: {\n fontWeight: theme.typography.fontWeightBold\n },\n headerSubheader: {\n paddingTop: theme.spacing(1)\n },\n headerAvatar: {},\n headerAction: {},\n headerContent: {},\n subheader: {\n display: \"flex\"\n }\n }),\n { name: \"BackstageInfoCard\" }\n);\nconst CardActionsTopRight = withStyles(\n (theme) => ({\n root: {\n display: \"inline-block\",\n padding: theme.spacing(8, 8, 0, 0),\n float: \"right\"\n }\n }),\n { name: \"BackstageInfoCardCardActionsTopRight\" }\n)(CardActions);\nconst VARIANT_STYLES = {\n card: {\n flex: {\n display: \"flex\",\n flexDirection: \"column\"\n },\n fullHeight: {\n display: \"flex\",\n flexDirection: \"column\",\n height: \"100%\"\n },\n gridItem: {\n display: \"flex\",\n flexDirection: \"column\",\n height: \"calc(100% - 10px)\",\n // for pages without content header\n marginBottom: \"10px\",\n breakInside: \"avoid-page\",\n \"@media print\": {\n height: \"auto\"\n }\n }\n },\n cardContent: {\n fullHeight: {\n flex: 1\n },\n gridItem: {\n flex: 1\n }\n }\n};\nfunction InfoCard(props) {\n const {\n title,\n subheader,\n divider = true,\n deepLink,\n slackChannel,\n errorBoundaryProps,\n variant,\n alignContent = \"normal\",\n children,\n headerStyle,\n headerProps,\n icon,\n action,\n actionsClassName,\n actions,\n cardClassName,\n actionsTopRight,\n className,\n noPadding,\n titleTypographyProps,\n subheaderTypographyProps\n } = props;\n const classes = useStyles();\n let calculatedStyle = {};\n let calculatedCardStyle = {};\n if (variant) {\n const variants = variant.split(/[\\s]+/g);\n variants.forEach((name) => {\n calculatedStyle = {\n ...calculatedStyle,\n ...VARIANT_STYLES.card[name]\n };\n calculatedCardStyle = {\n ...calculatedCardStyle,\n ...VARIANT_STYLES.cardContent[name]\n };\n });\n }\n const cardSubTitle = () => {\n if (!subheader && !icon) {\n return null;\n }\n return /* @__PURE__ */ jsxs(\"div\", { \"data-testid\": \"info-card-subheader\", children: [\n subheader && /* @__PURE__ */ jsx(\"div\", { className: classes.subheader, children: subheader }),\n icon\n ] });\n };\n const errProps = errorBoundaryProps || (slackChannel ? { slackChannel } : {});\n return /* @__PURE__ */ jsx(Card, { style: calculatedStyle, className, children: /* @__PURE__ */ jsxs(ErrorBoundary, { ...errProps, children: [\n title && /* @__PURE__ */ jsx(\n CardHeader,\n {\n classes: {\n root: classNames(classes.header),\n title: classes.headerTitle,\n subheader: classes.headerSubheader,\n avatar: classes.headerAvatar,\n action: classes.headerAction,\n content: classes.headerContent\n },\n title,\n subheader: cardSubTitle(),\n action,\n style: { ...headerStyle },\n titleTypographyProps,\n subheaderTypographyProps,\n ...headerProps\n }\n ),\n actionsTopRight && /* @__PURE__ */ jsx(CardActionsTopRight, { children: actionsTopRight }),\n divider && /* @__PURE__ */ jsx(Divider, {}),\n /* @__PURE__ */ jsx(\n CardContent,\n {\n className: classNames(cardClassName, {\n [classes.noPadding]: noPadding,\n [classes.contentAlignBottom]: alignContent === \"bottom\"\n }),\n style: calculatedCardStyle,\n children\n }\n ),\n actions && /* @__PURE__ */ jsx(CardActions, { className: actionsClassName, children: actions }),\n deepLink && /* @__PURE__ */ jsx(BottomLink, { ...deepLink })\n ] }) });\n}\n\nexport { InfoCard };\n//# sourceMappingURL=InfoCard.esm.js.map\n","import * as React from 'react';\n/**\n * @ignore - internal component.\n */\n\nvar TableContext = React.createContext();\n\nif (process.env.NODE_ENV !== 'production') {\n TableContext.displayName = 'TableContext';\n}\n\nexport default TableContext;"],"names":["Object","defineProperty","exports","value","tslib_1","react_1","useMountedState_1","__importDefault","fn","deps","initialState","loading","lastCallId","useRef","isMounted","default","_a","useState","state","set","callback","useCallback","args","_i","arguments","length","callId","current","prevState","__assign","apply","then","error","TableRow","props","ref","classes","className","_props$component","component","Component","_props$hover","hover","_props$selected","selected","other","tablelvl2","root","head","footer","variant","role","theme","color","display","verticalAlign","outline","backgroundColor","palette","action","secondary","main","selectedOpacity","name","mountedRef","get","useEffect","defaultComponent","TableBody","Provider","useEntity","versionedHolder","useVersionedContext","Error","atVersion","entity","createVersionedContext","useStyles","makeStyles","visuallyHidden","clip","clipPath","overflow","position","userSelect","whiteSpace","height","width","externalLink","externalLinkIcon","marginLeft","spacing","ExternalLinkIcon","Icon","useApp","getSystemIcon","jsx","isExternalUri","uri","test","scriptProtocolPattern","originalWindowOpen","window","open","__backstage","newOpen","url","String","this","getNodeText","node","Array","map","join","trim","children","includes","Link","forwardRef","onClick","noTrack","analytics","useAnalytics","to","obj","createRoutesFromChildren","Route","index","element","isReactRouterBeta","resolvedPath","basePath","useApi","configApiRef","getOptionalString","useBaseUrl","pathname","URL","trimEnd","useBasePath","external","startsWithBasePath","startsWith","concat","useResolvedPath","linkText","newWindow","exec","handleClick","event","captureEvent","attributes","jsxs","target","rel","href","_interopRequireDefault","_interopRequireWildcard","React","_default","createElement","d","TableHead","TableCell","_props$align","align","paddingProp","padding","scopeProp","scope","sizeProp","size","sortDirection","variantProp","table","isHeadCell","ariaSort","stickyHeader","typography","body2","borderBottom","type","divider","textAlign","text","primary","lineHeight","pxToRem","fontWeight","fontWeightMedium","body","fontSize","sizeSmall","paddingRight","paddingLeft","paddingCheckbox","paddingNone","alignLeft","alignCenter","alignRight","flexDirection","alignJustify","top","left","zIndex","background","Table","_props$padding","_props$size","_props$stickyHeader","borderCollapse","borderSpacing","captionSide","ApiProductInfoCard","config","fetchApi","fetchApiRef","backendUrl","getString","namespace","metadata","annotations","apiProductName","apiProduct","useAsync","async","response","fetch","json","InfoCard","title","Typography","Progress","ResponseErrorPanel","spec","Grid","container","item","xs","Box","p","gutterBottom","displayName","paragraph","description","alignItems","flexWrap","style","gap","strong","version","tags","ml","tag","Chip","label","plans","plan","tier","limits","entries","key","planPolicyRef","mt","md","contact","team","email","slack","documentation","docsURL","openAPISpec","useAsyncFn_1","maxWidth","boxTitle","margin","textSubtle","arrow","BottomLink","link","Divider","underline","m","A","LinkWrapper","LinkButton","Button","SlackLink","slackChannel","t","ErrorBoundary","constructor","super","errorInfo","componentDidCatch","console","setState","render","noPadding","paddingBottom","contentAlignBottom","header","headerTitle","fontWeightBold","headerSubheader","paddingTop","headerAvatar","headerAction","headerContent","subheader","CardActionsTopRight","withStyles","float","CardActions","VARIANT_STYLES","card","flex","fullHeight","gridItem","marginBottom","breakInside","cardContent","deepLink","errorBoundaryProps","alignContent","headerStyle","headerProps","icon","actionsClassName","actions","cardClassName","actionsTopRight","titleTypographyProps","subheaderTypographyProps","calculatedStyle","calculatedCardStyle","split","forEach","errProps","Card","CardHeader","avatar","content","CardContent"],"sourceRoot":""}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";(self.webpackChunkinternal_plugin_kuadrant=self.webpackChunkinternal_plugin_kuadrant||[]).push([[6281],{16281:(e,t,a)=>{a.d(t,{d:()=>N});var r=a(31085),n=a(95478),s=a(22097),i=a(35015),d=a(42367),o=a(86687),l=a(25010),c=a(96040),p=a(34955),u=a(46205),m=a(76891),v=a(61477),h=a(46805),A=a(16249),j=a(93453),y=a(64947),x=a(72501),g=a(10394),b=a(67720),f=a(31653),q=a(38605),k=a(55429),w=a(92399);const C=({open:e,request:t,action:a,onClose:s,onConfirm:i})=>{const[d,o]=(0,n.useState)("");return(0,r.jsxs)(m.A,{open:e,onClose:s,maxWidth:"sm",fullWidth:!0,children:[(0,r.jsxs)(v.A,{children:["approve"===a?"Approve":"Reject"," API Key Request"]}),(0,r.jsx)(h.A,{children:t&&(0,r.jsxs)(r.Fragment,{children:[(0,r.jsxs)("p",{children:[(0,r.jsx)("strong",{children:"User:"})," ",t.spec.requestedBy.userId]}),(0,r.jsxs)("p",{children:[(0,r.jsx)("strong",{children:"API:"})," ",t.spec.apiName]}),(0,r.jsxs)("p",{children:[(0,r.jsx)("strong",{children:"Plan:"})," ",t.spec.planTier]}),(0,r.jsxs)("p",{children:[(0,r.jsx)("strong",{children:"Use Case:"})," ",t.spec.useCase||"-"]}),(0,r.jsx)(A.A,{label:"Comment (optional)",multiline:!0,rows:3,fullWidth:!0,margin:"normal",value:d,onChange:e=>o(e.target.value)})]})}),(0,r.jsxs)(j.A,{children:[(0,r.jsx)(y.A,{onClick:s,children:"Cancel"}),(0,r.jsx)(y.A,{onClick:()=>{i(d),o("")},color:"approve"===a?"primary":"secondary",variant:"contained",children:"approve"===a?"Approve":"Reject"})]})]})},R=({open:e,requests:t,action:a,onClose:s,onConfirm:i})=>{const[d,o]=(0,n.useState)(""),l="approve"===a;return(0,r.jsxs)(m.A,{open:e,onClose:s,maxWidth:"md",fullWidth:!0,children:[(0,r.jsxs)(v.A,{children:[l?"Approve":"Reject"," ",t.length," API Key Requests"]}),(0,r.jsxs)(h.A,{children:[(0,r.jsxs)(x.A,{variant:"body2",paragraph:!0,children:["You are about to ",l?"approve":"reject"," the following requests:"]}),(0,r.jsx)(g.A,{mb:2,maxHeight:200,overflow:"auto",children:t.map(e=>(0,r.jsx)(g.A,{mb:1,p:1,bgcolor:"background.default",children:(0,r.jsxs)(x.A,{variant:"body2",children:[(0,r.jsx)("strong",{children:e.spec.requestedBy.userId})," - ",e.spec.apiName," (",e.spec.planTier,")"]})},`${e.metadata.namespace}/${e.metadata.name}`))}),(0,r.jsx)(A.A,{label:"Comment (optional)",multiline:!0,fullWidth:!0,margin:"normal",value:d,onChange:e=>o(e.target.value),helperText:`This comment will be applied to all ${l?"approved":"rejected"} requests`})]}),(0,r.jsxs)(j.A,{children:[(0,r.jsx)(y.A,{onClick:s,children:"Cancel"}),(0,r.jsx)(y.A,{onClick:()=>{i(d),o("")},color:l?"primary":"secondary",variant:"contained",children:l?"Approve All":"Reject All"})]})]})},N=()=>{const e=(0,s.useApi)(s.configApiRef),t=(0,s.useApi)(s.fetchApiRef),a=(0,s.useApi)(s.identityApiRef),m=e.getString("backend.baseUrl"),[v,h]=(0,n.useState)(0),[A,j]=(0,n.useState)(0),[N,B]=(0,n.useState)([]),[S,$]=(0,n.useState)({open:!1,request:null,action:"approve"}),[I,T]=(0,n.useState)({open:!1,requests:[],action:"approve"}),{allowed:P,loading:W,error:z}=(0,u.l)(p.H4),{value:U,loading:Q,error:_}=(0,i.A)(async()=>{const e=(await a.getBackstageIdentity()).userEntityRef;console.log("ApprovalQueueCard: fetching all requests from",`${m}/api/kuadrant/requests`);const r=await t.fetch(`${m}/api/kuadrant/requests`);if(!r.ok)return console.log("ApprovalQueueCard: failed to fetch requests, status:",r.status),{pending:[],approved:[],rejected:[],reviewedBy:e};const n=r.headers.get("content-type");if(!n||!n.includes("application/json"))return console.log("ApprovalQueueCard: received non-json response"),{pending:[],approved:[],rejected:[],reviewedBy:e};const s=(await r.json()).items||[];console.log("ApprovalQueueCard: received",s.length,"total requests"),console.log("ApprovalQueueCard: raw requests:",s);const i=s.filter(e=>{var t;return"Pending"===((null===(t=e.status)||void 0===t?void 0:t.phase)||"Pending")}),d=s.filter(e=>{var t;return"Approved"===(null===(t=e.status)||void 0===t?void 0:t.phase)}),o=s.filter(e=>{var t;return"Rejected"===(null===(t=e.status)||void 0===t?void 0:t.phase)});return console.log("ApprovalQueueCard: grouped -",{pending:i.length,approved:d.length,rejected:o.length}),{pending:i,approved:d,rejected:o,reviewedBy:e}},[m,t,a,v]);if(Q||W)return(0,r.jsx)(o.k,{});if(_)return(0,r.jsx)(d._,{error:_});if(z)return(0,r.jsxs)(g.A,{p:2,children:[(0,r.jsxs)(x.A,{color:"error",children:["Unable to check permissions: ",z.message]}),(0,r.jsx)(x.A,{variant:"body2",color:"textSecondary",children:"Permission: kuadrant.apikeyrequest.update"}),(0,r.jsx)(x.A,{variant:"body2",color:"textSecondary",children:"Please try again or contact your administrator"})]});const E=(null==U?void 0:U.pending)||[],H=(null==U?void 0:U.approved)||[],J=(null==U?void 0:U.rejected)||[],O=e=>new Date(e).toLocaleDateString("en-GB",{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"}),D=[{title:"Request Name",field:"metadata.name",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:e.metadata.name})},{title:"User",field:"spec.requestedBy.userId",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:e.spec.requestedBy.userId})},{title:"API",field:"spec.apiName",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:(0,r.jsx)("strong",{children:e.spec.apiName})})},{title:"Namespace",field:"spec.apiNamespace",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:e.spec.apiNamespace})},{title:"Plan",field:"spec.planTier",render:e=>(0,r.jsx)(b.A,{label:e.spec.planTier,size:"small"})},{title:"Use Case",field:"spec.useCase",render:e=>(0,r.jsx)(x.A,{variant:"body2",style:{maxWidth:200},noWrap:!0,title:e.spec.useCase,children:e.spec.useCase||"-"})},{title:"Requested",field:"spec.requestedAt",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:e.spec.requestedAt?O(e.spec.requestedAt):"-"})},{title:"Actions",render:e=>P?(0,r.jsxs)(g.A,{display:"flex",style:{gap:8},children:[(0,r.jsx)(y.A,{size:"small",startIcon:(0,r.jsx)(k.A,{}),onClick:()=>{$({open:!0,request:e,action:"approve"})},color:"primary",variant:"outlined",children:"Approve"}),(0,r.jsx)(y.A,{size:"small",startIcon:(0,r.jsx)(w.A,{}),onClick:()=>{$({open:!0,request:e,action:"reject"})},color:"secondary",variant:"outlined",children:"Reject"})]}):null}],F=[{title:"Request Name",field:"metadata.name",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:e.metadata.name})},{title:"User",field:"spec.requestedBy.userId",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:e.spec.requestedBy.userId})},{title:"API",field:"spec.apiName",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:(0,r.jsx)("strong",{children:e.spec.apiName})})},{title:"Namespace",field:"spec.apiNamespace",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:e.spec.apiNamespace})},{title:"Plan",field:"spec.planTier",render:e=>(0,r.jsx)(b.A,{label:e.spec.planTier,size:"small"})},{title:"Requested",field:"spec.requestedAt",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:e.spec.requestedAt?O(e.spec.requestedAt):"-"})},{title:"Approved",field:"status.reviewedAt",render:e=>{var t;return(0,r.jsx)(x.A,{variant:"body2",children:(null===(t=e.status)||void 0===t?void 0:t.reviewedAt)?O(e.status.reviewedAt):"-"})}},{title:"Reviewed By",field:"status.reviewedBy",render:e=>{var t;return(0,r.jsx)(x.A,{variant:"body2",children:(null===(t=e.status)||void 0===t?void 0:t.reviewedBy)||"-"})}},{title:"Approval Type",field:"status.reviewedBy",render:e=>{var t;const a="system"===(null===(t=e.status)||void 0===t?void 0:t.reviewedBy);return(0,r.jsx)(b.A,{label:a?"Automatic":"Manual",size:"small",color:a?"default":"primary"})}}],K=[{title:"Request Name",field:"metadata.name",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:e.metadata.name})},{title:"User",field:"spec.requestedBy.userId",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:e.spec.requestedBy.userId})},{title:"API",field:"spec.apiName",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:(0,r.jsx)("strong",{children:e.spec.apiName})})},{title:"Namespace",field:"spec.apiNamespace",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:e.spec.apiNamespace})},{title:"Plan",field:"spec.planTier",render:e=>(0,r.jsx)(b.A,{label:e.spec.planTier,size:"small"})},{title:"Requested",field:"spec.requestedAt",render:e=>(0,r.jsx)(x.A,{variant:"body2",children:e.spec.requestedAt?O(e.spec.requestedAt):"-"})},{title:"Rejected",field:"status.reviewedAt",render:e=>{var t;return(0,r.jsx)(x.A,{variant:"body2",children:(null===(t=e.status)||void 0===t?void 0:t.reviewedAt)?O(e.status.reviewedAt):"-"})}},{title:"Reviewed By",field:"status.reviewedBy",render:e=>{var t;return(0,r.jsx)(x.A,{variant:"body2",children:(null===(t=e.status)||void 0===t?void 0:t.reviewedBy)||"-"})}},{title:"Reason",field:"status.reason",render:e=>{var t,a;return(0,r.jsx)(x.A,{variant:"body2",style:{maxWidth:200},noWrap:!0,title:null===(t=e.status)||void 0===t?void 0:t.reason,children:(null===(a=e.status)||void 0===a?void 0:a.reason)||"-"})}}],L=(()=>{switch(A){case 0:default:return{data:H,columns:F,showSelection:!1};case 1:return{data:E.map(e=>{const t=N.some(t=>t.metadata.name===e.metadata.name&&t.metadata.namespace===e.metadata.namespace);return{...e,tableData:{checked:t}}}),columns:D,showSelection:!0};case 2:return{data:J,columns:K,showSelection:!1}}})();return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsxs)(c.n,{title:"API Access Requests",subheader:`${E.length} pending, ${H.length} approved, ${J.length} rejected`,children:[(0,r.jsx)(g.A,{mb:2,children:(0,r.jsxs)(f.A,{value:A,onChange:(e,t)=>{j(t),B([])},indicatorColor:"primary",textColor:"primary",children:[(0,r.jsx)(q.A,{label:`Approved (${H.length})`}),(0,r.jsx)(q.A,{label:`Pending (${E.length})`}),(0,r.jsx)(q.A,{label:`Rejected (${J.length})`})]})}),P&&1===A&&N.length>0&&(0,r.jsxs)(g.A,{mb:2,display:"flex",alignItems:"center",justifyContent:"space-between",p:2,bgcolor:"background.default",children:[(0,r.jsxs)(x.A,{variant:"body2",children:[N.length," request",1!==N.length?"s":""," selected"]}),(0,r.jsxs)(g.A,{display:"flex",style:{gap:8},children:[(0,r.jsx)(y.A,{size:"small",variant:"contained",color:"primary",startIcon:(0,r.jsx)(k.A,{}),onClick:()=>{0!==N.length&&T({open:!0,requests:N,action:"approve"})},children:"Approve Selected"}),(0,r.jsx)(y.A,{size:"small",variant:"contained",color:"secondary",startIcon:(0,r.jsx)(w.A,{}),onClick:()=>{0!==N.length&&T({open:!0,requests:N,action:"reject"})},children:"Reject Selected"})]})]}),0===L.data.length?(0,r.jsx)(g.A,{p:3,textAlign:"center",children:(0,r.jsxs)(x.A,{variant:"body1",color:"textSecondary",children:[0===A&&"No approved requests.",1===A&&"No pending requests.",2===A&&"No rejected requests."]})}):(0,r.jsx)(l.X,{options:{selection:P&&L.showSelection,paging:L.data.length>10,pageSize:10,search:!1,showTextRowsSelected:!1,toolbar:!1},data:L.data,columns:L.columns,onSelectionChange:e=>B(e)})]}),(0,r.jsx)(C,{open:S.open,request:S.request,action:S.action,onClose:()=>$({open:!1,request:null,action:"approve"}),onConfirm:async e=>{if(!S.request||!U)return;const a="approve"===S.action?`${m}/api/kuadrant/requests/${S.request.metadata.namespace}/${S.request.metadata.name}/approve`:`${m}/api/kuadrant/requests/${S.request.metadata.namespace}/${S.request.metadata.name}/reject`;try{if(!(await t.fetch(a,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({comment:e,reviewedBy:U.reviewedBy})})).ok)throw new Error(`failed to ${S.action} request`);$({open:!1,request:null,action:"approve"}),h(e=>e+1)}catch(e){console.error(`error ${S.action}ing request:`,e)}}}),(0,r.jsx)(R,{open:I.open,requests:I.requests,action:I.action,onClose:()=>T({open:!1,requests:[],action:"approve"}),onConfirm:async e=>{if(!U||0===I.requests.length)return;const a="approve"===I.action?`${m}/api/kuadrant/requests/bulk-approve`:`${m}/api/kuadrant/requests/bulk-reject`;try{if(!(await t.fetch(a,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({requests:I.requests.map(e=>({namespace:e.metadata.namespace,name:e.metadata.name})),comment:e,reviewedBy:U.reviewedBy})})).ok)throw new Error(`failed to bulk ${I.action} requests`);T({open:!1,requests:[],action:"approve"}),B([]),h(e=>e+1)}catch(e){console.error(`error bulk ${I.action}ing requests:`,e)}}})]})}},34955:(e,t,a)=>{a.d(t,{FL:()=>s,H4:()=>p,J:()=>n,KN:()=>l,TE:()=>c,ib:()=>i,jH:()=>m,qC:()=>d,uL:()=>u,vs:()=>o});var r=a(83572);(0,r.i)({name:"kuadrant.planpolicy.create",attributes:{action:"create"}}),(0,r.i)({name:"kuadrant.planpolicy.read",attributes:{action:"read"}}),(0,r.i)({name:"kuadrant.planpolicy.update",attributes:{action:"update"}}),(0,r.i)({name:"kuadrant.planpolicy.delete",attributes:{action:"delete"}});const n=(0,r.i)({name:"kuadrant.planpolicy.list",attributes:{action:"read"}}),s=(0,r.i)({name:"kuadrant.apiproduct.create",attributes:{action:"create"}}),i=((0,r.i)({name:"kuadrant.apiproduct.read",attributes:{action:"read"}}),(0,r.i)({name:"kuadrant.apiproduct.update",attributes:{action:"update"}})),d=(0,r.i)({name:"kuadrant.apiproduct.delete",attributes:{action:"delete"}}),o=(0,r.i)({name:"kuadrant.apiproduct.list",attributes:{action:"read"}}),l=(0,r.i)({name:"kuadrant.apikeyrequest.create",attributes:{action:"create"},resourceType:"apiproduct"}),c=((0,r.i)({name:"kuadrant.apikeyrequest.read.own",attributes:{action:"read"}}),(0,r.i)({name:"kuadrant.apikeyrequest.read.all",attributes:{action:"read"}})),p=(0,r.i)({name:"kuadrant.apikeyrequest.update",attributes:{action:"update"}}),u=((0,r.i)({name:"kuadrant.apikeyrequest.list",attributes:{action:"read"}}),(0,r.i)({name:"kuadrant.apikey.read.own",attributes:{action:"read"}}),(0,r.i)({name:"kuadrant.apikey.read.all",attributes:{action:"read"}}),(0,r.i)({name:"kuadrant.apikey.delete.own",attributes:{action:"delete"}})),m=(0,r.i)({name:"kuadrant.apikey.delete.all",attributes:{action:"delete"}})},46205:(e,t,a)=>{a.d(t,{W:()=>s,l:()=>n});var r=a(87421);function n(e,t){const a="resourceType"in e?{permission:e,resourceRef:t}:{permission:e},n=(0,r.J)(a);return{allowed:n.allowed,loading:n.loading,error:n.error}}function s(e,t,a,r){return!!r||!(!a||e!==t)}}}]);
|
|
2
|
-
//# sourceMappingURL=6281.29f4549b.chunk.js.map
|