fix ==> redirectToLink

This commit is contained in:
DESKTOP-1R2VSQH\Lenovo ThinkPad E490 2025-06-20 17:36:46 +07:00
parent 4c1c2c6084
commit e3d93ca713
11 changed files with 80 additions and 17 deletions

View file

@ -48,6 +48,7 @@ export default [
name: "masterPersonal", name: "masterPersonal",
component: personalPage, component: personalPage,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN"], Role: ["SUPER_ADMIN"],
}, },
}, },
@ -56,6 +57,7 @@ export default [
name: "masterPersonalDistrict", name: "masterPersonalDistrict",
component: personalDistrict, component: personalDistrict,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN"], Role: ["SUPER_ADMIN"],
}, },
}, },
@ -64,6 +66,7 @@ export default [
name: "masterPersonalSubDistrict", name: "masterPersonalSubDistrict",
component: personalSubDistrict, component: personalSubDistrict,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN"], Role: ["SUPER_ADMIN"],
}, },
}, },
@ -74,6 +77,7 @@ export default [
name: "masterPosition", name: "masterPosition",
component: positionPage, component: positionPage,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN"], Role: ["SUPER_ADMIN"],
}, },
}, },
@ -82,6 +86,7 @@ export default [
name: "masterPositionLevel", name: "masterPositionLevel",
component: positionLevelPage, component: positionLevelPage,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN"], Role: ["SUPER_ADMIN"],
}, },
}, },
@ -92,6 +97,7 @@ export default [
name: "masterPositionEmployee", name: "masterPositionEmployee",
component: positionEmployeePage, component: positionEmployeePage,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN"], Role: ["SUPER_ADMIN"],
}, },
}, },
@ -100,6 +106,7 @@ export default [
name: "masterPositionEmployeeLevel", name: "masterPositionEmployeeLevel",
component: positionEmployeeLevelPage, component: positionEmployeeLevelPage,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN"], Role: ["SUPER_ADMIN"],
}, },
}, },
@ -110,6 +117,7 @@ export default [
name: "masterCalendarWork", name: "masterCalendarWork",
component: calendarWorkPage, component: calendarWorkPage,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN"], Role: ["SUPER_ADMIN"],
}, },
}, },
@ -120,6 +128,7 @@ export default [
name: "masterInsigniaPage", name: "masterInsigniaPage",
component: masterInsignia, component: masterInsignia,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN"], Role: ["SUPER_ADMIN"],
}, },
}, },
@ -128,6 +137,7 @@ export default [
name: "masterInsigniadetail", name: "masterInsigniadetail",
component: detailInsignia, component: detailInsignia,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN"], Role: ["SUPER_ADMIN"],
}, },
}, },

View file

@ -1,3 +1,5 @@
import Auth from "@/views/auth.vue";
/** user*/ /** user*/
const ListsPageUser = () => import("@/modules/02_users/views/01_user.vue"); const ListsPageUser = () => import("@/modules/02_users/views/01_user.vue");
const PageManagementRole = () => const PageManagementRole = () =>
@ -31,6 +33,7 @@ export default [
name: "manageUsers", name: "manageUsers",
component: ListsPageUser, component: ListsPageUser,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN", "ADMIN"], Role: ["SUPER_ADMIN", "ADMIN"],
}, },
}, },
@ -39,6 +42,7 @@ export default [
name: "manageUsersRolesId", name: "manageUsersRolesId",
component: PageManagementRole, component: PageManagementRole,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN", "ADMIN"], Role: ["SUPER_ADMIN", "ADMIN"],
}, },
}, },
@ -47,6 +51,7 @@ export default [
name: "manageRoles", name: "manageRoles",
component: ListsPageRole, component: ListsPageRole,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN", "ADMIN"], Role: ["SUPER_ADMIN", "ADMIN"],
}, },
}, },
@ -56,6 +61,7 @@ export default [
name: "manageRolesId", name: "manageRolesId",
component: ListsPage2Role, component: ListsPage2Role,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN", "ADMIN"], Role: ["SUPER_ADMIN", "ADMIN"],
}, },
}, },
@ -65,6 +71,7 @@ export default [
name: "managePermission", name: "managePermission",
component: PermissionPage, component: PermissionPage,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN", "ADMIN"], Role: ["SUPER_ADMIN", "ADMIN"],
}, },
}, },
@ -74,6 +81,7 @@ export default [
name: "roleOrganization", name: "roleOrganization",
component: roleOrgview, component: roleOrgview,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN", "ADMIN"], Role: ["SUPER_ADMIN", "ADMIN"],
}, },
}, },
@ -82,6 +90,7 @@ export default [
name: "rolePositionSalary", name: "rolePositionSalary",
component: rolePositionSalary, component: rolePositionSalary,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN", "ADMIN"], Role: ["SUPER_ADMIN", "ADMIN"],
}, },
}, },
@ -91,6 +100,7 @@ export default [
name: "responsibilities", name: "responsibilities",
component: responsIbilitiesView, component: responsIbilitiesView,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN", "ADMIN"], Role: ["SUPER_ADMIN", "ADMIN"],
}, },
}, },

View file

@ -6,6 +6,7 @@ export default [
name: "viewLogs", name: "viewLogs",
component: ListsPage, component: ListsPage,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN", "ADMIN"], Role: ["SUPER_ADMIN", "ADMIN"],
}, },
}, },

View file

@ -6,6 +6,7 @@ export default [
name: "viewSystem", name: "viewSystem",
component: MainView, component: MainView,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN"], Role: ["SUPER_ADMIN"],
}, },
}, },

View file

@ -8,6 +8,7 @@ export default [
name: "commandTemplate", name: "commandTemplate",
component: ListsPage, component: ListsPage,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN"], Role: ["SUPER_ADMIN"],
}, },
}, },
@ -16,6 +17,7 @@ export default [
name: "salaryTemplate", name: "salaryTemplate",
component: SalaryTemplate, component: SalaryTemplate,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN"], Role: ["SUPER_ADMIN"],
}, },
}, },

View file

@ -6,6 +6,7 @@ export default [
name: "manageWebservices", name: "manageWebservices",
component: mainView, component: mainView,
meta: { meta: {
Auth: true,
Role: ["SUPER_ADMIN"], Role: ["SUPER_ADMIN"],
}, },
}, },

View file

@ -1,6 +1,7 @@
const ACCESS_TOKEN = "BMAHRISADM_KEYCLOAK_IDENTITY"; const ACCESS_TOKEN = "BMAHRISADM_KEYCLOAK_IDENTITY";
const key_C_Config = { const key_C_Config = {
url_Logout: import.meta.env.VITE_URL_SSO, url_Logout: import.meta.env.VITE_URL_SSO,
landing_PageUrl: import.meta.env.VITE_URL_LANDING,
}; };
interface AuthResponse { interface AuthResponse {
access_token: string; access_token: string;
@ -10,22 +11,32 @@ interface AuthResponse {
const authenticated = async () => ((await getToken()) ? true : false); const authenticated = async () => ((await getToken()) ? true : false);
async function setAuthen(r: AuthResponse, val: string) { async function setAuthen(r: AuthResponse, val: string, url?: string) {
await setCookie(ACCESS_TOKEN, r.access_token, r.expires_in); if (r && r.access_token) {
setCookie("SSO", val, r.expires_in); await setCookie(ACCESS_TOKEN, r.access_token, r.expires_in);
window.location.href = "/"; setCookie("SSO", val, r.expires_in);
window.location.href = url ? encodeURI(url) : "/";
}
} }
async function logout() { async function logout(force: boolean = false) {
await deleteCookie(ACCESS_TOKEN); if (!force) {
window.location.href = key_C_Config.url_Logout; await deleteCookie(ACCESS_TOKEN);
window.location.href = key_C_Config.url_Logout;
} else {
const currentUrl = window.location.href;
const loginUrl = `${
key_C_Config.landing_PageUrl
}?system=admin&redirectUrl=${encodeURIComponent(currentUrl)}`;
window.location.href = loginUrl;
}
} }
async function getToken() { async function getToken() {
return getCookie(ACCESS_TOKEN); return getCookie(ACCESS_TOKEN);
} }
// 2024-08-29T02:55:13.000Z // 2024-08-29T02:55:13.000Z
function setCookie(name: string, value: any, time: number) { async function setCookie(name: string, value: any, time: number) {
let expires = ""; let expires = "";
if (time) { if (time) {
const date = new Date(); const date = new Date();
@ -47,7 +58,7 @@ function getCookie(name: string) {
return null; return null;
} }
function deleteCookie(name: string) { async function deleteCookie(name: string) {
document.cookie = `${name}=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;`; document.cookie = `${name}=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;`;
} }
@ -71,4 +82,17 @@ async function tokenParsed() {
return JSON.parse(jsonPayload); return JSON.parse(jsonPayload);
} }
export { getToken, authenticated, logout, setAuthen, tokenParsed, getCookie }; async function redirectToLandingPage() {
await deleteCookie(ACCESS_TOKEN);
window.location.href = key_C_Config.landing_PageUrl;
}
export {
getToken,
authenticated,
logout,
setAuthen,
tokenParsed,
getCookie,
redirectToLandingPage,
};

View file

@ -33,9 +33,11 @@ http.interceptors.response.use(
function (error: any) { function (error: any) {
if (typeof error !== undefined) { if (typeof error !== undefined) {
// eslint-disable-next-line no-prototype-builtins // eslint-disable-next-line no-prototype-builtins
if (error.hasOwnProperty("response")) { if (error.hasOwnProperty("response")) {
if (error.response.status === 401 || error.response.status === 403) { if (error.response.status === 403) {
logout(); window.location.href = "/error";
// logout(true);
// Store.commit("SET_ERROR_MESSAGE", error.response.data.message); // Store.commit("SET_ERROR_MESSAGE", error.response.data.message);
// Store.commit("REMOVE_ACCESS_TOKEN") // Store.commit("REMOVE_ACCESS_TOKEN")
} }

View file

@ -95,7 +95,7 @@ router.beforeEach(async (to, from, next) => {
if (to.meta.Auth) { if (to.meta.Auth) {
const checkAuthen = await authenticated(); const checkAuthen = await authenticated();
if (!checkAuthen && to.meta.Auth) { if (!checkAuthen && to.meta.Auth) {
logout(); logout(true);
return; return;
} }
} }

View file

@ -6,7 +6,12 @@ import { useQuasar } from "quasar";
import { useRoute } from "vue-router"; import { useRoute } from "vue-router";
import config from "@/app.config"; import config from "@/app.config";
import http from "@/plugins/http"; import http from "@/plugins/http";
import { logout, tokenParsed, getCookie } from "@/plugins/auth"; import {
logout,
tokenParsed,
getCookie,
redirectToLandingPage,
} from "@/plugins/auth";
import checkPermission from "@/plugins/checkPermission"; import checkPermission from "@/plugins/checkPermission";
import { useCounterMixin } from "@/stores/mixin"; import { useCounterMixin } from "@/stores/mixin";
import { useDataStore } from "@/stores/data"; import { useDataStore } from "@/stores/data";
@ -627,7 +632,11 @@ onUnmounted(() => {
</div> --> </div> -->
<!-- <q-option-group v-model="group" :options="options" color="primary"/> --> <!-- <q-option-group v-model="group" :options="options" color="primary"/> -->
<q-list dense> <q-list dense>
<q-item clickable :href="landingPageUrl" v-if="isSsoToken"> <q-item
clickable
@click="redirectToLandingPage"
v-if="isSsoToken"
>
<q-item-section avatar> <q-item-section avatar>
<q-avatar <q-avatar
color="blue" color="blue"

View file

@ -1,7 +1,6 @@
<script setup lang="ts"> <script setup lang="ts">
import { onMounted } from "vue"; import { onMounted } from "vue";
import { useRoute } from "vue-router"; import { useRoute } from "vue-router";
import { setAuthen } from "@/plugins/auth"; import { setAuthen } from "@/plugins/auth";
const route = useRoute(); const route = useRoute();
@ -13,7 +12,11 @@ onMounted(async () => {
expires_in: route.query.expires ? route.query.expires : 36000, expires_in: route.query.expires ? route.query.expires : 36000,
refresh_token: route.query.accessToken, refresh_token: route.query.accessToken,
}; };
setAuthen(params, "y"); setAuthen(
params,
"y",
route.query.redirectUrl ? (route.query.redirectUrl as string) : "/"
);
} }
}); });
</script> </script>