@kuadrant/kuadrant-backstage-plugin-frontend 0.0.2-dev-61ff3d3 → 0.0.2-dev-5c79230

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (92) hide show
  1. package/dist/components/ApiKeyDetailPage/ApiKeyDetailPage.esm.js +319 -0
  2. package/dist/components/ApiKeyDetailPage/ApiKeyDetailPage.esm.js.map +1 -0
  3. package/dist/components/ApiKeyDetailPage/index.esm.js +2 -0
  4. package/dist/components/ApiKeyDetailPage/index.esm.js.map +1 -0
  5. package/dist/components/ApiKeyManagementTab/ApiKeyManagementTab.esm.js +340 -162
  6. package/dist/components/ApiKeyManagementTab/ApiKeyManagementTab.esm.js.map +1 -1
  7. package/dist/components/ApiKeysPage/ApiKeysPage.esm.js +43 -0
  8. package/dist/components/ApiKeysPage/ApiKeysPage.esm.js.map +1 -0
  9. package/dist/components/ApiKeysPage/index.esm.js +2 -0
  10. package/dist/components/ApiKeysPage/index.esm.js.map +1 -0
  11. package/dist/components/ApiProductInfoCard/ApiProductInfoCard.esm.js +23 -2
  12. package/dist/components/ApiProductInfoCard/ApiProductInfoCard.esm.js.map +1 -1
  13. package/dist/components/ApprovalQueueCard/ApprovalQueueCard.esm.js +312 -118
  14. package/dist/components/ApprovalQueueCard/ApprovalQueueCard.esm.js.map +1 -1
  15. package/dist/components/ApprovalQueueTable/ApprovalQueueTable.esm.js +645 -0
  16. package/dist/components/ApprovalQueueTable/ApprovalQueueTable.esm.js.map +1 -0
  17. package/dist/components/EditAPIKeyDialog/EditAPIKeyDialog.esm.js +14 -2
  18. package/dist/components/EditAPIKeyDialog/EditAPIKeyDialog.esm.js.map +1 -1
  19. package/dist/components/EntityApiApprovalTab/EntityApiApprovalTab.esm.js +276 -0
  20. package/dist/components/EntityApiApprovalTab/EntityApiApprovalTab.esm.js.map +1 -0
  21. package/dist/components/EntityApiApprovalTab/index.esm.js +2 -0
  22. package/dist/components/EntityApiApprovalTab/index.esm.js.map +1 -0
  23. package/dist/components/FilterPanel/FilterPanel.esm.js +127 -0
  24. package/dist/components/FilterPanel/FilterPanel.esm.js.map +1 -0
  25. package/dist/components/KuadrantPage/KuadrantPage.esm.js +93 -43
  26. package/dist/components/KuadrantPage/KuadrantPage.esm.js.map +1 -1
  27. package/dist/components/KuadrantPage/index.esm.js +1 -1
  28. package/dist/components/{MyApiKeysCard/MyApiKeysCard.esm.js → MyApiKeysTable/MyApiKeysTable.esm.js} +294 -176
  29. package/dist/components/MyApiKeysTable/MyApiKeysTable.esm.js.map +1 -0
  30. package/dist/components/PlanPolicyDetailsCard/PlanPolicyDetails.esm.js.map +1 -1
  31. package/dist/index.d.ts +8 -4
  32. package/dist/index.esm.js +1 -1
  33. package/dist/plugin.esm.js +30 -1
  34. package/dist/plugin.esm.js.map +1 -1
  35. package/dist/utils/styles.esm.js +14 -0
  36. package/dist/utils/styles.esm.js.map +1 -0
  37. package/dist-scalprum/{internal.plugin-kuadrant.90488643192ec2f36944.js → internal.plugin-kuadrant.a36ec4956222cb0faf61.js} +2 -2
  38. package/dist-scalprum/internal.plugin-kuadrant.a36ec4956222cb0faf61.js.map +1 -0
  39. package/dist-scalprum/plugin-manifest.json +2 -2
  40. package/dist-scalprum/static/2967.c684efaf.chunk.js +2 -0
  41. package/dist-scalprum/static/2967.c684efaf.chunk.js.map +1 -0
  42. package/dist-scalprum/static/3097.4bd6b35f.chunk.js +2 -0
  43. package/dist-scalprum/static/3097.4bd6b35f.chunk.js.map +1 -0
  44. package/dist-scalprum/static/4306.3a218ff1.chunk.js +2 -0
  45. package/dist-scalprum/static/4306.3a218ff1.chunk.js.map +1 -0
  46. package/dist-scalprum/static/5010.acf9a415.chunk.js +3 -0
  47. package/dist-scalprum/static/5010.acf9a415.chunk.js.map +1 -0
  48. package/dist-scalprum/static/5453.c1f90bdf.chunk.js +2 -0
  49. package/dist-scalprum/static/5453.c1f90bdf.chunk.js.map +1 -0
  50. package/dist-scalprum/static/6800.736d5da3.chunk.js +2 -0
  51. package/dist-scalprum/static/6800.736d5da3.chunk.js.map +1 -0
  52. package/dist-scalprum/static/6813.036a322f.chunk.js +2 -0
  53. package/dist-scalprum/static/6813.036a322f.chunk.js.map +1 -0
  54. package/dist-scalprum/static/6840.4728fab9.chunk.js +2 -0
  55. package/dist-scalprum/static/6840.4728fab9.chunk.js.map +1 -0
  56. package/dist-scalprum/static/6979.9699b350.chunk.js +2 -0
  57. package/dist-scalprum/static/6979.9699b350.chunk.js.map +1 -0
  58. package/dist-scalprum/static/7684.3d1fc1a1.chunk.js +2 -0
  59. package/dist-scalprum/static/7684.3d1fc1a1.chunk.js.map +1 -0
  60. package/dist-scalprum/static/8365.d3360f18.chunk.js +2 -0
  61. package/dist-scalprum/static/8365.d3360f18.chunk.js.map +1 -0
  62. package/dist-scalprum/static/8416.3604a311.chunk.js +2 -0
  63. package/dist-scalprum/static/8416.3604a311.chunk.js.map +1 -0
  64. package/dist-scalprum/static/8563.7e068fb0.chunk.js +3 -0
  65. package/dist-scalprum/static/8563.7e068fb0.chunk.js.map +1 -0
  66. package/dist-scalprum/static/exposed-PluginRoot.0717f1ce.chunk.js +2 -0
  67. package/dist-scalprum/static/exposed-PluginRoot.0717f1ce.chunk.js.map +1 -0
  68. package/package.json +1 -1
  69. package/dist/components/MyApiKeysCard/MyApiKeysCard.esm.js.map +0 -1
  70. package/dist-scalprum/internal.plugin-kuadrant.90488643192ec2f36944.js.map +0 -1
  71. package/dist-scalprum/static/1483.be69af13.chunk.js +0 -2
  72. package/dist-scalprum/static/1483.be69af13.chunk.js.map +0 -1
  73. package/dist-scalprum/static/3483.2f14a8ca.chunk.js +0 -3
  74. package/dist-scalprum/static/3483.2f14a8ca.chunk.js.map +0 -1
  75. package/dist-scalprum/static/4306.b68910c9.chunk.js +0 -2
  76. package/dist-scalprum/static/4306.b68910c9.chunk.js.map +0 -1
  77. package/dist-scalprum/static/4556.c6bedfc4.chunk.js +0 -3
  78. package/dist-scalprum/static/4556.c6bedfc4.chunk.js.map +0 -1
  79. package/dist-scalprum/static/5222.796292ca.chunk.js +0 -2
  80. package/dist-scalprum/static/5222.796292ca.chunk.js.map +0 -1
  81. package/dist-scalprum/static/532.146b1fd6.chunk.js +0 -2
  82. package/dist-scalprum/static/532.146b1fd6.chunk.js.map +0 -1
  83. package/dist-scalprum/static/5453.29118045.chunk.js +0 -2
  84. package/dist-scalprum/static/5453.29118045.chunk.js.map +0 -1
  85. package/dist-scalprum/static/6281.eb6e16a2.chunk.js +0 -2
  86. package/dist-scalprum/static/6281.eb6e16a2.chunk.js.map +0 -1
  87. package/dist-scalprum/static/8365.75ea3581.chunk.js +0 -2
  88. package/dist-scalprum/static/8365.75ea3581.chunk.js.map +0 -1
  89. package/dist-scalprum/static/exposed-PluginRoot.4183ceef.chunk.js +0 -2
  90. package/dist-scalprum/static/exposed-PluginRoot.4183ceef.chunk.js.map +0 -1
  91. /package/dist-scalprum/static/{4556.c6bedfc4.chunk.js.LICENSE.txt → 5010.acf9a415.chunk.js.LICENSE.txt} +0 -0
  92. /package/dist-scalprum/static/{3483.2f14a8ca.chunk.js.LICENSE.txt → 8563.7e068fb0.chunk.js.LICENSE.txt} +0 -0
@@ -0,0 +1,2 @@
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],u=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,u]}},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}},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")},34955:(e,t,n)=>{n.d(t,{Al:()=>o,DS:()=>p,EM:()=>c,FL:()=>i,J:()=>r,KV:()=>f,R_:()=>d,U3:()=>s,dp:()=>h,jH:()=>A,q0:()=>x,uL:()=>j,v_:()=>l,vs:()=>u,z4:()=>m});var a=n(83572);(0,a.i)({name:"kuadrant.planpolicy.create",attributes:{action:"create"}}),(0,a.i)({name:"kuadrant.planpolicy.read",attributes:{action:"read"}}),(0,a.i)({name:"kuadrant.planpolicy.update",attributes:{action:"update"}}),(0,a.i)({name:"kuadrant.planpolicy.delete",attributes:{action:"delete"}});const r=(0,a.i)({name:"kuadrant.planpolicy.list",attributes:{action:"read"}}),i=(0,a.i)({name:"kuadrant.apiproduct.create",attributes:{action:"create"}}),o=((0,a.i)({name:"kuadrant.apiproduct.read.own",attributes:{action:"read"}}),(0,a.i)({name:"kuadrant.apiproduct.read.all",attributes:{action:"read"}})),s=(0,a.i)({name:"kuadrant.apiproduct.update.own",attributes:{action:"update"}}),l=(0,a.i)({name:"kuadrant.apiproduct.update.all",attributes:{action:"update"}}),c=(0,a.i)({name:"kuadrant.apiproduct.delete.own",attributes:{action:"delete"}}),d=(0,a.i)({name:"kuadrant.apiproduct.delete.all",attributes:{action:"delete"}}),u=(0,a.i)({name:"kuadrant.apiproduct.list",attributes:{action:"read"}}),h=(0,a.i)({name:"kuadrant.apikey.create",attributes:{action:"create"},resourceType:"apiproduct"}),p=(0,a.i)({name:"kuadrant.apikey.read.own",attributes:{action:"read"}}),x=((0,a.i)({name:"kuadrant.apikey.read.all",attributes:{action:"read"}}),(0,a.i)({name:"kuadrant.apikey.update.own",attributes:{action:"update"}})),m=(0,a.i)({name:"kuadrant.apikey.update.all",attributes:{action:"update"}}),j=(0,a.i)({name:"kuadrant.apikey.delete.own",attributes:{action:"delete"}}),A=(0,a.i)({name:"kuadrant.apikey.delete.all",attributes:{action:"delete"}}),f=(0,a.i)({name:"kuadrant.apikey.approve",attributes:{action:"update"}})},37725:(e,t,n)=>{n.d(t,{N_:()=>v});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),u=n(95478),h=n(42469),p=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")||p.A,t=x();return(0,a.jsx)(e,{className:t.externalLinkIcon})},j=e=>/^([a-z+.-]+):/.test(e),A=/^[\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,f=window.open;if(f&&!f.__backstage){const e=function(...e){const t=String(e[0]);if(A.test(t))throw new Error("Rejected window.open() with a javascript: URL as a security precaution");return f.apply(this,e)};e.__backstage=!0,window.open=e}const y=e=>e instanceof Array?e.map(y).join(" ").trim():"object"==typeof e&&e?y(e?.props?.children):["string","number"].includes(typeof e)?String(e):"",v=(0,u.forwardRef)(({onClick:e,noTrack:t,externalLinkIcon:n,...o},l)=>{const u=x(),p=(0,r.useAnalytics)(),f=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=j(t),i=t.startsWith(n);return a||i||(t=n.concat(t)),t})(o.to):o.to,v=y(o.children)||f,g=j(f),k=g&&!!/^https?:/.exec(f);if(A.test(f))throw new Error("Link component rejected javascript: URL as a security precaution");const b=n=>{e?.(n),t||p.captureEvent("click",v,{attributes:{to:f}})};return g?(0,a.jsxs)(i.A,{...k?{target:"_blank",rel:"noopener"}:{},...o,...o["aria-label"]?{"aria-label":`${o["aria-label"]}, Opens in a new window`}:{},ref:l,href:f,onClick:b,className:c()(u.externalLink,o.className),children:[o.children,n&&(0,a.jsx)(m,{}),(0,a.jsx)(s.A,{component:"span",className:u.visuallyHidden,children:", Opens in a new window"})]}):(0,a.jsx)(i.A,{...o,ref:l,component:h.Link,to:f,onClick:b})})},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},46205:(e,t,n)=>{n.d(t,{W:()=>i,l:()=>r});var a=n(87421);function r(e,t){const n="resourceType"in e?{permission:e,resourceRef:t}:{permission:e},r=(0,a.J)(n);return{allowed:r.allowed,loading:r.loading,error:r.error}}function i(e,t,n,a){return!!a||!(!n||e!==t)}},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},75453:(e,t,n)=>{n.r(t),n.d(t,{ApiProductInfoCard:()=>b});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(26648),u=n(72501),h=n(10394),p=n(42899),x=n(67720),m=n(61009),j=n(47625),A=n(9719),f=n(54801),y=n(13677),v=n(91638),g=n(46205),k=n(34955);const b=()=>{var e,t,n,b,w,I,P;const{entity:_}=(0,r.tN)(),C=(0,i.useApi)(i.configApiRef),S=(0,i.useApi)(i.fetchApiRef),N=(0,i.useApi)(i.identityApiRef),E=C.getString("backend.baseUrl"),{allowed:R,loading:L}=(0,g.l)(k.Al),T=null===(e=_.metadata.annotations)||void 0===e?void 0:e["kuadrant.io/namespace"],O=null===(t=_.metadata.annotations)||void 0===t?void 0:t["kuadrant.io/apiproduct"],{value:B}=(0,v.A)(async()=>(await N.getBackstageIdentity()).userEntityRef.split("/")[1]||"guest",[N]),{value:D,loading:M,error:U}=(0,v.A)(async()=>{if(!T||!O)return null;const e=await S.fetch(`${E}/api/kuadrant/apiproducts/${T}/${O}`);if(!e.ok){const t=await e.json();throw new Error(t.error||`Failed to fetch API product: ${e.status}`)}return await e.json()},[E,S,T,O]),V=null==D||null===(b=D.metadata)||void 0===b||null===(n=b.annotations)||void 0===n?void 0:n["backstage.io/owner"],z=null==V?void 0:V.split("/")[1],W=R||B&&z===B;if(!T||!O)return(0,a.jsx)(o.n,{title:"API Product Information",children:(0,a.jsx)(u.A,{children:"No APIProduct linked to this API entity"})});if(M||L)return(0,a.jsx)(o.n,{title:"API Product Information",children:(0,a.jsx)(s.k,{})});if(D&&!W)return(0,a.jsx)(o.n,{title:"API Product Information",children:(0,a.jsx)(h.A,{p:2,children:(0,a.jsx)(u.A,{variant:"body2",color:"textSecondary",children:"You don't have permission to view this API product's details. Only the API owner or users with admin permissions can view this information."})})});if(U&&U.message.includes("you can only read your own"))return(0,a.jsx)(o.n,{title:"API Product Information",children:(0,a.jsx)(h.A,{p:2,children:(0,a.jsx)(u.A,{variant:"body2",color:"textSecondary",children:"You don't have permission to view this API product's details. Only the API owner or users with admin permissions can view this information."})})});if(U)return(0,a.jsx)(o.n,{title:"API Product Information",children:(0,a.jsx)(l._,{error:U})});if(!D)return(0,a.jsx)(o.n,{title:"API Product Information",children:(0,a.jsx)(u.A,{children:"APIProduct not found"})});const{spec:H,status:$}=D,F=(null==$||null===(w=$.discoveredAuthScheme)||void 0===w?void 0:w.authentication)||{},Y=Object.values(F),q=Y.some(e=>e.hasOwnProperty("jwt")),J=Y.find(e=>e.hasOwnProperty("jwt")),K=(null==J||null===(I=J.jwt)||void 0===I?void 0:I.issuerUrl)||"unknown",X=(null==$||null===(P=$.oidcDiscovery)||void 0===P?void 0:P.tokenEndpoint)||"unknown",G=(null==$?void 0:$.discoveredPlans)||[];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)(u.A,{variant:"h6",gutterBottom:!0,children:H.displayName||O}),(0,a.jsx)(u.A,{variant:"body2",color:"textSecondary",paragraph:!0,children:H.description}),(0,a.jsxs)(h.A,{display:"flex",alignItems:"center",flexWrap:"wrap",style:{gap:8},children:[(0,a.jsxs)(u.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:"Version:"})," ",H.version||"v1"]}),H.tags&&H.tags.length>0&&(0,a.jsx)(h.A,{display:"flex",ml:2,style:{gap:4},children:H.tags.map(e=>(0,a.jsx)(x.A,{label:e,size:"small"},e))})]}),(0,a.jsxs)(h.A,{mt:2,children:[(0,a.jsxs)(u.A,{variant:"body2",component:"div",children:[(0,a.jsx)("strong",{children:"Approval Mode:"})," ",(0,a.jsx)(x.A,{label:"automatic"===(H.approvalMode||"manual")?"Automatic":"Manual",size:"small",color:"automatic"===(H.approvalMode||"manual")?"primary":"default",style:{marginLeft:8}})]}),(0,a.jsx)(u.A,{variant:"caption",color:"textSecondary",style:{marginTop:4,display:"block"},children:"automatic"===(H.approvalMode||"manual")?"API keys are created immediately when requested":"API keys require manual approval before creation"})]})]})})}),G.length>0&&(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsxs)(o.n,{title:"Available Plans",children:[(0,a.jsxs)(m.A,{size:"small",children:[(0,a.jsx)(j.A,{children:(0,a.jsxs)(A.A,{children:[(0,a.jsx)(f.A,{children:"Tier"}),(0,a.jsx)(f.A,{children:"Rate Limits"})]})}),(0,a.jsx)(y.A,{children:G.map(e=>(0,a.jsxs)(A.A,{children:[(0,a.jsx)(f.A,{children:(0,a.jsx)(x.A,{label:e.tier,size:"small"})}),(0,a.jsx)(f.A,{children:e.limits&&Object.entries(e.limits).map(([e,t])=>(0,a.jsxs)(u.A,{variant:"body2",children:[String(t)," per ",e]},e))})]},e.tier))})]}),H.targetRef&&(0,a.jsx)(h.A,{mt:2,children:(0,a.jsxs)(u.A,{variant:"caption",color:"textSecondary",children:["HTTPRoute: ",(0,a.jsx)("strong",{children:H.targetRef.name})]})})]})}),(0,a.jsx)(p.A,{item:!0,xs:12,md:6,children:(0,a.jsx)(o.n,{title:"Contact Information",children:H.contact?(0,a.jsx)(h.A,{p:2,children:(0,a.jsxs)(p.A,{container:!0,spacing:2,children:[H.contact.team&&(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsxs)(u.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:"Team:"})," ",H.contact.team]})}),H.contact.email&&(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsxs)(u.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:"Email:"})," ",(0,a.jsx)(c.N_,{to:`mailto:${H.contact.email}`,children:H.contact.email})]})}),H.contact.slack&&(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsxs)(u.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:"Slack:"})," ",H.contact.slack]})})]})}):(0,a.jsx)(h.A,{p:2,children:(0,a.jsx)(u.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:H.documentation?(0,a.jsx)(h.A,{p:2,children:(0,a.jsxs)(p.A,{container:!0,spacing:2,children:[H.documentation.docsURL&&(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsxs)(u.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:"Documentation:"})," ",(0,a.jsx)(c.N_,{to:H.documentation.docsURL,target:"_blank",children:"View Docs"})]})}),H.documentation.openAPISpec&&(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsxs)(u.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:"OpenAPI Spec:"})," ",(0,a.jsx)(c.N_,{to:H.documentation.openAPISpec,target:"_blank",children:"View Spec"})]})})]})}):(0,a.jsx)(h.A,{p:2,children:(0,a.jsx)(u.A,{variant:"body2",color:"textSecondary",children:"No documentation links available"})})})}),q&&(0,a.jsx)(p.A,{item:!0,xs:12,md:6,children:(0,a.jsx)(o.n,{title:"OIDC Provider Discovery",children:(0,a.jsx)(h.A,{p:2,children:(0,a.jsxs)(p.A,{container:!0,spacing:2,children:[(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsx)(u.A,{variant:"body2",children:"This API uses OIDC authentication. Obtain a token from the identity provider below."})}),(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsxs)(u.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:"Identity Provider: "}),(0,a.jsx)(c.N_,{to:K,target:"_blank",children:K})]})}),(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsxs)(u.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:"Token Endpoint: "}),(0,a.jsx)(c.N_,{to:X,target:"_blank",children:X})]})}),(0,a.jsx)(p.A,{item:!0,xs:12,children:(0,a.jsx)(d.z,{text:`# Example (Client Credentials):\ncurl -X POST \\\n -d "grant_type=client_credentials" \\\n -d "client_id=YOUR_CLIENT_ID" \\\n -d "client_secret=YOUR_CLIENT_SECRET" \\\n ${X}\n`,language:"bash",showCopyCodeButton:!0})})]})})})})]})}},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:()=>N});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),u=n.n(d),h=n(10394),p=n(72501),x=n(52235),m=n(37725);const j=(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 A(e){const{link:t,title:n,onClick:r}=e,i=j();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)(p.A,{children:(0,a.jsx)("strong",{children:n})})}),(0,a.jsx)(x.A,{className:i.arrow})]})})]})}var f=n(95478),y=n(64947);const v=(0,f.forwardRef)((e,t)=>(0,a.jsx)(m.N_,{ref:t,...e,color:"initial"})),g=(0,f.forwardRef)((e,t)=>(0,a.jsx)(y.A,{ref:t,component:v,...e}));var k=n(34169),b=n(16098),w=n(67550);const I=e=>{const{slackChannel:t}=e,{t:n}=(0,w.i)(b.O);return t?"string"==typeof t?(0,a.jsx)(p.A,{children:n("errorBoundary.title",{slackChannel:t})}):t.href?(0,a.jsx)(g,{to:t.href,variant:"contained",children:t.name}):(0,a.jsx)(p.A,{children:n("errorBoundary.title",{slackChannel:t.name})}):null},P=class extends f.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)(k.b,{title:"Something Went Wrong",error:n,children:(0,a.jsx)(I,{slackChannel:e})}):t}},_=(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"}),C=(0,c.withStyles)(e=>({root:{display:"inline-block",padding:e.spacing(8,8,0,0),float:"right"}}),{name:"BackstageInfoCardCardActionsTopRight"})(i.A),S={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 N(e){const{title:t,subheader:n,divider:c=!0,deepLink:d,slackChannel:h,errorBoundaryProps:p,variant:x,alignContent:m="normal",children:j,headerStyle:f,headerProps:y,icon:v,action:g,actionsClassName:k,actions:b,cardClassName:w,actionsTopRight:I,className:N,noPadding:E,titleTypographyProps:R,subheaderTypographyProps:L}=e,T=_();let O={},B={};x&&x.split(/[\s]+/g).forEach(e=>{O={...O,...S.card[e]},B={...B,...S.cardContent[e]}});const D=p||(h?{slackChannel:h}:{});return(0,a.jsx)(r.A,{style:O,className:N,children:(0,a.jsxs)(P,{...D,children:[t&&(0,a.jsx)(s.A,{classes:{root:u()(T.header),title:T.headerTitle,subheader:T.headerSubheader,avatar:T.headerAvatar,action:T.headerAction,content:T.headerContent},title:t,subheader:n||v?(0,a.jsxs)("div",{"data-testid":"info-card-subheader",children:[n&&(0,a.jsx)("div",{className:T.subheader,children:n}),v]}):null,action:g,style:{...f},titleTypographyProps:R,subheaderTypographyProps:L,...y}),I&&(0,a.jsx)(C,{children:I}),c&&(0,a.jsx)(l.A,{}),(0,a.jsx)(o.A,{className:u()(w,{[T.noPadding]:E,[T.contentAlignBottom]:"bottom"===m}),style:B,children:j}),b&&(0,a.jsx)(i.A,{className:k,children:b}),d&&(0,a.jsx)(A,{...d})]})})}}}]);
2
+ //# sourceMappingURL=5453.c1f90bdf.chunk.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"static/5453.c1f90bdf.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/react-use/lib/useMountedState.js","webpack://internal.plugin-kuadrant/../../node_modules/@backstage/plugin-catalog-react/dist/hooks/useEntity.esm.js","webpack://internal.plugin-kuadrant/./src/permissions.ts","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/./src/utils/permissions.ts","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/icons/ArrowForward.js","webpack://internal.plugin-kuadrant/./src/components/ApiProductInfoCard/ApiProductInfoCard.tsx","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"],"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","\"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 { 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 { 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\n\n/**\n * permission to create new API products\n * granted to api owners and admins\n */\nexport const kuadrantApiProductCreatePermission = createPermission({\n name: 'kuadrant.apiproduct.create',\n attributes: { action: 'create' },\n});\n\n/**\n * permission to read API products owned by the current user\n * for api owners to view their own products\n */\nexport const kuadrantApiProductReadOwnPermission = createPermission({\n name: 'kuadrant.apiproduct.read.own',\n attributes: { action: 'read' },\n});\n\n/**\n * permission to read all API products regardless of ownership\n * for platform engineers/admins who need to view all products\n */\nexport const kuadrantApiProductReadAllPermission = createPermission({\n name: 'kuadrant.apiproduct.read.all',\n attributes: { action: 'read' },\n});\n\n/**\n * permission to update API products owned by the current user\n * for api owners to modify their own products\n */\nexport const kuadrantApiProductUpdateOwnPermission = createPermission({\n name: 'kuadrant.apiproduct.update.own',\n attributes: { action: 'update' },\n});\n\n/**\n * permission to update any API product regardless of ownership\n * for platform engineers/admins\n */\nexport const kuadrantApiProductUpdateAllPermission = createPermission({\n name: 'kuadrant.apiproduct.update.all',\n attributes: { action: 'update' },\n});\n\n/**\n * permission to delete API products owned by the current user\n * for api owners to remove their own products\n */\nexport const kuadrantApiProductDeleteOwnPermission = createPermission({\n name: 'kuadrant.apiproduct.delete.own',\n attributes: { action: 'delete' },\n});\n\n/**\n * permission to delete any API product regardless of ownership\n * for platform engineers/admins\n */\nexport const kuadrantApiProductDeleteAllPermission = createPermission({\n name: 'kuadrant.apiproduct.delete.all',\n attributes: { action: 'delete' },\n});\n\n/**\n * permission to list API products\n * backend filters results based on .own vs .all read permissions\n */\nexport const kuadrantApiProductListPermission = createPermission({\n name: 'kuadrant.apiproduct.list',\n attributes: { action: 'read' },\n});\n\n// apikey permissions\n\n/**\n * permission to create API keys (request API access)\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(kuadrantApiKeyCreatePermission)\n * use in backend with resource: { permission, resourceRef: 'apiproduct:namespace/name' }\n */\nexport const kuadrantApiKeyCreatePermission = createPermission({\n name: 'kuadrant.apikey.create',\n attributes: { action: 'create' },\n resourceType: 'apiproduct',\n});\n\n/**\n * permission to read API keys owned by the current user\n * allows users to view their own API keys and request history\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 view the approval queue and audit keys\n */\nexport const kuadrantApiKeyReadAllPermission = createPermission({\n name: 'kuadrant.apikey.read.all',\n attributes: { action: 'read' },\n});\n\n/**\n * permission to update API keys owned by the current user\n * allows users to edit their own pending requests (change plan tier, use case)\n */\nexport const kuadrantApiKeyUpdateOwnPermission = createPermission({\n name: 'kuadrant.apikey.update.own',\n attributes: { action: 'update' },\n});\n\n/**\n * permission to update any API key regardless of ownership\n * typically granted to API owners and platform engineers for approving/rejecting requests\n */\nexport const kuadrantApiKeyUpdateAllPermission = createPermission({\n name: 'kuadrant.apikey.update.all',\n attributes: { action: 'update' },\n});\n\n/**\n * permission to delete API keys owned by the current user\n * allows users to cancel their own requests or 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\n/**\n * permission to approve/reject API key requests\n * grants access to the approval queue - for API owners and admins only\n * separate from update.own which consumers use to edit their pending requests\n */\nexport const kuadrantApiKeyApprovePermission = createPermission({\n name: 'kuadrant.apikey.approve',\n attributes: { action: 'update' },\n});\n\nexport const kuadrantPermissions = [\n kuadrantPlanPolicyCreatePermission,\n kuadrantPlanPolicyReadPermission,\n kuadrantPlanPolicyUpdatePermission,\n kuadrantPlanPolicyDeletePermission,\n kuadrantPlanPolicyListPermission,\n kuadrantApiProductCreatePermission,\n kuadrantApiProductReadOwnPermission,\n kuadrantApiProductReadAllPermission,\n kuadrantApiProductUpdateOwnPermission,\n kuadrantApiProductUpdateAllPermission,\n kuadrantApiProductDeleteOwnPermission,\n kuadrantApiProductDeleteAllPermission,\n kuadrantApiProductListPermission,\n kuadrantApiKeyCreatePermission,\n kuadrantApiKeyReadOwnPermission,\n kuadrantApiKeyReadAllPermission,\n kuadrantApiKeyUpdateOwnPermission,\n kuadrantApiKeyUpdateAllPermission,\n kuadrantApiKeyDeleteOwnPermission,\n kuadrantApiKeyDeleteAllPermission,\n kuadrantApiKeyApprovePermission,\n];\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 { 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 * kuadrantApiKeyCreatePermission,\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","\"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 React from 'react';\nimport { useEntity } from '@backstage/plugin-catalog-react';\nimport { useApi, configApiRef, fetchApiRef, identityApiRef } from '@backstage/core-plugin-api';\nimport { InfoCard, Link, Progress, ResponseErrorPanel, CodeSnippet } 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';\nimport { useKuadrantPermission } from '../../utils/permissions';\nimport { kuadrantApiProductReadAllPermission } from '../../permissions';\n\nexport const ApiProductInfoCard = () => {\n const { entity } = useEntity();\n const config = useApi(configApiRef);\n const fetchApi = useApi(fetchApiRef);\n const identityApi = useApi(identityApiRef);\n const backendUrl = config.getString('backend.baseUrl');\n\n const { allowed: canReadAll, loading: permLoading } = useKuadrantPermission(\n kuadrantApiProductReadAllPermission\n );\n\n const namespace = entity.metadata.annotations?.['kuadrant.io/namespace'];\n const apiProductName = entity.metadata.annotations?.['kuadrant.io/apiproduct'];\n\n const { value: currentUserId } = useAsync(async () => {\n const identity = await identityApi.getBackstageIdentity();\n return identity.userEntityRef.split('/')[1] || 'guest';\n }, [identityApi]);\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\n if (!response.ok) {\n const errorData = await response.json();\n throw new Error(errorData.error || `Failed to fetch API product: ${response.status}`);\n }\n\n return await response.json();\n }, [backendUrl, fetchApi, namespace, apiProductName]);\n\n // check if user has permission to view this api product\n const owner = apiProduct?.metadata?.annotations?.['backstage.io/owner'];\n const ownerUserId = owner?.split('/')[1]; // extract \"owner1\" from \"user:default/owner1\"\n const canView = canReadAll || (currentUserId && ownerUserId === currentUserId);\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 || permLoading) {\n return (\n <InfoCard title=\"API Product Information\">\n <Progress />\n </InfoCard>\n );\n }\n\n // show permission message if user doesn't have permission\n if (apiProduct && !canView) {\n return (\n <InfoCard title=\"API Product Information\">\n <Box p={2}>\n <Typography variant=\"body2\" color=\"textSecondary\">\n You don't have permission to view this API product's details. Only the API owner or users with admin permissions can view this information.\n </Typography>\n </Box>\n </InfoCard>\n );\n }\n\n // also show permission message if we got a permission error from the backend\n if (error && error.message.includes('you can only read your own')) {\n return (\n <InfoCard title=\"API Product Information\">\n <Box p={2}>\n <Typography variant=\"body2\" color=\"textSecondary\">\n You don't have permission to view this API product's details. Only the API owner or users with admin permissions can view this information.\n </Typography>\n </Box>\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, status } = apiProduct;\n const authSchemes = status?.discoveredAuthScheme?.authentication || {};\n const schemeObjects = Object.values(authSchemes);\n const hasJwt = schemeObjects.some((scheme: any) =>\n scheme.hasOwnProperty(\"jwt\"),\n );\n\n // Extract JWT issuer from the first JWT scheme\n const jwtScheme = schemeObjects.find((scheme: any) => scheme.hasOwnProperty(\"jwt\"));\n const jwtIssuer = (jwtScheme as any)?.jwt?.issuerUrl || \"unknown\";\n const jwtTokenEndpoint = status?.oidcDiscovery?.tokenEndpoint || \"unknown\";\n\n const plans = status?.discoveredPlans || [];\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 mt={2}>\n <Typography variant=\"body2\" component=\"div\">\n <strong>Approval Mode:</strong>{' '}\n <Chip\n label={(spec.approvalMode || 'manual') === 'automatic' ? 'Automatic' : 'Manual'}\n size=\"small\"\n color={(spec.approvalMode || 'manual') === 'automatic' ? 'primary' : 'default'}\n style={{ marginLeft: 8 }}\n />\n </Typography>\n <Typography variant=\"caption\" color=\"textSecondary\" style={{ marginTop: 4, display: 'block' }}>\n {(spec.approvalMode || 'manual') === 'automatic'\n ? 'API keys are created immediately when requested'\n : 'API keys require manual approval before creation'}\n </Typography>\n </Box>\n </Box>\n </InfoCard>\n </Grid>\n\n {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>Rate Limits</TableCell>\n </TableRow>\n </TableHead>\n <TableBody>\n {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>\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.targetRef && (\n <Box mt={2}>\n <Typography variant=\"caption\" color=\"textSecondary\">\n HTTPRoute: <strong>{spec.targetRef.name}</strong>\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 {hasJwt && (\n <Grid item xs={12} md={6}>\n <InfoCard title=\"OIDC Provider Discovery\">\n <Box p={2}>\n <Grid container spacing={2}>\n <Grid item xs={12}>\n <Typography variant=\"body2\">\n This API uses OIDC authentication. Obtain a token from the identity provider below.\n </Typography>\n </Grid>\n <Grid item xs={12}>\n <Typography variant=\"body2\">\n <strong>Identity Provider: </strong>\n <Link to={jwtIssuer} target=\"_blank\">\n {jwtIssuer}\n </Link>\n </Typography>\n </Grid>\n <Grid item xs={12}>\n <Typography variant=\"body2\">\n <strong>Token Endpoint: </strong>\n <Link to={jwtTokenEndpoint} target=\"_blank\">\n {jwtTokenEndpoint}\n </Link>\n </Typography>\n </Grid>\n <Grid item xs={12}>\n <CodeSnippet\n text={`# Example (Client Credentials):\ncurl -X POST \\\\\n -d \"grant_type=client_credentials\" \\\\\n -d \"client_id=YOUR_CLIENT_ID\" \\\\\n -d \"client_secret=YOUR_CLIENT_SECRET\" \\\\\n ${jwtTokenEndpoint}\n`} // notsecret - template for user's own api key\n language=\"bash\"\n showCopyCodeButton\n />\n </Grid>\n </Grid>\n </Box>\n </InfoCard>\n </Grid>\n )}\n </Grid>\n );\n};\n","\"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"],"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","mountedRef","get","useEffect","useEntity","versionedHolder","useVersionedContext","Error","atVersion","entity","createVersionedContext","createPermission","name","attributes","action","kuadrantPlanPolicyListPermission","kuadrantApiProductCreatePermission","kuadrantApiProductReadAllPermission","kuadrantApiProductUpdateOwnPermission","kuadrantApiProductUpdateAllPermission","kuadrantApiProductDeleteOwnPermission","kuadrantApiProductDeleteAllPermission","kuadrantApiProductListPermission","kuadrantApiKeyCreatePermission","resourceType","kuadrantApiKeyReadOwnPermission","kuadrantApiKeyUpdateOwnPermission","kuadrantApiKeyUpdateAllPermission","kuadrantApiKeyDeleteOwnPermission","kuadrantApiKeyDeleteAllPermission","kuadrantApiKeyApprovePermission","useStyles","makeStyles","theme","visuallyHidden","clip","clipPath","overflow","position","userSelect","whiteSpace","height","width","externalLink","externalLinkIcon","verticalAlign","marginLeft","spacing","ExternalLinkIcon","Icon","useApp","getSystemIcon","classes","jsx","className","isExternalUri","uri","test","scriptProtocolPattern","originalWindowOpen","window","open","__backstage","newOpen","url","String","this","getNodeText","node","Array","map","join","trim","props","children","includes","Link","forwardRef","onClick","noTrack","ref","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","jsxs","target","rel","href","component","_interopRequireDefault","_interopRequireWildcard","React","_default","createElement","d","useKuadrantPermission","permission","resourceRef","permissionRequest","result","usePermission","allowed","canDeleteResource","ownerId","currentUserId","canDeleteOwn","canDeleteAll","ApiProductInfoCard","apiProduct","status","config","fetchApi","fetchApiRef","identityApi","identityApiRef","backendUrl","getString","canReadAll","permLoading","namespace","metadata","annotations","apiProductName","useAsync","async","getBackstageIdentity","userEntityRef","split","response","fetch","ok","errorData","json","owner","ownerUserId","canView","InfoCard","title","Typography","Progress","Box","p","variant","color","message","ResponseErrorPanel","spec","authSchemes","discoveredAuthScheme","authentication","schemeObjects","values","hasJwt","some","scheme","hasOwnProperty","jwtScheme","find","jwtIssuer","jwt","issuerUrl","jwtTokenEndpoint","oidcDiscovery","tokenEndpoint","plans","discoveredPlans","Grid","container","item","xs","gutterBottom","displayName","paragraph","description","display","alignItems","flexWrap","style","gap","strong","version","tags","ml","tag","Chip","label","size","mt","approvalMode","marginTop","Table","TableHead","TableRow","TableCell","TableBody","plan","tier","limits","entries","key","targetRef","md","contact","team","email","slack","documentation","docsURL","openAPISpec","CodeSnippet","text","language","showCopyCodeButton","useAsyncFn_1","root","maxWidth","padding","boxTitle","margin","palette","textSubtle","arrow","BottomLink","link","Divider","underline","fontWeight","m","A","LinkWrapper","LinkButton","Button","SlackLink","slackChannel","t","ErrorBoundary","Component","constructor","super","errorInfo","componentDidCatch","console","setState","render","noPadding","paddingBottom","contentAlignBottom","header","headerTitle","typography","fontWeightBold","headerSubheader","paddingTop","headerAvatar","headerAction","headerContent","subheader","CardActionsTopRight","withStyles","float","CardActions","VARIANT_STYLES","card","flex","flexDirection","fullHeight","gridItem","marginBottom","breakInside","cardContent","divider","deepLink","errorBoundaryProps","alignContent","headerStyle","headerProps","icon","actionsClassName","actions","cardClassName","actionsTopRight","titleTypographyProps","subheaderTypographyProps","calculatedStyle","calculatedCardStyle","forEach","errProps","Card","CardHeader","avatar","content","CardContent"],"sourceRoot":""}
@@ -0,0 +1,2 @@
1
+ "use strict";(self.webpackChunkinternal_plugin_kuadrant=self.webpackChunkinternal_plugin_kuadrant||[]).push([[6800],{16400:(e,t,a)=>{a.d(t,{tN:()=>n}),a(31085),a(26659);var r=a(64218);function n(){const e=(0,r.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,r.createVersionedContext)("entity-context")},34955:(e,t,a)=>{a.d(t,{Al:()=>o,DS:()=>v,EM:()=>l,FL:()=>i,J:()=>n,KV:()=>f,R_:()=>c,U3:()=>s,dp:()=>p,jH:()=>g,q0:()=>h,uL:()=>y,v_:()=>d,vs:()=>u,z4:()=>m});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"}}),i=(0,r.i)({name:"kuadrant.apiproduct.create",attributes:{action:"create"}}),o=((0,r.i)({name:"kuadrant.apiproduct.read.own",attributes:{action:"read"}}),(0,r.i)({name:"kuadrant.apiproduct.read.all",attributes:{action:"read"}})),s=(0,r.i)({name:"kuadrant.apiproduct.update.own",attributes:{action:"update"}}),d=(0,r.i)({name:"kuadrant.apiproduct.update.all",attributes:{action:"update"}}),l=(0,r.i)({name:"kuadrant.apiproduct.delete.own",attributes:{action:"delete"}}),c=(0,r.i)({name:"kuadrant.apiproduct.delete.all",attributes:{action:"delete"}}),u=(0,r.i)({name:"kuadrant.apiproduct.list",attributes:{action:"read"}}),p=(0,r.i)({name:"kuadrant.apikey.create",attributes:{action:"create"},resourceType:"apiproduct"}),v=(0,r.i)({name:"kuadrant.apikey.read.own",attributes:{action:"read"}}),h=((0,r.i)({name:"kuadrant.apikey.read.all",attributes:{action:"read"}}),(0,r.i)({name:"kuadrant.apikey.update.own",attributes:{action:"update"}})),m=(0,r.i)({name:"kuadrant.apikey.update.all",attributes:{action:"update"}}),y=(0,r.i)({name:"kuadrant.apikey.delete.own",attributes:{action:"delete"}}),g=(0,r.i)({name:"kuadrant.apikey.delete.all",attributes:{action:"delete"}}),f=(0,r.i)({name:"kuadrant.apikey.approve",attributes:{action:"update"}})},35015:(e,t,a)=>{a.d(t,{A:()=>o});var r=a(95478),n=a(85608),i=a(71581);function o(e,t){void 0===t&&(t=[]);var a=function(e,t,a){void 0===t&&(t=[]),void 0===a&&(a={loading:!1});var o=(0,r.useRef)(0),s=(0,i.A)(),d=(0,r.useState)(a),l=d[0],c=d[1],u=(0,r.useCallback)(function(){for(var t=[],a=0;a<arguments.length;a++)t[a]=arguments[a];var r=++o.current;return l.loading||c(function(e){return(0,n.__assign)((0,n.__assign)({},e),{loading:!0})}),e.apply(void 0,t).then(function(e){return s()&&r===o.current&&c({value:e,loading:!1}),e},function(e){return s()&&r===o.current&&c({error:e,loading:!1}),e})},t);return[l,u]}(e,t,{loading:!0}),o=a[0],s=a[1];return(0,r.useEffect)(function(){s()},[s]),o}},46205:(e,t,a)=>{a.d(t,{W:()=>i,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 i(e,t,a,r){return!!r||!(!a||e!==t)}},46299:(e,t,a)=>{a.d(t,{S:()=>r});const r=e=>{const t={border:"none"};switch(e){case"Approved":return{...t,backgroundColor:"#4caf50",color:"#fff"};case"Rejected":return{...t,backgroundColor:"#f44336",color:"#fff"};default:return{...t,backgroundColor:"#ff9800",color:"#fff"}}}},46800:(e,t,a)=>{a.r(t),a.d(t,{EntityApiApprovalTab:()=>I});var r=a(31085),n=a(95478),i=a(16400),o=a(22097),s=a(35015),d=a(86687),l=a(42367),c=a(25010),u=a(34955),p=a(46205),v=a(58837),h=a(10394),m=a(72501),y=a(76891),g=a(61477),f=a(46805),A=a(16249),b=a(93453),k=a(64947),x=a(78467),j=a(67720),w=a(71677),C=a(29365),q=a(55429),R=a(92399),P=a(46299);const S=(0,v.A)(e=>({useCasePanel:{padding:e.spacing(2),backgroundColor:e.palette.background.default},useCaseLabel:{fontWeight:600,marginBottom:e.spacing(1),color:e.palette.text.secondary,textTransform:"uppercase",fontSize:"0.75rem"}})),T=({request:e})=>{const t=S();return(0,r.jsxs)(h.A,{className:t.useCasePanel,onClick:e=>e.stopPropagation(),children:[(0,r.jsx)(m.A,{className:t.useCaseLabel,children:"Use Case"}),(0,r.jsx)(m.A,{variant:"body2",children:e.spec.useCase||"No use case provided"})]})},E=({open:e,request:t,action:a,processing:i,onClose:o,onConfirm:s})=>{const[d,l]=(0,n.useState)(""),c=()=>{l(""),o()},u="reject"===a,p=(null==t?void 0:t.metadata.name)||"",v=d===p;return(0,r.jsxs)(y.A,{open:e,onClose:i?void 0:c,maxWidth:"sm",fullWidth:!0,children:[(0,r.jsx)(g.A,{children:u?"Reject API key":"Approve API key"}),(0,r.jsx)(f.A,{children:t&&(0,r.jsxs)(r.Fragment,{children:[(0,r.jsxs)(m.A,{variant:"body2",paragraph:!0,children:[(0,r.jsx)("strong",{children:"Requester:"})," ",t.spec.requestedBy.userId]}),(0,r.jsxs)(m.A,{variant:"body2",paragraph:!0,children:[(0,r.jsx)("strong",{children:"Tier:"})," ",t.spec.planTier]}),t.spec.useCase&&(0,r.jsxs)(m.A,{variant:"body2",paragraph:!0,children:[(0,r.jsx)("strong",{children:"Use Case:"})," ",t.spec.useCase]}),u&&(0,r.jsx)(h.A,{mt:2,p:2,bgcolor:"error.light",borderRadius:1,children:(0,r.jsx)(m.A,{variant:"body2",children:"This action will permanently deny access. The user will need to submit a new request."})}),(0,r.jsx)(h.A,{mt:2,children:(0,r.jsx)(A.A,{fullWidth:!0,label:`Type "${p}" to confirm`,value:d,onChange:e=>l(e.target.value),disabled:i,autoFocus:!0})})]})}),(0,r.jsxs)(b.A,{children:[(0,r.jsx)(k.A,{onClick:c,disabled:i,children:"Cancel"}),(0,r.jsx)(k.A,{onClick:()=>{s(d),l("")},color:u?"secondary":"primary",variant:"contained",disabled:!v||i,startIcon:i?(0,r.jsx)(x.A,{size:16,color:"inherit"}):void 0,children:i?u?"Rejecting...":"Approving...":u?"Reject":"Approve"})]})]})},I=()=>{var e,t;const{entity:a}=(0,i.tN)(),v=(0,o.useApi)(o.configApiRef),y=(0,o.useApi)(o.fetchApiRef),g=(0,o.useApi)(o.identityApiRef),f=(0,o.useApi)(o.alertApiRef),A=v.getString("backend.baseUrl"),b=(null===(e=a.metadata.annotations)||void 0===e?void 0:e["kuadrant.io/apiproduct"])||a.metadata.name,k=(null===(t=a.metadata.annotations)||void 0===t?void 0:t["kuadrant.io/namespace"])||"default",[x,S]=(0,n.useState)(0),[I,$]=(0,n.useState)({open:!1,request:null,action:"approve",processing:!1}),{allowed:_,loading:z,error:B}=(0,p.l)(u.KV),{value:L,loading:N,error:F}=(0,s.A)(async()=>{const e=(await g.getBackstageIdentity()).userEntityRef,t=await y.fetch(`${A}/api/kuadrant/requests`);if(!t.ok)throw new Error("Failed to fetch requests");return{requests:((await t.json()).items||[]).filter(e=>{var t;return(null===(t=e.spec.apiProductRef)||void 0===t?void 0:t.name)===b&&e.metadata.namespace===k}),reviewedBy:e}},[A,y,g,b,k,x]);if(N||z)return(0,r.jsx)(d.k,{});if(F)return(0,r.jsx)(l._,{error:F});if(B)return(0,r.jsx)(h.A,{p:2,children:(0,r.jsxs)(m.A,{color:"error",children:["Unable to check permissions: ",B.message]})});if(!_)return(0,r.jsx)(h.A,{p:3,textAlign:"center",children:(0,r.jsx)(m.A,{variant:"body1",color:"textSecondary",children:"You don't have permission to view the approval queue for this API."})});const W=(null==L?void 0:L.requests)||[],U=W.filter(e=>{var t;return!(null===(t=e.status)||void 0===t?void 0:t.phase)||"Pending"===e.status.phase}),V=W.filter(e=>{var t;return"Approved"===(null===(t=e.status)||void 0===t?void 0:t.phase)}),D=W.filter(e=>{var t;return"Rejected"===(null===(t=e.status)||void 0===t?void 0:t.phase)}),J=[{title:"Requester",field:"spec.requestedBy.userId",render:e=>(0,r.jsx)(m.A,{variant:"body2",children:e.spec.requestedBy.userId})},{title:"Status",field:"status.phase",render:e=>{var t;const a=(null===(t=e.status)||void 0===t?void 0:t.phase)||"Pending",n="Approved"===a?"Active":a;return(0,r.jsx)(j.A,{label:n,size:"small",style:(0,P.S)(a)})}},{title:"Tier",field:"spec.planTier",render:e=>(0,r.jsx)(j.A,{label:e.spec.planTier,size:"small",variant:"outlined"})},{title:"Requested",field:"metadata.creationTimestamp",render:e=>e.metadata.creationTimestamp?(0,r.jsx)(m.A,{variant:"body2",children:new Date(e.metadata.creationTimestamp).toLocaleDateString()}):(0,r.jsx)(m.A,{variant:"body2",children:"-"})},{title:"Actions",filtering:!1,render:e=>{var t;return"Pending"!==((null===(t=e.status)||void 0===t?void 0:t.phase)||"Pending")?null:(0,r.jsxs)(h.A,{display:"flex",style:{gap:4},children:[(0,r.jsx)(w.Ay,{title:"Approve",children:(0,r.jsx)(C.A,{size:"small",onClick:()=>{$({open:!0,request:e,action:"approve",processing:!1})},children:(0,r.jsx)(q.A,{color:"primary"})})}),(0,r.jsx)(w.Ay,{title:"Reject",children:(0,r.jsx)(C.A,{size:"small",onClick:()=>{$({open:!0,request:e,action:"reject",processing:!1})},children:(0,r.jsx)(R.A,{color:"error"})})})]})}}],K=[{render:e=>{var t;const a=e.rowData;return(null==a||null===(t=a.metadata)||void 0===t?void 0:t.name)?(0,r.jsx)(T,{request:a}):(0,r.jsx)(h.A,{})}}];return(0,r.jsxs)(h.A,{p:2,children:[(0,r.jsx)(h.A,{mb:2,children:(0,r.jsxs)(m.A,{variant:"body2",color:"textSecondary",children:[U.length," pending, ",V.length," approved,"," ",D.length," rejected"]})}),0===W.length?(0,r.jsx)(h.A,{p:3,textAlign:"center",children:(0,r.jsx)(m.A,{variant:"body1",color:"textSecondary",children:"No API keys for this API."})}):(0,r.jsx)(c.X,{options:{paging:W.length>10,pageSize:20,search:!0,filtering:!1,debounceInterval:300,toolbar:!0,emptyRowsWhenPaging:!1},columns:J,data:W.map(e=>({...e,id:e.metadata.name})),detailPanel:K}),(0,r.jsx)(E,{open:I.open,request:I.request,action:I.action,processing:I.processing,onClose:()=>$({open:!1,request:null,action:"approve",processing:!1}),onConfirm:async()=>{if(!I.request||!L)return;$(e=>({...e,processing:!0}));const e="approve"===I.action?`${A}/api/kuadrant/requests/${I.request.metadata.namespace}/${I.request.metadata.name}/approve`:`${A}/api/kuadrant/requests/${I.request.metadata.namespace}/${I.request.metadata.name}/reject`;try{if(!(await y.fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({reviewedBy:L.reviewedBy})})).ok)throw new Error(`Failed to ${I.action} request`);$({open:!1,request:null,action:"approve",processing:!1}),S(e=>e+1),f.post({message:"API key "+("approve"===I.action?"approved":"rejected"),severity:"success",display:"transient"})}catch(e){console.error(`Error ${I.action}ing request:`,e),$(e=>({...e,processing:!1})),f.post({message:`Failed to ${I.action} API key`,severity:"error",display:"transient"})}}})]})}},55429:(e,t,a)=>{var r=a(4293),n=a(78920);t.A=void 0;var i=n(a(95478)),o=(0,r(a(74044)).default)(i.createElement("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z"}),"CheckCircle");t.A=o}}]);
2
+ //# sourceMappingURL=6800.736d5da3.chunk.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"static/6800.736d5da3.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/./src/permissions.ts","webpack://internal.plugin-kuadrant/../../node_modules/react-use/esm/useAsync.js","webpack://internal.plugin-kuadrant/../../node_modules/react-use/esm/useAsyncFn.js","webpack://internal.plugin-kuadrant/./src/utils/permissions.ts","webpack://internal.plugin-kuadrant/./src/utils/styles.ts","webpack://internal.plugin-kuadrant/./src/components/EntityApiApprovalTab/EntityApiApprovalTab.tsx","webpack://internal.plugin-kuadrant/../../node_modules/@material-ui/icons/CheckCircle.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","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\n\n/**\n * permission to create new API products\n * granted to api owners and admins\n */\nexport const kuadrantApiProductCreatePermission = createPermission({\n name: 'kuadrant.apiproduct.create',\n attributes: { action: 'create' },\n});\n\n/**\n * permission to read API products owned by the current user\n * for api owners to view their own products\n */\nexport const kuadrantApiProductReadOwnPermission = createPermission({\n name: 'kuadrant.apiproduct.read.own',\n attributes: { action: 'read' },\n});\n\n/**\n * permission to read all API products regardless of ownership\n * for platform engineers/admins who need to view all products\n */\nexport const kuadrantApiProductReadAllPermission = createPermission({\n name: 'kuadrant.apiproduct.read.all',\n attributes: { action: 'read' },\n});\n\n/**\n * permission to update API products owned by the current user\n * for api owners to modify their own products\n */\nexport const kuadrantApiProductUpdateOwnPermission = createPermission({\n name: 'kuadrant.apiproduct.update.own',\n attributes: { action: 'update' },\n});\n\n/**\n * permission to update any API product regardless of ownership\n * for platform engineers/admins\n */\nexport const kuadrantApiProductUpdateAllPermission = createPermission({\n name: 'kuadrant.apiproduct.update.all',\n attributes: { action: 'update' },\n});\n\n/**\n * permission to delete API products owned by the current user\n * for api owners to remove their own products\n */\nexport const kuadrantApiProductDeleteOwnPermission = createPermission({\n name: 'kuadrant.apiproduct.delete.own',\n attributes: { action: 'delete' },\n});\n\n/**\n * permission to delete any API product regardless of ownership\n * for platform engineers/admins\n */\nexport const kuadrantApiProductDeleteAllPermission = createPermission({\n name: 'kuadrant.apiproduct.delete.all',\n attributes: { action: 'delete' },\n});\n\n/**\n * permission to list API products\n * backend filters results based on .own vs .all read permissions\n */\nexport const kuadrantApiProductListPermission = createPermission({\n name: 'kuadrant.apiproduct.list',\n attributes: { action: 'read' },\n});\n\n// apikey permissions\n\n/**\n * permission to create API keys (request API access)\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(kuadrantApiKeyCreatePermission)\n * use in backend with resource: { permission, resourceRef: 'apiproduct:namespace/name' }\n */\nexport const kuadrantApiKeyCreatePermission = createPermission({\n name: 'kuadrant.apikey.create',\n attributes: { action: 'create' },\n resourceType: 'apiproduct',\n});\n\n/**\n * permission to read API keys owned by the current user\n * allows users to view their own API keys and request history\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 view the approval queue and audit keys\n */\nexport const kuadrantApiKeyReadAllPermission = createPermission({\n name: 'kuadrant.apikey.read.all',\n attributes: { action: 'read' },\n});\n\n/**\n * permission to update API keys owned by the current user\n * allows users to edit their own pending requests (change plan tier, use case)\n */\nexport const kuadrantApiKeyUpdateOwnPermission = createPermission({\n name: 'kuadrant.apikey.update.own',\n attributes: { action: 'update' },\n});\n\n/**\n * permission to update any API key regardless of ownership\n * typically granted to API owners and platform engineers for approving/rejecting requests\n */\nexport const kuadrantApiKeyUpdateAllPermission = createPermission({\n name: 'kuadrant.apikey.update.all',\n attributes: { action: 'update' },\n});\n\n/**\n * permission to delete API keys owned by the current user\n * allows users to cancel their own requests or 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\n/**\n * permission to approve/reject API key requests\n * grants access to the approval queue - for API owners and admins only\n * separate from update.own which consumers use to edit their pending requests\n */\nexport const kuadrantApiKeyApprovePermission = createPermission({\n name: 'kuadrant.apikey.approve',\n attributes: { action: 'update' },\n});\n\nexport const kuadrantPermissions = [\n kuadrantPlanPolicyCreatePermission,\n kuadrantPlanPolicyReadPermission,\n kuadrantPlanPolicyUpdatePermission,\n kuadrantPlanPolicyDeletePermission,\n kuadrantPlanPolicyListPermission,\n kuadrantApiProductCreatePermission,\n kuadrantApiProductReadOwnPermission,\n kuadrantApiProductReadAllPermission,\n kuadrantApiProductUpdateOwnPermission,\n kuadrantApiProductUpdateAllPermission,\n kuadrantApiProductDeleteOwnPermission,\n kuadrantApiProductDeleteAllPermission,\n kuadrantApiProductListPermission,\n kuadrantApiKeyCreatePermission,\n kuadrantApiKeyReadOwnPermission,\n kuadrantApiKeyReadAllPermission,\n kuadrantApiKeyUpdateOwnPermission,\n kuadrantApiKeyUpdateAllPermission,\n kuadrantApiKeyDeleteOwnPermission,\n kuadrantApiKeyDeleteAllPermission,\n kuadrantApiKeyApprovePermission,\n];\n","import { useEffect } from 'react';\nimport useAsyncFn from './useAsyncFn';\nexport default function useAsync(fn, deps) {\n if (deps === void 0) { deps = []; }\n var _a = useAsyncFn(fn, deps, {\n loading: true,\n }), state = _a[0], callback = _a[1];\n useEffect(function () {\n callback();\n }, [callback]);\n return state;\n}\n","import { __assign } from \"tslib\";\nimport { useCallback, useRef, useState } from 'react';\nimport useMountedState from './useMountedState';\nexport default function useAsyncFn(fn, deps, initialState) {\n if (deps === void 0) { deps = []; }\n if (initialState === void 0) { initialState = { loading: false }; }\n var lastCallId = useRef(0);\n var isMounted = useMountedState();\n var _a = useState(initialState), state = _a[0], set = _a[1];\n var callback = 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 (__assign(__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}\n","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 * kuadrantApiKeyCreatePermission,\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 { CSSProperties } from \"react\";\n\n/**\n * Returns inline styles for API key status chips.\n * Uses inline styles to ensure proper specificity with Material-UI Chip.\n */\nexport const getStatusChipStyle = (phase: string): CSSProperties => {\n const base = { border: \"none\" };\n switch (phase) {\n case \"Approved\":\n return { ...base, backgroundColor: \"#4caf50\", color: \"#fff\" };\n case \"Rejected\":\n return { ...base, backgroundColor: \"#f44336\", color: \"#fff\" };\n default:\n return { ...base, backgroundColor: \"#ff9800\", color: \"#fff\" };\n }\n};\n","import React, { useState } from \"react\";\nimport { useEntity } from \"@backstage/plugin-catalog-react\";\nimport {\n useApi,\n configApiRef,\n fetchApiRef,\n identityApiRef,\n alertApiRef,\n} from \"@backstage/core-plugin-api\";\nimport { useAsync } from \"react-use\";\nimport {\n Table,\n TableColumn,\n Progress,\n ResponseErrorPanel,\n} from \"@backstage/core-components\";\nimport { kuadrantApiKeyApprovePermission } from \"../../permissions\";\nimport { useKuadrantPermission } from \"../../utils/permissions\";\nimport {\n Box,\n Typography,\n Chip,\n IconButton,\n Tooltip,\n Button,\n Dialog,\n DialogTitle,\n DialogContent,\n DialogActions,\n TextField,\n CircularProgress,\n makeStyles,\n} from \"@material-ui/core\";\nimport CheckCircleIcon from \"@material-ui/icons/CheckCircle\";\nimport CancelIcon from \"@material-ui/icons/Cancel\";\nimport { APIKey } from \"../../types/api-management\";\nimport { getStatusChipStyle } from \"../../utils/styles\";\n\nconst useStyles = makeStyles((theme) => ({\n useCasePanel: {\n padding: theme.spacing(2),\n backgroundColor: theme.palette.background.default,\n },\n useCaseLabel: {\n fontWeight: 600,\n marginBottom: theme.spacing(1),\n color: theme.palette.text.secondary,\n textTransform: \"uppercase\",\n fontSize: \"0.75rem\",\n },\n}));\n\ninterface ExpandedRowProps {\n request: APIKey;\n}\n\nconst ExpandedRowContent = ({ request }: ExpandedRowProps) => {\n const classes = useStyles();\n\n return (\n <Box className={classes.useCasePanel} onClick={(e) => e.stopPropagation()}>\n <Typography className={classes.useCaseLabel}>Use Case</Typography>\n <Typography variant=\"body2\">\n {request.spec.useCase || \"No use case provided\"}\n </Typography>\n </Box>\n );\n};\n\ninterface ApprovalDialogProps {\n open: boolean;\n request: APIKey | null;\n action: \"approve\" | \"reject\";\n processing: boolean;\n onClose: () => void;\n onConfirm: (confirmText: string) => void;\n}\n\nconst ApprovalDialog = ({\n open,\n request,\n action,\n processing,\n onClose,\n onConfirm,\n}: ApprovalDialogProps) => {\n const [confirmText, setConfirmText] = useState(\"\");\n\n const handleClose = () => {\n setConfirmText(\"\");\n onClose();\n };\n\n const handleConfirm = () => {\n onConfirm(confirmText);\n setConfirmText(\"\");\n };\n\n const isReject = action === \"reject\";\n const expectedText = request?.metadata.name || \"\";\n const isConfirmValid = confirmText === expectedText;\n\n return (\n <Dialog\n open={open}\n onClose={processing ? undefined : handleClose}\n maxWidth=\"sm\"\n fullWidth\n >\n <DialogTitle>\n {isReject ? \"Reject API key\" : \"Approve API key\"}\n </DialogTitle>\n <DialogContent>\n {request && (\n <>\n <Typography variant=\"body2\" paragraph>\n <strong>Requester:</strong> {request.spec.requestedBy.userId}\n </Typography>\n <Typography variant=\"body2\" paragraph>\n <strong>Tier:</strong> {request.spec.planTier}\n </Typography>\n {request.spec.useCase && (\n <Typography variant=\"body2\" paragraph>\n <strong>Use Case:</strong> {request.spec.useCase}\n </Typography>\n )}\n {isReject && (\n <Box mt={2} p={2} bgcolor=\"error.light\" borderRadius={1}>\n <Typography variant=\"body2\">\n This action will permanently deny access. The user will need\n to submit a new request.\n </Typography>\n </Box>\n )}\n <Box mt={2}>\n <TextField\n fullWidth\n label={`Type \"${expectedText}\" to confirm`}\n value={confirmText}\n onChange={(e) => setConfirmText(e.target.value)}\n disabled={processing}\n autoFocus\n />\n </Box>\n </>\n )}\n </DialogContent>\n <DialogActions>\n <Button onClick={handleClose} disabled={processing}>\n Cancel\n </Button>\n <Button\n onClick={handleConfirm}\n color={isReject ? \"secondary\" : \"primary\"}\n variant=\"contained\"\n disabled={!isConfirmValid || processing}\n startIcon={\n processing ? (\n <CircularProgress size={16} color=\"inherit\" />\n ) : undefined\n }\n >\n {processing\n ? isReject\n ? \"Rejecting...\"\n : \"Approving...\"\n : isReject\n ? \"Reject\"\n : \"Approve\"}\n </Button>\n </DialogActions>\n </Dialog>\n );\n};\n\nexport const EntityApiApprovalTab = () => {\n const { entity } = useEntity();\n const config = useApi(configApiRef);\n const fetchApi = useApi(fetchApiRef);\n const identityApi = useApi(identityApiRef);\n const alertApi = useApi(alertApiRef);\n const backendUrl = config.getString(\"backend.baseUrl\");\n\n const apiProductName =\n entity.metadata.annotations?.[\"kuadrant.io/apiproduct\"] ||\n entity.metadata.name;\n const namespace =\n entity.metadata.annotations?.[\"kuadrant.io/namespace\"] || \"default\";\n\n const [refresh, setRefresh] = useState(0);\n const [dialogState, setDialogState] = useState<{\n open: boolean;\n request: APIKey | null;\n action: \"approve\" | \"reject\";\n processing: boolean;\n }>({\n open: false,\n request: null,\n action: \"approve\",\n processing: false,\n });\n\n const {\n allowed: canApprove,\n loading: permissionLoading,\n error: permissionError,\n } = useKuadrantPermission(kuadrantApiKeyApprovePermission);\n\n const { value, loading, error } = useAsync(async () => {\n const identity = await identityApi.getBackstageIdentity();\n const reviewedBy = identity.userEntityRef;\n\n const response = await fetchApi.fetch(\n `${backendUrl}/api/kuadrant/requests`,\n );\n if (!response.ok) {\n throw new Error(\"Failed to fetch requests\");\n }\n\n const data = await response.json();\n const allRequests: APIKey[] = data.items || [];\n\n // filter to this API product only\n const filtered = allRequests.filter(\n (r) =>\n r.spec.apiProductRef?.name === apiProductName &&\n r.metadata.namespace === namespace,\n );\n\n return { requests: filtered, reviewedBy };\n }, [backendUrl, fetchApi, identityApi, apiProductName, namespace, refresh]);\n\n const handleApprove = (request: APIKey) => {\n setDialogState({\n open: true,\n request,\n action: \"approve\",\n processing: false,\n });\n };\n\n const handleReject = (request: APIKey) => {\n setDialogState({\n open: true,\n request,\n action: \"reject\",\n processing: false,\n });\n };\n\n const handleConfirm = async () => {\n if (!dialogState.request || !value) return;\n\n setDialogState((prev) => ({ ...prev, processing: true }));\n\n const endpoint =\n dialogState.action === \"approve\"\n ? `${backendUrl}/api/kuadrant/requests/${dialogState.request.metadata.namespace}/${dialogState.request.metadata.name}/approve`\n : `${backendUrl}/api/kuadrant/requests/${dialogState.request.metadata.namespace}/${dialogState.request.metadata.name}/reject`;\n\n try {\n const response = await fetchApi.fetch(endpoint, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ reviewedBy: value.reviewedBy }),\n });\n\n if (!response.ok) {\n throw new Error(`Failed to ${dialogState.action} request`);\n }\n\n setDialogState({\n open: false,\n request: null,\n action: \"approve\",\n processing: false,\n });\n setRefresh((r) => r + 1);\n alertApi.post({\n message: `API key ${dialogState.action === \"approve\" ? \"approved\" : \"rejected\"}`,\n severity: \"success\",\n display: \"transient\",\n });\n } catch (err) {\n console.error(`Error ${dialogState.action}ing request:`, err);\n setDialogState((prev) => ({ ...prev, processing: false }));\n alertApi.post({\n message: `Failed to ${dialogState.action} API key`,\n severity: \"error\",\n display: \"transient\",\n });\n }\n };\n\n if (loading || permissionLoading) {\n return <Progress />;\n }\n\n if (error) {\n return <ResponseErrorPanel error={error} />;\n }\n\n if (permissionError) {\n return (\n <Box p={2}>\n <Typography color=\"error\">\n Unable to check permissions: {permissionError.message}\n </Typography>\n </Box>\n );\n }\n\n if (!canApprove) {\n return (\n <Box p={3} textAlign=\"center\">\n <Typography variant=\"body1\" color=\"textSecondary\">\n You don't have permission to view the approval queue for this API.\n </Typography>\n </Box>\n );\n }\n\n const requests = value?.requests || [];\n const pendingRequests = requests.filter(\n (r) => !r.status?.phase || r.status.phase === \"Pending\",\n );\n const approvedRequests = requests.filter(\n (r) => r.status?.phase === \"Approved\",\n );\n const rejectedRequests = requests.filter(\n (r) => r.status?.phase === \"Rejected\",\n );\n\n const columns: TableColumn<APIKey>[] = [\n {\n title: \"Requester\",\n field: \"spec.requestedBy.userId\",\n render: (row) => (\n <Typography variant=\"body2\">{row.spec.requestedBy.userId}</Typography>\n ),\n },\n {\n title: \"Status\",\n field: \"status.phase\",\n render: (row) => {\n const phase = row.status?.phase || \"Pending\";\n const label = phase === \"Approved\" ? \"Active\" : phase;\n return (\n <Chip label={label} size=\"small\" style={getStatusChipStyle(phase)} />\n );\n },\n },\n {\n title: \"Tier\",\n field: \"spec.planTier\",\n render: (row) => (\n <Chip label={row.spec.planTier} size=\"small\" variant=\"outlined\" />\n ),\n },\n {\n title: \"Requested\",\n field: \"metadata.creationTimestamp\",\n render: (row) => {\n if (!row.metadata.creationTimestamp)\n return <Typography variant=\"body2\">-</Typography>;\n return (\n <Typography variant=\"body2\">\n {new Date(row.metadata.creationTimestamp).toLocaleDateString()}\n </Typography>\n );\n },\n },\n {\n title: \"Actions\",\n filtering: false,\n render: (row) => {\n const phase = row.status?.phase || \"Pending\";\n if (phase !== \"Pending\") return null;\n return (\n <Box display=\"flex\" style={{ gap: 4 }}>\n <Tooltip title=\"Approve\">\n <IconButton size=\"small\" onClick={() => handleApprove(row)}>\n <CheckCircleIcon color=\"primary\" />\n </IconButton>\n </Tooltip>\n <Tooltip title=\"Reject\">\n <IconButton size=\"small\" onClick={() => handleReject(row)}>\n <CancelIcon color=\"error\" />\n </IconButton>\n </Tooltip>\n </Box>\n );\n },\n },\n ];\n\n const detailPanelConfig = [\n {\n render: (data: any) => {\n const request = data.rowData as APIKey;\n if (!request?.metadata?.name) return <Box />;\n return <ExpandedRowContent request={request} />;\n },\n },\n ];\n\n return (\n <Box p={2}>\n <Box mb={2}>\n <Typography variant=\"body2\" color=\"textSecondary\">\n {pendingRequests.length} pending, {approvedRequests.length} approved,{\" \"}\n {rejectedRequests.length} rejected\n </Typography>\n </Box>\n\n {requests.length === 0 ? (\n <Box p={3} textAlign=\"center\">\n <Typography variant=\"body1\" color=\"textSecondary\">\n No API keys for this API.\n </Typography>\n </Box>\n ) : (\n <Table\n options={{\n paging: requests.length > 10,\n pageSize: 20,\n search: true,\n filtering: false,\n debounceInterval: 300,\n toolbar: true,\n emptyRowsWhenPaging: false,\n }}\n columns={columns}\n data={requests.map((item) => ({ ...item, id: item.metadata.name }))}\n detailPanel={detailPanelConfig}\n />\n )}\n\n <ApprovalDialog\n open={dialogState.open}\n request={dialogState.request}\n action={dialogState.action}\n processing={dialogState.processing}\n onClose={() =>\n setDialogState({\n open: false,\n request: null,\n action: \"approve\",\n processing: false,\n })\n }\n onConfirm={handleConfirm}\n />\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 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z\"\n}), 'CheckCircle');\n\nexports.default = _default;"],"names":["useEntity","versionedHolder","useVersionedContext","Error","value","atVersion","entity","createVersionedContext","createPermission","name","attributes","action","kuadrantPlanPolicyListPermission","kuadrantApiProductCreatePermission","kuadrantApiProductReadAllPermission","kuadrantApiProductUpdateOwnPermission","kuadrantApiProductUpdateAllPermission","kuadrantApiProductDeleteOwnPermission","kuadrantApiProductDeleteAllPermission","kuadrantApiProductListPermission","kuadrantApiKeyCreatePermission","resourceType","kuadrantApiKeyReadOwnPermission","kuadrantApiKeyUpdateOwnPermission","kuadrantApiKeyUpdateAllPermission","kuadrantApiKeyDeleteOwnPermission","kuadrantApiKeyDeleteAllPermission","kuadrantApiKeyApprovePermission","useAsync","fn","deps","_a","initialState","loading","lastCallId","useRef","isMounted","useMountedState","useState","state","set","callback","useCallback","args","_i","arguments","length","callId","current","prevState","__assign","apply","then","error","useAsyncFn","useEffect","useKuadrantPermission","permission","resourceRef","permissionRequest","result","usePermission","allowed","canDeleteResource","ownerId","currentUserId","canDeleteOwn","canDeleteAll","getStatusChipStyle","phase","base","border","backgroundColor","color","useStyles","makeStyles","theme","useCasePanel","padding","spacing","palette","background","default","useCaseLabel","fontWeight","marginBottom","text","secondary","textTransform","fontSize","ExpandedRowContent","request","classes","Box","className","onClick","e","stopPropagation","Typography","variant","spec","useCase","ApprovalDialog","open","processing","onClose","onConfirm","confirmText","setConfirmText","handleClose","isReject","expectedText","metadata","isConfirmValid","Dialog","undefined","maxWidth","fullWidth","DialogTitle","DialogContent","paragraph","strong","requestedBy","userId","planTier","mt","p","bgcolor","borderRadius","TextField","label","onChange","target","disabled","autoFocus","DialogActions","Button","startIcon","CircularProgress","size","EntityApiApprovalTab","config","useApi","configApiRef","fetchApi","fetchApiRef","identityApi","identityApiRef","alertApi","alertApiRef","backendUrl","getString","apiProductName","annotations","namespace","refresh","setRefresh","dialogState","setDialogState","canApprove","permissionLoading","permissionError","async","reviewedBy","getBackstageIdentity","userEntityRef","response","fetch","ok","requests","json","items","filter","r","apiProductRef","Progress","ResponseErrorPanel","message","textAlign","pendingRequests","status","approvedRequests","rejectedRequests","columns","title","field","render","row","Chip","style","creationTimestamp","Date","toLocaleDateString","filtering","display","gap","Tooltip","IconButton","CheckCircleIcon","CancelIcon","detailPanelConfig","data","rowData","mb","Table","options","paging","pageSize","search","debounceInterval","toolbar","emptyRowsWhenPaging","map","item","id","detailPanel","prev","endpoint","method","headers","body","JSON","stringify","post","severity","err","console","_interopRequireDefault","_interopRequireWildcard","exports","React","_default","createElement","d"],"sourceRoot":""}
@@ -0,0 +1,2 @@
1
+ "use strict";(self.webpackChunkinternal_plugin_kuadrant=self.webpackChunkinternal_plugin_kuadrant||[]).push([[6813],{5030:(e,t,n)=>{Object.defineProperty(t,"__esModule",{value:!0});var a=n(85608),s=n(95478),r=a.__importDefault(n(10009));t.default=function(e,t,n){void 0===t&&(t=[]),void 0===n&&(n={loading:!1});var i=s.useRef(0),o=r.default(),l=s.useState(n),c=l[0],d=l[1],u=s.useCallback(function(){for(var t=[],n=0;n<arguments.length;n++)t[n]=arguments[n];var s=++i.current;return c.loading||d(function(e){return a.__assign(a.__assign({},e),{loading:!0})}),e.apply(void 0,t).then(function(e){return o()&&s===i.current&&d({value:e,loading:!1}),e},function(e){return o()&&s===i.current&&d({error:e,loading:!1}),e})},t);return[c,u]}},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}},16813:(e,t,n)=>{n.r(t),n.d(t,{ApiKeysPage:()=>pe});var a=n(31085),s=n(95478),r=n.n(s),i=n(10394),o=n(31653),l=n(38605),c=n(289),d=n(15831),u=n(45210),p=n(46681),m=n(38599),h=n(42469),v=n(37725),g=n(86687),f=n(42367),A=n(25010),x=n(22097),j=n(91638),y=n(58837),b=n(72501),k=n(67720),w=n(71677),P=n(29365),S=n(78467),C=n(37757),q=n(26343),I=n(76891),R=n(61477),$=n(46805),z=n(93453),T=n(64947),B=n(32269),N=n(61524),M=n(99594),E=n(77225),_=n(39590),L=n(16397),O=n(63221),D=n(37197),F=n(69621),W=n(12981),K=n(86901),U=n(69076),H=n(6924),V=n(23164);const Y=(0,y.A)(e=>({root:{width:240,minWidth:240,padding:e.spacing(2),borderRight:`1px solid ${e.palette.divider}`,backgroundColor:e.palette.background.paper,height:"100%",overflowY:"auto"},sectionTitle:{fontWeight:600,fontSize:"0.75rem",textTransform:"uppercase",letterSpacing:"0.05em",color:e.palette.text.secondary,marginBottom:e.spacing(1),display:"flex",alignItems:"center",justifyContent:"space-between",cursor:"pointer",userSelect:"none"},filterSection:{marginBottom:e.spacing(2)},checkbox:{padding:e.spacing(.5)},checkboxLabel:{fontSize:"0.875rem"},clearButton:{marginTop:e.spacing(2)},count:{fontSize:"0.75rem",color:e.palette.text.secondary,marginLeft:e.spacing(1)}})),J=({sections:e,filters:t,onChange:n,onClear:s})=>{const o=Y(),[l,c]=r().useState(new Set(e.filter(e=>e.collapsed).map(e=>e.id))),d=Object.values(t).some(e=>e.length>0);return(0,a.jsxs)(i.A,{className:o.root,children:[(0,a.jsxs)(i.A,{display:"flex",justifyContent:"space-between",alignItems:"center",mb:2,children:[(0,a.jsx)(b.A,{variant:"subtitle2",children:"Filters"}),d&&(0,a.jsx)(T.A,{size:"small",color:"primary",onClick:()=>{const t={};e.forEach(e=>{t[e.id]=[]}),n(t),null==s||s()},children:"Clear all"})]}),(0,a.jsx)(D.A,{}),e.map(e=>{const s=l.has(e.id),r=(t[e.id]||[]).length;return(0,a.jsxs)(i.A,{className:o.filterSection,mt:2,children:[(0,a.jsxs)(i.A,{className:o.sectionTitle,onClick:()=>{return t=e.id,void c(e=>{const n=new Set(e);return n.has(t)?n.delete(t):n.add(t),n});var t},children:[(0,a.jsxs)(i.A,{display:"flex",alignItems:"center",children:[(0,a.jsx)("span",{children:e.title}),r>0&&(0,a.jsxs)("span",{className:o.count,children:["(",r,")"]})]}),s?(0,a.jsx)(H.A,{fontSize:"small"}):(0,a.jsx)(V.A,{fontSize:"small"})]}),(0,a.jsx)(F.A,{in:!s,children:(0,a.jsx)(W.A,{children:e.options.map(s=>(0,a.jsx)(K.A,{control:(0,a.jsx)(U.A,{checked:(t[e.id]||[]).includes(s.value),onChange:()=>((e,a)=>{const s=t[e]||[],r=s.includes(a)?s.filter(e=>e!==a):[...s,a];n({...t,[e]:r})})(e.id,s.value),size:"small",className:o.checkbox,color:"primary"}),label:(0,a.jsxs)(i.A,{display:"flex",alignItems:"center",children:[(0,a.jsx)("span",{className:o.checkboxLabel,children:s.label}),void 0!==s.count&&(0,a.jsxs)("span",{className:o.count,children:["(",s.count,")"]})]})},s.value))})})]},e.id)})]})};var X=n(46299);const G=(0,y.A)(e=>({container:{display:"flex",height:"100%",minHeight:400},tableContainer:{flex:1,overflow:"auto"},useCasePanel:{padding:e.spacing(2),backgroundColor:e.palette.background.default},useCaseLabel:{fontWeight:600,marginBottom:e.spacing(1),color:e.palette.text.secondary,textTransform:"uppercase",fontSize:"0.75rem"},rejectedBanner:{backgroundColor:e.palette.error.light,border:`1px solid ${e.palette.error.main}`,borderRadius:e.shape.borderRadius,padding:e.spacing(1.5,2),marginBottom:e.spacing(2),display:"flex",alignItems:"center",gap:e.spacing(1)}})),Q=({request:e})=>{var t,n;const s=G(),r="Rejected"===(null===(t=e.status)||void 0===t?void 0:t.phase),o=(null===(n=e.spec.apiProductRef)||void 0===n?void 0:n.name)||"unknown";return(0,a.jsxs)(i.A,{className:s.useCasePanel,onClick:e=>e.stopPropagation(),children:[r&&(0,a.jsxs)(i.A,{className:s.rejectedBanner,children:[(0,a.jsx)(E.A,{color:"error",fontSize:"small"}),(0,a.jsxs)(b.A,{variant:"body2",children:["This API key was rejected."," ",(0,a.jsx)(v.N_,{to:`/catalog/default/api/${o}/api-keys`,children:"Request a new API key"})]})]}),(0,a.jsx)(b.A,{className:s.useCaseLabel,children:"Use Case"}),(0,a.jsx)(b.A,{variant:"body2",children:e.spec.useCase||"No use case provided"})]})},Z=()=>{var e,t;const n=G(),r=(0,h.useNavigate)(),o=(0,x.useApi)(x.configApiRef),l=(0,x.useApi)(x.fetchApiRef),c=(0,x.useApi)(x.alertApiRef),d=o.getString("backend.baseUrl"),[u,p]=(0,s.useState)(new Set),[m,y]=(0,s.useState)(null),[D,F]=(0,s.useState)(null),[W,K]=(0,s.useState)({open:!1,request:null,plans:[]}),[U,H]=(0,s.useState)(0),[V,Y]=(0,s.useState)(null),[Z,ee]=(0,s.useState)({open:!1,request:null}),[te,ne]=(0,s.useState)(new Map),[ae,se]=(0,s.useState)(new Set),[re,ie]=(0,s.useState)(new Set),[oe,le]=(0,s.useState)(!1),[ce,de]=(0,s.useState)(null),[ue,pe]=(0,s.useState)(new Set),[me,he]=(0,s.useState)({status:[],apiProduct:[],tier:[]}),{value:ve,loading:ge,error:fe}=(0,j.A)(async()=>{const[e,t]=await Promise.all([l.fetch(`${d}/api/kuadrant/requests/my`),l.fetch(`${d}/api/kuadrant/apiproducts`)]);if(!e.ok)throw new Error("failed to fetch requests");const n=(await e.json()).items||[];let a=[];t.ok&&(a=(await t.json()).items||[]);const s=new Map;return a.forEach(e=>{var t;const n=`${e.metadata.namespace}/${e.metadata.name}`,a=(null===(t=e.metadata.annotations)||void 0===t?void 0:t["backstage.io/owner"])||"unknown";s.set(n,a)}),{requests:n,products:a,ownerMap:s}},[d,l,U]),Ae=(0,s.useMemo)(()=>(null==ve?void 0:ve.requests)?ve.requests.filter(e=>!ue.has(e.metadata.name)):[],[null==ve?void 0:ve.requests,ue]),xe=(0,s.useMemo)(()=>{const e={Approved:0,Pending:0,Rejected:0},t=new Map,n=new Map;return Ae.forEach(a=>{var s,r;const i=(null===(s=a.status)||void 0===s?void 0:s.phase)||"Pending";e[i]++;const o=(null===(r=a.spec.apiProductRef)||void 0===r?void 0:r.name)||"unknown";t.set(o,(t.get(o)||0)+1);const l=a.spec.planTier||"unknown";n.set(l,(n.get(l)||0)+1)}),[{id:"status",title:"Status",options:[{value:"Approved",label:"Active",count:e.Approved},{value:"Pending",label:"Pending",count:e.Pending},{value:"Rejected",label:"Rejected",count:e.Rejected}]},{id:"apiProduct",title:"API Product",options:Array.from(t.entries()).map(([e,t])=>({value:e,label:e,count:t})),collapsed:t.size>5},{id:"tier",title:"Tier",options:Array.from(n.entries()).map(([e,t])=>({value:e,label:e.charAt(0).toUpperCase()+e.slice(1),count:t}))}]},[Ae]),je=(0,s.useMemo)(()=>Ae.filter(e=>{if(me.status.length>0){var t;const n=(null===(t=e.status)||void 0===t?void 0:t.phase)||"Pending";if(!me.status.includes(n))return!1}if(me.apiProduct.length>0){var n;const t=(null===(n=e.spec.apiProductRef)||void 0===n?void 0:n.name)||"unknown";if(!me.apiProduct.includes(t))return!1}if(me.tier.length>0){const t=e.spec.planTier||"unknown";if(!me.tier.includes(t))return!1}return!0}),[Ae,me]),ye=e=>{p(t=>{const n=new Set(t);return n.has(e)?n.delete(e):n.add(e),n})},be=()=>{y(null),F(null)},ke=async()=>{if(!D)return;const e=D;be();try{var t;const a=null===(t=e.spec.apiProductRef)||void 0===t?void 0:t.name,s=e.metadata.namespace,r=await l.fetch(`${d}/api/kuadrant/apiproducts/${s}/${a}`);if(r.ok){var n;const t=(null===(n=(await r.json()).spec)||void 0===n?void 0:n.plans)||[];K({open:!0,request:e,plans:t})}else K({open:!0,request:e,plans:[]})}catch(t){console.error("Error fetching plans:",t),K({open:!0,request:e,plans:[]})}},we=()=>{if(!D)return;const e=D;be(),ee({open:!0,request:e})},Pe=[{title:"API Product",field:"spec.apiProductRef.name",render:e=>{var t;const n=(null===(t=e.spec.apiProductRef)||void 0===t?void 0:t.name)||"unknown";return(0,a.jsx)(v.N_,{to:`/catalog/default/api/${n}/api-keys`,children:(0,a.jsx)("strong",{children:n})})}},{title:"Owner",field:"owner",render:e=>{var t,n;const s=`${e.metadata.namespace}/${null===(t=e.spec.apiProductRef)||void 0===t?void 0:t.name}`,r=((null==ve||null===(n=ve.ownerMap)||void 0===n?void 0:n.get(s))||"unknown").replace(/^user:default\//,"");return(0,a.jsx)(b.A,{variant:"body2",children:r})}},{title:"Status",field:"status.phase",render:e=>{var t;const n=(null===(t=e.status)||void 0===t?void 0:t.phase)||"Pending",s="Approved"===n?"Active":n;return(0,a.jsx)(k.A,{label:s,size:"small",style:(0,X.S)(n)})}},{title:"Tier",field:"spec.planTier",render:e=>(0,a.jsx)(k.A,{label:e.spec.planTier,size:"small",variant:"outlined"})},{title:"API Key",field:"status.secretRef",filtering:!1,render:e=>{var t,n,s,r;if("Approved"!==(null===(t=e.status)||void 0===t?void 0:t.phase))return(0,a.jsx)(b.A,{variant:"body2",color:"textSecondary",children:"-"});const o=`${e.metadata.namespace}/${e.metadata.name}`,l=null===(s=e.status)||void 0===s||null===(n=s.secretRef)||void 0===n?void 0:n.name,d=u.has(e.metadata.name),p=ae.has(o),m=te.get(o),h=!1!==(null===(r=e.status)||void 0===r?void 0:r.canReadSecret),v=re.has(o)||!h;return l?v&&!m?(0,a.jsx)(w.Ay,{title:"This API key has already been viewed and cannot be retrieved again",children:(0,a.jsxs)(i.A,{display:"flex",alignItems:"center",children:[(0,a.jsx)(b.A,{variant:"body2",color:"textSecondary",style:{fontFamily:"monospace",marginRight:8},children:"Already viewed"}),(0,a.jsx)(N.A,{fontSize:"small",color:"disabled"})]})}):(0,a.jsxs)(i.A,{display:"flex",alignItems:"center",style:{gap:8},children:[(0,a.jsx)(i.A,{fontFamily:"monospace",fontSize:"0.875rem",children:p?"Loading...":d&&m?m:"•".repeat(20)+"..."}),d&&m&&(0,a.jsx)(w.Ay,{title:"Copy to clipboard",children:(0,a.jsx)(P.A,{size:"small",onClick:async()=>{m&&(await navigator.clipboard.writeText(m),c.post({message:"API key copied to clipboard",severity:"success",display:"transient"}))},children:(0,a.jsx)(M.A,{fontSize:"small"})})}),(0,a.jsx)(w.Ay,{title:d?"Hide API key":"Reveal API key (one-time only)",children:(0,a.jsx)("span",{children:(0,a.jsx)(P.A,{size:"small",onClick:()=>{d?(((e,t)=>{const n=`${e}/${t}`;ne(e=>{const t=new Map(e);return t.delete(n),t})})(e.metadata.namespace,e.metadata.name),ye(e.metadata.name)):v||(de({namespace:e.metadata.namespace,name:e.metadata.name}),le(!0))},disabled:p||v&&!m,children:d?(0,a.jsx)(N.A,{fontSize:"small"}):(0,a.jsx)(B.A,{fontSize:"small"})})})})]}):(0,a.jsx)(b.A,{variant:"body2",color:"textSecondary",children:"Awaiting secret..."})}},{title:"Requested",field:"metadata.creationTimestamp",render:e=>{if(!e.metadata.creationTimestamp)return(0,a.jsx)(b.A,{variant:"body2",children:"-"});const t=new Date(e.metadata.creationTimestamp);return(0,a.jsx)(b.A,{variant:"body2",children:t.toLocaleDateString()})}},{title:"Actions",filtering:!1,width:"100px",render:e=>V===e.metadata.name?(0,a.jsx)(S.A,{size:20}):(0,a.jsxs)(i.A,{display:"flex",style:{gap:4},children:[(0,a.jsx)(w.Ay,{title:"View details",children:(0,a.jsx)(P.A,{size:"small",onClick:t=>{t.stopPropagation(),r(`/kuadrant/api-keys/${e.metadata.namespace}/${e.metadata.name}`)},children:(0,a.jsx)(B.A,{fontSize:"small"})})}),(0,a.jsx)(w.Ay,{title:"Delete",children:(0,a.jsx)(P.A,{size:"small",onClick:t=>{t.stopPropagation(),ee({open:!0,request:e})},children:(0,a.jsx)(_.A,{fontSize:"small"})})})]})}],Se=(0,s.useMemo)(()=>[{render:e=>{var t;const n=e.rowData;return(null==n||null===(t=n.metadata)||void 0===t?void 0:t.name)?(0,a.jsx)(Q,{request:n}):(0,a.jsx)(i.A,{})}}],[]);return ge?(0,a.jsx)(g.k,{}):fe?(0,a.jsx)(f._,{error:fe}):(0,a.jsxs)(a.Fragment,{children:[(0,a.jsxs)(i.A,{className:n.container,children:[(0,a.jsx)(J,{sections:xe,filters:me,onChange:he}),(0,a.jsx)(i.A,{className:n.tableContainer,children:0===je.length?(0,a.jsx)(i.A,{p:4,textAlign:"center",children:(0,a.jsx)(b.A,{variant:"body1",color:"textSecondary",children:0===Ae.length?"No API keys found. Request access to an API to get started.":"No API keys match the selected filters."})}):(0,a.jsx)(A.X,{options:{paging:je.length>10,pageSize:20,search:!0,filtering:!1,debounceInterval:300,toolbar:!0,emptyRowsWhenPaging:!1},columns:Pe,data:je.map(e=>({...e,id:e.metadata.name})),detailPanel:Se})})]}),(0,a.jsx)(C.A,{id:"myapikeys-menu",open:Boolean(m),onClose:be,anchorReference:"anchorPosition",anchorPosition:m||{top:0,left:0},children:D&&(()=>{const e=[];var t;return e.push((0,a.jsx)(q.A,{onClick:()=>{r(`/kuadrant/api-keys/${D.metadata.namespace}/${D.metadata.name}`),be()},children:"View Details"},"view")),(t=D).status&&"Pending"!==t.status.phase||e.push((0,a.jsx)(q.A,{onClick:ke,children:"Edit"},"edit")),e.push((0,a.jsx)(q.A,{onClick:we,children:"Delete"},"delete")),e})()}),W.request&&(0,a.jsx)(L.e,{open:W.open,request:W.request,availablePlans:W.plans,onClose:()=>K({open:!1,request:null,plans:[]}),onSuccess:()=>{K({open:!1,request:null,plans:[]}),H(e=>e+1)}}),(0,a.jsx)(O.K,{open:Z.open,title:"Delete API Key",description:`Are you sure you want to delete this API key for ${(null===(t=Z.request)||void 0===t||null===(e=t.spec.apiProductRef)||void 0===e?void 0:e.name)||"this API"}?`,deleting:null!==V,onConfirm:async()=>{if(!Z.request)return;const e=Z.request,t=e.metadata.name;pe(e=>new Set(e).add(t)),Y(t);try{if(!(await l.fetch(`${d}/api/kuadrant/requests/${e.metadata.namespace}/${e.metadata.name}`,{method:"DELETE"})).ok)throw new Error("Failed to delete request");H(e=>e+1),c.post({message:"API key deleted",severity:"success",display:"transient"}),ee({open:!1,request:null})}catch(e){console.error("Error deleting request:",e),pe(e=>{const n=new Set(e);return n.delete(t),n}),c.post({message:"Failed to delete API key",severity:"error",display:"transient"})}finally{Y(null)}},onCancel:()=>{ee({open:!1,request:null})}}),(0,a.jsxs)(I.A,{open:oe,onClose:()=>{le(!1),de(null)},maxWidth:"sm",children:[(0,a.jsx)(R.A,{children:(0,a.jsxs)(i.A,{display:"flex",alignItems:"center",children:[(0,a.jsx)(E.A,{color:"primary",style:{marginRight:8}}),"View API Key"]})}),(0,a.jsxs)($.A,{children:[(0,a.jsxs)(b.A,{variant:"body1",paragraph:!0,children:["This API key can only be viewed ",(0,a.jsx)("strong",{children:"once"}),". After you reveal it, you will not be able to retrieve it again."]}),(0,a.jsx)(b.A,{variant:"body2",color:"textSecondary",children:"Make sure to copy and store it securely before closing this view."})]}),(0,a.jsxs)(z.A,{children:[(0,a.jsx)(T.A,{onClick:()=>{le(!1),de(null)},children:"Cancel"}),(0,a.jsx)(T.A,{variant:"contained",color:"primary",onClick:()=>{ce&&((async(e,t)=>{const n=`${e}/${t}`;if(!ae.has(n)){se(e=>new Set(e).add(n));try{const a=await l.fetch(`${d}/api/kuadrant/apikeys/${e}/${t}/secret`);if(a.ok){const e=await a.json();ne(t=>new Map(t).set(n,e.apiKey)),ie(e=>new Set(e).add(n))}else 403===a.status&&(ie(e=>new Set(e).add(n)),c.post({message:"This API key has already been viewed and cannot be retrieved again.",severity:"warning",display:"transient"}))}catch(e){console.error("failed to fetch api key:",e)}finally{se(e=>{const t=new Set(e);return t.delete(n),t})}}})(ce.namespace,ce.name),ye(ce.name)),le(!1),de(null)},children:"Reveal API Key"})]})]})]})};var ee=n(35015),te=n(34955),ne=n(46205),ae=n(16249),se=n(55429),re=n(92399);const ie=(0,y.A)(e=>({container:{display:"flex",height:"100%",minHeight:400},tableContainer:{flex:1,overflow:"auto"},useCasePanel:{padding:e.spacing(2),backgroundColor:e.palette.background.default},useCaseLabel:{fontWeight:600,marginBottom:e.spacing(1),color:e.palette.text.secondary,textTransform:"uppercase",fontSize:"0.75rem"},bulkActions:{padding:e.spacing(2),backgroundColor:e.palette.background.default,borderBottom:`1px solid ${e.palette.divider}`,display:"flex",alignItems:"center",justifyContent:"space-between"}})),oe=({open:e,request:t,action:n,processing:s,onClose:o,onConfirm:l})=>{var c,d;const[u,p]=r().useState(""),m="approve"===n?"Approve":"Reject",h="approve"===n?"Approving...":"Rejecting...",v="reject"===n,g=(null==t||null===(c=t.spec.requestedBy)||void 0===c?void 0:c.userId)||"",f=!v||u===g;return r().useEffect(()=>{e||p("")},[e]),(0,a.jsxs)(I.A,{open:e,onClose:s?void 0:o,maxWidth:"sm",fullWidth:!0,children:[(0,a.jsx)(R.A,{children:v?(0,a.jsxs)(i.A,{display:"flex",alignItems:"center",style:{gap:8},children:[(0,a.jsx)(re.A,{color:"error"}),(0,a.jsxs)("span",{children:[m," API Key"]})]}):(0,a.jsxs)("span",{children:[m," API Key"]})}),(0,a.jsx)($.A,{children:t&&(0,a.jsxs)(a.Fragment,{children:[(0,a.jsxs)("p",{children:[(0,a.jsx)("strong",{children:"User:"})," ",t.spec.requestedBy.userId]}),(0,a.jsxs)("p",{children:[(0,a.jsx)("strong",{children:"API:"})," ",(null===(d=t.spec.apiProductRef)||void 0===d?void 0:d.name)||"unknown"]}),(0,a.jsxs)("p",{children:[(0,a.jsx)("strong",{children:"Tier:"})," ",t.spec.planTier]}),(0,a.jsxs)(i.A,{mb:2,children:[(0,a.jsx)(b.A,{variant:"body2",component:"span",style:{fontWeight:"bold"},children:"Use Case:"})," ",(0,a.jsx)(b.A,{variant:"body2",component:"span",style:{whiteSpace:"pre-wrap"},children:t.spec.useCase||"-"})]}),v&&(0,a.jsxs)(i.A,{mt:2,children:[(0,a.jsxs)(b.A,{variant:"body2",color:"textSecondary",gutterBottom:!0,children:["Type ",(0,a.jsx)("strong",{children:g})," to confirm rejection:"]}),(0,a.jsx)(ae.A,{fullWidth:!0,variant:"outlined",size:"small",value:u,onChange:e=>p(e.target.value),disabled:s,autoFocus:!0,placeholder:g})]})]})}),(0,a.jsxs)(z.A,{children:[(0,a.jsx)(T.A,{onClick:o,disabled:s,children:"Cancel"}),(0,a.jsx)(T.A,{onClick:l,color:"approve"===n?"primary":"secondary",variant:"contained",disabled:s||!f,startIcon:s?(0,a.jsx)(S.A,{size:16,color:"inherit"}):void 0,children:s?h:m})]})]})},le=({open:e,requests:t,action:n,processing:s,onClose:r,onConfirm:o})=>{const l="approve"===n,c=l?"Approve All":"Reject All",d=l?"Approving...":"Rejecting...";return(0,a.jsxs)(I.A,{open:e,onClose:s?void 0:r,maxWidth:"md",fullWidth:!0,children:[(0,a.jsxs)(R.A,{children:[l?"Approve":"Reject"," ",t.length," API Keys"]}),(0,a.jsxs)($.A,{children:[(0,a.jsxs)(b.A,{variant:"body2",paragraph:!0,children:["You are about to ",l?"approve":"reject"," the following API keys:"]}),(0,a.jsx)(i.A,{mb:2,maxHeight:200,overflow:"auto",children:t.map(e=>{var t;return(0,a.jsx)(i.A,{mb:1,p:1,bgcolor:"background.default",children:(0,a.jsxs)(b.A,{variant:"body2",children:[(0,a.jsx)("strong",{children:e.spec.requestedBy.userId})," -"," ",(null===(t=e.spec.apiProductRef)||void 0===t?void 0:t.name)||"unknown"," (",e.spec.planTier,")"]})},`${e.metadata.namespace}/${e.metadata.name}`)})})]}),(0,a.jsxs)(z.A,{children:[(0,a.jsx)(T.A,{onClick:r,disabled:s,children:"Cancel"}),(0,a.jsx)(T.A,{onClick:o,color:l?"primary":"secondary",variant:"contained",disabled:s,startIcon:s?(0,a.jsx)(S.A,{size:16,color:"inherit"}):void 0,children:s?d:c})]})]})},ce=({request:e})=>{const t=ie();return(0,a.jsxs)(i.A,{className:t.useCasePanel,onClick:e=>e.stopPropagation(),children:[(0,a.jsx)(b.A,{className:t.useCaseLabel,children:"Use Case"}),(0,a.jsx)(b.A,{variant:"body2",children:e.spec.useCase||"No use case provided"})]})},de=()=>{var e;const t=ie(),n=(0,x.useApi)(x.configApiRef),r=(0,x.useApi)(x.fetchApiRef),o=(0,x.useApi)(x.identityApiRef),l=(0,x.useApi)(x.alertApiRef),c=n.getString("backend.baseUrl"),[d,u]=(0,s.useState)(0),[p,m]=(0,s.useState)([]),[h,j]=(0,s.useState)({open:!1,request:null,action:"approve",processing:!1}),[y,w]=(0,s.useState)({open:!1,requests:[],action:"approve",processing:!1}),[P,S]=(0,s.useState)({status:[],apiProduct:[],tier:[]}),{allowed:C,loading:q,error:I}=(0,ne.l)(te.z4),{allowed:R,loading:$,error:z}=(0,ne.l)(te.q0),B=q||$,N=I||z,{value:M,loading:E,error:_}=(0,ee.A)(async()=>{const e=(await o.getBackstageIdentity()).userEntityRef,[t,n]=await Promise.all([r.fetch(`${c}/api/kuadrant/requests`),r.fetch(`${c}/api/kuadrant/apiproducts`)]);if(!t.ok)return{allRequests:[],reviewedBy:e,ownedApiProducts:new Set};const a=t.headers.get("content-type");if(!(null==a?void 0:a.includes("application/json")))return l.post({message:"Unexpected content-type from the server response.",display:"transient",severity:"warning"}),{allRequests:[],reviewedBy:e,ownedApiProducts:new Set};const s=(await t.json()).items||[],i=new Set;if(n.ok){const t=await n.json();for(const n of t.items||[]){var d,u;(null===(u=n.metadata)||void 0===u||null===(d=u.annotations)||void 0===d?void 0:d["backstage.io/owner"])===e&&i.add(`${n.metadata.namespace}/${n.metadata.name}`)}}return{allRequests:s,reviewedBy:e,ownedApiProducts:i}},[c,r,o,d]),L=(0,s.useMemo)(()=>{if(!(null==M?void 0:M.allRequests))return[];const e={Approved:0,Pending:0,Rejected:0},t=new Map,n=new Map;return M.allRequests.forEach(a=>{var s,r;const i=(null===(s=a.status)||void 0===s?void 0:s.phase)||"Pending";e[i]++;const o=(null===(r=a.spec.apiProductRef)||void 0===r?void 0:r.name)||"unknown";t.set(o,(t.get(o)||0)+1);const l=a.spec.planTier||"unknown";n.set(l,(n.get(l)||0)+1)}),[{id:"status",title:"Status",options:[{value:"Pending",label:"Pending",count:e.Pending},{value:"Approved",label:"Approved",count:e.Approved},{value:"Rejected",label:"Rejected",count:e.Rejected}]},{id:"apiProduct",title:"API Product",options:Array.from(t.entries()).map(([e,t])=>({value:e,label:e,count:t})),collapsed:t.size>5},{id:"tier",title:"Tier",options:Array.from(n.entries()).map(([e,t])=>({value:e,label:e.charAt(0).toUpperCase()+e.slice(1),count:t}))}]},[null==M?void 0:M.allRequests]),O=(0,s.useMemo)(()=>(null==M?void 0:M.allRequests)?M.allRequests.filter(e=>{if(P.status.length>0){var t;const n=(null===(t=e.status)||void 0===t?void 0:t.phase)||"Pending";if(!P.status.includes(n))return!1}if(P.apiProduct.length>0){var n;const t=(null===(n=e.spec.apiProductRef)||void 0===n?void 0:n.name)||"unknown";if(!P.apiProduct.includes(t))return!1}if(P.tier.length>0){const t=e.spec.planTier||"unknown";if(!P.tier.includes(t))return!1}return!0}):[],[null==M?void 0:M.allRequests,P]),D=e=>new Date(e).toLocaleDateString("en-GB",{year:"numeric",month:"short",day:"numeric"}),F=[{title:"Requester",field:"spec.requestedBy.userId",render:e=>(0,a.jsx)(b.A,{variant:"body2",children:e.spec.requestedBy.userId})},{title:"API Product",field:"spec.apiProductRef.name",render:e=>{var t;const n=(null===(t=e.spec.apiProductRef)||void 0===t?void 0:t.name)||"unknown";return(0,a.jsx)(v.N_,{to:`/catalog/default/api/${n}`,children:(0,a.jsx)("strong",{children:n})})}},{title:"Status",field:"status.phase",render:e=>{var t;const n=(null===(t=e.status)||void 0===t?void 0:t.phase)||"Pending";return(0,a.jsx)(k.A,{label:n,size:"small",style:(0,X.S)(n)})}},{title:"Tier",field:"spec.planTier",render:e=>(0,a.jsx)(k.A,{label:e.spec.planTier,size:"small",variant:"outlined"})},{title:"Requested",field:"metadata.creationTimestamp",render:e=>(0,a.jsx)(b.A,{variant:"body2",children:e.metadata.creationTimestamp?D(e.metadata.creationTimestamp):"-"})},{title:"Reviewed By",field:"status.reviewedBy",render:e=>{var t;if(!(null===(t=e.status)||void 0===t?void 0:t.reviewedBy))return(0,a.jsx)(b.A,{variant:"body2",color:"textSecondary",children:"-"});const n=e.status.reviewedBy.replace(/^user:default\//,""),s="system"===n;return(0,a.jsxs)(i.A,{children:[(0,a.jsx)(b.A,{variant:"body2",children:s?"Automatic":n}),e.status.reviewedAt&&(0,a.jsx)(b.A,{variant:"caption",color:"textSecondary",children:D(e.status.reviewedAt)})]})}},{title:"Actions",filtering:!1,render:e=>{var t,n,s;if("Pending"!==((null===(t=e.status)||void 0===t?void 0:t.phase)||"Pending"))return null;const r=`${e.metadata.namespace}/${(null===(n=e.spec.apiProductRef)||void 0===n?void 0:n.name)||"unknown"}`;var o;const l=null!==(o=null==M||null===(s=M.ownedApiProducts)||void 0===s?void 0:s.has(r))&&void 0!==o&&o;return C||R&&l?(0,a.jsxs)(i.A,{display:"flex",style:{gap:8},children:[(0,a.jsx)(T.A,{size:"small",startIcon:(0,a.jsx)(se.A,{}),onClick:()=>{j({open:!0,request:e,action:"approve",processing:!1})},color:"primary",variant:"outlined",children:"Approve"}),(0,a.jsx)(T.A,{size:"small",startIcon:(0,a.jsx)(re.A,{}),onClick:()=>{j({open:!0,request:e,action:"reject",processing:!1})},color:"secondary",variant:"outlined",children:"Reject"})]}):null}}],W=(0,s.useMemo)(()=>[{render:e=>{var t;const n=e.rowData;return(null==n||null===(t=n.metadata)||void 0===t?void 0:t.name)?(0,a.jsx)(ce,{request:n}):(0,a.jsx)(i.A,{})}}],[]);if(E||B)return(0,a.jsx)(g.k,{});if(_)return(0,a.jsx)(f._,{error:_});if(N)return(0,a.jsx)(i.A,{p:2,children:(0,a.jsxs)(b.A,{color:"error",children:["Unable to check permissions: ",N.message]})});const K=C||R;return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsxs)(i.A,{className:t.container,children:[(0,a.jsx)(J,{sections:L,filters:P,onChange:S}),(0,a.jsxs)(i.A,{className:t.tableContainer,children:[p.length>0&&(0,a.jsxs)(i.A,{className:t.bulkActions,children:[(0,a.jsxs)(b.A,{variant:"body2",children:[p.length," request",1!==p.length?"s":""," selected"]}),(0,a.jsxs)(i.A,{display:"flex",style:{gap:8},children:[(0,a.jsx)(T.A,{size:"small",variant:"contained",color:"primary",startIcon:(0,a.jsx)(se.A,{}),onClick:()=>{0!==p.length&&w({open:!0,requests:p,action:"approve",processing:!1})},children:"Approve Selected"}),(0,a.jsx)(T.A,{size:"small",variant:"contained",color:"secondary",startIcon:(0,a.jsx)(re.A,{}),onClick:()=>{0!==p.length&&w({open:!0,requests:p,action:"reject",processing:!1})},children:"Reject Selected"})]})]}),0===O.length?(0,a.jsx)(i.A,{p:4,textAlign:"center",children:(0,a.jsx)(b.A,{variant:"body1",color:"textSecondary",children:0===(null==M||null===(e=M.allRequests)||void 0===e?void 0:e.length)?"No API keys found.":"No API keys match the selected filters."})}):(0,a.jsx)(A.X,{options:{selection:K,showSelectAllCheckbox:O.some(e=>{var t;return!(null===(t=e.status)||void 0===t?void 0:t.phase)||"Pending"===e.status.phase}),selectionProps:e=>{var t,n;return{disabled:"Pending"!==(null===(t=e.status)||void 0===t?void 0:t.phase)&&void 0!==(null===(n=e.status)||void 0===n?void 0:n.phase)}},paging:O.length>10,pageSize:20,search:!0,filtering:!1,debounceInterval:300,showTextRowsSelected:!1,toolbar:!0,emptyRowsWhenPaging:!1},columns:F,data:O.map(e=>{const t=p.some(t=>t.metadata.name===e.metadata.name&&t.metadata.namespace===e.metadata.namespace);return{...e,id:e.metadata.name,tableData:{checked:t}}}),onSelectionChange:e=>{const t=e.filter(e=>{var t;return!(null===(t=e.status)||void 0===t?void 0:t.phase)||"Pending"===e.status.phase});m(t)},detailPanel:W})]})]}),(0,a.jsx)(oe,{open:h.open,request:h.request,action:h.action,processing:h.processing,onClose:()=>j({open:!1,request:null,action:"approve",processing:!1}),onConfirm:async()=>{if(!h.request||!M)return;j(e=>({...e,processing:!0}));const e="approve"===h.action?`${c}/api/kuadrant/requests/${h.request.metadata.namespace}/${h.request.metadata.name}/approve`:`${c}/api/kuadrant/requests/${h.request.metadata.namespace}/${h.request.metadata.name}/reject`;try{if(!(await r.fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({reviewedBy:M.reviewedBy})})).ok)throw new Error(`failed to ${h.action} request`);j({open:!1,request:null,action:"approve",processing:!1}),m(e=>e.filter(e=>{var t,n;return e.metadata.name!==(null===(t=h.request)||void 0===t?void 0:t.metadata.name)||e.metadata.namespace!==(null===(n=h.request)||void 0===n?void 0:n.metadata.namespace)})),u(e=>e+1);const t="approve"===h.action?"approved":"rejected";l.post({message:`API key ${t}`,severity:"success",display:"transient"})}catch(e){console.error(`error ${h.action}ing request:`,e),j(e=>({...e,processing:!1})),l.post({message:`Failed to ${h.action} API key`,severity:"error",display:"transient"})}}}),(0,a.jsx)(le,{open:y.open,requests:y.requests,action:y.action,processing:y.processing,onClose:()=>w({open:!1,requests:[],action:"approve",processing:!1}),onConfirm:async()=>{if(!M||0===y.requests.length)return;w(e=>({...e,processing:!0}));const e="approve"===y.action,t=e?`${c}/api/kuadrant/requests/bulk-approve`:`${c}/api/kuadrant/requests/bulk-reject`;try{if(!(await r.fetch(t,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({requests:y.requests.map(e=>({namespace:e.metadata.namespace,name:e.metadata.name})),reviewedBy:M.reviewedBy})})).ok)throw new Error(`failed to bulk ${y.action} requests`);const n=y.requests.length,a=e?"approved":"rejected";w({open:!1,requests:[],action:"approve",processing:!1}),m([]),u(e=>e+1),l.post({message:`${n} API keys ${a}`,severity:"success",display:"transient"})}catch(e){console.error(`error bulk ${y.action}ing requests:`,e),w(e=>({...e,processing:!1})),l.post({message:`Failed to bulk ${y.action} API keys`,severity:"error",display:"transient"})}}})]})},ue=()=>{const[e,t]=(0,s.useState)(0),{allowed:n,loading:r}=(0,ne.l)(te.KV);return(0,a.jsxs)(c.Y,{themeId:"tool",children:[(0,a.jsx)(d.Y,{title:"API Keys",subtitle:"API keys management for Kubernetes",children:(0,a.jsx)(u.Y,{children:"Manage your API keys and access requests"})}),(0,a.jsxs)(p.U,{children:[(0,a.jsx)(i.A,{mb:2,children:(0,a.jsxs)(o.A,{value:e,onChange:(e,n)=>{t(n)},indicatorColor:"primary",textColor:"primary",children:[(0,a.jsx)(l.A,{label:"My API keys","data-testid":"my-api-keys-tab"}),!r&&n&&(0,a.jsx)(l.A,{label:"API keys approval","data-testid":"api-keys-approval-tab"})]})}),0===e&&(0,a.jsx)(Z,{}),1===e&&n&&(0,a.jsx)(de,{})]})]})},pe=()=>(0,a.jsx)(m.B,{permission:te.DS,errorMessage:"you don't have permission to view the API Keys page",children:(0,a.jsx)(ue,{})})},23164:(e,t,n)=>{var a=n(4293),s=n(78920);t.A=void 0;var r=s(n(95478)),i=(0,a(n(74044)).default)(r.createElement("path",{d:"M12 8l-6 6 1.41 1.41L12 10.83l4.59 4.58L18 14z"}),"ExpandLess");t.A=i},27799:(e,t,n)=>{var a=n(4293),s=n(78920);t.A=void 0;var r=s(n(95478)),i=(0,a(n(74044)).default)(r.createElement("path",{d:"M21 5v6.59l-3-3.01-4 4.01-4-4-4 4-3-3.01V5c0-1.1.9-2 2-2h14c1.1 0 2 .9 2 2zm-3 6.42l3 3.01V19c0 1.1-.9 2-2 2H5c-1.1 0-2-.9-2-2v-6.58l3 2.99 4-4 4 4 4-3.99z"}),"BrokenImage");t.A=i},38599:(e,t,n)=>{n.d(t,{B:()=>l});var a=n(31085),s=(n(95478),n(10394)),r=n(72501),i=n(86687),o=n(46205);const l=({children:e,permission:t,fallback:n,errorMessage:l})=>{const{allowed:c,loading:d,error:u}=(0,o.l)(t);return d?(0,a.jsx)(i.k,{}):u?(0,a.jsxs)(s.A,{p:4,children:[(0,a.jsxs)(r.A,{color:"error",children:["Unable to check permissions: ",u.message]}),(0,a.jsx)(r.A,{variant:"body2",color:"textSecondary",children:"Please try again or contact your administrator"})]}):c?(0,a.jsx)(a.Fragment,{children:e}):n?(0,a.jsx)(a.Fragment,{children:n}):(0,a.jsxs)(s.A,{p:4,children:[(0,a.jsx)(r.A,{color:"textSecondary",children:l||"You don't have permission to view this page"}),(0,a.jsx)(s.A,{mt:1,children:(0,a.jsxs)(r.A,{variant:"caption",color:"textSecondary",children:["Required permission: ",t.name]})})]})}},39590:(e,t,n)=>{var a=n(4293),s=n(78920);t.A=void 0;var r=s(n(95478)),i=(0,a(n(74044)).default)(r.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=i},45210:(e,t,n)=>{n.d(t,{Y:()=>I});var a=n(31085),s=n(22097),r=n(10394),i=n(64947),o=n(93453),l=n(29365),c=n(46423),d=n(5951),u=n(26343),p=n(28233),m=n(55197),h=n(37976),v=n(72501),g=n(5893),f=n(95478),A=(n(45250),n(42469),n(16098)),x=n(67550);const j=()=>{const{t:e}=(0,x.i)(A.O);return{url:"https://github.com/backstage/backstage/issues",items:[{title:e("supportConfig.default.title"),icon:"warning",links:[{title:e("supportConfig.default.linkTitle"),url:"https://github.com/backstage/backstage/blob/master/app-config.yaml"}]}]}};var y=n(27799);function b(e){const{id:t,Fallback:n=y.A,...r}=e,i=(0,s.useApp)().getSystemIcon(t)??n;return(0,a.jsx)(i,{...r})}function k(e){return(0,a.jsx)(b,{id:"help",...e})}var w=n(37725);const P=(0,h.makeStyles)({popoverList:{minWidth:260,maxWidth:400},menuItem:{whiteSpace:"normal"}},{name:"BackstageSupportButton"}),S=({icon:e})=>{const t=(0,s.useApp)(),n=e?t.getSystemIcon(e)??k:k;return(0,a.jsx)(n,{})},C=({link:e})=>(0,a.jsx)(w.N_,{to:e.url,children:e.title??e.url}),q=({item:e})=>(0,a.jsxs)(u.A,{button:!1,children:[(0,a.jsx)(c.A,{children:(0,a.jsx)(S,{icon:e.icon})}),(0,a.jsx)(d.A,{primary:e.title,secondary:e.links?.reduce((e,t,n)=>[...e,n>0&&(0,a.jsx)("br",{},n),(0,a.jsx)(C,{link:t},t.url)],[])})]});function I(e){const{t}=(0,x.i)(A.O),{title:n,items:c,children:d}=e,{items:h}=function(){const e=(0,s.useApiHolder)().get(s.configApiRef),t=e?.getOptionalConfig("app.support"),n=j();return t?{url:t.getString("url"),items:t.getConfigArray("items").flatMap(e=>({title:e.getString("title"),icon:e.getOptionalString("icon"),links:(e.getOptionalConfigArray("links")??[]).flatMap(e=>({url:e.getString("url"),title:e.getOptionalString("title")??""}))}))}:n}(),[y,b]=(0,f.useState)(!1),[w,S]=(0,f.useState)(null),C=P(),I=(0,s.useApi)(s.configApiRef).getOptionalConfig("app.support"),R=(0,g.A)(e=>e.breakpoints.down("sm")),$=e=>{S(e.currentTarget),b(!0)},z=()=>{b(!1)};return I?(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(r.A,{display:"flex",ml:1,children:R?(0,a.jsx)(l.A,{color:"primary",size:"small",onClick:$,"data-testid":"support-button","aria-label":"Support",children:(0,a.jsx)(k,{})}):(0,a.jsx)(i.A,{"data-testid":"support-button","aria-label":"Support",color:"primary",onClick:$,startIcon:(0,a.jsx)(k,{}),children:t("supportButton.title")})}),(0,a.jsxs)(m.Ay,{"data-testid":"support-button-popover",open:y,anchorEl:w,anchorOrigin:{vertical:"bottom",horizontal:"right"},transformOrigin:{vertical:"top",horizontal:"right"},onClose:z,children:[(0,a.jsxs)(p.A,{className:C.popoverList,autoFocusItem:Boolean(w),children:[n&&(0,a.jsx)(u.A,{button:!1,alignItems:"flex-start",className:C.menuItem,children:(0,a.jsx)(v.A,{variant:"subtitle1",children:n})}),f.Children.map(d,(e,t)=>(0,a.jsx)(u.A,{button:!1,alignItems:"flex-start",className:C.menuItem,children:e},`child-${t}`)),(c??h).map((e,t)=>(0,a.jsx)(q,{item:e},`item-${t}`))]}),(0,a.jsx)(o.A,{children:(0,a.jsx)(i.A,{color:"primary",onClick:z,"aria-label":"Close",children:t("supportButton.close")})})]})]}):null}},46299:(e,t,n)=>{n.d(t,{S:()=>a});const a=e=>{const t={border:"none"};switch(e){case"Approved":return{...t,backgroundColor:"#4caf50",color:"#fff"};case"Rejected":return{...t,backgroundColor:"#f44336",color:"#fff"};default:return{...t,backgroundColor:"#ff9800",color:"#fff"}}}},55429:(e,t,n)=>{var a=n(4293),s=n(78920);t.A=void 0;var r=s(n(95478)),i=(0,a(n(74044)).default)(r.createElement("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z"}),"CheckCircle");t.A=i},91638:(e,t,n)=>{var a=n(85608),s=n(95478),r=a.__importDefault(n(5030));t.A=function(e,t){void 0===t&&(t=[]);var n=r.default(e,t,{loading:!0}),a=n[0],i=n[1];return s.useEffect(function(){i()},[i]),a}}}]);
2
+ //# sourceMappingURL=6813.036a322f.chunk.js.map