accessProfile.ts 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279
  1. import { defineStore } from 'pinia'
  2. import {$roleUtils} from "~/services/rights/roleUtils";
  3. import {
  4. AbilitiesType,
  5. baseAccessState,
  6. baseOrganizationState,
  7. OrignalAccessState
  8. } from "~/types/interfaces";
  9. import {computed, ref, Ref} from "@vue/reactivity";
  10. import {useEach} from "#imports";
  11. import {useAbility} from "@casl/vue";
  12. import {useOrganizationProfileStore} from "~/stores/organizationProfile";
  13. export const useAccessProfileStore = defineStore('accessProfile', () => {
  14. // State
  15. const bearer: Ref<string | null> = ref(null)
  16. const id: Ref<number | null> = ref(null)
  17. const switchId: Ref<number | null> = ref(null)
  18. const name: Ref<string | null> = ref(null)
  19. const givenName: Ref<string | null> = ref(null)
  20. const gender: Ref<string | null> = ref(null)
  21. const avatarId: Ref<number | null> = ref(null)
  22. const activityYear: Ref<number | null> = ref(null)
  23. const historical = ref([])
  24. const roles: Ref<Array<string>> = ref([])
  25. const abilities: Ref<Array<AbilitiesType>> = ref([])
  26. const isAdminAccess: Ref<boolean | null> = ref(false)
  27. const isSuperAdminAccess: Ref<boolean | null> = ref(false)
  28. const isAdmin: Ref<boolean | null> = ref(false)
  29. const isAdministratifManager: Ref<boolean | null> = ref(false)
  30. const isPedagogicManager: Ref<boolean | null> = ref(false)
  31. const isFinancialManager: Ref<boolean | null> = ref(false)
  32. const isCaMember: Ref<boolean | null> = ref(false)
  33. const isStudent: Ref<boolean | null> = ref(false)
  34. const isTeacher: Ref<boolean | null> = ref(false)
  35. const isMember: Ref<boolean | null> = ref(false)
  36. const isOther: Ref<boolean | null> = ref(false)
  37. const isGuardian: Ref<boolean | null> = ref(false)
  38. const isPayer: Ref<boolean | null> = ref(false)
  39. const multiAccesses: Ref<Array<baseOrganizationState>> = ref([])
  40. const familyAccesses: Ref<Array<baseAccessState>> = ref([])
  41. const originalAccess = ref(null)
  42. // Getters
  43. /**
  44. * Est-ce que l'utilisateur possède un compte administrateur
  45. * @return {boolean}
  46. */
  47. const isAdminAccount = computed((): boolean => {
  48. return isAdminAccess.value ?? false
  49. })
  50. /**
  51. * Retourne l'id de la session en cours
  52. * @return {boolean}
  53. */
  54. const currentAccessId = computed((): number => {
  55. return switchId.value ?? (id.value ?? 0)
  56. })
  57. // Actions
  58. const setMultiAccesses = (organizations: any) => {
  59. useEach(organizations, (organization: baseOrganizationState) => {
  60. multiAccesses.value.push({
  61. id: organization.id,
  62. name: organization.name
  63. })
  64. })
  65. }
  66. const setFamilyAccesses = (accesses: any) => {
  67. useEach(accesses, (access: baseAccessState) => {
  68. const a: baseAccessState = {
  69. id: access.id,
  70. name: access.name,
  71. givenName: access.givenName,
  72. gender: access.gender,
  73. avatarId: access.avatarId
  74. }
  75. familyAccesses.value.push(a)
  76. })
  77. }
  78. const setProfile = (profile: any) => {
  79. const profileRoles: Array<string> = Object.values(profile.roles)
  80. name.value = profile.name
  81. givenName.value = profile.givenName
  82. gender.value = profile.gender
  83. avatarId.value = profile.avatarId
  84. activityYear.value = profile.activityYear
  85. historical.value = profile.historical
  86. isAdminAccess.value = profile.isAdminAccess
  87. isAdmin.value = $roleUtils.isA('ADMIN', profileRoles)
  88. isAdministratifManager.value = $roleUtils.isA('ADMINISTRATIF_MANAGER', profileRoles)
  89. isPedagogicManager.value = $roleUtils.isA('PEDAGOGICS_MANAGER', profileRoles)
  90. isFinancialManager.value = $roleUtils.isA('FINANCIAL_MANAGER', profileRoles)
  91. isCaMember.value = $roleUtils.isA('CA', profileRoles)
  92. isStudent.value = $roleUtils.isA('STUDENT', profileRoles)
  93. isTeacher.value = $roleUtils.isA('TEACHER', profileRoles)
  94. isMember.value = $roleUtils.isA('MEMBER', profileRoles)
  95. isOther.value = $roleUtils.isA('OTHER', profileRoles)
  96. isGuardian.value = profile.isGuardian
  97. isPayer.value = profile.isPayor
  98. roles.value = $roleUtils.filterFunctionRoles(profileRoles)
  99. // Time to add the original Access (switch User case)
  100. originalAccess.value = profile.originalAccess
  101. // Time to set Multi Accesses
  102. setMultiAccesses(profile.multiAccesses)
  103. // Time to set Family Accesses
  104. setFamilyAccesses(profile.familyAccesses)
  105. // Time to set Organization Profile
  106. const organizationProfileStore = useOrganizationProfileStore()
  107. organizationProfileStore.setProfile(profile.organization)
  108. }
  109. const refreshProfile = (profile: any) => {
  110. name.value = profile.name
  111. givenName.value = profile.givenName
  112. gender.value = profile.gender
  113. avatarId.value = profile.avatarId
  114. activityYear.value = profile.activityYear
  115. const organizationProfileStore = useOrganizationProfileStore()
  116. organizationProfileStore.refreshProfile(profile.organization)
  117. }
  118. const setOriginalAccess = (access: any) => {
  119. if (access) {
  120. const organization: baseOrganizationState = {
  121. id: access.organization.id,
  122. name: access.organization.name
  123. }
  124. const originalAccess: OrignalAccessState = {
  125. id: access.id,
  126. name: access.name,
  127. givenName: access.givenName,
  128. gender: access.gender,
  129. isSuperAdminAccess: access.isSuperAdminAccess,
  130. avatarId: access.avatarId,
  131. organization: organization
  132. }
  133. setOriginalAccess(originalAccess)
  134. }
  135. }
  136. /**
  137. * Teste le profil d'un utilisateur
  138. *
  139. * @param {string} profile : profile à tester
  140. * @return {boolean}
  141. */
  142. const testProfile = (profile:string): boolean => {
  143. const factory: {[key: string]: boolean|null} = {
  144. 'admin': isAdmin.value,
  145. 'administratifManager': isAdministratifManager.value,
  146. 'pedagogicManager': isPedagogicManager.value,
  147. 'financialManager': isFinancialManager.value,
  148. 'caMember': isCaMember.value,
  149. 'student': isStudent.value,
  150. 'teacher': isTeacher.value,
  151. 'member': isMember.value,
  152. 'other': isOther.value,
  153. 'guardian': isGuardian.value,
  154. 'payor': isPayer.value,
  155. }
  156. if (!(profile in factory)) {
  157. return false
  158. }
  159. return factory[profile] ?? false
  160. }
  161. /**
  162. * Retourne vrai si l'utilisateur connecté possède l'un des profils passés en paramètre
  163. *
  164. * @param {Array<string>} profiles Profils à tester
  165. * @return {boolean}
  166. */
  167. const hasProfile = (profiles: Array<string>|null): boolean => {
  168. if (null === profiles)
  169. return true;
  170. let hasProfile = false;
  171. profiles.map(async (profile) => {
  172. if (testProfile(profile))
  173. hasProfile = true;
  174. });
  175. return hasProfile;
  176. }
  177. /**
  178. * Est-ce que l'utilisateur possède l'habilité
  179. *
  180. * @param {Array<AbilitiesType>} abilities Habilités à tester
  181. * @return {boolean}
  182. */
  183. const hasAbility = (abilities: Array<AbilitiesType>|null): boolean => {
  184. if(abilities === null)
  185. return true;
  186. const { can } = useAbility()
  187. let hasAbility= false;
  188. abilities.map((ability) => {
  189. if (can(ability.action, ability.subject))
  190. hasAbility = true;
  191. });
  192. return hasAbility;
  193. }
  194. /**
  195. * Est-ce que l'utilisateur possède le ou les rôles donnés ?
  196. *
  197. * @param {Array<string>} roles Rôles à tester
  198. * @return {boolean}
  199. */
  200. const hasRole = computed((rolesToTest: Array<string>|null): boolean => {
  201. if (rolesToTest === null) {
  202. return true
  203. }
  204. rolesToTest.map((r) => {
  205. if (roles.value.includes(r)) {
  206. return true
  207. }
  208. })
  209. return false
  210. })
  211. return {
  212. bearer,
  213. id,
  214. switchId,
  215. name,
  216. givenName,
  217. gender,
  218. avatarId,
  219. activityYear,
  220. historical,
  221. roles,
  222. abilities,
  223. isAdminAccess,
  224. isSuperAdminAccess,
  225. isAdmin,
  226. isAdministratifManager,
  227. isPedagogicManager,
  228. isFinancialManager,
  229. isCaMember,
  230. isStudent,
  231. isTeacher,
  232. isMember,
  233. isOther,
  234. isGuardian,
  235. isPayer,
  236. multiAccesses,
  237. familyAccesses,
  238. originalAccess,
  239. isAdminAccount,
  240. currentAccessId,
  241. setMultiAccesses,
  242. setFamilyAccesses,
  243. setProfile,
  244. refreshProfile,
  245. setOriginalAccess,
  246. hasProfile,
  247. hasAbility,
  248. hasRole,
  249. }
  250. })