diff --git a/package.json b/package.json index 3d72d1df..bbb22195 100644 --- a/package.json +++ b/package.json @@ -36,7 +36,8 @@ "@kong/kong-auth-elements": "2.12.6", "@kong/kongponents": "8.127.0", "@kong/markdown": "1.7.8", - "@kong/sdk-portal-js": "2.14.0", + "@kong/sdk-portal-js": "2.15.4", + "@unhead/vue": "1.11.6", "@xstate/vue": "2.0.0", "axios": "1.6.7", "date-fns": "3.3.0", diff --git a/src/App.vue b/src/App.vue index 01b71dcd..480c9ca3 100644 --- a/src/App.vue +++ b/src/App.vue @@ -33,6 +33,7 @@ import Nav from '@/components/Nav.vue' import { portalApiV2 } from '@/services' import { useAppStore } from '@/stores' import { createRedirectHandler } from './helpers/auth' +import { useHead } from '@unhead/vue' const initialLoadingId = 'initial-fullscreen-loading-container' @@ -42,6 +43,11 @@ export default defineComponent({ Nav }, setup () { + const { canonicalDomain } = useAppStore() + + useHead({ + link: [{ rel: 'canonical', href: canonicalDomain }] + }) removeElementFromDOMById(initialLoadingId) }, computed: { diff --git a/src/main.ts b/src/main.ts index 01a9b89d..e6156ed8 100644 --- a/src/main.ts +++ b/src/main.ts @@ -1,3 +1,4 @@ +import { createHead } from '@unhead/vue' import { createApp } from 'vue' import piniaInstance, { useAppStore } from '@/stores' @@ -37,6 +38,9 @@ import portalAnalyticsBridge from '@kong-ui-public/portal-analytics-bridge' async function init () { const app = createApp(App) + const head = createHead() + + app.use(head) // Initialize the Pinia store app.use(piniaInstance) @@ -65,7 +69,8 @@ async function init () { is_public: isPublic, basic_auth_enabled: basicAuthEnabled, rbac_enabled: isRbacEnabled, - allowed_time_period: allowedTimePeriod + allowed_time_period: allowedTimePeriod, + canonical_domain: canonicalDomain } = portalContext.data if (isPublic === false) { @@ -74,7 +79,7 @@ async function init () { const authClientConfig = { basicAuthEnabled, oidcAuthEnabled } - setPortalData({ portalId, orgId, authClientConfig, featuresetId, featureSet, isPublic, isRbacEnabled, allowedTimePeriod }) + setPortalData({ portalId, orgId, authClientConfig, featuresetId, featureSet, isPublic, isRbacEnabled, allowedTimePeriod, canonicalDomain }) setSession(session) // Fetch session data from localStorage diff --git a/src/stores/app.ts b/src/stores/app.ts index a262139f..078e5def 100644 --- a/src/stores/app.ts +++ b/src/stores/app.ts @@ -15,6 +15,7 @@ interface PortalData { isPublic: boolean; isRbacEnabled: boolean; allowedTimePeriod: string; + canonicalDomain: string; } export const useAppStore = defineStore('app', () => { @@ -28,6 +29,7 @@ export const useAppStore = defineStore('app', () => { const featuresetId = ref(null) const featureSet = ref('') const allowedTimePeriod = ref(PortalTimeframeKeys.ONE_DAY) + const canonicalDomain = ref('') const authClientConfig = ref<{ basicAuthEnabled: boolean; oidcAuthEnabled: boolean; @@ -68,6 +70,10 @@ export const useAppStore = defineStore('app', () => { if (data.allowedTimePeriod) { allowedTimePeriod.value = data.allowedTimePeriod } + + if (data.canonicalDomain) { + canonicalDomain.value = data.canonicalDomain + } } const setSession = (session: SessionCookie) => { @@ -85,6 +91,7 @@ export const useAppStore = defineStore('app', () => { featuresetId, featureSet, allowedTimePeriod, + canonicalDomain, authClientConfig, logout, diff --git a/yarn.lock b/yarn.lock index 4d9ba42a..9f11a903 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1266,12 +1266,12 @@ mermaid "^10.9.1" uuid "^10.0.0" -"@kong/sdk-portal-js@2.14.0": - version "2.14.0" - resolved "https://registry.yarnpkg.com/@kong/sdk-portal-js/-/sdk-portal-js-2.14.0.tgz#f39c01a3de23270fef1ca8ad5a8e52e9a69eb6b0" - integrity sha512-3ZJckN0Ei1ul3k+U5wuzmlA/K2ZRw2uQmYtO0UUPfD9G5A5eiOAWvJWrHCIBYk407DOVUjto2TdCAyFnjpjpWg== +"@kong/sdk-portal-js@2.15.4": + version "2.15.4" + resolved "https://registry.yarnpkg.com/@kong/sdk-portal-js/-/sdk-portal-js-2.15.4.tgz#0020c4b2f892df656bda615e078f8ad7db908037" + integrity sha512-zRgjA518C9g5Pyv3oksHK/f4MastP/KBbkgMahUe9LdOWrUFdUScy0jC/8W1PihK6Szd8VhNVgScSfG/2OYy+A== dependencies: - axios "1.6.0" + axios "1.7.4" "@kong/swagger-ui-kong-theme-universal@^4.3.3": version "4.3.3" @@ -2590,6 +2590,40 @@ resolved "https://registry.yarnpkg.com/@ungap/structured-clone/-/structured-clone-1.2.0.tgz#756641adb587851b5ccb3e095daf27ae581c8406" integrity sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ== +"@unhead/dom@1.11.6": + version "1.11.6" + resolved "https://registry.yarnpkg.com/@unhead/dom/-/dom-1.11.6.tgz#639e90793eb18605038591d496ee772d0e6a1449" + integrity sha512-FYU8Cu+XWcpbO4OvXdB6x7m6GTPcl6CW7igI8rNu6Kc0Ilxb+atxIvyFXdTGAyB7h/F0w3ex06ZVWJ65f3EW8A== + dependencies: + "@unhead/schema" "1.11.6" + "@unhead/shared" "1.11.6" + +"@unhead/schema@1.11.6": + version "1.11.6" + resolved "https://registry.yarnpkg.com/@unhead/schema/-/schema-1.11.6.tgz#4528d08ecb1addae0721221aca443fc04bb61bdd" + integrity sha512-Ava5+kQERaZ2fi66phgR9KZQr9SsheN1YhhKM8fCP2A4Jb5lHUssVQ19P0+89V6RX9iUg/Q27WdEbznm75LzhQ== + dependencies: + hookable "^5.5.3" + zhead "^2.2.4" + +"@unhead/shared@1.11.6": + version "1.11.6" + resolved "https://registry.yarnpkg.com/@unhead/shared/-/shared-1.11.6.tgz#f70a0b0c72bfb836f96f36a20bb1831ddecd160e" + integrity sha512-aGrtzRCcFlVh9iru73fBS8FA1vpQskS190t5cCRRMpisOEunVv3ueqXN1F8CseQd0W4wyEr/ycDvdfKt+RPv5g== + dependencies: + "@unhead/schema" "1.11.6" + +"@unhead/vue@1.11.6": + version "1.11.6" + resolved "https://registry.yarnpkg.com/@unhead/vue/-/vue-1.11.6.tgz#dd9b117777f3be93b39a9cf50099a7b7b2ae7a94" + integrity sha512-CMuDJGTi4n4wKdOp6/JmB9roGshjTdoFKF34PEkXu4+g97BiVFiZ9LvgY44+UlWCUzQHcqEPRQIzm9iKEqcfKw== + dependencies: + "@unhead/schema" "1.11.6" + "@unhead/shared" "1.11.6" + defu "^6.1.4" + hookable "^5.5.3" + unhead "1.11.6" + "@vitejs/plugin-vue-jsx@3.1.0": version "3.1.0" resolved "https://registry.yarnpkg.com/@vitejs/plugin-vue-jsx/-/plugin-vue-jsx-3.1.0.tgz#9953fd9456539e1f0f253bf0fcd1289e66c67cd1" @@ -3298,15 +3332,6 @@ aws4@^1.8.0: resolved "https://registry.yarnpkg.com/aws4/-/aws4-1.12.0.tgz#ce1c9d143389679e253b314241ea9aa5cec980d3" integrity sha512-NmWvPnx0F1SfrQbYwOi7OeaNGokp9XhzNioJ/CSBs8Qa4vxug81mhJEAVZwxXuBmYB5KDRfMq/F3RR0BIU7sWg== -axios@1.6.0: - version "1.6.0" - resolved "https://registry.yarnpkg.com/axios/-/axios-1.6.0.tgz#f1e5292f26b2fd5c2e66876adc5b06cdbd7d2102" - integrity sha512-EZ1DYihju9pwVB+jg67ogm+Tmqc6JmhamRN6I4Zt8DfZu5lbcQGw3ozH9lFejSJgs/ibaef3A9PMXPLeefFGJg== - dependencies: - follow-redirects "^1.15.0" - form-data "^4.0.0" - proxy-from-env "^1.1.0" - axios@1.6.7, axios@^1.4.0, axios@^1.6.0: version "1.6.7" resolved "https://registry.yarnpkg.com/axios/-/axios-1.6.7.tgz#7b48c2e27c96f9c68a2f8f31e2ab19f59b06b0a7" @@ -3316,6 +3341,15 @@ axios@1.6.7, axios@^1.4.0, axios@^1.6.0: form-data "^4.0.0" proxy-from-env "^1.1.0" +axios@1.7.4: + version "1.7.4" + resolved "https://registry.yarnpkg.com/axios/-/axios-1.7.4.tgz#4c8ded1b43683c8dd362973c393f3ede24052aa2" + integrity sha512-DukmaFRnY6AzAALSH4J2M3k6PkaC+MfaAGdEERRWcC9q3/TWQwLpHR8ZRLKTdQ3aBDL64EdluRDjJqKw+BPZEw== + dependencies: + follow-redirects "^1.15.6" + form-data "^4.0.0" + proxy-from-env "^1.1.0" + axios@^1.7.0: version "1.7.2" resolved "https://registry.yarnpkg.com/axios/-/axios-1.7.2.tgz#b625db8a7051fbea61c35a3cbb3a1daa7b9c7621" @@ -4847,6 +4881,11 @@ define-properties@^1.1.3, define-properties@^1.1.4, define-properties@^1.2.0: has-property-descriptors "^1.0.0" object-keys "^1.1.1" +defu@^6.1.4: + version "6.1.4" + resolved "https://registry.yarnpkg.com/defu/-/defu-6.1.4.tgz#4e0c9cf9ff68fe5f3d7f2765cc1a012dfdcb0479" + integrity sha512-mEQCMmwJu317oSz8CwdIOdwf3xMif1ttiM8LTufzc3g6kR+9Pe236twL8j3IYT1F7GfRgGcW6MWxzZjLIkuHIg== + delaunator@5: version "5.0.1" resolved "https://registry.yarnpkg.com/delaunator/-/delaunator-5.0.1.tgz#39032b08053923e924d6094fe2cde1a99cc51278" @@ -6164,7 +6203,7 @@ focus-trap@^7.4.3, focus-trap@^7.5.2: dependencies: tabbable "^6.2.0" -follow-redirects@^1.15.0, follow-redirects@^1.15.4, follow-redirects@^1.15.6: +follow-redirects@^1.15.4, follow-redirects@^1.15.6: version "1.15.6" resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.6.tgz#7f815c0cda4249c74ff09e95ef97c23b5fd0399b" integrity sha512-wWN62YITEaOpSK584EZXJafH1AGpO8RVgElfkuXbTOrPX4fIfOyEpW/CsiNd8JdYrAoOvafRTOEnvsO++qCqFA== @@ -6821,6 +6860,11 @@ hook-std@^3.0.0: resolved "https://registry.yarnpkg.com/hook-std/-/hook-std-3.0.0.tgz#47038a01981e07ce9d83a6a3b2eb98cad0f7bd58" integrity sha512-jHRQzjSDzMtFy34AGj1DN+vq54WVuhSvKgrHf0OMiFQTwDD4L/qqofVEWjLOBMTn5+lCD3fPg32W9yOfnEJTTw== +hookable@^5.5.3: + version "5.5.3" + resolved "https://registry.yarnpkg.com/hookable/-/hookable-5.5.3.tgz#6cfc358984a1ef991e2518cb9ed4a778bbd3215d" + integrity sha512-Yc+BQe8SvoXH1643Qez1zqLRmbA5rCL+sSmk6TVos0LWVfNIB7PGncdlId77WzLGSIB5KaWgTaNTs2lNVEI6VQ== + hosted-git-info@^2.1.4: version "2.8.9" resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-2.8.9.tgz#dffc0bf9a21c02209090f2aa69429e1414daf3f9" @@ -12065,6 +12109,16 @@ underscore@^1.8.3: resolved "https://registry.yarnpkg.com/underscore/-/underscore-1.13.6.tgz#04786a1f589dc6c09f761fc5f45b89e935136441" integrity sha512-+A5Sja4HP1M08MaXya7p5LvjuM7K6q/2EaC0+iovj/wOcMsTzMvDFbasi/oSapiwOlt252IqsKqPjCl7huKS0A== +unhead@1.11.6: + version "1.11.6" + resolved "https://registry.yarnpkg.com/unhead/-/unhead-1.11.6.tgz#2358cfe4e1d2a6f70d992a0ec57bc7ae5f6354dc" + integrity sha512-TKTQGUzHKF925VZ4KZVbLfKFzTVTEWfPLaXKmkd/ptEY2FHEoJUF7xOpAWc3K7Jzy/ExS66TL7GnLLjtd4sISg== + dependencies: + "@unhead/dom" "1.11.6" + "@unhead/schema" "1.11.6" + "@unhead/shared" "1.11.6" + hookable "^5.5.3" + unicode-emoji-modifier-base@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/unicode-emoji-modifier-base/-/unicode-emoji-modifier-base-1.0.0.tgz#dbbd5b54ba30f287e2a8d5a249da6c0cef369459" @@ -12605,3 +12659,8 @@ zenscroll@^4.0.2: version "4.0.2" resolved "https://registry.yarnpkg.com/zenscroll/-/zenscroll-4.0.2.tgz#e8d5774d1c0738a47bcfa8729f3712e2deddeb25" integrity sha512-jEA1znR7b4C/NnaycInCU6h/d15ZzCd1jmsruqOKnZP6WXQSMH3W2GL+OXbkruslU4h+Tzuos0HdswzRUk/Vgg== + +zhead@^2.2.4: + version "2.2.4" + resolved "https://registry.yarnpkg.com/zhead/-/zhead-2.2.4.tgz#87cd1e2c3d2f465fa9f43b8db23f9716dfe6bed7" + integrity sha512-8F0OI5dpWIA5IGG5NHUg9staDwz/ZPxZtvGVf01j7vHqSyZ0raHY+78atOVxRqb73AotX22uV1pXt3gYSstGag==