@kong-ui-public/entities-gateway-services 3.11.30-pr.2196.4ae50c01a.0 → 3.11.31-pr.2030.0e42f58dc.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/package.json +5 -5
  2. package/dist/entities-gateway-services.es.js +0 -2386
  3. package/dist/entities-gateway-services.umd.js +0 -1
  4. package/dist/style.css +0 -1
  5. package/dist/types/components/GatewayServiceConfigCard.vue.d.ts +0 -62
  6. package/dist/types/components/GatewayServiceConfigCard.vue.d.ts.map +0 -1
  7. package/dist/types/components/GatewayServiceForm.vue.d.ts +0 -101
  8. package/dist/types/components/GatewayServiceForm.vue.d.ts.map +0 -1
  9. package/dist/types/components/GatewayServiceList.vue.d.ts +0 -136
  10. package/dist/types/components/GatewayServiceList.vue.d.ts.map +0 -1
  11. package/dist/types/components/LegacyGatewayServiceForm.vue.d.ts +0 -86
  12. package/dist/types/components/LegacyGatewayServiceForm.vue.d.ts.map +0 -1
  13. package/dist/types/composables/getPortFromProtocol.d.ts +0 -4
  14. package/dist/types/composables/getPortFromProtocol.d.ts.map +0 -1
  15. package/dist/types/composables/index.d.ts +0 -10
  16. package/dist/types/composables/index.d.ts.map +0 -1
  17. package/dist/types/composables/useI18n.d.ts +0 -9
  18. package/dist/types/composables/useI18n.d.ts.map +0 -1
  19. package/dist/types/composables/useUrlValidators.d.ts +0 -8
  20. package/dist/types/composables/useUrlValidators.d.ts.map +0 -1
  21. package/dist/types/constants.d.ts +0 -15
  22. package/dist/types/constants.d.ts.map +0 -1
  23. package/dist/types/gateway-services-endpoints.d.ts +0 -24
  24. package/dist/types/gateway-services-endpoints.d.ts.map +0 -1
  25. package/dist/types/index.d.ts +0 -8
  26. package/dist/types/index.d.ts.map +0 -1
  27. package/dist/types/types/gateway-service-config-card.d.ts +0 -28
  28. package/dist/types/types/gateway-service-config-card.d.ts.map +0 -1
  29. package/dist/types/types/gateway-service-form.d.ts +0 -75
  30. package/dist/types/types/gateway-service-form.d.ts.map +0 -1
  31. package/dist/types/types/gateway-service-list.d.ts +0 -36
  32. package/dist/types/types/gateway-service-list.d.ts.map +0 -1
  33. package/dist/types/types/index.d.ts +0 -4
  34. package/dist/types/types/index.d.ts.map +0 -1
  35. package/dist/types/utils/index.d.ts +0 -2
  36. package/dist/types/utils/index.d.ts.map +0 -1
  37. package/dist/types/utils/urlValidator.d.ts +0 -4
  38. package/dist/types/utils/urlValidator.d.ts.map +0 -1
@@ -1,2386 +0,0 @@
1
- import { defineComponent as Le, computed as k, ref as D, watch as Fe, onBeforeMount as tt, resolveComponent as W, openBlock as S, createElementBlock as $, createVNode as d, unref as l, createSlots as Te, withCtx as m, createBlock as $e, Teleport as je, createElementVNode as I, createCommentVNode as M, createTextVNode as Z, toDisplayString as P, withModifiers as De, reactive as Me, onMounted as He, renderSlot as Ze, Transition as We, Fragment as lt, renderList as ot } from "vue";
2
- import { useRouter as qe } from "vue-router";
3
- import { BookIcon as ze, AddIcon as it, ServicesIcon as rt } from "@kong/icons";
4
- import { createI18n as st, i18nTComponent as at } from "@kong-ui-public/i18n";
5
- import { useAxios as Ge, useTableState as nt, useFetcher as ct, useDeleteUrlBuilder as dt, FetcherStatus as ut, EntityBaseTable as ft, EntityFilter as pt, PermissionsWrapper as Ue, TableTags as mt, EntityEmptyState as vt, EntityToggleModal as gt, EntityDeleteModal as yt, EntityTypes as _t, useErrors as Je, useValidators as Qe, EntityBaseFormType as Be, useGatewayFeatureSupported as Xe, EntityBaseForm as Ye, SupportedEntityType as Oe, EntityFormSection as Ke, useHelpers as et, ConfigurationSchemaSection as Ae, ConfigurationSchemaType as bt, EntityBaseConfigCard as ht } from "@kong-ui-public/entities-shared";
6
- const wt = {
7
- create: "New gateway service",
8
- serverless_create: "Add a Service",
9
- copy_id: "Copy ID",
10
- copy_json: "Copy JSON",
11
- edit: "Edit",
12
- clear: "Clear",
13
- view: "View Details",
14
- delete: {
15
- title: "Delete a Gateway Service",
16
- description: "Deleting this Gateway Service will also remove any associated plugins. This action cannot be reversed.",
17
- menu_label: "Delete"
18
- }
19
- }, kt = {
20
- placeholder: {
21
- konnect: "Filter by name",
22
- kongManager: "Filter by exact name or ID"
23
- }
24
- }, Vt = {
25
- title: "Gateway Services",
26
- list: {
27
- toolbar_actions: {
28
- new_gateway_service: "New gateway service"
29
- },
30
- table_headers: {
31
- name: "Name",
32
- control_plane: "Control Plane",
33
- protocol: "Protocol",
34
- host: "Host",
35
- port: "Port",
36
- path: "Path",
37
- enabled: "Enabled",
38
- tags: "Tags",
39
- id: "ID",
40
- created_at: "Created At",
41
- updated_at: "Last Modified"
42
- },
43
- empty_state: {
44
- title: "Configure a New Gateway Service",
45
- description: "Gateway services are used to proxy traffic.",
46
- serverless_title: "Configure your first Gateway Service"
47
- }
48
- },
49
- empty_state_v2: {
50
- create: "New gateway service",
51
- title: "Configure your first gateway service",
52
- group: "Services created in gateways within this group will automatically appear here.",
53
- description: "Gateway services represent backend APIs or microservices that receive traffic routed through the gateway."
54
- },
55
- form: {
56
- buttons: {
57
- try_sample: "Try sample API"
58
- },
59
- errors: {
60
- host: {
61
- empty: "Host cannot be empty",
62
- invalid: "Invalid host"
63
- },
64
- port: {
65
- type: "Port must be a number",
66
- invalid: "Port must be between 0 and 65535"
67
- },
68
- path: {
69
- prefix: "Path must begin with /",
70
- invalid: "Path should not include characters outside of the reserved list of RFC 3986"
71
- },
72
- protocol: {
73
- empty: "Protocol cannot be empty",
74
- invalid: "Protocol - value must be one of http, https, grpc, grpcs, tcp, udp, tls, tls_passthrough, ws, wss"
75
- },
76
- url: {
77
- invalid: "The URL must follow a valid format. Example: https://api.kong-air.com/flights"
78
- }
79
- },
80
- sections: {
81
- general: {
82
- title: "General Information",
83
- description: "Provide a name and tags to help identify and manage this service."
84
- },
85
- keys: {
86
- title: "Service endpoint",
87
- description: "Define where this service should send requests.",
88
- checkedGroupLabel: "Choose how and where to send traffic",
89
- urlLabel: "Full URL",
90
- checkedGroupAltLabel: "Protocol, host, port and path",
91
- url: {
92
- label: "Full URL",
93
- description: "Define the service using a single, complete API URL for simple setup."
94
- },
95
- protocol: {
96
- label: "Protocol, host, port, and path",
97
- description: "Manually specify each component of the API’s URL for advanced configurations."
98
- },
99
- viewAdvancedFields: "View advanced fields"
100
- }
101
- },
102
- fields: {
103
- upstream_url: {
104
- label: "Full URL",
105
- placeholder: "e.g. https://api.kong-air.com/flights",
106
- tooltip_for_konnect: "This is the URL of the API you will manage in Konnect.",
107
- tooltip_for_km: "This is the URL of the API you will manage in Kong Gateway."
108
- },
109
- name: {
110
- label: "Name",
111
- placeholder: "Enter a unique name",
112
- tooltip: "The Service name."
113
- },
114
- protocol: {
115
- label: "Protocol",
116
- tooltip: "The protocol used to communicate with the upstream.",
117
- options: {
118
- http: "http",
119
- https: "https",
120
- tcp: "tcp",
121
- tls: "tls",
122
- tls_passthrough: "tls_passthrough",
123
- grpc: "grpc",
124
- grpcs: "grpcs",
125
- ws: "ws",
126
- wss: "wss",
127
- udp: "udp"
128
- }
129
- },
130
- host: {
131
- label: "Host",
132
- placeholder: "e.g. api.kong-air.com",
133
- tooltip: "The host of the upstream server. Note that the host value is case sensitive."
134
- },
135
- path: {
136
- label: "Path",
137
- placeholder: "e.g. /sample",
138
- tooltip: "The path to be used in request to the upstream server."
139
- },
140
- port: {
141
- label: "Port",
142
- tooltip: "The upstream server port."
143
- },
144
- retries: {
145
- label: "Retries",
146
- tooltip: "The number of retries to execute upon failure to proxy."
147
- },
148
- connect_timeout: {
149
- label: "Connection timeout",
150
- tooltip: "The timeout in milliseconds for establishing a connection to the upstream server."
151
- },
152
- write_timeout: {
153
- label: "Write timeout",
154
- tooltip: "The timeout in milliseconds between two successive write operations for transmitting a request to the upstream server."
155
- },
156
- read_timeout: {
157
- label: "Read timeout",
158
- tooltip: "The timeout in milliseconds between two successive read operations for transmitting a request to the upstream server."
159
- },
160
- client_certificate: {
161
- label: "Client certificate",
162
- placeholder: "Enter a Certificate ID",
163
- tooltip: "Certificate to be used as client certificate while TLS handshaking to the upstream server."
164
- },
165
- ca_certificates: {
166
- label: "CA certificates",
167
- placeholder: "Enter a comma separated list of CA Certificate IDs",
168
- tooltip: "Array of {code1} object UUIDs that are used to build the trust store while verifying upstream server's TLS certificate. If set to {code2} when Nginx default is respected. If default CA list in Nginx are not specified and TLS verification is enabled, then handshake with upstream server will always fail (because no CA are trusted).",
169
- code1: "CA Certificate",
170
- code2: "null"
171
- },
172
- tls_verify_enabled: {
173
- label: "TLS verify",
174
- help: "If unchecked, use default system setting",
175
- tooltip: "Whether to enable verification of upstream server TLS certificate. If set to {code1}, then the Nginx default is respected.",
176
- code1: "null"
177
- },
178
- tls_verify_option: {
179
- unset: {
180
- display: "Use default system setting"
181
- },
182
- true: {
183
- label: "True",
184
- display: "On"
185
- },
186
- false: {
187
- label: "False",
188
- display: "Off"
189
- }
190
- },
191
- tags: {
192
- label: "Tags",
193
- tooltip: "An optional set of strings associated with the Service for grouping and filtering.",
194
- placeholder: "Enter a list of tags separated by comma",
195
- help: "e.g. tag1, tag2, tag3",
196
- collapse: "Add tags"
197
- },
198
- enabled: {
199
- label: "Enabled",
200
- tooltip: "Whether the Service is active. If set to {false}, the proxy behavior will be as if any routes attached to it do not exist (404). Default: {true}.",
201
- false: "false",
202
- true: "true"
203
- }
204
- }
205
- }
206
- }, Ct = {
207
- general: "Gateway Services could not be retrieved",
208
- delete: "The gateway service could not be deleted at this time.",
209
- copy: "Failed to copy to clipboard",
210
- urlErrorMessage: "Error: invalid URL"
211
- }, St = {
212
- success: "Copied {val} to clipboard",
213
- success_brief: "Successfully copied to clipboard"
214
- }, It = {
215
- gateway_services: "gateway services"
216
- }, Pt = {
217
- actions: wt,
218
- search: kt,
219
- gateway_services: Vt,
220
- errors: Ct,
221
- copy: St,
222
- glossary: It
223
- };
224
- function Et() {
225
- const n = st("en-us", Pt);
226
- return {
227
- i18n: n,
228
- i18nT: at(n)
229
- // Translation component <i18n-t>
230
- };
231
- }
232
- function Ut() {
233
- return {
234
- getPortFromProtocol: (X, _) => {
235
- const v = [80, 443], a = Number(_);
236
- if ((a || a === 0) && !v.includes(a))
237
- return a;
238
- switch (X) {
239
- case "grpcs":
240
- case "tls":
241
- case "https":
242
- case "wss":
243
- return 443;
244
- case "grpc":
245
- case "tcp":
246
- case "http":
247
- case "ws":
248
- default:
249
- return 80;
250
- }
251
- }
252
- };
253
- }
254
- function $t() {
255
- const { i18n: { t: n } } = se.useI18n();
256
- return {
257
- validateHost: (h) => {
258
- if (!h || h.trim() === "") return n("gateway_services.form.errors.host.empty");
259
- const L = /^(?!:\/\/)([a-zA-Z0-9]([a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(\.([a-zA-Z0-9]([a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?))*)(\.[a-zA-Z]{1,63})?$/;
260
- return /^((25[0-5]|2[0-4][0-9]|[0-1]?[0-9]?[0-9])\.){3}(25[0-5]|2[0-4][0-9]|[0-1]?[0-9]?[0-9])$/.test(h) || L.test(h) ? "" : n("gateway_services.form.errors.host.invalid");
261
- },
262
- validateProtocol: (h, L) => !h || h.trim() === "" ? n("gateway_services.form.errors.protocol.empty") : (h = h.slice(0, -1), L.find((r) => {
263
- if (r.value === h) return r;
264
- }) === void 0 ? n("gateway_services.form.errors.protocol.invalid") : ""),
265
- validatePath: (h) => !h || h === "" ? "" : h.startsWith("/") ? /[^A-Za-z0-9\-._~:/?#[\]@!$&'()*+,;=%]/.test(h) ? n("gateway_services.form.errors.path.invalid") : "" : n("gateway_services.form.errors.path.prefix"),
266
- validatePort: (h) => {
267
- if (h == null || h === "")
268
- return "";
269
- const L = typeof h == "string" ? parseInt(h, 10) : h;
270
- return isNaN(L) ? n("gateway_services.form.errors.port.type") : L < 0 || L > 65535 ? n("gateway_services.form.errors.port.invalid") : "";
271
- }
272
- };
273
- }
274
- const se = {
275
- useI18n: Et,
276
- usePortFromProtocol: Ut,
277
- useUrlValidators: $t
278
- }, xe = "/v2/control-planes/{controlPlaneId}/core-entities", Re = "/{workspace}", pe = {
279
- list: {
280
- konnect: {
281
- all: `${xe}/services`
282
- },
283
- kongManager: {
284
- all: `${Re}/services`
285
- }
286
- },
287
- form: {
288
- konnect: {
289
- create: `${xe}/services`,
290
- validate: `${xe}/v1/schemas/json/service/validate`,
291
- edit: `${xe}/services/{id}`
292
- },
293
- kongManager: {
294
- create: `${Re}/services`,
295
- validate: `${Re}/schemas/services/validate`,
296
- edit: `${Re}/services/{id}`
297
- }
298
- }
299
- }, Ft = "#00abd2", At = "24px", xt = { class: "kong-ui-entities-gateway-services-list" }, Rt = { class: "button-row" }, Tt = { class: "empty-state-icon-gateway" }, Mt = { key: 1 }, Bt = /* @__PURE__ */ Le({
300
- __name: "GatewayServiceList",
301
- props: {
302
- /** The base konnect or kongManger config. Pass additional config props in the shared entity component as needed. */
303
- config: {
304
- type: Object,
305
- required: !0,
306
- validator: (n) => !(!n || !["konnect", "kongManager"].includes(n == null ? void 0 : n.app) || !n.createRoute || !n.getViewRoute || !n.getEditRoute || n.app === "kongManager" && !n.isExactMatch && !n.filterSchema)
307
- },
308
- // used to override the default identifier for the cache entry
309
- cacheIdentifier: {
310
- type: String,
311
- default: ""
312
- },
313
- /** A synchronous or asynchronous function, that returns a boolean, that evaluates if the user can create a new entity */
314
- canCreate: {
315
- type: Function,
316
- required: !1,
317
- default: async () => !0
318
- },
319
- /** A synchronous or asynchronous function, that returns a boolean, that evaluates if the user can delete a given entity */
320
- canDelete: {
321
- type: Function,
322
- required: !1,
323
- default: async () => !0
324
- },
325
- /** A synchronous or asynchronous function, that returns a boolean, that evaluates if the user can edit a given entity */
326
- canEdit: {
327
- type: Function,
328
- required: !1,
329
- default: async () => !0
330
- },
331
- /** A synchronous or asynchronous function, that returns a boolean, that evaluates if the user can retrieve (view details) a given entity */
332
- canRetrieve: {
333
- type: Function,
334
- required: !1,
335
- default: async () => !0
336
- },
337
- /** default to false, setting to true will teleport the toolbar button to the destination in the consuming app */
338
- useActionOutside: {
339
- type: Boolean,
340
- default: !1
341
- },
342
- /** user is onboarding, use onboarding text */
343
- isServerless: {
344
- type: Boolean,
345
- default: !1
346
- },
347
- /**
348
- * Enables the new empty state design, this prop can be removed when
349
- * the khcp-14756-empty-states-m2 FF is removed.
350
- */
351
- enableV2EmptyStates: {
352
- type: Boolean,
353
- default: !1
354
- }
355
- },
356
- emits: ["error", "click:learn-more", "copy:success", "copy:error", "delete:success", "toggle:success"],
357
- setup(n, { emit: X }) {
358
- var c;
359
- const _ = X, v = n, { i18n: { t: a, formatUnixTimeStamp: h } } = se.useI18n(), L = qe(), { axiosInstance: Q } = Ge((c = v.config) == null ? void 0 : c.axiosRequestConfig), { hasRecords: r, handleStateChange: j } = nt(() => N.value), A = k(() => r.value && v.config.app === "konnect"), Se = k(() => !v.enableV2EmptyStates && v.config.app === "konnect"), be = k(() => v.config.app !== "kongManager" || !!v.config.disableSorting), Y = {
360
- // the Name column is non-hidable
361
- name: { label: a("gateway_services.list.table_headers.name"), searchable: !0, sortable: !0, hidable: !1 },
362
- ...v.config.showControlPlaneColumn ? { control_plane: { label: a("gateway_services.list.table_headers.control_plane") } } : {},
363
- protocol: { label: a("gateway_services.list.table_headers.protocol"), searchable: !0, sortable: !0 },
364
- host: { label: a("gateway_services.list.table_headers.host"), searchable: !0, sortable: !0 },
365
- port: { label: a("gateway_services.list.table_headers.port"), searchable: !0, sortable: !0 },
366
- path: { label: a("gateway_services.list.table_headers.path"), searchable: !0, sortable: !0 },
367
- enabled: { label: a("gateway_services.list.table_headers.enabled"), searchable: !0, sortable: !0 },
368
- tags: { label: a("gateway_services.list.table_headers.tags"), sortable: !1 },
369
- updated_at: { label: a("gateway_services.list.table_headers.updated_at"), sortable: !0 },
370
- created_at: { label: a("gateway_services.list.table_headers.created_at"), sortable: !0 }
371
- }, he = {
372
- columnVisibility: {
373
- created_at: !1
374
- }
375
- }, ae = Y, x = k(() => {
376
- var p, C;
377
- let g = `${v.config.apiBaseUrl}${pe.list[v.config.app].all}`;
378
- return v.config.app === "konnect" ? g = g.replace(/{controlPlaneId}/gi, ((p = v.config) == null ? void 0 : p.controlPlaneId) || "") : v.config.app === "kongManager" && (g = g.replace(/\/{workspace}/gi, (C = v.config) != null && C.workspace ? `/${v.config.workspace}` : "")), g;
379
- }), me = k(() => v.config.apiBaseUrl.startsWith("/") ? new URL(`${window.location.origin}${x.value}`) : new URL(x.value)), N = D(""), Ie = k(() => {
380
- const g = v.config.app === "konnect" || v.config.isExactMatch;
381
- if (g)
382
- return {
383
- isExactMatch: g,
384
- placeholder: a(`search.placeholder.${v.config.app}`)
385
- };
386
- const { name: p, enabled: C, protocol: K, host: ue, port: G, path: fe } = Y;
387
- return {
388
- isExactMatch: g,
389
- fields: { name: p, enabled: C, protocol: K, host: ue, port: G, path: fe },
390
- schema: v.config.filterSchema
391
- };
392
- }), {
393
- fetcher: o,
394
- fetcherState: w,
395
- fetcherCacheKey: ie
396
- } = ct(k(() => ({ ...v.config, cacheIdentifier: v.cacheIdentifier })), x), ve = () => {
397
- N.value = "";
398
- }, we = () => {
399
- ie.value++;
400
- }, e = D(null), F = k(() => ({
401
- ctaPath: v.config.createRoute,
402
- ctaText: R.value ? v.isServerless ? a("actions.serverless_create") : a("actions.create") : void 0,
403
- message: `${a("gateway_services.list.empty_state.description")}${v.config.additionMessageForEmptyState ? ` ${v.config.additionMessageForEmptyState}` : ""}`,
404
- title: R.value ? v.isServerless ? a("gateway_services.list.empty_state.serverless_title") : a("gateway_services.list.empty_state.title") : a("gateway_services.title")
405
- })), ne = D(!1), q = D(null), re = k(() => {
406
- const g = {
407
- action: "disable",
408
- id: "",
409
- name: ""
410
- };
411
- if (q.value) {
412
- const { enabled: p, id: C, name: K } = q.value;
413
- g.action = p ? "disable" : "enable", g.id = C, g.name = K || C;
414
- }
415
- return g;
416
- }), Pe = (g) => {
417
- ne.value = !0, q.value = g;
418
- }, oe = () => {
419
- ne.value = !1, q.value = null;
420
- }, ke = async () => {
421
- var K, ue;
422
- if (!await ((K = v.canEdit) == null ? void 0 : K.call(v, q.value)) || !q.value)
423
- return;
424
- const p = `${me.value.href}/${q.value.id}`, C = !q.value.enabled;
425
- try {
426
- const { data: G } = ((ue = v.config) == null ? void 0 : ue.app) === "konnect" ? await Q.put(p, { ...q.value, enabled: C }) : await Q.patch(p, { ...q.value, enabled: C });
427
- _("toggle:success", G), q.value.enabled = C;
428
- } catch (G) {
429
- _("error", G);
430
- }
431
- }, Ve = (g) => {
432
- v.config.getControlPlaneRoute && L.push(v.config.getControlPlaneRoute(g));
433
- }, ce = async (g, p) => {
434
- const C = g.id;
435
- if (!await p(C)) {
436
- _("copy:error", {
437
- entity: g,
438
- field: "id",
439
- message: a("errors.copy")
440
- });
441
- return;
442
- }
443
- _("copy:success", {
444
- entity: g,
445
- field: "id",
446
- message: a("copy.success", { val: C })
447
- });
448
- }, ge = async (g, p) => {
449
- const C = JSON.stringify(g);
450
- if (!await p(C)) {
451
- _("copy:error", {
452
- entity: g,
453
- message: a("errors.copy")
454
- });
455
- return;
456
- }
457
- _("copy:success", {
458
- entity: g,
459
- message: a("copy.success_brief")
460
- });
461
- }, ye = async (g) => {
462
- var C;
463
- await ((C = v.canRetrieve) == null ? void 0 : C.call(v, g)) && L.push(v.config.getViewRoute(g.id));
464
- }, Ee = (g) => ({
465
- label: a("actions.view"),
466
- to: v.config.getViewRoute(g)
467
- }), ee = (g) => ({
468
- label: a("actions.edit"),
469
- to: v.config.getEditRoute(g)
470
- }), z = D(void 0), H = D(!1), te = D(!1), de = D(""), i = dt(v.config, x.value), u = (g) => {
471
- z.value = g, H.value = !0, de.value = "";
472
- }, V = () => {
473
- H.value = !1, z.value = void 0;
474
- }, J = async () => {
475
- var g, p, C;
476
- if ((g = z.value) != null && g.id) {
477
- te.value = !0;
478
- try {
479
- await Q.delete(i(z.value.id)), _("delete:success", z.value), V(), ie.value++;
480
- } catch (K) {
481
- de.value = ((C = (p = K.response) == null ? void 0 : p.data) == null ? void 0 : C.message) || K.message || a("errors.delete"), _("error", K);
482
- } finally {
483
- te.value = !1;
484
- }
485
- }
486
- }, B = () => {
487
- L.push(v.config.createRoute);
488
- };
489
- Fe(w, (g) => {
490
- var p, C, K;
491
- if (g.status === ut.Error) {
492
- e.value = {
493
- title: a("errors.general")
494
- }, (K = (C = (p = g.error) == null ? void 0 : p.response) == null ? void 0 : C.data) != null && K.message && (e.value.message = g.error.response.data.message), _("error", g.error);
495
- return;
496
- }
497
- e.value = null;
498
- });
499
- const R = D(!1);
500
- return tt(async () => {
501
- R.value = await v.canCreate();
502
- }), (g, p) => {
503
- const C = W("KButton"), K = W("KBadge"), ue = W("KInputSwitch"), G = W("KDropdownItem"), fe = W("KClipboardProvider");
504
- return S(), $("div", xt, [
505
- d(l(ft), {
506
- "cache-identifier": n.cacheIdentifier,
507
- "default-table-preferences": he,
508
- "disable-sorting": be.value,
509
- "empty-state-options": F.value,
510
- "enable-entity-actions": "",
511
- "error-message": e.value,
512
- fetcher: l(o),
513
- "fetcher-cache-key": l(ie),
514
- "pagination-type": "offset",
515
- "preferences-storage-key": "kong-ui-entities-gateway-services-list",
516
- query: N.value,
517
- "table-headers": l(ae),
518
- onClearSearchInput: ve,
519
- "onClick:row": p[5] || (p[5] = (b) => ye(b)),
520
- onSort: we,
521
- onState: l(j)
522
- }, Te({
523
- "toolbar-filter": m(() => [
524
- d(l(pt), {
525
- modelValue: N.value,
526
- "onUpdate:modelValue": p[0] || (p[0] = (b) => N.value = b),
527
- config: Ie.value
528
- }, null, 8, ["modelValue", "config"])
529
- ]),
530
- "toolbar-button": m(() => [
531
- (S(), $e(je, {
532
- disabled: !n.useActionOutside,
533
- to: "#kong-ui-app-page-header-action-button"
534
- }, [
535
- I("div", Rt, [
536
- A.value ? (S(), $e(C, {
537
- key: 0,
538
- appearance: "secondary",
539
- class: "open-learning-hub",
540
- "data-testid": "gateway-services-learn-more-button",
541
- icon: "",
542
- onClick: p[1] || (p[1] = (b) => g.$emit("click:learn-more"))
543
- }, {
544
- default: m(() => [
545
- d(l(ze), { decorative: "" })
546
- ]),
547
- _: 1
548
- })) : M("", !0),
549
- d(l(Ue), {
550
- "auth-function": () => n.canCreate()
551
- }, {
552
- default: m(() => [
553
- d(C, {
554
- appearance: "primary",
555
- "data-testid": "toolbar-add-gateway-service",
556
- size: n.useActionOutside ? "medium" : "large",
557
- to: n.config.createRoute
558
- }, {
559
- default: m(() => [
560
- d(l(it)),
561
- Z(" " + P(l(a)("gateway_services.list.toolbar_actions.new_gateway_service")), 1)
562
- ]),
563
- _: 1
564
- }, 8, ["size", "to"])
565
- ]),
566
- _: 1
567
- }, 8, ["auth-function"])
568
- ])
569
- ], 8, ["disabled"]))
570
- ]),
571
- name: m(({ rowValue: b }) => [
572
- I("b", null, P(b ?? "-"), 1)
573
- ]),
574
- control_plane: m(({ row: b }) => {
575
- var t;
576
- return [
577
- (t = b.x_meta) != null && t.cluster_id ? (S(), $e(K, {
578
- key: 0,
579
- tooltip: b.x_meta.cluster_id,
580
- "truncation-tooltip": "",
581
- onClick: De((s) => Ve(b.x_meta.cluster_id), ["stop"])
582
- }, {
583
- default: m(() => [
584
- Z(P(b.x_meta.cluster_id), 1)
585
- ]),
586
- _: 2
587
- }, 1032, ["tooltip", "onClick"])) : (S(), $("b", Mt, "-"))
588
- ];
589
- }),
590
- enabled: m(({ row: b }) => [
591
- d(l(Ue), {
592
- "auth-function": () => n.canEdit(b),
593
- "force-show": ""
594
- }, {
595
- default: m(({ isAllowed: t }) => [
596
- I("div", {
597
- onClick: p[4] || (p[4] = De(() => {
598
- }, ["stop"]))
599
- }, [
600
- d(ue, {
601
- modelValue: b.enabled,
602
- "onUpdate:modelValue": (s) => b.enabled = s,
603
- "data-testid": `row-${b.id}-toggle-input`,
604
- disabled: !t,
605
- onClick: De((s) => Pe(b), ["prevent"])
606
- }, null, 8, ["modelValue", "onUpdate:modelValue", "data-testid", "disabled", "onClick"])
607
- ])
608
- ]),
609
- _: 2
610
- }, 1032, ["auth-function"])
611
- ]),
612
- tags: m(({ rowValue: b }) => [
613
- d(l(mt), { tags: b }, null, 8, ["tags"])
614
- ]),
615
- created_at: m(({ rowValue: b }) => [
616
- Z(P(l(h)(b)), 1)
617
- ]),
618
- updated_at: m(({ row: b, rowValue: t }) => [
619
- Z(P(l(h)(t ?? b.created_at)), 1)
620
- ]),
621
- actions: m(({ row: b }) => [
622
- d(fe, null, {
623
- default: m(({ copyToClipboard: t }) => [
624
- d(G, {
625
- "data-testid": "action-entity-copy-id",
626
- onClick: (s) => ce(b, t)
627
- }, {
628
- default: m(() => [
629
- Z(P(l(a)("actions.copy_id")), 1)
630
- ]),
631
- _: 2
632
- }, 1032, ["onClick"])
633
- ]),
634
- _: 2
635
- }, 1024),
636
- d(fe, null, {
637
- default: m(({ copyToClipboard: t }) => [
638
- d(G, {
639
- "data-testid": "action-entity-copy-json",
640
- onClick: (s) => ge(b, t)
641
- }, {
642
- default: m(() => [
643
- Z(P(l(a)("actions.copy_json")), 1)
644
- ]),
645
- _: 2
646
- }, 1032, ["onClick"])
647
- ]),
648
- _: 2
649
- }, 1024),
650
- d(l(Ue), {
651
- "auth-function": () => n.canRetrieve(b)
652
- }, {
653
- default: m(() => [
654
- d(G, {
655
- "data-testid": "action-entity-view",
656
- "has-divider": "",
657
- item: Ee(b.id)
658
- }, null, 8, ["item"])
659
- ]),
660
- _: 2
661
- }, 1032, ["auth-function"]),
662
- d(l(Ue), {
663
- "auth-function": () => n.canEdit(b)
664
- }, {
665
- default: m(() => [
666
- d(G, {
667
- "data-testid": "action-entity-edit",
668
- item: ee(b.id)
669
- }, null, 8, ["item"])
670
- ]),
671
- _: 2
672
- }, 1032, ["auth-function"]),
673
- d(l(Ue), {
674
- "auth-function": () => n.canDelete(b)
675
- }, {
676
- default: m(() => [
677
- d(G, {
678
- danger: "",
679
- "data-testid": "action-entity-delete",
680
- "has-divider": "",
681
- onClick: (t) => u(b)
682
- }, {
683
- default: m(() => [
684
- Z(P(l(a)("actions.delete.menu_label")), 1)
685
- ]),
686
- _: 2
687
- }, 1032, ["onClick"])
688
- ]),
689
- _: 2
690
- }, 1032, ["auth-function"])
691
- ]),
692
- _: 2
693
- }, [
694
- !l(r) && Se.value ? {
695
- name: "outside-actions",
696
- fn: m(() => [
697
- (S(), $e(je, {
698
- disabled: !n.useActionOutside,
699
- to: "#kong-ui-app-page-header-action-button"
700
- }, [
701
- d(C, {
702
- appearance: "secondary",
703
- class: "open-learning-hub",
704
- "data-testid": "gateway-services-more-button",
705
- icon: "",
706
- onClick: p[2] || (p[2] = (b) => g.$emit("click:learn-more"))
707
- }, {
708
- default: m(() => [
709
- d(l(ze), { decorative: "" })
710
- ]),
711
- _: 1
712
- })
713
- ], 8, ["disabled"]))
714
- ]),
715
- key: "0"
716
- } : void 0,
717
- !N.value && n.enableV2EmptyStates && n.config.app === "konnect" ? {
718
- name: "empty-state",
719
- fn: m(() => {
720
- var b;
721
- return [
722
- d(l(vt), {
723
- "action-button-text": l(a)("gateway_services.empty_state_v2.create"),
724
- appearance: "secondary",
725
- "can-create": () => n.canCreate(),
726
- "data-testid": "gateway-services-entity-empty-state",
727
- description: l(a)("gateway_services.empty_state_v2.description"),
728
- "learn-more": n.config.app === "konnect",
729
- title: l(a)("gateway_services.empty_state_v2.title"),
730
- "onClick:create": B,
731
- "onClick:learnMore": p[3] || (p[3] = (t) => g.$emit("click:learn-more"))
732
- }, Te({
733
- image: m(() => [
734
- I("div", Tt, [
735
- d(l(rt), {
736
- color: l(Ft),
737
- size: l(At)
738
- }, null, 8, ["color", "size"])
739
- ])
740
- ]),
741
- _: 2
742
- }, [
743
- (b = n.config) != null && b.isControlPlaneGroup ? {
744
- name: "message",
745
- fn: m(() => [
746
- Z(P(l(a)("gateway_services.empty_state_v2.group")), 1)
747
- ]),
748
- key: "0"
749
- } : void 0
750
- ]), 1032, ["action-button-text", "can-create", "description", "learn-more", "title"])
751
- ];
752
- }),
753
- key: "1"
754
- } : void 0
755
- ]), 1032, ["cache-identifier", "disable-sorting", "empty-state-options", "error-message", "fetcher", "fetcher-cache-key", "query", "table-headers", "onState"]),
756
- d(l(gt), {
757
- action: re.value.action,
758
- "entity-id": re.value.id,
759
- "entity-name": re.value.name,
760
- "entity-type": l(a)("glossary.gateway_services"),
761
- "on-confirm": ke,
762
- visible: ne.value,
763
- onCancel: oe,
764
- onProceed: oe
765
- }, null, 8, ["action", "entity-id", "entity-name", "entity-type", "visible"]),
766
- d(l(yt), {
767
- "action-pending": te.value,
768
- description: l(a)("actions.delete.description"),
769
- "entity-name": z.value && (z.value.name || z.value.id),
770
- "entity-type": l(_t).GatewayService,
771
- error: de.value,
772
- title: l(a)("actions.delete.title"),
773
- visible: H.value,
774
- onCancel: V,
775
- onProceed: J
776
- }, null, 8, ["action-pending", "description", "entity-name", "entity-type", "error", "title", "visible"])
777
- ]);
778
- };
779
- }
780
- }), Ne = (n, X) => {
781
- const _ = n.__vccOpts || n;
782
- for (const [v, a] of X)
783
- _[v] = a;
784
- return _;
785
- }, Fl = /* @__PURE__ */ Ne(Bt, [["__scopeId", "data-v-210f19c5"]]), Kt = { class: "kong-ui-entities-gateway-service-form" }, Lt = { key: 0 }, Dt = { class: "gateway-service-form-traffic-label" }, Wt = { class: "gateway-service-form-margin-bottom" }, qt = {
786
- key: 0,
787
- class: "gateway-service-form-group-fields"
788
- }, Gt = {
789
- key: 1,
790
- class: "gateway-service-form-group-fields"
791
- }, Ot = { key: 0 }, Nt = { class: "gateway-service-form-margin-top" }, jt = { class: "gateway-service-form-margin-bottom" }, zt = { class: "gateway-service-form-margin-bottom" }, Ht = { class: "gateway-service-form-margin-bottom" }, Zt = { class: "gateway-service-form-margin-bottom" }, Jt = {
792
- key: 0,
793
- class: "gateway-service-form-margin-bottom"
794
- }, Qt = {
795
- key: 1,
796
- class: "gateway-service-form-margin-bottom"
797
- }, Xt = {
798
- key: 2,
799
- class: "gateway-service-form-margin-bottom"
800
- }, Yt = {
801
- key: 0,
802
- class: "checkbox-aligned-radio"
803
- }, el = {
804
- key: 1,
805
- class: "checkbox-aligned-radio"
806
- }, tl = /* @__PURE__ */ Le({
807
- __name: "LegacyGatewayServiceForm",
808
- props: {
809
- /** The base konnect or kongManger config. Pass additional config props in the shared entity component as needed. */
810
- config: {
811
- type: Object,
812
- required: !0,
813
- validator: (n) => !(!n || !["konnect", "kongManager"].includes(n == null ? void 0 : n.app) || n.app === "konnect" && !n.controlPlaneId || n.app === "kongManager" && typeof n.workspace != "string" || !n.cancelRoute)
814
- },
815
- /** If a valid Gateway Service ID is provided, it will put the form in Edit mode instead of Create */
816
- gatewayServiceId: {
817
- type: String,
818
- required: !1,
819
- default: ""
820
- },
821
- /** Whether show or hide EntityFormSection info column */
822
- hideSectionsInfo: {
823
- type: Boolean,
824
- required: !1,
825
- default: !1
826
- }
827
- },
828
- emits: ["update", "error", "url-valid:success", "url-valid:error", "loading", "model-updated"],
829
- setup(n, { expose: X, emit: _ }) {
830
- var de;
831
- const v = _, a = n, h = D(!0), L = qe(), { i18nT: Q, i18n: { t: r } } = se.useI18n(), { getMessageFromError: j } = Je(), { axiosInstance: A } = Ge((de = a.config) == null ? void 0 : de.axiosRequestConfig), Se = Qe(), be = k(() => pe.form[a.config.app].edit), Y = k(() => a.gatewayServiceId ? Be.Edit : Be.Create), he = D(!1), ae = k(() => !!a.gatewayServiceId), x = D(ae.value ? "protocol" : "url"), me = se.usePortFromProtocol(), N = D(""), Ie = k(() => !!N.value), o = Me({
832
- fields: {
833
- name: "",
834
- protocol: "http",
835
- host: "",
836
- path: "",
837
- port: 80,
838
- url: "",
839
- retries: 5,
840
- connect_timeout: 6e4,
841
- write_timeout: 6e4,
842
- read_timeout: 6e4,
843
- client_certificate: "",
844
- ca_certificates: "",
845
- tls_verify_enabled: !1,
846
- tls_verify_value: !1,
847
- tags: ""
848
- },
849
- isReadonly: !1,
850
- errorMessage: ""
851
- }), w = Me({
852
- name: "",
853
- protocol: "http",
854
- host: "",
855
- path: "",
856
- port: 80,
857
- url: "",
858
- retries: 5,
859
- connect_timeout: 6e4,
860
- write_timeout: 6e4,
861
- read_timeout: 6e4,
862
- client_certificate: "",
863
- ca_certificates: "",
864
- tls_verify_enabled: !1,
865
- tls_verify_value: !1,
866
- tags: ""
867
- }), ie = a.config.app === "konnect" || Xe({
868
- gatewayInfo: a.config.gatewayInfo,
869
- // 'ws' and 'wss' are not valid values for the protocol field in Gateway Community Edition or before Gateway Enterprise Edition 3.0
870
- supportedRange: {
871
- enterprise: ["3.0"]
872
- }
873
- }), ve = [
874
- {
875
- label: r("gateway_services.form.fields.protocol.options.http"),
876
- value: "http",
877
- group: "http"
878
- },
879
- {
880
- label: r("gateway_services.form.fields.protocol.options.https"),
881
- value: "https",
882
- group: "http"
883
- },
884
- {
885
- label: r("gateway_services.form.fields.protocol.options.tcp"),
886
- value: "tcp",
887
- group: "tcp"
888
- },
889
- {
890
- label: r("gateway_services.form.fields.protocol.options.tls"),
891
- value: "tls",
892
- group: "tcp"
893
- },
894
- {
895
- label: r("gateway_services.form.fields.protocol.options.tls_passthrough"),
896
- value: "tls_passthrough",
897
- group: "tcp"
898
- },
899
- {
900
- label: r("gateway_services.form.fields.protocol.options.grpc"),
901
- value: "grpc",
902
- group: "grpc"
903
- },
904
- {
905
- label: r("gateway_services.form.fields.protocol.options.grpcs"),
906
- value: "grpcs",
907
- group: "grpc"
908
- },
909
- ...ie ? [
910
- {
911
- label: r("gateway_services.form.fields.protocol.options.ws"),
912
- value: "ws",
913
- group: "websocket"
914
- },
915
- {
916
- label: r("gateway_services.form.fields.protocol.options.wss"),
917
- value: "wss",
918
- group: "websocket"
919
- }
920
- ] : [],
921
- {
922
- label: r("gateway_services.form.fields.protocol.options.udp"),
923
- value: "udp",
924
- group: "udp"
925
- }
926
- ], we = { url: "url", protocol: "protocol" }, e = (i, u) => {
927
- u.value;
928
- }, F = (i) => i ? parseFloat(i) : 0, ne = () => {
929
- h.value = !0, o.errorMessage = "", o.fields.host = w.host, o.fields.path = w.path, o.fields.port = w.port, o.fields.protocol = w.protocol, o.fields.url = w.url, o.fields.retries = w.retries, o.fields.connect_timeout = w.connect_timeout, o.fields.write_timeout = w.write_timeout, o.fields.read_timeout = w.read_timeout, o.fields.client_certificate = w.client_certificate, o.fields.ca_certificates = w.ca_certificates, o.fields.tls_verify_enabled = w.tls_verify_enabled, o.fields.tls_verify_value = w.tls_verify_value;
930
- }, q = () => {
931
- if (o.fields.url && x.value === "url")
932
- try {
933
- const i = new URL(o.fields.url);
934
- o.errorMessage = "", o.fields.protocol = i.protocol.slice(0, -1), o.fields.host = i.hostname, o.fields.path = i.pathname;
935
- const u = Number(i.port);
936
- he.value = !!u, o.fields.port = u || me.getPortFromProtocol(o.fields.protocol), o.errorMessage = "", v("url-valid:success");
937
- } catch (i) {
938
- o.errorMessage = r("errors.urlErrorMessage"), v("url-valid:error", j(i));
939
- }
940
- else
941
- v("url-valid:success"), o.errorMessage = "";
942
- }, re = k(() => !["tcp", "tls", "tls_passthrough", "grpc", "grpcs", "udp"].includes(o.fields.protocol)), Pe = k(() => {
943
- if (x.value === "url")
944
- return !0;
945
- const i = ["https", "wss", "tls"].includes(o.fields.protocol);
946
- return x.value === "protocol" && i;
947
- }), oe = k(() => {
948
- if (x.value === "url")
949
- return !0;
950
- const i = ["https", "tls"].includes(o.fields.protocol);
951
- return x.value === "protocol" && i;
952
- }), ke = k(() => {
953
- if (x.value === "url")
954
- return !0;
955
- const i = ["https", "wss", "tls"].includes(o.fields.protocol);
956
- return x.value === "protocol" && i;
957
- }), Ve = (i) => {
958
- N.value = Se.utf8Name(i);
959
- }, ce = k(() => ae.value && JSON.stringify(o.fields) !== JSON.stringify(w) || x.value === "url" && !!o.fields.url || x.value === "protocol" && !!o.fields.host), ge = (i) => {
960
- var u, V, J;
961
- o.fields.name = (i == null ? void 0 : i.name) || "", o.fields.tags = ((u = i == null ? void 0 : i.tags) == null ? void 0 : u.join(", ")) || "", o.fields.protocol = (i == null ? void 0 : i.protocol) || "http", o.fields.path = (i == null ? void 0 : i.path) || "", o.fields.read_timeout = i != null && i.read_timeout || (i == null ? void 0 : i.read_timeout) === 0 ? i == null ? void 0 : i.read_timeout : 6e4, o.fields.retries = i != null && i.retries || (i == null ? void 0 : i.retries) === 0 ? i == null ? void 0 : i.retries : 5, o.fields.host = (i == null ? void 0 : i.host) || "", o.fields.connect_timeout = i != null && i.connect_timeout || (i == null ? void 0 : i.connect_timeout) === 0 ? i == null ? void 0 : i.connect_timeout : 6e4, o.fields.tls_verify_enabled = (i == null ? void 0 : i.tls_verify) !== "" && (i == null ? void 0 : i.tls_verify) !== null && (i == null ? void 0 : i.tls_verify) !== void 0, o.fields.tls_verify_value = i != null && i.tls_verify ? i == null ? void 0 : i.tls_verify : !1, o.fields.ca_certificates = ((V = i == null ? void 0 : i.ca_certificates) == null ? void 0 : V.join(",")) || "", o.fields.client_certificate = ((J = i == null ? void 0 : i.client_certificate) == null ? void 0 : J.id) || "", o.fields.write_timeout = i != null && i.write_timeout || (i == null ? void 0 : i.write_timeout) === 0 ? i == null ? void 0 : i.write_timeout : 6e4, o.fields.port = i != null && i.port || (i == null ? void 0 : i.port) === 0 ? i == null ? void 0 : i.port : 80, Object.assign(w, o.fields);
962
- }, ye = () => {
963
- L.push(a.config.cancelRoute);
964
- }, Ee = k(() => {
965
- var u, V;
966
- let i = `${a.config.apiBaseUrl}${pe.form[a.config.app].validate}`;
967
- return a.config.app === "konnect" ? i = i.replace(/{controlPlaneId}/gi, ((u = a.config) == null ? void 0 : u.controlPlaneId) || "") : a.config.app === "kongManager" && (i = i.replace(/\/{workspace}/gi, (V = a.config) != null && V.workspace ? `/${a.config.workspace}` : "")), i = i.replace(/{id}/gi, a.gatewayServiceId), i;
968
- }), ee = k(() => {
969
- var u, V;
970
- let i = `${a.config.apiBaseUrl}${pe.form[a.config.app][Y.value]}`;
971
- return a.config.app === "konnect" ? i = i.replace(/{controlPlaneId}/gi, ((u = a.config) == null ? void 0 : u.controlPlaneId) || "") : a.config.app === "kongManager" && (i = i.replace(/\/{workspace}/gi, (V = a.config) != null && V.workspace ? `/${a.config.workspace}` : "")), i = i.replace(/{id}/gi, a.gatewayServiceId), i;
972
- }), z = (i) => {
973
- let u = "";
974
- i.url && (u = new URL(i.url).protocol), (["https", "wss", "tls"].includes(i.protocol) || ["https", "wss", "tls"].includes(u)) && (i.tls_verify = i.tls_verify_enabled ? i.tls_verify_value : null), delete i.tls_verify_enabled, delete i.tls_verify_value;
975
- }, H = k(() => {
976
- var u, V, J, B;
977
- const i = {
978
- name: o.fields.name || null,
979
- tags: o.fields.tags ? (J = (V = (u = o.fields.tags) == null ? void 0 : u.split(",")) == null ? void 0 : V.map((R) => String(R || "").trim())) == null ? void 0 : J.filter((R) => R !== "") : null,
980
- protocol: o.fields.protocol,
981
- path: o.fields.path || null,
982
- read_timeout: o.fields.read_timeout,
983
- retries: o.fields.retries,
984
- host: o.fields.host,
985
- connect_timeout: o.fields.connect_timeout,
986
- tls_verify_value: o.fields.tls_verify_value,
987
- tls_verify_enabled: o.fields.tls_verify_enabled,
988
- ca_certificates: o.fields.ca_certificates ? (B = o.fields.ca_certificates) == null ? void 0 : B.split(",").filter((R) => R !== "") : null,
989
- client_certificate: o.fields.client_certificate ? { id: o.fields.client_certificate } : null,
990
- write_timeout: o.fields.write_timeout,
991
- port: o.fields.port,
992
- url: o.fields.url
993
- };
994
- return o.fields.client_certificate && ["https", "wss", "tls"].includes(o.fields.protocol) && (i.client_certificate = { id: o.fields.client_certificate }), o.fields.tls_verify_enabled && ["https", "wss", "tls"].includes(o.fields.protocol) && (i.tls_verify = o.fields.tls_verify_value), re.value || (i.path = null), Y.value === "create" ? x.value === "url" ? (delete i.protocol, delete i.host, delete i.path, a.config.app === "konnect" && delete i.port) : delete i.url : Y.value === "edit" && delete i.url, i;
995
- }), te = async () => {
996
- var i, u, V, J;
997
- try {
998
- o.isReadonly = !0, q();
999
- const B = H.value;
1000
- z(B);
1001
- let R;
1002
- if (await A.post(Ee.value, B), Y.value === "create" ? R = await A.post(ee.value, B) : Y.value === "edit" && (R = ((i = a.config) == null ? void 0 : i.app) === "konnect" ? await A.put(ee.value, B) : await A.patch(ee.value, B)), R) {
1003
- const { data: c } = R;
1004
- o.fields.name = (c == null ? void 0 : c.name) || "", o.fields.port = c.port || me.getPortFromProtocol(c.protocol), o.fields.protocol = (c == null ? void 0 : c.protocol) || "http", o.fields.host = (c == null ? void 0 : c.host) || "", o.fields.path = (c == null ? void 0 : c.path) || "", o.fields.url = (c == null ? void 0 : c.url) || "", o.fields.retries = c != null && c.retries || (c == null ? void 0 : c.retries) === 0 ? c == null ? void 0 : c.retries : 5, o.fields.connect_timeout = c != null && c.connect_timeout || (c == null ? void 0 : c.connect_timeout) === 0 ? c == null ? void 0 : c.connect_timeout : 6e4, o.fields.write_timeout = c != null && c.write_timeout || (c == null ? void 0 : c.write_timeout) === 0 ? c == null ? void 0 : c.write_timeout : 6e4, o.fields.read_timeout = c != null && c.read_timeout || (c == null ? void 0 : c.read_timeout) === 0 ? c == null ? void 0 : c.read_timeout : 6e4, o.fields.client_certificate = ((u = c == null ? void 0 : c.client_certificate) == null ? void 0 : u.id) || "", o.fields.ca_certificates = (V = c == null ? void 0 : c.ca_certificates) != null && V.length ? c == null ? void 0 : c.ca_certificates.join(",") : "", o.fields.tls_verify_enabled = (c == null ? void 0 : c.tls_verify) !== "" && (c == null ? void 0 : c.tls_verify) !== null && (c == null ? void 0 : c.tls_verify) !== void 0, o.fields.tls_verify_value = o.fields.tls_verify_enabled && (c == null ? void 0 : c.tls_verify), o.fields.tags = (J = c == null ? void 0 : c.tags) != null && J.length ? c.tags.join(", ") : "", Object.assign(w, o.fields), v("update", R == null ? void 0 : R.data);
1005
- }
1006
- return R;
1007
- } catch (B) {
1008
- o.errorMessage = j(B), v("error", B);
1009
- } finally {
1010
- o.isReadonly = !1;
1011
- }
1012
- };
1013
- return Fe(() => a.gatewayServiceId, () => {
1014
- Object.assign(o.fields, w);
1015
- }), Fe(o.fields, (i) => {
1016
- o.fields.port = me.getPortFromProtocol(i.protocol, String(i.port)), v("model-updated", H.value);
1017
- }), He(() => {
1018
- v("model-updated", H.value);
1019
- }), X({
1020
- validateUrl: q,
1021
- getPayload: H,
1022
- saveFormData: te,
1023
- canSubmit: ce,
1024
- initForm: ge
1025
- }), (i, u) => {
1026
- const V = W("KInput"), J = W("KLabel"), B = W("KRadio"), R = W("KSelect"), c = W("KCheckbox"), g = W("KCollapse");
1027
- return S(), $("div", Kt, [
1028
- d(l(Ye), {
1029
- "can-submit": ce.value,
1030
- config: n.config,
1031
- "edit-id": n.gatewayServiceId,
1032
- "entity-type": l(Oe).GatewayService,
1033
- "error-message": o.errorMessage,
1034
- "fetch-url": be.value,
1035
- "form-fields": H.value,
1036
- "is-readonly": o.isReadonly,
1037
- onCancel: ye,
1038
- "onFetch:error": u[25] || (u[25] = (p) => i.$emit("error", p)),
1039
- "onFetch:success": ge,
1040
- onLoading: u[26] || (u[26] = (p) => i.$emit("loading", p)),
1041
- onSubmit: te
1042
- }, {
1043
- "form-actions": m(() => [
1044
- Ze(i.$slots, "form-actions", {
1045
- canSubmit: ce.value,
1046
- cancel: ye,
1047
- submit: te
1048
- }, void 0, !0)
1049
- ]),
1050
- default: m(() => [
1051
- d(l(Ke), {
1052
- description: l(r)("gateway_services.form.sections.general.description"),
1053
- "hide-info-header": n.hideSectionsInfo,
1054
- title: l(r)("gateway_services.form.sections.general.title")
1055
- }, {
1056
- default: m(() => [
1057
- d(V, {
1058
- modelValue: o.fields.name,
1059
- "onUpdate:modelValue": u[0] || (u[0] = (p) => o.fields.name = p),
1060
- modelModifiers: { trim: !0 },
1061
- autocomplete: "off",
1062
- "data-testid": "gateway-service-name-input",
1063
- error: Ie.value,
1064
- "error-message": N.value,
1065
- label: l(r)("gateway_services.form.fields.name.label"),
1066
- "label-attributes": {
1067
- info: l(r)("gateway_services.form.fields.name.tooltip"),
1068
- tooltipAttributes: { maxWidth: "400" }
1069
- },
1070
- name: "name",
1071
- placeholder: l(r)("gateway_services.form.fields.name.placeholder"),
1072
- readonly: o.isReadonly,
1073
- type: "text",
1074
- onInput: Ve
1075
- }, null, 8, ["modelValue", "error", "error-message", "label", "label-attributes", "placeholder", "readonly"]),
1076
- d(V, {
1077
- modelValue: o.fields.tags,
1078
- "onUpdate:modelValue": u[1] || (u[1] = (p) => o.fields.tags = p),
1079
- modelModifiers: { trim: !0 },
1080
- autocomplete: "off",
1081
- "data-testid": "gateway-service-tags-input",
1082
- help: l(r)("gateway_services.form.fields.tags.help"),
1083
- label: l(r)("gateway_services.form.fields.tags.label"),
1084
- "label-attributes": {
1085
- info: l(r)("gateway_services.form.fields.tags.tooltip"),
1086
- tooltipAttributes: { maxWidth: "400" }
1087
- },
1088
- name: "tags",
1089
- placeholder: l(r)("gateway_services.form.fields.tags.placeholder"),
1090
- readonly: o.isReadonly,
1091
- type: "text"
1092
- }, null, 8, ["modelValue", "help", "label", "label-attributes", "placeholder", "readonly"])
1093
- ]),
1094
- _: 1
1095
- }, 8, ["description", "hide-info-header", "title"]),
1096
- d(l(Ke), {
1097
- description: l(r)("gateway_services.form.sections.keys.description"),
1098
- "hide-info-header": n.hideSectionsInfo,
1099
- title: l(r)("gateway_services.form.sections.keys.title")
1100
- }, {
1101
- default: m(() => [
1102
- ae.value ? M("", !0) : (S(), $("div", Lt, [
1103
- I("div", Dt, [
1104
- d(J, { required: "" }, {
1105
- default: m(() => [
1106
- Z(P(l(r)("gateway_services.form.sections.keys.checkedGroupLabel")), 1)
1107
- ]),
1108
- _: 1
1109
- })
1110
- ]),
1111
- I("div", Wt, [
1112
- d(B, {
1113
- modelValue: x.value,
1114
- "onUpdate:modelValue": u[2] || (u[2] = (p) => x.value = p),
1115
- "data-testid": "gateway-service-url-radio",
1116
- "selected-value": we.url,
1117
- onChange: ne
1118
- }, {
1119
- default: m(() => [
1120
- Z(P(l(r)("gateway_services.form.sections.keys.urlLabel")), 1)
1121
- ]),
1122
- _: 1
1123
- }, 8, ["modelValue", "selected-value"])
1124
- ]),
1125
- x.value === "url" ? (S(), $("div", qt, [
1126
- d(V, {
1127
- modelValue: o.fields.url,
1128
- "onUpdate:modelValue": u[3] || (u[3] = (p) => o.fields.url = p),
1129
- modelModifiers: { trim: !0 },
1130
- class: "gateway-service-url-input gateway-service-form-margin-bottom",
1131
- "data-testid": "gateway-service-url-input",
1132
- label: l(r)("gateway_services.form.fields.upstream_url.label"),
1133
- "label-attributes": {
1134
- info: n.config.app === "konnect" ? l(r)("gateway_services.form.fields.upstream_url.tooltip_for_konnect") : l(r)("gateway_services.form.fields.upstream_url.tooltip_for_km"),
1135
- tooltipAttributes: { maxWidth: "400" }
1136
- },
1137
- name: "url",
1138
- placeholder: l(r)("gateway_services.form.fields.upstream_url.placeholder"),
1139
- required: ""
1140
- }, null, 8, ["modelValue", "label", "label-attributes", "placeholder"])
1141
- ])) : M("", !0),
1142
- d(B, {
1143
- modelValue: x.value,
1144
- "onUpdate:modelValue": u[4] || (u[4] = (p) => x.value = p),
1145
- "checked-group": "protocol",
1146
- "data-testid": "gateway-service-protocol-radio",
1147
- "selected-value": we.protocol,
1148
- onChange: ne
1149
- }, {
1150
- default: m(() => [
1151
- Z(P(l(r)("gateway_services.form.sections.keys.checkedGroupAltLabel")), 1)
1152
- ]),
1153
- _: 1
1154
- }, 8, ["modelValue", "selected-value"])
1155
- ])),
1156
- x.value === "protocol" || ae.value ? (S(), $("div", Gt, [
1157
- d(R, {
1158
- modelValue: o.fields.protocol,
1159
- "onUpdate:modelValue": u[5] || (u[5] = (p) => o.fields.protocol = p),
1160
- "data-testid": "gateway-service-protocol-select",
1161
- items: ve,
1162
- label: l(r)("gateway_services.form.fields.protocol.label"),
1163
- "label-attributes": {
1164
- info: l(r)("gateway_services.form.fields.protocol.tooltip"),
1165
- tooltipAttributes: { maxWidth: "400" }
1166
- },
1167
- readonly: o.isReadonly,
1168
- required: "",
1169
- width: "100%",
1170
- onSelected: u[6] || (u[6] = (p) => e(o.fields.protocol, p))
1171
- }, null, 8, ["modelValue", "label", "label-attributes", "readonly"]),
1172
- d(V, {
1173
- modelValue: o.fields.host,
1174
- "onUpdate:modelValue": u[7] || (u[7] = (p) => o.fields.host = p),
1175
- modelModifiers: { trim: !0 },
1176
- class: "gateway-service-form-margin-top",
1177
- "data-testid": "gateway-service-host-input",
1178
- label: l(r)("gateway_services.form.fields.host.label"),
1179
- "label-attributes": {
1180
- info: l(r)("gateway_services.form.fields.host.tooltip"),
1181
- tooltipAttributes: { maxWidth: "400" }
1182
- },
1183
- name: "host",
1184
- placeholder: l(r)("gateway_services.form.fields.host.placeholder"),
1185
- required: ""
1186
- }, null, 8, ["modelValue", "label", "label-attributes", "placeholder"]),
1187
- re.value ? (S(), $("div", Ot, [
1188
- d(V, {
1189
- modelValue: o.fields.path,
1190
- "onUpdate:modelValue": u[8] || (u[8] = (p) => o.fields.path = p),
1191
- modelModifiers: { trim: !0 },
1192
- class: "gateway-service-form-margin-top",
1193
- "data-testid": "gateway-service-path-input",
1194
- label: l(r)("gateway_services.form.fields.path.label"),
1195
- "label-attributes": {
1196
- info: l(r)("gateway_services.form.fields.path.tooltip"),
1197
- tooltipAttributes: { maxWidth: "400" }
1198
- },
1199
- name: "path",
1200
- placeholder: l(r)("gateway_services.form.fields.path.placeholder")
1201
- }, null, 8, ["modelValue", "label", "label-attributes", "placeholder"])
1202
- ])) : M("", !0),
1203
- d(V, {
1204
- modelValue: o.fields.port,
1205
- "onUpdate:modelValue": [
1206
- u[9] || (u[9] = (p) => o.fields.port = p),
1207
- u[10] || (u[10] = () => {
1208
- o.fields.port = F(o.fields.port + "");
1209
- })
1210
- ],
1211
- class: "gateway-service-form-margin-top",
1212
- "data-testid": "gateway-service-port-input",
1213
- label: l(r)("gateway_services.form.fields.port.label"),
1214
- "label-attributes": {
1215
- info: l(r)("gateway_services.form.fields.port.tooltip"),
1216
- tooltipAttributes: { maxWidth: "400" }
1217
- },
1218
- name: "port",
1219
- type: "number"
1220
- }, null, 8, ["modelValue", "label", "label-attributes"])
1221
- ])) : M("", !0),
1222
- d(g, {
1223
- modelValue: h.value,
1224
- "onUpdate:modelValue": u[24] || (u[24] = (p) => h.value = p),
1225
- "data-testid": "advanced-fields-collapse",
1226
- "trigger-alignment": "leading",
1227
- "trigger-label": l(r)("gateway_services.form.sections.keys.viewAdvancedFields")
1228
- }, {
1229
- default: m(() => [
1230
- I("div", Nt, [
1231
- I("div", jt, [
1232
- d(V, {
1233
- modelValue: o.fields.retries,
1234
- "onUpdate:modelValue": [
1235
- u[11] || (u[11] = (p) => o.fields.retries = p),
1236
- u[12] || (u[12] = () => {
1237
- o.fields.retries = F(o.fields.retries + "");
1238
- })
1239
- ],
1240
- autocomplete: "off",
1241
- "data-testid": "gateway-service-retries-input",
1242
- label: l(r)("gateway_services.form.fields.retries.label"),
1243
- "label-attributes": {
1244
- info: l(r)("gateway_services.form.fields.retries.tooltip"),
1245
- tooltipAttributes: { maxWidth: "400" }
1246
- },
1247
- name: "retries",
1248
- readonly: o.isReadonly,
1249
- type: "number"
1250
- }, null, 8, ["modelValue", "label", "label-attributes", "readonly"])
1251
- ]),
1252
- I("div", zt, [
1253
- d(V, {
1254
- modelValue: o.fields.connect_timeout,
1255
- "onUpdate:modelValue": [
1256
- u[13] || (u[13] = (p) => o.fields.connect_timeout = p),
1257
- u[14] || (u[14] = () => {
1258
- o.fields.connect_timeout = F(o.fields.connect_timeout + "");
1259
- })
1260
- ],
1261
- autocomplete: "off",
1262
- "data-testid": "gateway-service-connTimeout-input",
1263
- label: l(r)("gateway_services.form.fields.connect_timeout.label"),
1264
- "label-attributes": {
1265
- info: l(r)("gateway_services.form.fields.connect_timeout.tooltip"),
1266
- tooltipAttributes: { maxWidth: "400" }
1267
- },
1268
- name: "connTimeout",
1269
- readonly: o.isReadonly,
1270
- type: "number"
1271
- }, null, 8, ["modelValue", "label", "label-attributes", "readonly"])
1272
- ]),
1273
- I("div", Ht, [
1274
- d(V, {
1275
- modelValue: o.fields.write_timeout,
1276
- "onUpdate:modelValue": [
1277
- u[15] || (u[15] = (p) => o.fields.write_timeout = p),
1278
- u[16] || (u[16] = () => {
1279
- o.fields.write_timeout = F(o.fields.write_timeout + "");
1280
- })
1281
- ],
1282
- autocomplete: "off",
1283
- "data-testid": "gateway-service-writeTimeout-input",
1284
- label: l(r)("gateway_services.form.fields.write_timeout.label"),
1285
- "label-attributes": {
1286
- info: l(r)("gateway_services.form.fields.write_timeout.tooltip"),
1287
- tooltipAttributes: { maxWidth: "400" }
1288
- },
1289
- name: "writeTimeout",
1290
- readonly: o.isReadonly,
1291
- type: "number"
1292
- }, null, 8, ["modelValue", "label", "label-attributes", "readonly"])
1293
- ]),
1294
- I("div", Zt, [
1295
- d(V, {
1296
- modelValue: o.fields.read_timeout,
1297
- "onUpdate:modelValue": [
1298
- u[17] || (u[17] = (p) => o.fields.read_timeout = p),
1299
- u[18] || (u[18] = () => {
1300
- o.fields.read_timeout = F(o.fields.read_timeout + "");
1301
- })
1302
- ],
1303
- autocomplete: "off",
1304
- "data-testid": "gateway-service-readTimeout-input",
1305
- label: l(r)("gateway_services.form.fields.read_timeout.label"),
1306
- "label-attributes": {
1307
- info: l(r)("gateway_services.form.fields.read_timeout.tooltip"),
1308
- tooltipAttributes: { maxWidth: "400" }
1309
- },
1310
- name: "readTimeout",
1311
- readonly: o.isReadonly,
1312
- type: "number"
1313
- }, null, 8, ["modelValue", "label", "label-attributes", "readonly"])
1314
- ]),
1315
- Pe.value ? (S(), $("div", Jt, [
1316
- d(V, {
1317
- modelValue: o.fields.client_certificate,
1318
- "onUpdate:modelValue": u[19] || (u[19] = (p) => o.fields.client_certificate = p),
1319
- modelModifiers: { trim: !0 },
1320
- autocomplete: "off",
1321
- "data-testid": "gateway-service-clientCert-input",
1322
- label: l(r)("gateway_services.form.fields.client_certificate.label"),
1323
- "label-attributes": {
1324
- info: l(r)("gateway_services.form.fields.client_certificate.tooltip"),
1325
- tooltipAttributes: { maxWidth: "400" }
1326
- },
1327
- name: "clientCert",
1328
- placeholder: l(r)("gateway_services.form.fields.client_certificate.placeholder"),
1329
- readonly: o.isReadonly,
1330
- type: "text"
1331
- }, null, 8, ["modelValue", "label", "label-attributes", "placeholder", "readonly"])
1332
- ])) : M("", !0),
1333
- oe.value ? (S(), $("div", Qt, [
1334
- d(V, {
1335
- modelValue: o.fields.ca_certificates,
1336
- "onUpdate:modelValue": u[20] || (u[20] = (p) => o.fields.ca_certificates = p),
1337
- modelModifiers: { trim: !0 },
1338
- autocomplete: "off",
1339
- "data-testid": "gateway-service-ca-certs-input",
1340
- label: l(r)("gateway_services.form.fields.ca_certificates.label"),
1341
- "label-attributes": { tooltipAttributes: { maxWidth: "400" } },
1342
- placeholder: l(r)("gateway_services.form.fields.ca_certificates.placeholder"),
1343
- readonly: o.isReadonly,
1344
- type: "text"
1345
- }, {
1346
- "label-tooltip": m(() => [
1347
- d(l(Q), {
1348
- keypath: "gateway_services.form.fields.ca_certificates.tooltip",
1349
- scope: "global"
1350
- }, {
1351
- code1: m(() => [
1352
- I("code", null, P(l(r)("gateway_services.form.fields.ca_certificates.code1")), 1)
1353
- ]),
1354
- code2: m(() => [
1355
- I("code", null, P(l(r)("gateway_services.form.fields.ca_certificates.code2")), 1)
1356
- ]),
1357
- _: 1
1358
- })
1359
- ]),
1360
- _: 1
1361
- }, 8, ["modelValue", "label", "placeholder", "readonly"])
1362
- ])) : M("", !0),
1363
- ke.value ? (S(), $("div", Xt, [
1364
- d(c, {
1365
- modelValue: o.fields.tls_verify_enabled,
1366
- "onUpdate:modelValue": u[21] || (u[21] = (p) => o.fields.tls_verify_enabled = p),
1367
- "data-testid": "gateway-service-tls-verify-checkbox",
1368
- description: l(r)("gateway_services.form.fields.tls_verify_enabled.help"),
1369
- label: l(r)("gateway_services.form.fields.tls_verify_enabled.label"),
1370
- "label-attributes": { tooltipAttributes: { maxWidth: "400" } }
1371
- }, {
1372
- tooltip: m(() => [
1373
- d(l(Q), {
1374
- keypath: "gateway_services.form.fields.tls_verify_enabled.tooltip",
1375
- scope: "global"
1376
- }, {
1377
- code1: m(() => [
1378
- I("code", null, P(l(r)("gateway_services.form.fields.tls_verify_enabled.code1")), 1)
1379
- ]),
1380
- _: 1
1381
- })
1382
- ]),
1383
- _: 1
1384
- }, 8, ["modelValue", "description", "label"]),
1385
- o.fields.tls_verify_enabled ? (S(), $("div", Yt, [
1386
- d(B, {
1387
- modelValue: o.fields.tls_verify_value,
1388
- "onUpdate:modelValue": u[22] || (u[22] = (p) => o.fields.tls_verify_value = p),
1389
- "data-testid": "gateway-service-tls-verify-true-option",
1390
- label: l(r)("gateway_services.form.fields.tls_verify_option.true.label"),
1391
- "selected-value": !0
1392
- }, null, 8, ["modelValue", "label"])
1393
- ])) : M("", !0),
1394
- o.fields.tls_verify_enabled ? (S(), $("div", el, [
1395
- d(B, {
1396
- modelValue: o.fields.tls_verify_value,
1397
- "onUpdate:modelValue": u[23] || (u[23] = (p) => o.fields.tls_verify_value = p),
1398
- "data-testid": "gateway-service-tls-verify-false-option",
1399
- label: l(r)("gateway_services.form.fields.tls_verify_option.false.label"),
1400
- "selected-value": !1
1401
- }, null, 8, ["modelValue", "label"])
1402
- ])) : M("", !0)
1403
- ])) : M("", !0)
1404
- ])
1405
- ]),
1406
- _: 1
1407
- }, 8, ["modelValue", "trigger-label"])
1408
- ]),
1409
- _: 1
1410
- }, 8, ["description", "hide-info-header", "title"])
1411
- ]),
1412
- _: 3
1413
- }, 8, ["can-submit", "config", "edit-id", "entity-type", "error-message", "fetch-url", "form-fields", "is-readonly"])
1414
- ]);
1415
- };
1416
- }
1417
- }), Al = /* @__PURE__ */ Ne(tl, [["__scopeId", "data-v-59d8e66b"]]), ll = { class: "kong-ui-gateway-service-entity-config-card" }, xl = /* @__PURE__ */ Le({
1418
- __name: "GatewayServiceConfigCard",
1419
- props: {
1420
- /** The base konnect or kongManger config. Pass additional config props in the shared entity component as needed. */
1421
- config: {
1422
- type: Object,
1423
- required: !0,
1424
- validator: (n) => !(!n || !["konnect", "kongManager"].includes(n == null ? void 0 : n.app) || n.app === "konnect" && !n.controlPlaneId || n.app === "kongManager" && typeof n.workspace != "string" || !n.entityId)
1425
- },
1426
- /**
1427
- * External link for documentation that determines visibility of Documentation button
1428
- */
1429
- configCardDoc: {
1430
- type: String,
1431
- default: "",
1432
- required: !1
1433
- },
1434
- /**
1435
- * Control visibility of card title content
1436
- */
1437
- hideTitle: {
1438
- type: Boolean,
1439
- default: !1
1440
- }
1441
- },
1442
- emits: ["loading", "fetch:error", "fetch:success"],
1443
- setup(n) {
1444
- const X = n, { i18n: { t: _ }, i18nT: v } = se.useI18n(), a = k(() => pe.form[X.config.app].edit), { getPropValue: h } = et(), L = (r, j) => h(r, j) === !0 ? _("gateway_services.form.fields.tls_verify_option.true.display") : _("gateway_services.form.fields.tls_verify_option.false.display"), Q = D({
1445
- id: {},
1446
- name: {
1447
- tooltip: _("gateway_services.form.fields.name.tooltip")
1448
- },
1449
- enabled: {},
1450
- updated_at: {},
1451
- created_at: {},
1452
- protocol: {
1453
- section: Ae.Basic,
1454
- tooltip: _("gateway_services.form.fields.protocol.tooltip")
1455
- },
1456
- host: {
1457
- section: Ae.Basic,
1458
- tooltip: _("gateway_services.form.fields.host.tooltip")
1459
- },
1460
- path: {
1461
- section: Ae.Basic,
1462
- tooltip: _("gateway_services.form.fields.path.tooltip")
1463
- },
1464
- port: {
1465
- section: Ae.Basic,
1466
- tooltip: _("gateway_services.form.fields.port.tooltip")
1467
- },
1468
- tags: {
1469
- tooltip: _("gateway_services.form.fields.tags.tooltip")
1470
- },
1471
- // advanced fields
1472
- retries: {
1473
- order: 1,
1474
- tooltip: _("gateway_services.form.fields.retries.tooltip")
1475
- },
1476
- connect_timeout: {
1477
- order: 2,
1478
- tooltip: _("gateway_services.form.fields.connect_timeout.tooltip")
1479
- },
1480
- write_timeout: {
1481
- order: 3,
1482
- tooltip: _("gateway_services.form.fields.write_timeout.tooltip")
1483
- },
1484
- read_timeout: {
1485
- order: 4,
1486
- tooltip: _("gateway_services.form.fields.read_timeout.tooltip")
1487
- },
1488
- client_certificate: {
1489
- order: 5,
1490
- tooltip: _("gateway_services.form.fields.client_certificate.tooltip")
1491
- },
1492
- ca_certificates: {
1493
- type: bt.BadgeTag,
1494
- label: _("gateway_services.form.fields.ca_certificates.label"),
1495
- order: 6
1496
- },
1497
- tls_verify: {
1498
- label: _("gateway_services.form.fields.tls_verify_enabled.label")
1499
- },
1500
- tls_verify_depth: {
1501
- hidden: !0
1502
- }
1503
- });
1504
- return (r, j) => (S(), $("div", ll, [
1505
- d(l(ht), {
1506
- config: n.config,
1507
- "config-card-doc": n.configCardDoc,
1508
- "config-schema": Q.value,
1509
- "entity-type": l(Oe).GatewayService,
1510
- "fetch-url": a.value,
1511
- "hide-title": n.hideTitle,
1512
- "onFetch:error": j[0] || (j[0] = (A) => r.$emit("fetch:error", A)),
1513
- "onFetch:success": j[1] || (j[1] = (A) => r.$emit("fetch:success", A)),
1514
- onLoading: j[2] || (j[2] = (A) => r.$emit("loading", A))
1515
- }, {
1516
- "enabled-label-tooltip": m(() => [
1517
- d(l(v), {
1518
- keypath: "gateway_services.form.fields.enabled.tooltip",
1519
- scope: "global"
1520
- }, {
1521
- false: m(() => [
1522
- I("code", null, P(l(_)("gateway_services.form.fields.enabled.false")), 1)
1523
- ]),
1524
- true: m(() => [
1525
- I("code", null, P(l(_)("gateway_services.form.fields.enabled.true")), 1)
1526
- ]),
1527
- _: 1
1528
- })
1529
- ]),
1530
- "ca_certificates-label-tooltip": m(() => [
1531
- d(l(v), {
1532
- keypath: "gateway_services.form.fields.ca_certificates.tooltip",
1533
- scope: "global"
1534
- }, {
1535
- code1: m(() => [
1536
- I("code", null, P(l(_)("gateway_services.form.fields.ca_certificates.code1")), 1)
1537
- ]),
1538
- code2: m(() => [
1539
- I("code", null, P(l(_)("gateway_services.form.fields.ca_certificates.code2")), 1)
1540
- ]),
1541
- _: 1
1542
- })
1543
- ]),
1544
- "tls_verify-label-tooltip": m(() => [
1545
- d(l(v), {
1546
- keypath: "gateway_services.form.fields.tls_verify_enabled.tooltip",
1547
- scope: "global"
1548
- }, {
1549
- code1: m(() => [
1550
- I("code", null, P(l(_)("gateway_services.form.fields.tls_verify_enabled.code1")), 1)
1551
- ]),
1552
- _: 1
1553
- })
1554
- ]),
1555
- tls_verify: m((A) => [
1556
- Z(P(typeof l(h)("rowValue", A) == "boolean" ? L("rowValue", A) : l(_)("gateway_services.form.fields.tls_verify_option.unset.display")), 1)
1557
- ]),
1558
- client_certificate: m((A) => [
1559
- Z(P(l(h)("rowValue", A) ? l(h)("rowValue", A).id : "–"), 1)
1560
- ]),
1561
- _: 1
1562
- }, 8, ["config", "config-card-doc", "config-schema", "entity-type", "fetch-url", "hide-title"])
1563
- ]));
1564
- }
1565
- }), le = {
1566
- name: "Kong-Air-Flights-API",
1567
- tags: [],
1568
- protocol: "https",
1569
- path: "/flights",
1570
- read_timeout: 6e4,
1571
- retries: 5,
1572
- host: "api.kong-air.com",
1573
- connect_timeout: 6e4,
1574
- ca_certificates: null,
1575
- client_certificate: null,
1576
- write_timeout: 6e4,
1577
- port: 443
1578
- }, ol = { class: "kong-ui-entities-gateway-service-form" }, il = {
1579
- key: 0,
1580
- class: "gateway-service-form-general-info"
1581
- }, rl = { class: "gateway-service-form-group-selection-wrapper" }, sl = {
1582
- key: 0,
1583
- class: "gateway-service-form-group-fields"
1584
- }, al = {
1585
- key: 0,
1586
- class: "gateway-service-form-group-fields"
1587
- }, nl = { key: 0 }, cl = {
1588
- key: 0,
1589
- class: "gateway-service-form-advanced-fields"
1590
- }, dl = { class: "gateway-service-form-margin-bottom" }, ul = { class: "gateway-service-form-margin-bottom" }, fl = { class: "gateway-service-form-margin-bottom" }, pl = { class: "gateway-service-form-margin-bottom" }, ml = {
1591
- key: 0,
1592
- class: "gateway-service-form-margin-bottom"
1593
- }, vl = {
1594
- key: 1,
1595
- class: "gateway-service-form-margin-bottom"
1596
- }, gl = {
1597
- key: 2,
1598
- class: "gateway-service-form-margin-bottom"
1599
- }, yl = {
1600
- key: 0,
1601
- class: "checkbox-aligned-radio"
1602
- }, _l = {
1603
- key: 1,
1604
- class: "checkbox-aligned-radio"
1605
- }, bl = { class: "gateway-service-form-tags" }, hl = { class: "form-error-list" }, wl = /* @__PURE__ */ Le({
1606
- __name: "GatewayServiceForm",
1607
- props: {
1608
- /** The base konnect or kongManger config. Pass additional config props in the shared entity component as needed. */
1609
- config: {
1610
- type: Object,
1611
- required: !0,
1612
- validator: (n) => !(!n || !["konnect", "kongManager"].includes(n == null ? void 0 : n.app) || n.app === "konnect" && !n.controlPlaneId || n.app === "kongManager" && typeof n.workspace != "string" || !n.cancelRoute)
1613
- },
1614
- /** If a valid Gateway Service ID is provided, it will put the form in Edit mode instead of Create */
1615
- gatewayServiceId: {
1616
- type: String,
1617
- required: !1,
1618
- default: ""
1619
- },
1620
- /** Whether show or hide EntityFormSection info column */
1621
- hideSectionsInfo: {
1622
- type: Boolean,
1623
- required: !1,
1624
- default: !1
1625
- },
1626
- /** Whether show or hide Try sample API button */
1627
- hideTrySampleApiButton: {
1628
- type: Boolean,
1629
- required: !1,
1630
- default: !1
1631
- }
1632
- },
1633
- emits: ["update", "error", "url-valid:success", "url-valid:error", "loading", "model-updated", "try-sample-api"],
1634
- setup(n, { expose: X, emit: _ }) {
1635
- var b;
1636
- const v = _, a = n, h = D(!0), L = qe(), { i18nT: Q, i18n: { t: r } } = se.useI18n(), { getErrorFieldsFromError: j } = Je(), { axiosInstance: A } = Ge((b = a.config) == null ? void 0 : b.axiosRequestConfig), Se = Qe(), { validateHost: be, validatePath: Y, validatePort: he, validateProtocol: ae } = se.useUrlValidators(), { objectsAreEqual: x } = et(), me = k(() => pe.form[a.config.app].edit), N = k(() => a.gatewayServiceId ? Be.Edit : Be.Create), Ie = D(!1), o = k(() => !!a.gatewayServiceId), w = D(o.value ? "protocol" : "url"), ie = se.usePortFromProtocol(), ve = D(""), we = k(() => !!ve.value || !!ee("name")), e = Me({
1637
- fields: {
1638
- name: "",
1639
- protocol: "http",
1640
- host: "",
1641
- path: "",
1642
- port: 80,
1643
- url: "",
1644
- retries: 5,
1645
- connect_timeout: 6e4,
1646
- write_timeout: 6e4,
1647
- read_timeout: 6e4,
1648
- client_certificate: "",
1649
- ca_certificates: "",
1650
- tls_verify_enabled: !1,
1651
- tls_verify_value: !1,
1652
- tags: ""
1653
- },
1654
- isReadonly: !1,
1655
- errorMessages: [],
1656
- formFieldErrors: {
1657
- host: "",
1658
- port: "",
1659
- path: "",
1660
- name: "",
1661
- url: "",
1662
- tags: "",
1663
- retries: "",
1664
- connect_timeout: "",
1665
- write_timeout: "",
1666
- read_timeout: "",
1667
- client_certificate: "",
1668
- ca_certificates: "",
1669
- tls_verify_enabled: "",
1670
- tls_verify_value: ""
1671
- }
1672
- }), F = Me({
1673
- name: "",
1674
- protocol: "http",
1675
- host: "",
1676
- path: "",
1677
- port: 80,
1678
- url: "",
1679
- retries: 5,
1680
- connect_timeout: 6e4,
1681
- write_timeout: 6e4,
1682
- read_timeout: 6e4,
1683
- client_certificate: "",
1684
- ca_certificates: "",
1685
- tls_verify_enabled: !1,
1686
- tls_verify_value: !1,
1687
- tags: ""
1688
- }), ne = a.config.app === "konnect" || Xe({
1689
- gatewayInfo: a.config.gatewayInfo,
1690
- // 'ws' and 'wss' are not valid values for the protocol field in Gateway Community Edition or before Gateway Enterprise Edition 3.0
1691
- supportedRange: {
1692
- enterprise: ["3.0"]
1693
- }
1694
- }), q = [
1695
- {
1696
- label: r("gateway_services.form.fields.protocol.options.http"),
1697
- value: "http",
1698
- group: "http"
1699
- },
1700
- {
1701
- label: r("gateway_services.form.fields.protocol.options.https"),
1702
- value: "https",
1703
- group: "http"
1704
- },
1705
- {
1706
- label: r("gateway_services.form.fields.protocol.options.tcp"),
1707
- value: "tcp",
1708
- group: "tcp"
1709
- },
1710
- {
1711
- label: r("gateway_services.form.fields.protocol.options.tls"),
1712
- value: "tls",
1713
- group: "tcp"
1714
- },
1715
- {
1716
- label: r("gateway_services.form.fields.protocol.options.tls_passthrough"),
1717
- value: "tls_passthrough",
1718
- group: "tcp"
1719
- },
1720
- {
1721
- label: r("gateway_services.form.fields.protocol.options.grpc"),
1722
- value: "grpc",
1723
- group: "grpc"
1724
- },
1725
- {
1726
- label: r("gateway_services.form.fields.protocol.options.grpcs"),
1727
- value: "grpcs",
1728
- group: "grpc"
1729
- },
1730
- ...ne ? [
1731
- {
1732
- label: r("gateway_services.form.fields.protocol.options.ws"),
1733
- value: "ws",
1734
- group: "websocket"
1735
- },
1736
- {
1737
- label: r("gateway_services.form.fields.protocol.options.wss"),
1738
- value: "wss",
1739
- group: "websocket"
1740
- }
1741
- ] : [],
1742
- {
1743
- label: r("gateway_services.form.fields.protocol.options.udp"),
1744
- value: "udp",
1745
- group: "udp"
1746
- }
1747
- ], re = { url: "url", protocol: "protocol" }, Pe = (t, s) => {
1748
- s.value;
1749
- }, oe = (t) => t ? parseFloat(t) : 0, ke = () => {
1750
- e.fields.host = F.host, e.fields.path = F.path, e.fields.port = F.port, e.fields.protocol = F.protocol, e.fields.url = F.url, e.fields.retries = F.retries, e.fields.connect_timeout = F.connect_timeout, e.fields.write_timeout = F.write_timeout, e.fields.read_timeout = F.read_timeout, e.fields.client_certificate = F.client_certificate, e.fields.ca_certificates = F.ca_certificates, e.fields.tls_verify_enabled = F.tls_verify_enabled, e.fields.tls_verify_value = F.tls_verify_value;
1751
- }, Ve = () => {
1752
- h.value = !0, H(), e.errorMessages = [], ke();
1753
- }, ce = () => {
1754
- switch (ke(), e.fields.name = `${le.name}-${(/* @__PURE__ */ new Date()).toISOString().replace(/\D/g, "").slice(0, 17)}`, w.value) {
1755
- case "url":
1756
- e.fields.url = `${le.protocol}://${le.host}${le.path}`;
1757
- break;
1758
- case "protocol":
1759
- e.fields.host = le.host, e.fields.path = le.path, e.fields.protocol = le.protocol, e.fields.port = le.port;
1760
- break;
1761
- default:
1762
- e.fields.url = `${le.protocol}://${le.host}${le.path}`;
1763
- }
1764
- }, ge = () => {
1765
- if (H(), e.fields.url.length)
1766
- try {
1767
- const t = new URL(e.fields.url), s = ae(t.protocol, q);
1768
- if (s) throw new Error(s);
1769
- e.fields.protocol = t.protocol.slice(0, -1);
1770
- const E = be(t.hostname);
1771
- if (E) throw new Error(E);
1772
- e.fields.host = t.hostname;
1773
- const O = Y(t.pathname);
1774
- if (O) throw new Error(O);
1775
- e.fields.path = t.pathname;
1776
- const U = he(t.port);
1777
- if (U) throw new Error(U);
1778
- const T = Number(t.port);
1779
- Ie.value = !!T, e.fields.port = T || ie.getPortFromProtocol(e.fields.protocol), v("url-valid:success");
1780
- } catch {
1781
- v("url-valid:error", r("gateway_services.form.errors.url.invalid")), e.formFieldErrors.url = r("gateway_services.form.errors.url.invalid");
1782
- }
1783
- }, ye = (t) => {
1784
- H(t);
1785
- }, Ee = k(() => !!e.formFieldErrors.url || !!e.formFieldErrors.host || !!e.formFieldErrors.port), ee = (t) => {
1786
- if (e.errorMessages.length) return "";
1787
- const s = e.formFieldErrors;
1788
- return s[t] ? s[t] : "";
1789
- }, z = (t) => {
1790
- H(t ?? void 0);
1791
- const s = be(e.fields.host);
1792
- s && (e.formFieldErrors.host = s);
1793
- const E = Y(e.fields.path);
1794
- E && (e.formFieldErrors.path = E);
1795
- const O = he(e.fields.port);
1796
- O && (e.formFieldErrors.port = O), te.value ? v("url-valid:success") : v("url-valid:error", e.errorMessages.join(",") || r("gateway_services.form.errors.url.invalid"));
1797
- }, H = (t) => {
1798
- if (t)
1799
- e.formFieldErrors[t] = "";
1800
- else
1801
- for (let s in e.formFieldErrors)
1802
- e.formFieldErrors[s] = "";
1803
- e.errorMessages = [];
1804
- }, te = k(() => {
1805
- for (let t in e.formFieldErrors)
1806
- if (e.formFieldErrors[t].length)
1807
- return !1;
1808
- return !0;
1809
- }), de = () => {
1810
- e.fields.url && w.value === "url" ? ge() : z();
1811
- }, i = () => `new-service-${(/* @__PURE__ */ new Date()).toISOString().replace(/\D/g, "").slice(0, 17)}`, u = k(() => !["tcp", "tls", "tls_passthrough", "grpc", "grpcs", "udp"].includes(e.fields.protocol)), V = k(() => {
1812
- if (w.value === "url")
1813
- return !0;
1814
- const t = ["https", "wss", "tls"].includes(e.fields.protocol);
1815
- return w.value === "protocol" && t;
1816
- }), J = k(() => {
1817
- if (w.value === "url")
1818
- return !0;
1819
- const t = ["https", "tls"].includes(e.fields.protocol);
1820
- return w.value === "protocol" && t;
1821
- }), B = k(() => {
1822
- if (w.value === "url")
1823
- return !0;
1824
- const t = ["https", "wss", "tls"].includes(e.fields.protocol);
1825
- return w.value === "protocol" && t;
1826
- }), R = (t) => {
1827
- H("name"), ve.value = Se.utf8Name(t);
1828
- }, c = k(() => {
1829
- const t = !o.value || !x(e.fields, F), s = w.value === "url" && !!e.fields.url && te.value, E = w.value === "protocol" && !!e.fields.host && te.value;
1830
- return t && (s || E);
1831
- }), g = (t) => {
1832
- var s, E, O;
1833
- e.fields.name = (t == null ? void 0 : t.name) || "", e.fields.tags = ((s = t == null ? void 0 : t.tags) == null ? void 0 : s.join(", ")) || "", e.fields.protocol = (t == null ? void 0 : t.protocol) || "http", e.fields.path = (t == null ? void 0 : t.path) || "", e.fields.read_timeout = t != null && t.read_timeout || (t == null ? void 0 : t.read_timeout) === 0 ? t == null ? void 0 : t.read_timeout : 6e4, e.fields.retries = t != null && t.retries || (t == null ? void 0 : t.retries) === 0 ? t == null ? void 0 : t.retries : 5, e.fields.host = (t == null ? void 0 : t.host) || "", e.fields.connect_timeout = t != null && t.connect_timeout || (t == null ? void 0 : t.connect_timeout) === 0 ? t == null ? void 0 : t.connect_timeout : 6e4, e.fields.tls_verify_enabled = (t == null ? void 0 : t.tls_verify) !== "" && (t == null ? void 0 : t.tls_verify) !== null && (t == null ? void 0 : t.tls_verify) !== void 0, e.fields.tls_verify_value = t != null && t.tls_verify ? t == null ? void 0 : t.tls_verify : !1, e.fields.ca_certificates = ((E = t == null ? void 0 : t.ca_certificates) == null ? void 0 : E.join(",")) || "", e.fields.client_certificate = ((O = t == null ? void 0 : t.client_certificate) == null ? void 0 : O.id) || "", e.fields.write_timeout = t != null && t.write_timeout || (t == null ? void 0 : t.write_timeout) === 0 ? t == null ? void 0 : t.write_timeout : 6e4, e.fields.port = t != null && t.port || (t == null ? void 0 : t.port) === 0 ? t == null ? void 0 : t.port : 80, Object.assign(F, e.fields);
1834
- }, p = () => {
1835
- L.push(a.config.cancelRoute);
1836
- }, C = k(() => {
1837
- var s, E;
1838
- let t = `${a.config.apiBaseUrl}${pe.form[a.config.app].validate}`;
1839
- return a.config.app === "konnect" ? t = t.replace(/{controlPlaneId}/gi, ((s = a.config) == null ? void 0 : s.controlPlaneId) || "") : a.config.app === "kongManager" && (t = t.replace(/\/{workspace}/gi, (E = a.config) != null && E.workspace ? `/${a.config.workspace}` : "")), t = t.replace(/{id}/gi, a.gatewayServiceId), t;
1840
- }), K = k(() => {
1841
- var s, E;
1842
- let t = `${a.config.apiBaseUrl}${pe.form[a.config.app][N.value]}`;
1843
- return a.config.app === "konnect" ? t = t.replace(/{controlPlaneId}/gi, ((s = a.config) == null ? void 0 : s.controlPlaneId) || "") : a.config.app === "kongManager" && (t = t.replace(/\/{workspace}/gi, (E = a.config) != null && E.workspace ? `/${a.config.workspace}` : "")), t = t.replace(/{id}/gi, a.gatewayServiceId), t;
1844
- }), ue = (t) => {
1845
- let s = "";
1846
- t.url && (s = new URL(t.url).protocol), (["https", "wss", "tls"].includes(t.protocol) || ["https", "wss", "tls"].includes(s)) && (t.tls_verify = t.tls_verify_enabled ? t.tls_verify_value : null), delete t.tls_verify_enabled, delete t.tls_verify_value;
1847
- }, G = k(() => {
1848
- var s, E, O, U;
1849
- const t = {
1850
- name: e.fields.name || null,
1851
- tags: e.fields.tags ? (O = (E = (s = e.fields.tags) == null ? void 0 : s.split(",")) == null ? void 0 : E.map((T) => String(T || "").trim())) == null ? void 0 : O.filter((T) => T !== "") : null,
1852
- protocol: e.fields.protocol,
1853
- path: e.fields.path || null,
1854
- read_timeout: e.fields.read_timeout,
1855
- retries: e.fields.retries,
1856
- host: e.fields.host,
1857
- connect_timeout: e.fields.connect_timeout,
1858
- tls_verify_value: e.fields.tls_verify_value,
1859
- tls_verify_enabled: e.fields.tls_verify_enabled,
1860
- ca_certificates: e.fields.ca_certificates ? (U = e.fields.ca_certificates) == null ? void 0 : U.split(",").filter((T) => T !== "") : null,
1861
- client_certificate: e.fields.client_certificate ? { id: e.fields.client_certificate } : null,
1862
- write_timeout: e.fields.write_timeout,
1863
- port: e.fields.port,
1864
- url: e.fields.url
1865
- };
1866
- return e.fields.client_certificate && ["https", "wss", "tls"].includes(e.fields.protocol) && (t.client_certificate = { id: e.fields.client_certificate }), e.fields.tls_verify_enabled && ["https", "wss", "tls"].includes(e.fields.protocol) && (t.tls_verify = e.fields.tls_verify_value), u.value || (t.path = null), N.value === "create" ? w.value === "url" ? (delete t.protocol, delete t.host, delete t.path, a.config.app === "konnect" && delete t.port) : delete t.url : N.value === "edit" && delete t.url, t;
1867
- }), fe = async () => {
1868
- var t, s, E, O;
1869
- try {
1870
- e.isReadonly = !0;
1871
- const U = G.value;
1872
- ue(U);
1873
- let T;
1874
- if (await A.post(C.value, U), N.value === "create" ? T = await A.post(K.value, U) : N.value === "edit" && (T = ((t = a.config) == null ? void 0 : t.app) === "konnect" ? await A.put(K.value, U) : await A.patch(K.value, U)), T) {
1875
- const { data: f } = T;
1876
- e.fields.name = (f == null ? void 0 : f.name) || "", e.fields.port = f.port || ie.getPortFromProtocol(f.protocol), e.fields.protocol = (f == null ? void 0 : f.protocol) || "http", e.fields.host = (f == null ? void 0 : f.host) || "", e.fields.path = (f == null ? void 0 : f.path) || "", e.fields.url = (f == null ? void 0 : f.url) || "", e.fields.retries = f != null && f.retries || (f == null ? void 0 : f.retries) === 0 ? f == null ? void 0 : f.retries : 5, e.fields.connect_timeout = f != null && f.connect_timeout || (f == null ? void 0 : f.connect_timeout) === 0 ? f == null ? void 0 : f.connect_timeout : 6e4, e.fields.write_timeout = f != null && f.write_timeout || (f == null ? void 0 : f.write_timeout) === 0 ? f == null ? void 0 : f.write_timeout : 6e4, e.fields.read_timeout = f != null && f.read_timeout || (f == null ? void 0 : f.read_timeout) === 0 ? f == null ? void 0 : f.read_timeout : 6e4, e.fields.client_certificate = ((s = f == null ? void 0 : f.client_certificate) == null ? void 0 : s.id) || "", e.fields.ca_certificates = (E = f == null ? void 0 : f.ca_certificates) != null && E.length ? f == null ? void 0 : f.ca_certificates.join(",") : "", e.fields.tls_verify_enabled = (f == null ? void 0 : f.tls_verify) !== "" && (f == null ? void 0 : f.tls_verify) !== null && (f == null ? void 0 : f.tls_verify) !== void 0, e.fields.tls_verify_value = e.fields.tls_verify_enabled && (f == null ? void 0 : f.tls_verify), e.fields.tags = (O = f == null ? void 0 : f.tags) != null && O.length ? f.tags.join(", ") : "", Object.assign(F, e.fields), v("update", T == null ? void 0 : T.data);
1877
- }
1878
- return T;
1879
- } catch (U) {
1880
- const { fields: T, messages: f } = j(U);
1881
- e.errorMessages = f, T.length && T.forEach((_e) => {
1882
- const Ce = _e.field;
1883
- Ce === "client_certificate.id" ? e.formFieldErrors.client_certificate = _e.message : Ce.startsWith("ca_certificates") ? e.formFieldErrors.ca_certificates = _e.message : Object.keys(e.formFieldErrors).includes(Ce) && (e.formFieldErrors = {
1884
- ...e.formFieldErrors,
1885
- [Ce]: _e.message
1886
- });
1887
- }), v("error", U);
1888
- } finally {
1889
- e.isReadonly = !1;
1890
- }
1891
- };
1892
- return Fe(() => a.gatewayServiceId, () => {
1893
- Object.assign(e.fields, F);
1894
- }), Fe(e.fields, (t) => {
1895
- e.fields.port = ie.getPortFromProtocol(t.protocol, String(t.port)), v("model-updated", G.value);
1896
- }), He(() => {
1897
- v("model-updated", G.value), o.value || (e.fields.name = i());
1898
- }), X({
1899
- validateUrl: de,
1900
- getPayload: G,
1901
- saveFormData: fe,
1902
- canSubmit: c,
1903
- initForm: g
1904
- }), (t, s) => {
1905
- const E = W("KRadio"), O = W("KButton"), U = W("KInput"), T = W("KSelect"), f = W("KCheckbox"), _e = W("KCollapse"), Ce = W("KAlert");
1906
- return S(), $("div", ol, [
1907
- d(l(Ye), {
1908
- "can-submit": c.value,
1909
- config: n.config,
1910
- "edit-id": n.gatewayServiceId,
1911
- "entity-type": l(Oe).GatewayService,
1912
- "fetch-url": me.value,
1913
- "form-fields": G.value,
1914
- "is-readonly": e.isReadonly,
1915
- onCancel: p,
1916
- "onFetch:error": s[30] || (s[30] = (y) => t.$emit("error", y)),
1917
- "onFetch:success": g,
1918
- onLoading: s[31] || (s[31] = (y) => t.$emit("loading", y)),
1919
- onSubmit: fe
1920
- }, {
1921
- "form-actions": m(() => [
1922
- Ze(t.$slots, "form-actions", {
1923
- canSubmit: c.value,
1924
- cancel: p,
1925
- submit: fe
1926
- }, void 0, !0)
1927
- ]),
1928
- default: m(() => [
1929
- d(l(Ke), {
1930
- description: l(r)("gateway_services.form.sections.keys.description"),
1931
- "hide-info-header": n.hideSectionsInfo,
1932
- title: l(r)("gateway_services.form.sections.keys.title")
1933
- }, {
1934
- default: m(() => [
1935
- o.value ? M("", !0) : (S(), $("div", il, [
1936
- I("div", rl, [
1937
- d(E, {
1938
- modelValue: w.value,
1939
- "onUpdate:modelValue": s[0] || (s[0] = (y) => w.value = y),
1940
- card: "",
1941
- "card-orientation": "horizontal",
1942
- "data-testid": "gateway-service-url-radio",
1943
- description: l(r)("gateway_services.form.sections.keys.url.description"),
1944
- label: l(r)("gateway_services.form.sections.keys.url.label"),
1945
- "selected-value": re.url,
1946
- onChange: Ve
1947
- }, null, 8, ["modelValue", "description", "label", "selected-value"]),
1948
- d(E, {
1949
- modelValue: w.value,
1950
- "onUpdate:modelValue": s[1] || (s[1] = (y) => w.value = y),
1951
- card: "",
1952
- "card-orientation": "horizontal",
1953
- "checked-group": "protocol",
1954
- "data-testid": "gateway-service-protocol-radio",
1955
- description: l(r)("gateway_services.form.sections.keys.protocol.description"),
1956
- label: l(r)("gateway_services.form.sections.keys.protocol.label"),
1957
- "selected-value": re.protocol,
1958
- onChange: Ve
1959
- }, null, 8, ["modelValue", "description", "label", "selected-value"])
1960
- ]),
1961
- d(We, { name: "slide-fade" }, {
1962
- default: m(() => [
1963
- w.value === "url" ? (S(), $("div", sl, [
1964
- d(U, {
1965
- modelValue: e.fields.url,
1966
- "onUpdate:modelValue": s[2] || (s[2] = (y) => e.fields.url = y),
1967
- modelModifiers: { trim: !0 },
1968
- class: "gateway-service-url-input gateway-service-form-margin-bottom",
1969
- "data-testid": "gateway-service-url-input",
1970
- error: Ee.value,
1971
- "error-message": ee("url"),
1972
- label: l(r)("gateway_services.form.fields.upstream_url.label"),
1973
- "label-attributes": {
1974
- info: n.config.app === "konnect" ? l(r)("gateway_services.form.fields.upstream_url.tooltip_for_konnect") : l(r)("gateway_services.form.fields.upstream_url.tooltip_for_km"),
1975
- tooltipAttributes: { maxWidth: "400" }
1976
- },
1977
- name: "url",
1978
- placeholder: l(r)("gateway_services.form.fields.upstream_url.placeholder"),
1979
- required: "",
1980
- onInput: ge
1981
- }, Te({ _: 2 }, [
1982
- n.hideTrySampleApiButton ? void 0 : {
1983
- name: "after",
1984
- fn: m(() => [
1985
- d(O, {
1986
- appearance: "tertiary",
1987
- "data-testid": "try-sample-api",
1988
- size: "small",
1989
- onClick: ce
1990
- }, {
1991
- default: m(() => [
1992
- Z(P(l(r)("gateway_services.form.buttons.try_sample")), 1)
1993
- ]),
1994
- _: 1
1995
- })
1996
- ]),
1997
- key: "0"
1998
- }
1999
- ]), 1032, ["modelValue", "error", "error-message", "label", "label-attributes", "placeholder"])
2000
- ])) : M("", !0)
2001
- ]),
2002
- _: 1
2003
- })
2004
- ])),
2005
- d(We, { name: "slide-fade" }, {
2006
- default: m(() => [
2007
- w.value === "protocol" || o.value ? (S(), $("div", al, [
2008
- d(T, {
2009
- modelValue: e.fields.protocol,
2010
- "onUpdate:modelValue": s[3] || (s[3] = (y) => e.fields.protocol = y),
2011
- "data-testid": "gateway-service-protocol-select",
2012
- items: q,
2013
- label: l(r)("gateway_services.form.fields.protocol.label"),
2014
- "label-attributes": {
2015
- info: l(r)("gateway_services.form.fields.protocol.tooltip"),
2016
- tooltipAttributes: { maxWidth: "400" }
2017
- },
2018
- readonly: e.isReadonly,
2019
- required: "",
2020
- width: "100%",
2021
- onSelected: s[4] || (s[4] = (y) => Pe(e.fields.protocol, y))
2022
- }, null, 8, ["modelValue", "label", "label-attributes", "readonly"]),
2023
- d(U, {
2024
- modelValue: e.fields.host,
2025
- "onUpdate:modelValue": s[5] || (s[5] = (y) => e.fields.host = y),
2026
- modelModifiers: { trim: !0 },
2027
- class: "gateway-service-form-margin-top",
2028
- "data-testid": "gateway-service-host-input",
2029
- error: !!e.formFieldErrors.host,
2030
- "error-message": ee("host"),
2031
- label: l(r)("gateway_services.form.fields.host.label"),
2032
- "label-attributes": {
2033
- info: l(r)("gateway_services.form.fields.host.tooltip"),
2034
- tooltipAttributes: { maxWidth: "400" }
2035
- },
2036
- name: "host",
2037
- placeholder: l(r)("gateway_services.form.fields.host.placeholder"),
2038
- required: "",
2039
- onInput: s[6] || (s[6] = (y) => z("host"))
2040
- }, Te({ _: 2 }, [
2041
- n.hideTrySampleApiButton ? void 0 : {
2042
- name: "after",
2043
- fn: m(() => [
2044
- d(O, {
2045
- appearance: "tertiary",
2046
- size: "small",
2047
- onClick: ce
2048
- }, {
2049
- default: m(() => [
2050
- Z(P(l(r)("gateway_services.form.buttons.try_sample")), 1)
2051
- ]),
2052
- _: 1
2053
- })
2054
- ]),
2055
- key: "0"
2056
- }
2057
- ]), 1032, ["modelValue", "error", "error-message", "label", "label-attributes", "placeholder"]),
2058
- u.value ? (S(), $("div", nl, [
2059
- d(U, {
2060
- modelValue: e.fields.path,
2061
- "onUpdate:modelValue": s[7] || (s[7] = (y) => e.fields.path = y),
2062
- modelModifiers: { trim: !0 },
2063
- class: "gateway-service-form-margin-top",
2064
- "data-testid": "gateway-service-path-input",
2065
- error: !!e.formFieldErrors.path,
2066
- "error-message": ee("path"),
2067
- label: l(r)("gateway_services.form.fields.path.label"),
2068
- "label-attributes": {
2069
- info: l(r)("gateway_services.form.fields.path.tooltip"),
2070
- tooltipAttributes: { maxWidth: "400" }
2071
- },
2072
- name: "path",
2073
- placeholder: l(r)("gateway_services.form.fields.path.placeholder"),
2074
- onInput: s[8] || (s[8] = (y) => z("path"))
2075
- }, null, 8, ["modelValue", "error", "error-message", "label", "label-attributes", "placeholder"])
2076
- ])) : M("", !0),
2077
- d(U, {
2078
- modelValue: e.fields.port,
2079
- "onUpdate:modelValue": [
2080
- s[9] || (s[9] = (y) => e.fields.port = y),
2081
- s[11] || (s[11] = () => {
2082
- e.fields.port = oe(e.fields.port + "");
2083
- })
2084
- ],
2085
- class: "gateway-service-form-margin-top",
2086
- "data-testid": "gateway-service-port-input",
2087
- error: !!e.formFieldErrors.port,
2088
- "error-message": ee("port"),
2089
- label: l(r)("gateway_services.form.fields.port.label"),
2090
- "label-attributes": {
2091
- info: l(r)("gateway_services.form.fields.port.tooltip"),
2092
- tooltipAttributes: { maxWidth: "400" }
2093
- },
2094
- name: "port",
2095
- type: "number",
2096
- onInput: s[10] || (s[10] = (y) => z("port"))
2097
- }, null, 8, ["modelValue", "error", "error-message", "label", "label-attributes"])
2098
- ])) : M("", !0)
2099
- ]),
2100
- _: 1
2101
- }),
2102
- d(_e, {
2103
- modelValue: h.value,
2104
- "onUpdate:modelValue": s[27] || (s[27] = (y) => h.value = y),
2105
- "data-testid": "advanced-fields-collapse",
2106
- "trigger-alignment": "leading",
2107
- "trigger-label": l(r)("gateway_services.form.sections.keys.viewAdvancedFields")
2108
- }, {
2109
- default: m(() => [
2110
- d(We, { name: "slide-fade" }, {
2111
- default: m(() => [
2112
- h.value ? M("", !0) : (S(), $("div", cl, [
2113
- I("div", dl, [
2114
- d(U, {
2115
- modelValue: e.fields.retries,
2116
- "onUpdate:modelValue": [
2117
- s[12] || (s[12] = (y) => e.fields.retries = y),
2118
- s[13] || (s[13] = () => {
2119
- e.fields.retries = oe(e.fields.retries + "");
2120
- })
2121
- ],
2122
- autocomplete: "off",
2123
- "data-testid": "gateway-service-retries-input",
2124
- label: l(r)("gateway_services.form.fields.retries.label"),
2125
- "label-attributes": {
2126
- info: l(r)("gateway_services.form.fields.retries.tooltip"),
2127
- tooltipAttributes: { maxWidth: "400" }
2128
- },
2129
- name: "retries",
2130
- readonly: e.isReadonly,
2131
- type: "number"
2132
- }, null, 8, ["modelValue", "label", "label-attributes", "readonly"])
2133
- ]),
2134
- I("div", ul, [
2135
- d(U, {
2136
- modelValue: e.fields.connect_timeout,
2137
- "onUpdate:modelValue": [
2138
- s[14] || (s[14] = (y) => e.fields.connect_timeout = y),
2139
- s[15] || (s[15] = () => {
2140
- e.fields.connect_timeout = oe(e.fields.connect_timeout + "");
2141
- })
2142
- ],
2143
- autocomplete: "off",
2144
- "data-testid": "gateway-service-connTimeout-input",
2145
- label: l(r)("gateway_services.form.fields.connect_timeout.label"),
2146
- "label-attributes": {
2147
- info: l(r)("gateway_services.form.fields.connect_timeout.tooltip"),
2148
- tooltipAttributes: { maxWidth: "400" }
2149
- },
2150
- name: "connTimeout",
2151
- readonly: e.isReadonly,
2152
- type: "number"
2153
- }, null, 8, ["modelValue", "label", "label-attributes", "readonly"])
2154
- ]),
2155
- I("div", fl, [
2156
- d(U, {
2157
- modelValue: e.fields.write_timeout,
2158
- "onUpdate:modelValue": [
2159
- s[16] || (s[16] = (y) => e.fields.write_timeout = y),
2160
- s[17] || (s[17] = () => {
2161
- e.fields.write_timeout = oe(e.fields.write_timeout + "");
2162
- })
2163
- ],
2164
- autocomplete: "off",
2165
- "data-testid": "gateway-service-writeTimeout-input",
2166
- label: l(r)("gateway_services.form.fields.write_timeout.label"),
2167
- "label-attributes": {
2168
- info: l(r)("gateway_services.form.fields.write_timeout.tooltip"),
2169
- tooltipAttributes: { maxWidth: "400" }
2170
- },
2171
- name: "writeTimeout",
2172
- readonly: e.isReadonly,
2173
- type: "number"
2174
- }, null, 8, ["modelValue", "label", "label-attributes", "readonly"])
2175
- ]),
2176
- I("div", pl, [
2177
- d(U, {
2178
- modelValue: e.fields.read_timeout,
2179
- "onUpdate:modelValue": [
2180
- s[18] || (s[18] = (y) => e.fields.read_timeout = y),
2181
- s[19] || (s[19] = () => {
2182
- e.fields.read_timeout = oe(e.fields.read_timeout + "");
2183
- })
2184
- ],
2185
- autocomplete: "off",
2186
- "data-testid": "gateway-service-readTimeout-input",
2187
- label: l(r)("gateway_services.form.fields.read_timeout.label"),
2188
- "label-attributes": {
2189
- info: l(r)("gateway_services.form.fields.read_timeout.tooltip"),
2190
- tooltipAttributes: { maxWidth: "400" }
2191
- },
2192
- name: "readTimeout",
2193
- readonly: e.isReadonly,
2194
- type: "number"
2195
- }, null, 8, ["modelValue", "label", "label-attributes", "readonly"])
2196
- ]),
2197
- V.value ? (S(), $("div", ml, [
2198
- d(U, {
2199
- modelValue: e.fields.client_certificate,
2200
- "onUpdate:modelValue": s[20] || (s[20] = (y) => e.fields.client_certificate = y),
2201
- modelModifiers: { trim: !0 },
2202
- autocomplete: "off",
2203
- "data-testid": "gateway-service-clientCert-input",
2204
- error: !!e.formFieldErrors.client_certificate,
2205
- label: l(r)("gateway_services.form.fields.client_certificate.label"),
2206
- "label-attributes": {
2207
- info: l(r)("gateway_services.form.fields.client_certificate.tooltip"),
2208
- tooltipAttributes: { maxWidth: "400" }
2209
- },
2210
- name: "clientCert",
2211
- placeholder: l(r)("gateway_services.form.fields.client_certificate.placeholder"),
2212
- readonly: e.isReadonly,
2213
- type: "text",
2214
- onInput: s[21] || (s[21] = (y) => ye("client_certificate"))
2215
- }, null, 8, ["modelValue", "error", "label", "label-attributes", "placeholder", "readonly"])
2216
- ])) : M("", !0),
2217
- J.value ? (S(), $("div", vl, [
2218
- d(U, {
2219
- modelValue: e.fields.ca_certificates,
2220
- "onUpdate:modelValue": s[22] || (s[22] = (y) => e.fields.ca_certificates = y),
2221
- modelModifiers: { trim: !0 },
2222
- autocomplete: "off",
2223
- "data-testid": "gateway-service-ca-certs-input",
2224
- error: !!e.formFieldErrors.ca_certificates,
2225
- label: l(r)("gateway_services.form.fields.ca_certificates.label"),
2226
- "label-attributes": { tooltipAttributes: { maxWidth: "400" } },
2227
- placeholder: l(r)("gateway_services.form.fields.ca_certificates.placeholder"),
2228
- readonly: e.isReadonly,
2229
- type: "text",
2230
- onInput: s[23] || (s[23] = (y) => ye("ca_certificates"))
2231
- }, {
2232
- "label-tooltip": m(() => [
2233
- d(l(Q), {
2234
- keypath: "gateway_services.form.fields.ca_certificates.tooltip",
2235
- scope: "global"
2236
- }, {
2237
- code1: m(() => [
2238
- I("code", null, P(l(r)("gateway_services.form.fields.ca_certificates.code1")), 1)
2239
- ]),
2240
- code2: m(() => [
2241
- I("code", null, P(l(r)("gateway_services.form.fields.ca_certificates.code2")), 1)
2242
- ]),
2243
- _: 1
2244
- })
2245
- ]),
2246
- _: 1
2247
- }, 8, ["modelValue", "error", "label", "placeholder", "readonly"])
2248
- ])) : M("", !0),
2249
- B.value ? (S(), $("div", gl, [
2250
- d(f, {
2251
- modelValue: e.fields.tls_verify_enabled,
2252
- "onUpdate:modelValue": s[24] || (s[24] = (y) => e.fields.tls_verify_enabled = y),
2253
- "data-testid": "gateway-service-tls-verify-checkbox",
2254
- description: l(r)("gateway_services.form.fields.tls_verify_enabled.help"),
2255
- label: l(r)("gateway_services.form.fields.tls_verify_enabled.label"),
2256
- "label-attributes": { tooltipAttributes: { maxWidth: "400" } }
2257
- }, {
2258
- tooltip: m(() => [
2259
- d(l(Q), {
2260
- keypath: "gateway_services.form.fields.tls_verify_enabled.tooltip",
2261
- scope: "global"
2262
- }, {
2263
- code1: m(() => [
2264
- I("code", null, P(l(r)("gateway_services.form.fields.tls_verify_enabled.code1")), 1)
2265
- ]),
2266
- _: 1
2267
- })
2268
- ]),
2269
- _: 1
2270
- }, 8, ["modelValue", "description", "label"]),
2271
- e.fields.tls_verify_enabled ? (S(), $("div", yl, [
2272
- d(E, {
2273
- modelValue: e.fields.tls_verify_value,
2274
- "onUpdate:modelValue": s[25] || (s[25] = (y) => e.fields.tls_verify_value = y),
2275
- "data-testid": "gateway-service-tls-verify-true-option",
2276
- label: l(r)("gateway_services.form.fields.tls_verify_option.true.label"),
2277
- "selected-value": !0
2278
- }, null, 8, ["modelValue", "label"])
2279
- ])) : M("", !0),
2280
- e.fields.tls_verify_enabled ? (S(), $("div", _l, [
2281
- d(E, {
2282
- modelValue: e.fields.tls_verify_value,
2283
- "onUpdate:modelValue": s[26] || (s[26] = (y) => e.fields.tls_verify_value = y),
2284
- "data-testid": "gateway-service-tls-verify-false-option",
2285
- label: l(r)("gateway_services.form.fields.tls_verify_option.false.label"),
2286
- "selected-value": !1
2287
- }, null, 8, ["modelValue", "label"])
2288
- ])) : M("", !0)
2289
- ])) : M("", !0)
2290
- ]))
2291
- ]),
2292
- _: 1
2293
- })
2294
- ]),
2295
- _: 1
2296
- }, 8, ["modelValue", "trigger-label"])
2297
- ]),
2298
- _: 1
2299
- }, 8, ["description", "hide-info-header", "title"]),
2300
- d(l(Ke), {
2301
- description: l(r)("gateway_services.form.sections.general.description"),
2302
- "hide-info-header": n.hideSectionsInfo,
2303
- title: l(r)("gateway_services.form.sections.general.title")
2304
- }, {
2305
- default: m(() => [
2306
- d(U, {
2307
- modelValue: e.fields.name,
2308
- "onUpdate:modelValue": s[28] || (s[28] = (y) => e.fields.name = y),
2309
- modelModifiers: { trim: !0 },
2310
- autocomplete: "off",
2311
- "data-testid": "gateway-service-name-input",
2312
- error: we.value,
2313
- "error-message": ve.value,
2314
- label: l(r)("gateway_services.form.fields.name.label"),
2315
- "label-attributes": {
2316
- info: l(r)("gateway_services.form.fields.name.tooltip"),
2317
- tooltipAttributes: { maxWidth: "400" }
2318
- },
2319
- name: "name",
2320
- placeholder: l(r)("gateway_services.form.fields.name.placeholder"),
2321
- readonly: e.isReadonly,
2322
- type: "text",
2323
- onInput: R
2324
- }, null, 8, ["modelValue", "error", "error-message", "label", "label-attributes", "placeholder", "readonly"]),
2325
- d(_e, {
2326
- "data-testid": "tags-collapse",
2327
- "trigger-alignment": "leading",
2328
- "trigger-label": l(r)("gateway_services.form.fields.tags.collapse")
2329
- }, {
2330
- default: m(() => [
2331
- I("div", bl, [
2332
- d(U, {
2333
- modelValue: e.fields.tags,
2334
- "onUpdate:modelValue": s[29] || (s[29] = (y) => e.fields.tags = y),
2335
- modelModifiers: { trim: !0 },
2336
- autocomplete: "off",
2337
- "data-testid": "gateway-service-tags-input",
2338
- help: l(r)("gateway_services.form.fields.tags.help"),
2339
- label: l(r)("gateway_services.form.fields.tags.label"),
2340
- "label-attributes": {
2341
- info: l(r)("gateway_services.form.fields.tags.tooltip"),
2342
- tooltipAttributes: { maxWidth: "400" }
2343
- },
2344
- name: "tags",
2345
- placeholder: l(r)("gateway_services.form.fields.tags.placeholder"),
2346
- readonly: e.isReadonly,
2347
- type: "text"
2348
- }, null, 8, ["modelValue", "help", "label", "label-attributes", "placeholder", "readonly"])
2349
- ])
2350
- ]),
2351
- _: 1
2352
- }, 8, ["trigger-label"])
2353
- ]),
2354
- _: 1
2355
- }, 8, ["description", "hide-info-header", "title"]),
2356
- e.errorMessages.length ? (S(), $e(Ce, {
2357
- key: 0,
2358
- appearance: "danger",
2359
- "data-testid": "form-error"
2360
- }, {
2361
- default: m(() => [
2362
- I("ul", hl, [
2363
- (S(!0), $(lt, null, ot(e.errorMessages, (y) => (S(), $("li", { key: y }, P(y), 1))), 128))
2364
- ])
2365
- ]),
2366
- _: 1
2367
- })) : M("", !0)
2368
- ]),
2369
- _: 3
2370
- }, 8, ["can-submit", "config", "edit-id", "entity-type", "fetch-url", "form-fields", "is-readonly"])
2371
- ]);
2372
- };
2373
- }
2374
- }), Rl = /* @__PURE__ */ Ne(wl, [["__scopeId", "data-v-a94ad8c2"]]), { validateHost: kl, validatePort: Vl, validateProtocol: Cl, validatePath: Sl } = se.useUrlValidators(), Tl = () => ({
2375
- validateHost: kl,
2376
- validatePort: Vl,
2377
- validateProtocol: Cl,
2378
- validatePath: Sl
2379
- });
2380
- export {
2381
- xl as GatewayServiceConfigCard,
2382
- Rl as GatewayServiceForm,
2383
- Fl as GatewayServiceList,
2384
- Al as LegacyGatewayServiceForm,
2385
- Tl as useUrlValidator
2386
- };