aboutsummaryrefslogtreecommitdiffstats
path: root/apps
diff options
context:
space:
mode:
Diffstat (limited to 'apps')
-rw-r--r--apps/settings/src/store/app_api_apps.js399
1 files changed, 0 insertions, 399 deletions
diff --git a/apps/settings/src/store/app_api_apps.js b/apps/settings/src/store/app_api_apps.js
deleted file mode 100644
index 7470c8c44b1..00000000000
--- a/apps/settings/src/store/app_api_apps.js
+++ /dev/null
@@ -1,399 +0,0 @@
-/**
- * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
- * SPDX-License-Identifier: AGPL-3.0-or-later
- */
-
-import axios from '@nextcloud/axios'
-import api from './api.js'
-import Vue from 'vue'
-import { generateUrl } from '@nextcloud/router'
-import { showError, showInfo } from '@nextcloud/dialogs'
-import { loadState } from '@nextcloud/initial-state'
-
-const state = {
- apps: [],
- categories: [],
- updateCount: loadState('settings', 'appstoreExAppUpdateCount', 0),
- loading: {},
- loadingList: false,
- statusUpdater: null,
- gettingCategoriesPromise: null,
- daemonAccessible: loadState('settings', 'defaultDaemonConfigAccessible', false),
- defaultDaemon: loadState('settings', 'defaultDaemonConfig', null),
-}
-
-const mutations = {
-
- APPS_API_FAILURE(state, error) {
- showError(t('settings', 'An error occurred during the request. Unable to proceed.') + '<br>' + error.error.response.data.data.message, { isHTML: true })
- console.error(state, error)
- },
-
- initCategories(state, { categories, updateCount }) {
- state.categories = categories
- state.updateCount = updateCount
- },
-
- updateCategories(state, categoriesPromise) {
- state.gettingCategoriesPromise = categoriesPromise
- },
-
- setUpdateCount(state, updateCount) {
- state.updateCount = updateCount
- },
-
- addCategory(state, category) {
- state.categories.push(category)
- },
-
- appendCategories(state, categoriesArray) {
- // convert obj to array
- state.categories = categoriesArray
- },
-
- setAllApps(state, apps) {
- state.apps = apps
- },
-
- setError(state, { appId, error }) {
- if (!Array.isArray(appId)) {
- appId = [appId]
- }
- appId.forEach((_id) => {
- const app = state.apps.find(app => app.id === _id)
- app.error = error
- })
- },
-
- enableApp(state, { appId }) {
- const app = state.apps.find(app => app.id === appId)
- if (!app.installed) {
- app.installed = true
- app.needsDownload = false
- app.daemon = state.defaultDaemon
- app.status = {
- type: 'install',
- action: 'deploy',
- init: 0,
- deploy: 0,
- }
- }
- app.active = true
- app.canUnInstall = false
- app.removable = true
- app.error = null
- },
-
- disableApp(state, appId) {
- const app = state.apps.find(app => app.id === appId)
- app.active = false
- if (app.removable) {
- app.canUnInstall = true
- }
- },
-
- uninstallApp(state, appId) {
- state.apps.find(app => app.id === appId).active = false
- state.apps.find(app => app.id === appId).needsDownload = true
- state.apps.find(app => app.id === appId).installed = false
- state.apps.find(app => app.id === appId).canUnInstall = false
- state.apps.find(app => app.id === appId).canInstall = true
- state.apps.find(app => app.id === appId).daemon = null
- state.apps.find(app => app.id === appId).status = {}
- if (state.apps.find(app => app.id === appId).update !== null) {
- state.updateCount--
- }
- state.apps.find(app => app.id === appId).update = null
- },
-
- updateApp(state, { appId }) {
- const app = state.apps.find(app => app.id === appId)
- const version = app.update
- app.update = null
- app.version = version
- app.status = {
- type: 'update',
- action: 'deploy',
- init: 0,
- deploy: 0,
- }
- app.error = null
- state.updateCount--
- },
-
- startLoading(state, id) {
- Vue.set(state.loading, id, true) // eslint-disable-line
- },
-
- stopLoading(state, id) {
- Vue.set(state.loading, id, false) // eslint-disable-line
- },
-
- setAppStatus(state, { appId, status }) {
- const app = state.apps.find(app => app.id === appId)
- if (status.type === 'install' && status.deploy === 100 && status.action === '') {
- console.debug('catching intermediate state deploying -> initializing')
- // catching moment when app is deployed but initialization status not started yet
- status.action = 'init'
- app.canUnInstall = true
- }
- if (status.error !== '') {
- app.error = status.error
- app.canUnInstall = true
- }
- if (status.deploy === 100 && status.init === 100) {
- app.active = true
- app.canUnInstall = false
- app.removable = true
- }
- app.status = status
- },
-
- setIntervalUpdater(state, updater) {
- state.statusUpdater = updater
- },
-}
-
-const getters = {
- loading(state) {
- return function(id) {
- return state.loading[id]
- }
- },
- getCategories(state) {
- return state.categories
- },
- getAllApps(state) {
- return state.apps
- },
- getUpdateCount(state) {
- return state.updateCount
- },
- getCategoryById: (state) => (selectedCategoryId) => {
- return state.categories.find((category) => category.id === selectedCategoryId)
- },
- getDaemonAccessible(state) {
- return state.daemonAccessible
- },
- getAppStatus(state) {
- return function(appId) {
- return state.apps.find(app => app.id === appId).status
- }
- },
- getStatusUpdater(state) {
- return state.statusUpdater
- },
- getInitializingOrDeployingApps(state) {
- return state.apps.filter(app => Object.hasOwn(app.status, 'action')
- && (app.status.action === 'deploy' || app.status.action === 'init' || app.status.action === 'healthcheck')
- && app.status.type !== '')
- },
-}
-
-const actions = {
-
- enableApp(context, { appId }) {
- return api.requireAdmin().then((response) => {
- context.commit('startLoading', appId)
- context.commit('startLoading', 'install')
- return axios.post(generateUrl(`/apps/app_api/apps/enable/${appId}`))
- .then((response) => {
- context.commit('stopLoading', appId)
- context.commit('stopLoading', 'install')
-
- context.commit('enableApp', { appId })
-
- context.dispatch('updateAppsStatus')
-
- // check for server health
- return axios.get(generateUrl('apps/files'))
- .then(() => {
- if (response.data.update_required) {
- showInfo(
- t(
- 'app_api',
- 'The app has been enabled but needs to be updated.',
- ),
- {
- onClick: () => window.location.reload(),
- close: false,
- },
- )
- setTimeout(function() {
- location.reload()
- }, 5000)
- }
- })
- .catch(() => {
- context.commit('setError', {
- appId: [appId],
- error: t('settings', 'Error: This app cannot be enabled because it makes the server unstable'),
- })
- })
- })
- .catch((error) => {
- context.commit('stopLoading', appId)
- context.commit('stopLoading', 'install')
- context.commit('setError', {
- appId: [appId],
- error: error.response.data.data.message,
- })
- context.commit('APPS_API_FAILURE', { appId, error })
- })
- }).catch((error) => context.commit('API_FAILURE', { appId, error }, { root: true }))
- },
-
- forceEnableApp(context, { appId }) {
- return api.requireAdmin().then(() => {
- context.commit('startLoading', appId)
- context.commit('startLoading', 'install')
- return api.post(generateUrl('/apps/app_api/apps/force'), { appId })
- .then((response) => {
- location.reload()
- })
- .catch((error) => {
- context.commit('stopLoading', appId)
- context.commit('stopLoading', 'install')
- context.commit('setError', {
- appId: [appId],
- error: error.response.data.data.message,
- })
- context.commit('APPS_API_FAILURE', { appId, error })
- })
- }).catch((error) => context.commit('API_FAILURE', { appId, error }, { root: true }))
- },
-
- disableApp(context, { appId }) {
- return api.requireAdmin().then((response) => {
- context.commit('startLoading', appId)
- return api.get(generateUrl(`apps/app_api/apps/disable/${appId}`))
- .then((response) => {
- context.commit('stopLoading', appId)
- context.commit('disableApp', appId)
- return true
- })
- .catch((error) => {
- context.commit('disableApp', appId)
- context.commit('stopLoading', appId)
- context.commit('APPS_API_FAILURE', { appId, error })
- })
- }).catch((error) => context.commit('API_FAILURE', { appId, error }, { root: true }))
- },
-
- uninstallApp(context, { appId, removeData }) {
- return api.requireAdmin().then((response) => {
- context.commit('startLoading', appId)
- return api.get(generateUrl(`/apps/app_api/apps/uninstall/${appId}?removeData=${removeData}`))
- .then((response) => {
- context.commit('stopLoading', appId)
- context.commit('uninstallApp', appId)
- return true
- })
- .catch((error) => {
- context.commit('stopLoading', appId)
- context.commit('APPS_API_FAILURE', { appId, error })
- })
- }).catch((error) => context.commit('API_FAILURE', { appId, error }, { root: true }))
- },
-
- updateApp(context, { appId }) {
- return api.requireAdmin().then((response) => {
- context.commit('startLoading', appId)
- context.commit('startLoading', 'install')
- return api.get(generateUrl(`/apps/app_api/apps/update/${appId}`))
- .then((response) => {
- context.commit('stopLoading', 'install')
- context.commit('stopLoading', appId)
- context.commit('updateApp', { appId })
- context.dispatch('updateAppsStatus')
- return true
- })
- .catch((error) => {
- context.commit('stopLoading', appId)
- context.commit('stopLoading', 'install')
- context.commit('APPS_API_FAILURE', { appId, error })
- })
- }).catch((error) => context.commit('API_FAILURE', { appId, error }, { root: true }))
- },
-
- getAllApps(context) {
- context.commit('startLoading', 'list')
- return api.get(generateUrl('/apps/app_api/apps/list'))
- .then((response) => {
- context.commit('setAllApps', response.data.apps)
- context.commit('stopLoading', 'list')
- return true
- })
- .catch((error) => context.commit('API_FAILURE', error, { root: true }))
- },
-
- async getCategories(context, { shouldRefetchCategories = false } = {}) {
- if (shouldRefetchCategories || !context.state.gettingCategoriesPromise) {
- context.commit('startLoading', 'categories')
- try {
- const categoriesPromise = api.get(generateUrl('/apps/app_api/apps/categories'))
- context.commit('updateCategories', categoriesPromise)
- const categoriesPromiseResponse = await categoriesPromise
- if (categoriesPromiseResponse.data.length > 0) {
- context.commit('appendCategories', categoriesPromiseResponse.data)
- context.commit('stopLoading', 'categories')
- return true
- }
- context.commit('stopLoading', 'categories')
- return false
- } catch (error) {
- context.commit('API_FAILURE', error, { root: true })
- }
- }
- return context.state.gettingCategoriesPromise
- },
-
- getAppStatus(context, { appId }) {
- return api.get(generateUrl(`/apps/app_api/apps/status/${appId}`))
- .then((response) => {
- context.commit('setAppStatus', { appId, status: response.data })
- const initializingOrDeployingApps = context.getters.getInitializingOrDeployingApps
- console.debug('initializingOrDeployingApps after setAppStatus', initializingOrDeployingApps)
- if (initializingOrDeployingApps.length === 0) {
- console.debug('clearing interval')
- clearInterval(context.getters.getStatusUpdater)
- context.commit('setIntervalUpdater', null)
- }
- if (Object.hasOwn(response.data, 'error')
- && response.data.error !== ''
- && initializingOrDeployingApps.length === 1) {
- clearInterval(context.getters.getStatusUpdater)
- context.commit('setIntervalUpdater', null)
- }
- })
- .catch((error) => {
- context.commit('API_FAILURE', error, { root: true })
- context.commit('unregisterApp', { appId })
- context.dispatch('updateAppsStatus')
- })
- },
-
- updateAppsStatus(context) {
- clearInterval(context.getters.getStatusUpdater) // clear previous interval if exists
- const initializingOrDeployingApps = context.getters.getInitializingOrDeployingApps
- if (initializingOrDeployingApps.length === 0) {
- return
- }
- context.commit('setIntervalUpdater', setInterval(() => {
- const initializingOrDeployingApps = context.getters.getInitializingOrDeployingApps
- console.debug('initializingOrDeployingApps', initializingOrDeployingApps)
- Array.from(initializingOrDeployingApps).forEach(app => {
- context.dispatch('getAppStatus', { appId: app.id })
- })
- }, 2000))
- },
-
-}
-
-export default {
- namespaced: true, // we will use AppAPI store module explicitly, since methods names are the same, we need to scope it
- state,
- mutations,
- getters,
- actions,
-}