useAppMaintenanceCheck.ts 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. // Copyright (C) 2012-2023 Zammad Foundation, https://zammad-foundation.org/
  2. import { onMounted, reactive, watch } from 'vue'
  3. import { useRouteQuery } from '@vueuse/router'
  4. import {
  5. useNotifications,
  6. NotificationTypes,
  7. } from '@shared/components/CommonNotifications'
  8. import { useApplicationBuildChecksumQuery } from '@shared/graphql/queries/applicationBuildChecksum.api'
  9. import { useAppMaintenanceSubscription } from '@shared/graphql/subscriptions/appMaintenance.api'
  10. import type {
  11. ApplicationBuildChecksumQuery,
  12. ApplicationBuildChecksumQueryVariables,
  13. AppMaintenanceSubscription,
  14. AppMaintenanceSubscriptionVariables,
  15. } from '@shared/graphql/types'
  16. import { EnumAppMaintenanceType } from '@shared/graphql/types'
  17. import {
  18. QueryHandler,
  19. SubscriptionHandler,
  20. } from '@shared/server/apollo/handler'
  21. import testFlags from '@shared/utils/testFlags'
  22. import { registerSW } from '@shared/sw/register'
  23. let checksumQuery: QueryHandler<
  24. ApplicationBuildChecksumQuery,
  25. ApplicationBuildChecksumQueryVariables
  26. >
  27. let previousChecksum: string
  28. let appMaintenanceSubscription: SubscriptionHandler<
  29. AppMaintenanceSubscription,
  30. AppMaintenanceSubscriptionVariables
  31. >
  32. const useAppMaintenanceCheck = () => {
  33. const updateServiceWorker = registerSW({
  34. path: '/mobile/sw.js',
  35. scope: '/mobile/',
  36. })
  37. const notify = (message: string, callback: () => void) => {
  38. useNotifications().notify({
  39. message,
  40. type: NotificationTypes.Warn,
  41. persistent: true,
  42. callback,
  43. })
  44. }
  45. onMounted(() => {
  46. if (checksumQuery) return
  47. // Default poll interval: every minute.
  48. const defaultPollInterval = 60 * 1000
  49. const applicationRebuildCheckInterval = useRouteQuery(
  50. 'ApplicationRebuildCheckInterval',
  51. defaultPollInterval.toString(),
  52. )
  53. const options = reactive({
  54. pollInterval: parseInt(applicationRebuildCheckInterval.value, 10),
  55. })
  56. watch(applicationRebuildCheckInterval, () => {
  57. options.pollInterval = parseInt(applicationRebuildCheckInterval.value, 10)
  58. })
  59. checksumQuery = new QueryHandler(useApplicationBuildChecksumQuery(options))
  60. const notificationMessage = __(
  61. 'A newer version of the app is available. Please reload at your earliest.',
  62. )
  63. checksumQuery.watchOnResult((queryResult): void => {
  64. if (!queryResult?.applicationBuildChecksum.length) return
  65. if (!previousChecksum) {
  66. previousChecksum = queryResult?.applicationBuildChecksum
  67. testFlags.set('useApplicationBuildChecksumQuery.firstResult')
  68. }
  69. if (queryResult?.applicationBuildChecksum !== previousChecksum) {
  70. notify(notificationMessage, () => {
  71. updateServiceWorker(true)
  72. })
  73. }
  74. })
  75. appMaintenanceSubscription = new SubscriptionHandler(
  76. useAppMaintenanceSubscription(),
  77. )
  78. appMaintenanceSubscription.onResult((result) => {
  79. const type = result.data?.appMaintenance.type
  80. let message = notificationMessage
  81. if (!type) {
  82. testFlags.set('useAppMaintenanceSubscription.subscribed')
  83. return
  84. }
  85. switch (type) {
  86. case EnumAppMaintenanceType.ConfigChanged:
  87. message = __(
  88. 'The configuration of Zammad has changed. Please reload at your earliest.',
  89. )
  90. break
  91. case EnumAppMaintenanceType.RestartAuto:
  92. case EnumAppMaintenanceType.RestartManual:
  93. // TODO: this case cannot be handled right now. Legacy interface performs a connectivity check.
  94. break
  95. default:
  96. break
  97. }
  98. notify(message, () => window.location.reload())
  99. })
  100. })
  101. }
  102. export default useAppMaintenanceCheck