access.ts 7.6 KB

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