api refactoring

This commit is contained in:
Čarodej
2022-05-11 09:19:55 +02:00
parent d2371e667f
commit 70901a2df5
59 changed files with 861 additions and 578 deletions
+1 -1
View File
@@ -1,6 +1,6 @@
APP_NAME=Laravel APP_NAME=Laravel
APP_ENV=local APP_ENV=local
APP_KEY=base64:7BmLEVLO3kx5hHcR3MlXZIg89wr5pMu9NOipcxttmaU= APP_KEY=base64:8yxp90qaG22isu7sxy8zfiuGvkXoAzJBtdr3/ztuH7w=
APP_DEBUG=true APP_DEBUG=true
APP_URL=http://localhost APP_URL=http://localhost
APP_DEMO=false APP_DEMO=false
+30 -29
View File
@@ -1,35 +1,35 @@
{ {
"/js/main.js": "/js/main.js", "/js/main.js": "/js/main.js",
"/chunks/request.js": "/chunks/request.js?id=e2e83e87b1f6d097", "/chunks/request.js": "/chunks/request.js?id=f5c1db9739c4c1c0",
"/chunks/request-upload.js": "/chunks/request-upload.js?id=3bc3423d2305cd30", "/chunks/request-upload.js": "/chunks/request-upload.js?id=1201e261c848a844",
"/chunks/setup-wizard.js": "/chunks/setup-wizard.js?id=19a0784e59d768ec", "/chunks/setup-wizard.js": "/chunks/setup-wizard.js?id=19a0784e59d768ec",
"/chunks/status-check.js": "/chunks/status-check.js?id=9239a586761b912d", "/chunks/status-check.js": "/chunks/status-check.js?id=a5ba5fb895af7040",
"/chunks/purchase-code.js": "/chunks/purchase-code.js?id=ba76b9a8adbfdc0b", "/chunks/purchase-code.js": "/chunks/purchase-code.js?id=ba76b9a8adbfdc0b",
"/chunks/database.js": "/chunks/database.js?id=5113b0d4284f764f", "/chunks/database.js": "/chunks/database.js?id=9d365d9b60a201dd",
"/chunks/environment.js": "/chunks/environment.js?id=e4fdb87ff173d48a", "/chunks/environment.js": "/chunks/environment.js?id=e4fdb87ff173d48a",
"/chunks/app-setup.js": "/chunks/app-setup.js?id=cbe7bfed06400736", "/chunks/app-setup.js": "/chunks/app-setup.js?id=cbe7bfed06400736",
"/chunks/admin-account.js": "/chunks/admin-account.js?id=78d257775f5fc485", "/chunks/admin-account.js": "/chunks/admin-account.js?id=78d257775f5fc485",
"/chunks/shared.js": "/chunks/shared.js?id=0c2f68a87ccf9be3", "/chunks/shared.js": "/chunks/shared.js?id=2fba310a3f0823f9",
"/chunks/shared/browser.js": "/chunks/shared/browser.js?id=3fd9baddb7333c24", "/chunks/shared/browser.js": "/chunks/shared/browser.js?id=ebf193e6828917dc",
"/chunks/shared/single-file.js": "/chunks/shared/single-file.js?id=a6063bed9be75a09", "/chunks/shared/single-file.js": "/chunks/shared/single-file.js?id=e1ca697ccf4363dc",
"/chunks/shared/authenticate.js": "/chunks/shared/authenticate.js?id=b5519d193bce2339", "/chunks/shared/authenticate.js": "/chunks/shared/authenticate.js?id=b5519d193bce2339",
"/chunks/not-found.js": "/chunks/not-found.js?id=d31bd699138cf828", "/chunks/not-found.js": "/chunks/not-found.js?id=d31bd699138cf828",
"/chunks/temporary-unavailable.js": "/chunks/temporary-unavailable.js?id=26798085f527d955", "/chunks/temporary-unavailable.js": "/chunks/temporary-unavailable.js?id=26798085f527d955",
"/chunks/admin.js": "/chunks/admin.js?id=ac53badd82034a88", "/chunks/admin.js": "/chunks/admin.js?id=1eece624920f98df",
"/chunks/dashboard.js": "/chunks/dashboard.js?id=5ab55a12214433c8", "/chunks/dashboard.js": "/chunks/dashboard.js?id=5ab55a12214433c8",
"/chunks/invoices.js": "/chunks/invoices.js?id=799928609f57ca10", "/chunks/invoices.js": "/chunks/invoices.js?id=799928609f57ca10",
"/chunks/subscriptions.js": "/chunks/subscriptions.js?id=a0c4f59d0ec4aee0", "/chunks/subscriptions.js": "/chunks/subscriptions.js?id=a0c4f59d0ec4aee0",
"/chunks/pages.js": "/chunks/pages.js?id=bb5cc8327ca846a3", "/chunks/pages.js": "/chunks/pages.js?id=bb5cc8327ca846a3",
"/chunks/page-edit.js": "/chunks/page-edit.js?id=0bdc8a5935fd2197", "/chunks/page-edit.js": "/chunks/page-edit.js?id=0bdc8a5935fd2197",
"/chunks/plans.js": "/chunks/plans.js?id=76398906ad873fc3", "/chunks/plans.js": "/chunks/plans.js?id=d4e39044c5fc0ad4",
"/chunks/users.js": "/chunks/users.js?id=b6629338e26b8313", "/chunks/users.js": "/chunks/users.js?id=b6629338e26b8313",
"/chunks/user-create.js": "/chunks/user-create.js?id=40254ae98547761e", "/chunks/user-create.js": "/chunks/user-create.js?id=40254ae98547761e",
"/chunks/plan-create/fixed.js": "/chunks/plan-create/fixed.js?id=18f9d1ab17996507", "/chunks/plan-create/fixed.js": "/chunks/plan-create/fixed.js?id=549867504d6e4e4e",
"/chunks/plan-create/metered.js": "/chunks/plan-create/metered.js?id=40e9f287b5258a40", "/chunks/plan-create/metered.js": "/chunks/plan-create/metered.js?id=40e9f287b5258a40",
"/chunks/user.js": "/chunks/user.js?id=cf9a2a0d8c1fa1d9", "/chunks/user.js": "/chunks/user.js?id=cf9a2a0d8c1fa1d9",
"/chunks/user-detail.js": "/chunks/user-detail.js?id=ff6c1fc63a372d96", "/chunks/user-detail.js": "/chunks/user-detail.js?id=ff6c1fc63a372d96",
"/chunks/user-storage.js": "/chunks/user-storage.js?id=4f76194837113969", "/chunks/user-storage.js": "/chunks/user-storage.js?id=0e26321285c15e1a",
"/chunks/user-subscription.js": "/chunks/user-subscription.js?id=797d77ff2b1c08cc", "/chunks/user-subscription.js": "/chunks/user-subscription.js?id=189de61fad1cd281",
"/chunks/user-password.js": "/chunks/user-password.js?id=900ae71c3d4199ea", "/chunks/user-password.js": "/chunks/user-password.js?id=900ae71c3d4199ea",
"/chunks/user-delete.js": "/chunks/user-delete.js?id=a3091617207684e5", "/chunks/user-delete.js": "/chunks/user-delete.js?id=a3091617207684e5",
"/chunks/plan.js": "/chunks/plan.js?id=3e7b0b34c2247e6c", "/chunks/plan.js": "/chunks/plan.js?id=3e7b0b34c2247e6c",
@@ -38,38 +38,39 @@
"/chunks/plan-delete.js": "/chunks/plan-delete.js?id=630deb1fc4e17ed9", "/chunks/plan-delete.js": "/chunks/plan-delete.js?id=630deb1fc4e17ed9",
"/chunks/payments.js": "/chunks/payments.js?id=d59a2a18b680d65c", "/chunks/payments.js": "/chunks/payments.js?id=d59a2a18b680d65c",
"/chunks/payments/billings.js": "/chunks/payments/billings.js?id=27d6c1b58dbd1e6c", "/chunks/payments/billings.js": "/chunks/payments/billings.js?id=27d6c1b58dbd1e6c",
"/chunks/payments/settings.js": "/chunks/payments/settings.js?id=450162f937b7b2fd", "/chunks/payments/settings.js": "/chunks/payments/settings.js?id=f940f2c965eb41eb",
"/chunks/app-settings.js": "/chunks/app-settings.js?id=b0d1082fdcbbd17c", "/chunks/app-settings.js": "/chunks/app-settings.js?id=b0d1082fdcbbd17c",
"/chunks/app-appearance.js": "/chunks/app-appearance.js?id=8ba3feb2cc81a2c3", "/chunks/app-appearance.js": "/chunks/app-appearance.js?id=8ba3feb2cc81a2c3",
"/chunks/app-index.js": "/chunks/app-index.js?id=0c50096e8de09288", "/chunks/app-index.js": "/chunks/app-index.js?id=0c50096e8de09288",
"/chunks/app-environment.js": "/chunks/app-environment.js?id=3436286fd625f8b7", "/chunks/app-environment.js": "/chunks/app-environment.js?id=3436286fd625f8b7",
"/chunks/app-others.js": "/chunks/app-others.js?id=dd23507db4551d0a", "/chunks/app-others.js": "/chunks/app-others.js?id=dd23507db4551d0a",
"/chunks/app-sign-in-out.js": "/chunks/app-sign-in-out.js?id=f79027ce1f1f4c4b", "/chunks/app-sign-in-out.js": "/chunks/app-sign-in-out.js?id=77ac953ce49b5b55",
"/chunks/app-adsense.js": "/chunks/app-adsense.js?id=c7e7dc2975317062", "/chunks/app-adsense.js": "/chunks/app-adsense.js?id=c7e7dc2975317062",
"/chunks/app-server.js": "/chunks/app-server.js?id=ff66d34e90ff98a0", "/chunks/app-server.js": "/chunks/app-server.js?id=ff66d34e90ff98a0",
"/chunks/app-language.js": "/chunks/app-language.js?id=46d7fc713d36cea8", "/chunks/app-language.js": "/chunks/app-language.js?id=46d7fc713d36cea8",
"/chunks/homepage.js": "/chunks/homepage.js?id=0dabc3156ab1336c", "/chunks/homepage.js": "/chunks/homepage.js?id=55c3e017e2a12876",
"/chunks/dynamic-page.js": "/chunks/dynamic-page.js?id=9553d7a2912cb901", "/chunks/dynamic-page.js": "/chunks/dynamic-page.js?id=9553d7a2912cb901",
"/chunks/contact-us.js": "/chunks/contact-us.js?id=ea99d85aa3500595", "/chunks/contact-us.js": "/chunks/contact-us.js?id=ea99d85aa3500595",
"/chunks/successfully-email-verified.js": "/chunks/successfully-email-verified.js?id=c26cb144101e7c79", "/chunks/successfully-email-verified.js": "/chunks/successfully-email-verified.js?id=c26cb144101e7c79",
"/chunks/successfully-email-send.js": "/chunks/successfully-email-send.js?id=170d814982e1c475", "/chunks/successfully-email-send.js": "/chunks/successfully-email-send.js?id=170d814982e1c475",
"/chunks/sign-in.js": "/chunks/sign-in.js?id=c648cb698176a993", "/chunks/sign-in.js": "/chunks/sign-in.js?id=1631a0f4a4ad25c2",
"/chunks/sign-up.js": "/chunks/sign-up.js?id=3d7559511768cd0e", "/chunks/sign-up.js": "/chunks/sign-up.js?id=2af6073efe54c560",
"/chunks/forgotten-password.js": "/chunks/forgotten-password.js?id=27cda9364b6593d8", "/chunks/forgotten-password.js": "/chunks/forgotten-password.js?id=ff8954243e86c1e1",
"/chunks/create-new-password.js": "/chunks/create-new-password.js?id=2f0401ee2fc148c4", "/chunks/create-new-password.js": "/chunks/create-new-password.js?id=2f0401ee2fc148c4",
"/chunks/settings.js": "/chunks/settings.js?id=2f1ec837e7673e6d", "/chunks/settings.js": "/chunks/settings.js?id=83d20f90399191b9",
"/chunks/profile.js": "/chunks/profile.js?id=3e24bb5e1f52d4bb", "/chunks/profile.js": "/chunks/profile.js?id=3e24bb5e1f52d4bb",
"/chunks/settings-password.js": "/chunks/settings-password.js?id=d00bf503d8126dc4", "/chunks/settings-password.js": "/chunks/settings-password.js?id=d00bf503d8126dc4",
"/chunks/settings-storage.js": "/chunks/settings-storage.js?id=092e324aad54656b", "/chunks/settings-storage.js": "/chunks/settings-storage.js?id=ecfee7f7e98204f8",
"/chunks/billing.js": "/chunks/billing.js?id=115c25478cee576d", "/chunks/billing.js": "/chunks/billing.js?id=a21fc7e052c60acd",
"/chunks/platform.js": "/chunks/platform.js?id=d4e8d92aed88b8ee", "/chunks/platform.js": "/chunks/platform.js?id=4c28a2760f5cd8ea",
"/chunks/files.js": "/chunks/files.js?id=a74bc8acc7ea876a", "/chunks/files.js": "/chunks/files.js?id=5f29f35c280e680b",
"/chunks/recent-uploads.js": "/chunks/recent-uploads.js?id=c6ed26eaace65f01", "/chunks/recent-uploads.js": "/chunks/recent-uploads.js?id=6f43aea38e0927bc",
"/chunks/my-shared-items.js": "/chunks/my-shared-items.js?id=6adbb309c700eaf7", "/chunks/my-shared-items.js": "/chunks/my-shared-items.js?id=6e819ffe88a0fd1d",
"/chunks/trash.js": "/chunks/trash.js?id=32b84e2c25561372", "/chunks/trash.js": "/chunks/trash.js?id=1885832b8dd60529",
"/chunks/team-folders.js": "/chunks/team-folders.js?id=dc85357a1433f4e4", "/chunks/team-folders.js": "/chunks/team-folders.js?id=709509b3e2dd2bf5",
"/chunks/shared-with-me.js": "/chunks/shared-with-me.js?id=3168dd6a723f72f1", "/chunks/shared-with-me.js": "/chunks/shared-with-me.js?id=e86d3c1f72e6fde2",
"/chunks/invitation.js": "/chunks/invitation.js?id=424b2783d9785a09", "/chunks/invitation.js": "/chunks/invitation.js?id=424b2783d9785a09",
"/css/tailwind.css": "/css/tailwind.css", "/css/tailwind.css": "/css/tailwind.css",
"/css/app.css": "/css/app.css" "/css/app.css": "/css/app.css",
"/chunks/demo.js": "/chunks/demo.js?id=355303e4230cb5ae"
} }
+1 -4
View File
@@ -116,11 +116,8 @@ export default {
config: this.$root.$data.config, config: this.$root.$data.config,
}) })
// Get installation state
let installation = this.$root.$data.config.installation
// Redirect to setup wizard // Redirect to setup wizard
if (installation === 'installation-needed') { if (this.$root.$data.config.installation === 'installation-needed') {
this.isLoaded = true this.isLoaded = true
if (window.location.pathname.split('/')[1] !== 'setup-wizard') { if (window.location.pathname.split('/')[1] !== 'setup-wizard') {
@@ -50,7 +50,7 @@ export default {
reader.readAsDataURL(file) reader.readAsDataURL(file)
// Update user avatar // Update user avatar
this.$updateImage('/user/settings', 'avatar', event.target.files[0]) this.$updateAvatar(event.target.files[0])
} else { } else {
alert(this.$t('wrong_image_error')) alert(this.$t('wrong_image_error'))
} }
+30 -5
View File
@@ -63,6 +63,27 @@ const FunctionHelpers = {
}) })
} }
Vue.prototype.$updateAvatar = function (image) {
// Create form
let formData = new FormData()
// Add image to form
formData.append('avatar', image)
axios
.post(`${store.getters.api}/user/avatar`, formData, {
headers: {
'Content-Type': 'multipart/form-data',
},
})
.catch(() => {
events.$emit('alert:open', {
title: this.$t('popup_error.title'),
message: this.$t('popup_error.message'),
})
})
}
Vue.prototype.$scrollTop = function () { Vue.prototype.$scrollTop = function () {
const container = document.getElementsByTagName('html')[0] const container = document.getElementsByTagName('html')[0]
@@ -226,17 +247,21 @@ const FunctionHelpers = {
'.part' '.part'
do { do {
let isLast = chunks.length === 1, let isLastChunk = chunks.length === 1 ? 1 : 0,
chunk = chunks.shift(), chunk = chunks.shift(),
attempts = 0 attempts = 0
// Set form data // Set form data
formData.set('name', item.file.name) formData.set('name', item.file.name)
formData.set('file', chunk, source_name) formData.set('chunk', chunk, source_name)
formData.set('path', item.path)
formData.set('parent_id', item.parent_id)
formData.set('extension', item.file.name.split('.').pop()) formData.set('extension', item.file.name.split('.').pop())
formData.set('is_last', isLast) formData.set('is_last_chunk', isLastChunk)
if (item.path && item.path !== '/')
formData.set('path', item.path)
if (item.parent_id)
formData.set('parent_id', item.parent_id)
// Upload chunks // Upload chunks
do { do {
+2 -2
View File
@@ -19,7 +19,7 @@ const actions = {
commit('LOADING_STATE', { loading: true, data: [] }) commit('LOADING_STATE', { loading: true, data: [] })
axios axios
.get(`${getters.api}/browse/folders/${id}${getters.sorting.URI}`) .get(`${getters.api}/browse/folders/${id || 'all'}${getters.sorting.URI}`)
.then((response) => { .then((response) => {
let folders = response.data.folders.data let folders = response.data.folders.data
let files = response.data.files.data let files = response.data.files.data
@@ -85,7 +85,7 @@ const actions = {
commit('LOADING_STATE', { loading: true, data: [] }) commit('LOADING_STATE', { loading: true, data: [] })
axios axios
.get(`${getters.api}/browse/trash/${id}${getters.sorting.URI}`) .get(`${getters.api}/browse/trash/${id || 'all'}${getters.sorting.URI}`)
.then((response) => { .then((response) => {
let folders = response.data.folders.data let folders = response.data.folders.data
let files = response.data.files.data let files = response.data.files.data
+3 -3
View File
@@ -149,9 +149,9 @@ const actions = {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
// Get route // Get route
let route = { let route = {
RequestUpload: `/api/upload-request/${router.currentRoute.params.token}/upload`, RequestUpload: `/api/upload-request/${router.currentRoute.params.token}/upload/chunks`,
Public: `/api/editor/upload/${router.currentRoute.params.token}`, Public: `/api/editor/upload/chunks/${router.currentRoute.params.token}`,
}[router.currentRoute.name] || '/api/upload' }[router.currentRoute.name] || '/api/upload/chunks'
// Create cancel token for axios cancellation // Create cancel token for axios cancellation
const CancelToken = axios.CancelToken, const CancelToken = axios.CancelToken,
+2 -2
View File
@@ -17,7 +17,7 @@ const actions = {
} }
axios axios
.get(`${getters.api}/teams/folders/${id}${getters.sorting.URI}`) .get(`${getters.api}/teams/folders/${id || 'all'}${getters.sorting.URI}`)
.then((response) => { .then((response) => {
let folders = response.data.folders.data let folders = response.data.folders.data
let files = response.data.files.data let files = response.data.files.data
@@ -59,7 +59,7 @@ const actions = {
} }
axios axios
.get(`${getters.api}/teams/shared-with-me/${id}${getters.sorting.URI}`) .get(`${getters.api}/teams/shared-with-me/${id || 'all'}${getters.sorting.URI}`)
.then((response) => { .then((response) => {
let folders = response.data.folders.data let folders = response.data.folders.data
let files = response.data.files.data let files = response.data.files.data
+1 -1
View File
@@ -13,7 +13,7 @@ const actions = {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
axios axios
.get(`/api/upload-request/${router.currentRoute.params.token}/browse/${id}${getters.sorting.URI}`) .get(`/api/upload-request/${router.currentRoute.params.token}/browse/${id || 'all'}${getters.sorting.URI}`)
.then((response) => { .then((response) => {
let folders = response.data.folders.data let folders = response.data.folders.data
let files = response.data.files.data let files = response.data.files.data
+4 -4
View File
@@ -93,7 +93,7 @@ const actions = {
context.commit('ADD_TO_FAVOURITES', favouritesWidget) context.commit('ADD_TO_FAVOURITES', favouritesWidget)
axios axios
.post(context.getters.api + '/folders/favourites', { .post(context.getters.api + '/favourites', {
ids: itemsToFavourites, ids: itemsToFavourites,
}) })
.catch(() => { .catch(() => {
@@ -105,19 +105,19 @@ const actions = {
commit('REMOVE_ITEM_FROM_FAVOURITES', folder) commit('REMOVE_ITEM_FROM_FAVOURITES', folder)
axios axios
.post(getters.api + '/folders/favourites/' + folder.data.id, { .post(getters.api + '/favourites/' + folder.data.id, {
_method: 'delete', _method: 'delete',
}) })
.catch(() => Vue.prototype.$isSomethingWrong()) .catch(() => Vue.prototype.$isSomethingWrong())
}, },
readAllNotifications: ({ commit }) => { readAllNotifications: ({ commit }) => {
axios.post('/api/user/notifications/read') axios.post('/api/notifications/read')
.then(() => { .then(() => {
commit('UPDATE_NOTIFICATION_COUNT', 0) commit('UPDATE_NOTIFICATION_COUNT', 0)
}) })
}, },
deleteAllNotifications: ({ commit }) => { deleteAllNotifications: ({ commit }) => {
axios.delete('/api/user/notifications') axios.delete('/api/notifications')
.then(() => { .then(() => {
commit('FLUSH_NOTIFICATIONS') commit('FLUSH_NOTIFICATIONS')
}) })
@@ -119,7 +119,7 @@ export default {
// Send request to get user reset link // Send request to get user reset link
axios axios
.post('/api/password/email', { .post('/api/password/recover', {
email: this.recoverEmail, email: this.recoverEmail,
}) })
.then(() => { .then(() => {
+1 -1
View File
@@ -275,7 +275,7 @@ export default {
}, },
resendEmail() { resendEmail() {
axios axios
.post('/api/user/email/verify/resend', { .post('/api/user/verify', {
email: this.loginEmail, email: this.loginEmail,
}) })
.then(() => { .then(() => {
+87 -144
View File
@@ -1,70 +1,15 @@
@php
use Monolog\Handler\MissingExtensionException;
use VueFileManager\Subscription\Domain\Plans\Models\Plan;
use VueFileManager\Subscription\Domain\Transactions\Models\Transaction;
use VueFileManager\Subscription\Domain\Subscriptions\Models\Subscription;
try {
// Bcmath Extension
$storageDefaultSpaceFormatted = isset($settings->default_max_storage_amount)
? format_gigabytes($settings->default_max_storage_amount)
: format_gigabytes(5);
$uploadLimit = isset($settings->upload_limit)
? format_bytes($settings->upload_limit)
: 'undefined';
$chunkSize = isset($settings->chunk_size)
? format_bytes($settings->chunk_size)
: format_bytes(64);
$uploadLimitFormatted = isset($settings->upload_limit)
? format_megabytes($settings->upload_limit)
: null;
} catch (MissingExtensionException $exception) {
$storageDefaultSpaceFormatted = '5GB';
$uploadLimit = 'undefined';
$uploadLimitFormatted = 5;
$chunkSize = 64000000;
}
try {
// Subscription
$isEmptySubscriptions = Subscription::count() === 0;
$isEmptyTransactions = Transaction::count() === 0;
$isEmptyPlans = Plan::count() === 0;
$plan = Plan::where('status', 'active')
->where('type', 'metered');
// User
$isUser = auth()->check();
$user = Auth::user();
// Default user settings
$defaultEmoji = $isUser ? $user->settings->emoji_type : 'twemoji';
$defaultThemeMode = $isUser ? $user->settings->theme_mode : 'system';
} catch (PDOException $e) {
[$isUser, $isEmptyPlans, $isEmptyTransactions, $isEmptySubscriptions] = false;
$plan = null;
$defaultEmoji = 'twemoji';
$defaultThemeMode = 'system';
}
@endphp
<!DOCTYPE html> <!DOCTYPE html>
<html class="{{ $installation === 'installation-needed' ? 'dark:bg-dark-background bg-light-background' : '' }}" style="min-height: 100%" lang="{{ str_replace('_', '-', app()->getLocale()) }}"> <html class="{{ $config->installation === 'installation-needed' ? 'dark:bg-dark-background bg-light-background' : '' }}" style="min-height: 100%" lang="{{ str_replace('_', '-', app()->getLocale()) }}">
<head> <head>
<meta name="theme-color" content="{{ $settings->app_color ?? '#00BC7E' }}"> <meta name="theme-color" content="{{ $config->app_color ?? '#00BC7E' }}">
<meta charset="utf-8"> <meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no, minimal-ui"> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no, minimal-ui">
<meta name="description" content="{{ $settings->app_description ?? __t('app_description') }}"> <meta name="description" content="{{ $config->app_description ?? __t('app_description') }}">
<title> <title>
{{ $settings->app_title ?? 'VueFileManager' }} | {{ $settings->app_description ?? __t('app_description') }} {{ $config->app_title ?? 'VueFileManager' }} | {{ $config->app_description ?? __t('app_description') }}
</title> </title>
{{--StyleSheet--}} {{--StyleSheet--}}
@@ -73,18 +18,18 @@
{{--OG items--}} {{--OG items--}}
<meta property="og:url" content="{{ url('/') }}"> <meta property="og:url" content="{{ url('/') }}">
<meta property="og:title" content="{{ $settings->app_title ?? 'VueFileManager' }} | {{ $settings->app_description ?? __t('app_description') }}"> <meta property="og:title" content="{{ $config->app_title ?? 'VueFileManager' }} | {{ $config->app_description ?? __t('app_description') }}">
<meta property="og:description" content="{{ $settings->app_description ?? __t('app_description') }}"> <meta property="og:description" content="{{ $config->app_description ?? __t('app_description') }}">
<meta property="og:image" content="{{ isset($settings->app_og_image) ? url($settings->app_og_image) : '' }}"> <meta property="og:image" content="{{ isset($config->app_og_image) ? url($config->app_og_image) : '' }}">
{{-- Apple Mobile Web App--}} {{-- Apple Mobile Web App--}}
<meta name="apple-mobile-web-app-capable" content="yes"> <meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="white"> <meta name="apple-mobile-web-app-status-bar-style" content="white">
<meta name="apple-mobile-web-app-title" content="{{ $settings->app_title ?? 'VueFileManager' }}"> <meta name="apple-mobile-web-app-title" content="{{ $config->app_title ?? 'VueFileManager' }}">
{{--Icons--}} {{--Icons--}}
<link rel="apple-touch-icon-precomposed" sizes="152x152" href="{{ isset($settings->app_touch_icon) ? url($settings->app_touch_icon) : '' }}"> <link rel="apple-touch-icon-precomposed" sizes="152x152" href="{{ isset($config->app_touch_icon) ? url($config->app_touch_icon) : '' }}">
<link rel="icon" href="{{ isset($settings->app_favicon) ? url($settings->app_favicon) : asset('favicon.png') }}?v={{ get_version() }}"> <link rel="icon" href="{{ isset($config->app_favicon) ? url($config->app_favicon) : asset('favicon.png') }}?v={{ get_version() }}">
{{--Format Detection--}} {{--Format Detection--}}
<meta name="format-detection" content="telephone=no"> <meta name="format-detection" content="telephone=no">
@@ -97,115 +42,113 @@
<div id="app"></div> <div id="app"></div>
<script> <script>
// todo: refactoring
let config = { let config = {
host: '{{ url('/') }}', host: '{{ $config->host }}',
api: '{{ url('/api') }}', api: '{{ $config->api }}',
locale: '{{ app()->getLocale() }}', locale: '{{ $config->locale }}',
broadcasting: '{{ config('broadcasting.default') }}', broadcasting: '{{ $config->broadcasting }}',
broadcastingKey: '{{ config('broadcasting.connections.pusher.key') }}', broadcastingKey: '{{ $config->broadcastingKey }}',
broadcastingHost: '{{ config('broadcasting.connections.pusher.options.host') }}', broadcastingHost: '{{ $config->broadcastingHost }}',
broadcastingPort: '{{ config('broadcasting.connections.pusher.options.port') }}', broadcastingPort: '{{ $config->broadcastingPort }}',
broadcastingCluster: '{{ config('broadcasting.connections.pusher.options.cluster') }}', broadcastingCluster: '{{ $config->broadcastingCluster }}',
app_logo: '{{ $settings->app_logo ?? null }}', app_logo: '{{ $config->app_logo }}',
app_logo_dark: '{{ $settings->app_logo_dark ?? null }}', app_logo_dark: '{{ $config->app_logo_dark }}',
app_logo_horizontal: '{{ $settings->app_logo_horizontal ?? null }}', app_logo_horizontal: '{{ $config->app_logo_horizontal }}',
app_logo_horizontal_dark: '{{ $settings->app_logo_horizontal_dark ?? null }}', app_logo_horizontal_dark: '{{ $config->app_logo_horizontal_dark }}',
app_color: '{{ $settings->app_color ?? '#00BC7E' }}', app_color: '{{ $config->app_color }}',
app_footer: '{!! $settings->footer_content ?? null !!}', app_footer: '{!! $config->app_footer !!}',
app_name: '{{ $settings->app_title ?? 'VueFileManager' }}', app_name: '{{ $config->app_name }}',
app_description: '{{ $settings->app_description ?? __t('app_description') }}', app_description: '{{ $config->app_description }}',
allowHomepage: {{ $settings->allow_homepage ?? 1 }}, allowHomepage: {{ $config->allowHomepage }},
storageLimit: {{ $settings->storage_limitation ?? 1 }}, storageLimit: {{ $config->storageLimit }},
teamsDefaultMembers: {{ $settings->default_max_team_member ?? 10 }}, teamsDefaultMembers: {{ $config->teamsDefaultMembers }},
storageDefaultSpace: {{ $settings->default_max_storage_amount ?? 5 }}, storageDefaultSpace: {{ $config->storageDefaultSpace }},
storageDefaultSpaceFormatted: '{{ $storageDefaultSpaceFormatted }}', storageDefaultSpaceFormatted: '{{ $config->storageDefaultSpaceFormatted }}',
mimetypesBlacklist: '{{ isset($settings->mimetypes_blacklist) ? $settings->mimetypes_blacklist: null}}', mimetypesBlacklist: '{{ $config->mimetypesBlacklist }}',
uploadLimit: {{ $uploadLimit }}, uploadLimit: {{ $config->uploadLimit }},
uploadLimitFormatted: '{{ $uploadLimitFormatted }}', uploadLimitFormatted: '{{ $config->uploadLimitFormatted }}',
chunkSize: {{ $chunkSize }}, chunkSize: {{ $config->chunkSize }},
isAuthenticated: {{ $isUser ? 1 : 0 }}, isAuthenticated: {{ $config->isAuthenticated }},
isSaaS: {{ $settings && optional($settings)->license === 'extended' ? 1 : 0 }}, isSaaS: {{ $config->isSaaS }},
isDev: {{ is_dev() ? 1 : 0 }}, isDev: {{ $config->isDev }},
isDemo: {{ config('vuefilemanager.is_demo') ? 1 : 0 }}, isDemo: {{ $config->isDemo }},
legal: {!! $legal ?? 'undefined' !!}, legal: {!! $config->legal !!},
installation: '{{ $installation ?? 'initial' }}', installation: '{{ $config->installation }}',
statusCheck: {!! json_encode($status_check) ?? 'undefined' !!}, statusCheck: {!! $config->statusCheck !!},
isSetupWizardDemo: {{ config('vuefilemanager.is_setup_wizard_demo') ? 1 : 0 }}, isSetupWizardDemo: {{ $config->isSetupWizardDemo }},
isSetupWizardDebug: {{ config('vuefilemanager.is_setup_wizard_debug') ? 1 : 0 }}, isSetupWizardDebug: {{ $config->isSetupWizardDebug }},
// States // States
isEmptyPlans: {{ $isEmptyPlans ? 1 : 0 }}, isEmptyPlans: {{ $config->isEmptyPlans }},
isEmptyTransactions: {{ $isEmptyTransactions ? 1 : 0 }}, isEmptyTransactions: {{ $config->isEmptyTransactions }},
isEmptySubscriptions: {{ $isEmptySubscriptions ? 1 : 0 }}, isEmptySubscriptions: {{ $config->isEmptySubscriptions }},
// Hidden set ups // Hidden set ups
isAdminVueFileManagerBar: {{ config('vuefilemanager.is_admin_vuefilemanager_bar', 1) ? 1 : 0 }}, isAdminVueFileManagerBar: {{ $config->isAdminVueFileManagerBar }},
// Metered // Metered
allowed_registration_bonus: {{ $settings->allowed_registration_bonus ?? 0 }}, allowed_registration_bonus: {{ $config->allowed_registration_bonus }},
registration_bonus_amount: {{ $settings->registration_bonus_amount ?? 0 }}, registration_bonus_amount: {{ $config->registration_bonus_amount }},
isCreatedMeteredPlan: {{ $plan && $plan->exists() ? 1 : 0 }}, isCreatedMeteredPlan: {{ $config->isCreatedMeteredPlan }},
meteredPlanId: '{{ $plan && $plan->exists() ? $plan->first()->id : null }}', meteredPlanId: '{{ $config->meteredPlanId }}',
// Payments // Payments
allowed_payments: {{ $settings->allowed_payments ?? 0 }}, allowed_payments: {{ $config->allowed_payments }},
subscriptionType: '{{ $settings->subscription_type ?? 'none' }}', subscriptionType: '{{ $config->subscriptionType }}',
// PayPal // PayPal
isPayPal: {{ $settings->allowed_paypal ?? 0 }}, isPayPal: {{ $config->isPayPal }},
isPayPalLive: {{ config('subscription.credentials.paypal.is_live') ? 1 : 0 }}, isPayPalLive: {{ $config->isPayPalLive }},
paypal_client_id: '{{ config('subscription.credentials.paypal.id') }}', paypal_client_id: '{{ $config->paypal_client_id }}',
paypal_payment_description: '{{ $settings->paypal_payment_description ?? '' }}', paypal_payment_description: '{{ $config->paypal_payment_description }}',
// Paystack // Paystack
isPaystack: {{ $settings->allowed_paystack ?? 0 }}, isPaystack: {{ $config->isPaystack }},
paystack_public_key: '{{ config('subscription.credentials.paystack.public_key') }}', paystack_public_key: '{{ $config->paystack_public_key }}',
paystack_payment_description: '{{ $settings->paystack_payment_description ?? '' }}', paystack_payment_description: '{{ $config->paystack_payment_description }}',
// Stripe // Stripe
isStripe: {{ $settings->allowed_stripe ?? 0 }}, isStripe: {{ $config->isStripe }},
stripe_public_key: '{{ config('subscription.credentials.stripe.public_key') }}', stripe_public_key: '{{ $config->stripe_public_key }}',
stripe_payment_description: '{{ $settings->stripe_payment_description ?? '' }}', stripe_payment_description: '{{ $config->stripe_payment_description }}',
// ReCaptcha // ReCaptcha
recaptcha_client_id: '{{ config('services.recaptcha.client_id') }}', recaptcha_client_id: '{{ $config->recaptcha_client_id }}',
allowedRecaptcha: {{ $settings->allowed_recaptcha ?? 0 }}, allowedRecaptcha: {{ $config->allowedRecaptcha }},
isRecaptchaConfigured: {{ config('services.recaptcha.client_id') ? 1 : 0 }}, isRecaptchaConfigured: {{ $config->isRecaptchaConfigured }},
// Social logins // Social logins
allowedFacebookLogin: {{ $settings->allowed_facebook_login ?? 0 }}, allowedFacebookLogin: {{ $config->allowedFacebookLogin }},
isFacebookLoginConfigured: {{ config('services.facebook.client_id') ? 1 : 0 }}, isFacebookLoginConfigured: {{ $config->isFacebookLoginConfigured }},
allowedGoogleLogin: {{ $settings->allowed_google_login ?? 0 }}, allowedGoogleLogin: {{ $config->allowedGoogleLogin }},
isGoogleLoginConfigured: {{ config('services.google.client_id') ? 1 : 0 }}, isGoogleLoginConfigured: {{ $config->isGoogleLoginConfigured }},
allowedGithubLogin: {{ $settings->allowed_github_login ?? 0 }}, allowedGithubLogin: {{ $config->allowedGithubLogin }},
isGithubLoginConfigured: {{ config('services.github.client_id') ? 1 : 0 }}, isGithubLoginConfigured: {{ $config->isGithubLoginConfigured }},
// Adsense // Adsense
allowedAdsense: {{ $settings?->allowed_adsense ?? 0 }}, allowedAdsense: {{ $config->allowedAdsense }},
adsenseClientId: '{{ $settings->adsense_client_id ?? '' }}', adsenseClientId: '{{ $config->adsenseClientId }}',
adsenseBanner01: `{!! $settings->adsense_banner_01 ?? '' !!}`, adsenseBanner01: `{!! $config->adsenseBanner01 !!}`,
adsenseBanner02: `{!! $settings->adsense_banner_02 ?? '' !!}`, adsenseBanner02: `{!! $config->adsenseBanner02 !!}`,
adsenseBanner03: `{!! $settings->adsense_banner_03 ?? '' !!}`, adsenseBanner03: `{!! $config->adsenseBanner03 !!}`,
// User settings // User settings
defaultEmoji: '{{ $defaultEmoji }}', defaultEmoji: '{{ $config->defaultEmoji }}',
defaultThemeMode: '{{ $defaultThemeMode }}', defaultThemeMode: '{{ $config->defaultThemeMode }}',
// App settings // App settings
userRegistration: {{ $settings->registration ?? 1 }}, userRegistration: {{ $config->userRegistration }},
userVerification: {{ $settings->user_verification ?? 0 }}, userVerification: {{ $config->userVerification }},
} }
</script> </script>
@@ -215,14 +158,14 @@
<script src="{{ asset('js/main.js') }}?v={{ get_version() }}"></script> <script src="{{ asset('js/main.js') }}?v={{ get_version() }}"></script>
{{--Global site tag (gtag.js) - Google Analytics--}} {{--Global site tag (gtag.js) - Google Analytics--}}
@if(isset($settings->google_analytics) && $settings->google_analytics) @if(isset($config->google_analytics) && $config->google_analytics)
<script async src="https://www.googletagmanager.com/gtag/js?id={{ $settings->google_analytics }}"></script> <script async src="https://www.googletagmanager.com/gtag/js?id={{ $config->google_analytics }}"></script>
<script> <script>
window.dataLayer = window.dataLayer || []; window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);} function gtag(){dataLayer.push(arguments);}
gtag('js', new Date()); gtag('js', new Date());
gtag('config', '{{ $settings->google_analytics }}'); gtag('config', '{{ $config->google_analytics }}');
</script> </script>
@endif @endif
@else @else
@@ -231,8 +174,8 @@
@endif @endif
{{--Adsense code--}} {{--Adsense code--}}
@if(optional($settings)->allowed_adsense) @if(optional($config)->allowed_adsense)
<script async src="https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client={{ $settings->adsense_client_id ?? '' }}" crossorigin="anonymous"></script> <script async src="https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client={{ $config->adsense_client_id ?? '' }}" crossorigin="anonymous"></script>
<script> <script>
(adsbygoogle = window.adsbygoogle || []).push({}); (adsbygoogle = window.adsbygoogle || []).push({});
+16 -3
View File
@@ -1,5 +1,6 @@
<?php <?php
use Domain\Settings\Controllers\GetConfigController;
use Domain\Zip\Controllers\ZipController; use Domain\Zip\Controllers\ZipController;
use Domain\Pages\Controllers\PagesController; use Domain\Pages\Controllers\PagesController;
use Domain\Sharing\Controllers\ShareController; use Domain\Sharing\Controllers\ShareController;
@@ -13,6 +14,7 @@ use Domain\SetupWizard\Controllers\PingAPIController;
use Domain\Folders\Controllers\CreateFolderController; use Domain\Folders\Controllers\CreateFolderController;
use Domain\Browsing\Controllers\BrowseFolderController; use Domain\Browsing\Controllers\BrowseFolderController;
use Domain\Sharing\Controllers\ShareViaEmailController; use Domain\Sharing\Controllers\ShareViaEmailController;
use Domain\Files\Controllers\UploadFileChunksController;
use Domain\Folders\Controllers\NavigationTreeController; use Domain\Folders\Controllers\NavigationTreeController;
use Domain\Items\Controllers\MoveFileOrFolderController; use Domain\Items\Controllers\MoveFileOrFolderController;
use App\Socialite\Controllers\SocialiteRedirectController; use App\Socialite\Controllers\SocialiteRedirectController;
@@ -28,9 +30,13 @@ use Domain\Homepage\Controllers\SendContactMessageController;
use Domain\RemoteUpload\Controllers\RemoteUploadFileController; use Domain\RemoteUpload\Controllers\RemoteUploadFileController;
use Domain\Sharing\Controllers\GetShareLinkViaQrCodeController; use Domain\Sharing\Controllers\GetShareLinkViaQrCodeController;
use App\Users\Controllers\Authentication\RegisterUserController; use App\Users\Controllers\Authentication\RegisterUserController;
use Domain\Notifications\Controllers\GetUserNotificationsController;
use Domain\Notifications\Controllers\FlushUserNotificationsController;
use Domain\Notifications\Controllers\MarkUserNotificationsAsReadController;
// Ping Pong // Ping Pong
Route::get('/ping', PingAPIController::class); Route::get('/ping', PingAPIController::class);
Route::get('/config', GetConfigController::class);
// Pages // Pages
Route::apiResource('/page', PagesController::class); Route::apiResource('/page', PagesController::class);
@@ -47,7 +53,7 @@ Route::get('/socialite/{provider}/redirect', SocialiteRedirectController::class)
// Password reset // Password reset
Route::group(['prefix' => 'password'], function () { Route::group(['prefix' => 'password'], function () {
Route::post('/email', [ForgotPasswordController::class, 'sendResetLinkEmail']); Route::post('/recover', [ForgotPasswordController::class, 'sendResetLinkEmail']);
Route::post('/reset', [ResetPasswordController::class, 'reset']); Route::post('/reset', [ResetPasswordController::class, 'reset']);
}); });
@@ -74,8 +80,13 @@ Route::group(['middleware' => ['auth:sanctum']], function () {
Route::apiResource('/share', ShareController::class); Route::apiResource('/share', ShareController::class);
Route::post('/share/{id}', ShareItemController::class); Route::post('/share/{id}', ShareItemController::class);
// Notifications
Route::post('/notifications/read', MarkUserNotificationsAsReadController::class);
Route::delete('/notifications', FlushUserNotificationsController::class);
Route::get('/notifications', GetUserNotificationsController::class);
// Favourites // Favourites
Route::apiResource('/folders/favourites', FavouriteController::class); Route::apiResource('/favourites', FavouriteController::class);
// Search // Search
Route::get('/search', SpotlightSearchController::class); Route::get('/search', SpotlightSearchController::class);
@@ -84,9 +95,11 @@ Route::group(['middleware' => ['auth:sanctum']], function () {
// User master,editor routes // User master,editor routes
Route::group(['middleware' => ['auth:sanctum']], function () { Route::group(['middleware' => ['auth:sanctum']], function () {
Route::post('/upload/remote', RemoteUploadFileController::class); Route::post('/upload/remote', RemoteUploadFileController::class);
Route::post('/create-folder', CreateFolderController::class); Route::post('/upload/chunks', UploadFileChunksController::class);
Route::post('/upload', UploadFileController::class); Route::post('/upload', UploadFileController::class);
Route::post('/create-folder', CreateFolderController::class);
Route::patch('/rename/{id}', RenameFileOrFolderController::class); Route::patch('/rename/{id}', RenameFileOrFolderController::class);
Route::post('/remove', DeleteFileOrFolderController::class); Route::post('/remove', DeleteFileOrFolderController::class);
Route::post('/move', MoveFileOrFolderController::class); Route::post('/move', MoveFileOrFolderController::class);
+3 -2
View File
@@ -3,10 +3,10 @@
use Domain\Sharing\Controllers\ShareController; use Domain\Sharing\Controllers\ShareController;
use Domain\Zip\Controllers\VisitorZipController; use Domain\Zip\Controllers\VisitorZipController;
use Domain\Files\Controllers\VisitorShowFileController; use Domain\Files\Controllers\VisitorShowFileController;
use Domain\Files\Controllers\VisitorUploadFileController;
use Domain\Folders\Controllers\VisitorCreateFolderController; use Domain\Folders\Controllers\VisitorCreateFolderController;
use Domain\Sharing\Controllers\WebCrawlerOpenGraphController; use Domain\Sharing\Controllers\WebCrawlerOpenGraphController;
use Domain\Browsing\Controllers\VisitorBrowseFolderController; use Domain\Browsing\Controllers\VisitorBrowseFolderController;
use Domain\Files\Controllers\VisitorUploadFileChunksController;
use Domain\Items\Controllers\VisitorMoveFileOrFolderController; use Domain\Items\Controllers\VisitorMoveFileOrFolderController;
use Domain\Items\Controllers\VisitorDeleteFileOrFolderController; use Domain\Items\Controllers\VisitorDeleteFileOrFolderController;
use Domain\Items\Controllers\VisitorRenameFileOrFolderController; use Domain\Items\Controllers\VisitorRenameFileOrFolderController;
@@ -18,8 +18,9 @@ use Domain\Browsing\Controllers\VisitorSearchFilesAndFoldersController;
// Browse functions // Browse functions
Route::group(['prefix' => 'editor'], function () { Route::group(['prefix' => 'editor'], function () {
Route::post('/upload/remote/{shared}', VisitorRemoteUploadFileController::class); Route::post('/upload/remote/{shared}', VisitorRemoteUploadFileController::class);
Route::post('/upload/chunks/{shared}', VisitorUploadFileChunksController::class);
Route::post('/create-folder/{shared}', VisitorCreateFolderController::class); Route::post('/create-folder/{shared}', VisitorCreateFolderController::class);
Route::post('/upload/{shared}', VisitorUploadFileController::class);
Route::patch('/rename/{id}/{shared}', VisitorRenameFileOrFolderController::class); Route::patch('/rename/{id}/{shared}', VisitorRenameFileOrFolderController::class);
Route::post('/remove/{shared}', VisitorDeleteFileOrFolderController::class); Route::post('/remove/{shared}', VisitorDeleteFileOrFolderController::class);
+3 -2
View File
@@ -8,8 +8,8 @@ use Domain\UploadRequest\Controllers\BrowseUploadRequestController;
use Domain\UploadRequest\Controllers\CreateUploadRequestController; use Domain\UploadRequest\Controllers\CreateUploadRequestController;
use Domain\UploadRequest\Controllers\MoveItemInUploadRequestController; use Domain\UploadRequest\Controllers\MoveItemInUploadRequestController;
use Domain\UploadRequest\Controllers\SetUploadRequestAsFilledController; use Domain\UploadRequest\Controllers\SetUploadRequestAsFilledController;
use Domain\UploadRequest\Controllers\UploadFilesForUploadRequestController;
use Domain\UploadRequest\Controllers\GetFolderTreeForUploadRequestController; use Domain\UploadRequest\Controllers\GetFolderTreeForUploadRequestController;
use Domain\UploadRequest\Controllers\UploadFileChunksForUploadRequestController;
use Domain\RemoteUpload\Controllers\UploadFilesRemotelyForUploadRequestController; use Domain\RemoteUpload\Controllers\UploadFilesRemotelyForUploadRequestController;
Route::get('/{uploadRequest}', GetUploadRequestController::class); Route::get('/{uploadRequest}', GetUploadRequestController::class);
@@ -21,7 +21,8 @@ Route::group(['middleware' => 'upload-request'], function () {
// Edit // Edit
Route::post('/{uploadRequest}/upload/remote', UploadFilesRemotelyForUploadRequestController::class); Route::post('/{uploadRequest}/upload/remote', UploadFilesRemotelyForUploadRequestController::class);
Route::post('/{uploadRequest}/upload', UploadFilesForUploadRequestController::class); Route::post('/{uploadRequest}/upload/chunks', UploadFileChunksForUploadRequestController::class);
Route::patch('/{uploadRequest}/rename/{id}', RenameFileOrFolderController::class); Route::patch('/{uploadRequest}/rename/{id}', RenameFileOrFolderController::class);
Route::post('/{uploadRequest}/create-folder', CreateFolderController::class); Route::post('/{uploadRequest}/create-folder', CreateFolderController::class);
Route::post('/{uploadRequest}/remove', DeleteFileOrFolderController::class); Route::post('/{uploadRequest}/remove', DeleteFileOrFolderController::class);
+4 -10
View File
@@ -1,5 +1,6 @@
<?php <?php
use App\Users\Controllers\Account\UpdateAvatarController;
use App\Users\Controllers\Account\AccountDetailsController; use App\Users\Controllers\Account\AccountDetailsController;
use App\Users\Controllers\Account\UpdatePasswordController; use App\Users\Controllers\Account\UpdatePasswordController;
use App\Users\Controllers\Account\StorageCapacityController; use App\Users\Controllers\Account\StorageCapacityController;
@@ -7,34 +8,27 @@ use App\Users\Controllers\Verification\VerifyEmailController;
use Domain\Transactions\Controllers\GetTransactionsController; use Domain\Transactions\Controllers\GetTransactionsController;
use App\Users\Controllers\Authentication\CheckAccountController; use App\Users\Controllers\Authentication\CheckAccountController;
use App\Users\Controllers\Account\UpdateProfileSettingsController; use App\Users\Controllers\Account\UpdateProfileSettingsController;
use Domain\Notifications\Controllers\GetUserNotificationsController;
use App\Users\Controllers\Authentication\AccountAccessTokenController; use App\Users\Controllers\Authentication\AccountAccessTokenController;
use Domain\Notifications\Controllers\FlushUserNotificationsController;
use App\Users\Controllers\Verification\ResendVerificationEmailController; use App\Users\Controllers\Verification\ResendVerificationEmailController;
use Domain\Notifications\Controllers\MarkUserNotificationsAsReadController;
Route::post('/check', CheckAccountController::class); Route::post('/check', CheckAccountController::class);
// Email verification // Email verification
Route::get('/email/verify/{id}', VerifyEmailController::class) Route::get('/verify/{id}', VerifyEmailController::class)
->name('verification.verify'); ->name('verification.verify');
Route::post('/email/verify/resend', ResendVerificationEmailController::class) Route::post('/verify', ResendVerificationEmailController::class)
->name('verification.send'); ->name('verification.send');
Route::group(['middleware' => ['auth:sanctum']], function () { Route::group(['middleware' => ['auth:sanctum']], function () {
// User Access Token // User Access Token
Route::apiResource('/tokens', AccountAccessTokenController::class); Route::apiResource('/tokens', AccountAccessTokenController::class);
// Notifications
Route::post('/notifications/read', MarkUserNotificationsAsReadController::class);
Route::delete('/notifications', FlushUserNotificationsController::class);
Route::get('/notifications', GetUserNotificationsController::class);
// Account // Account
Route::patch('/settings', UpdateProfileSettingsController::class); Route::patch('/settings', UpdateProfileSettingsController::class);
Route::get('/transactions', GetTransactionsController::class); Route::get('/transactions', GetTransactionsController::class);
Route::post('/password', UpdatePasswordController::class); Route::post('/password', UpdatePasswordController::class);
Route::get('/storage', StorageCapacityController::class); Route::get('/storage', StorageCapacityController::class);
Route::post('/avatar', UpdateAvatarController::class);
Route::get('/', AccountDetailsController::class); Route::get('/', AccountDetailsController::class);
}); });
@@ -0,0 +1,35 @@
<?php
namespace App\Users\Controllers\Account;
use Illuminate\Http\JsonResponse;
use App\Http\Controllers\Controller;
use App\Users\Requests\UpdateAvatarRequest;
class UpdateAvatarController extends Controller
{
/**
* Update user settings
*/
public function __invoke(
UpdateAvatarRequest $request
): JsonResponse {
$successMessage = [
'type' => 'success',
'message' => 'The avatar was successfully updated.',
];
// Check if is demo
if (isDemoAccount()) {
return response()->json($successMessage);
}
$request
->user()
->settings()
->update([
'avatar' => store_avatar($request, 'avatar'),
]);
return response()->json($successMessage);
}
}
@@ -3,7 +3,6 @@ namespace App\Users\Controllers\Account;
use Illuminate\Http\JsonResponse; use Illuminate\Http\JsonResponse;
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Auth;
use Illuminate\Database\QueryException; use Illuminate\Database\QueryException;
use App\Users\Requests\UpdateUserProfileSettingsRequest; use App\Users\Requests\UpdateUserProfileSettingsRequest;
@@ -25,23 +24,10 @@ class UpdateProfileSettingsController extends Controller
return response()->json($successMessage); return response()->json($successMessage);
} }
// Get user
$user = Auth::user();
// Update avatar
if ($request->hasFile('avatar')) {
$user
->settings()
->update([
'avatar' => store_avatar($request, 'avatar'),
]);
return response()->json($successMessage);
}
// Try to store user option // Try to store user option
try { try {
$user $request
->user()
->settings() ->settings()
->update(make_single_input($request)); ->update(make_single_input($request));
} catch (QueryException $e) { } catch (QueryException $e) {
@@ -21,7 +21,7 @@ class CheckAccountController extends Controller
return response()->json([ return response()->json([
'type' => 'error', 'type' => 'error',
'message' => __t('user_not_fount'), 'message' => __t('user_not_fount'),
]); ], 404);
} }
return response()->json([ return response()->json([
+1 -1
View File
@@ -109,7 +109,7 @@ class User extends Authenticatable implements MustVerifyEmail
'used' => (float) get_storage_percentage($this->usedCapacity, $this->limitations->max_storage_amount), 'used' => (float) get_storage_percentage($this->usedCapacity, $this->limitations->max_storage_amount),
'used_formatted' => get_storage_percentage($this->usedCapacity, $this->limitations->max_storage_amount) . '%', 'used_formatted' => get_storage_percentage($this->usedCapacity, $this->limitations->max_storage_amount) . '%',
'capacity' => $this->limitations->max_storage_amount, 'capacity' => $this->limitations->max_storage_amount,
'capacity_formatted' => format_gigabytes($this->limitations->max_storage_amount), 'capacity_formatted' => toGigabytes($this->limitations->max_storage_amount),
]; ];
} }
+1 -1
View File
@@ -59,7 +59,7 @@ class UserLimitation extends Model
return [ return [
'use' => Metric::bytes($userCapacity)->format(), 'use' => Metric::bytes($userCapacity)->format(),
'total' => format_gigabytes($this->max_storage_amount), 'total' => toGigabytes($this->max_storage_amount),
'percentage' => get_storage_percentage($userCapacity, $this->max_storage_amount), 'percentage' => get_storage_percentage($userCapacity, $this->max_storage_amount),
]; ];
} }
@@ -0,0 +1,29 @@
<?php
namespace App\Users\Requests;
use Illuminate\Foundation\Http\FormRequest;
class UpdateAvatarRequest extends FormRequest
{
/**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize()
{
return true;
}
/**
* Get the validation rules that apply to the request.
*
* @return array
*/
public function rules()
{
return [
'avatar' => 'required|file',
];
}
}
@@ -24,8 +24,7 @@ class UpdateUserProfileSettingsRequest extends FormRequest
{ {
return [ return [
'name' => 'required|string', 'name' => 'required|string',
'value' => 'sometimes|string', 'value' => 'required|string',
'avatar' => 'sometimes|file',
]; ];
} }
} }
@@ -30,7 +30,7 @@ class UserStorageResource extends JsonResource
'type' => 'storage', 'type' => 'storage',
'attributes' => [ 'attributes' => [
'used' => Metric::bytes($this->usedCapacity)->format(), 'used' => Metric::bytes($this->usedCapacity)->format(),
'capacity' => format_gigabytes($totalCapacity), 'capacity' => toGigabytes($totalCapacity),
'percentage' => (float) get_storage_percentage($this->usedCapacity, $totalCapacity), 'percentage' => (float) get_storage_percentage($this->usedCapacity, $totalCapacity),
], ],
'meta' => [ 'meta' => [
+1 -1
View File
@@ -30,7 +30,7 @@ class UserSubscription extends JsonResource
'canceled' => $this->subscription('main')->cancelled(), 'canceled' => $this->subscription('main')->cancelled(),
'name' => $subscription['product']['name'], 'name' => $subscription['product']['name'],
'capacity' => (int) $subscription['product']['metadata']['capacity'], 'capacity' => (int) $subscription['product']['metadata']['capacity'],
'capacity_formatted' => format_gigabytes($subscription['product']['metadata']['capacity']), 'capacity_formatted' => toGigabytes($subscription['product']['metadata']['capacity']),
'slug' => $subscription['plan']['id'], 'slug' => $subscription['plan']['id'],
'canceled_at' => format_date($active_subscription['canceled_at'], 'd. M. Y'), 'canceled_at' => format_date($active_subscription['canceled_at'], 'd. M. Y'),
'created_at' => format_date($active_subscription['current_period_start'], 'd. M. Y'), 'created_at' => format_date($active_subscription['current_period_start'], 'd. M. Y'),
+3 -2
View File
@@ -3,11 +3,12 @@ namespace Domain\Files\Actions;
use Domain\Folders\Models\Folder; use Domain\Folders\Models\Folder;
use Illuminate\Support\Collection; use Illuminate\Support\Collection;
use Domain\Files\Requests\UploadRequest; use Domain\Files\Requests\UploadFileRequest;
use Domain\Files\Requests\UploadChunkRequest;
class GetFileParentId class GetFileParentId
{ {
public function __invoke(UploadRequest $request, string $userId): ?string public function __invoke(UploadChunkRequest|UploadFileRequest $request, string $userId): ?string
{ {
// extract file path // extract file path
$directoryPath = collect( $directoryPath = collect(
@@ -4,7 +4,8 @@ namespace Domain\Files\Actions;
use App\Users\Models\User; use App\Users\Models\User;
use Domain\Files\Models\File; use Domain\Files\Models\File;
use Illuminate\Support\Facades\Storage; use Illuminate\Support\Facades\Storage;
use Domain\Files\Requests\UploadRequest; use Domain\Files\Requests\UploadFileRequest;
use Domain\Files\Requests\UploadChunkRequest;
use Domain\Traffic\Actions\RecordUploadAction; use Domain\Traffic\Actions\RecordUploadAction;
use League\Flysystem\UnableToRetrieveMetadata; use League\Flysystem\UnableToRetrieveMetadata;
@@ -24,7 +25,7 @@ class ProcessFileAction
* Upload new file * Upload new file
*/ */
public function __invoke( public function __invoke(
UploadRequest $request, UploadChunkRequest|UploadFileRequest $request,
User $user, User $user,
string $name, string $name,
): File { ): File {
@@ -50,7 +51,7 @@ class ProcessFileAction
} }
// File size handling // File size handling
if ($uploadLimit && $size > format_bytes($uploadLimit)) { if ($uploadLimit && $size > toBytes($uploadLimit)) {
abort(413); abort(413);
} }
@@ -3,7 +3,7 @@ namespace Domain\Files\Actions;
use Illuminate\Support\Facades\File; use Illuminate\Support\Facades\File;
use Illuminate\Support\Facades\Storage; use Illuminate\Support\Facades\Storage;
use Domain\Files\Requests\UploadRequest; use Domain\Files\Requests\UploadChunkRequest;
use Illuminate\Contracts\Filesystem\FileNotFoundException; use Illuminate\Contracts\Filesystem\FileNotFoundException;
class StoreFileChunksAction class StoreFileChunksAction
@@ -11,10 +11,10 @@ class StoreFileChunksAction
/** /**
* @throws FileNotFoundException * @throws FileNotFoundException
*/ */
public function __invoke(UploadRequest $request) public function __invoke(UploadChunkRequest $request)
{ {
// Get uploaded file // Get uploaded file
$file = $request->file('file'); $file = $request->file('chunk');
// Get chunk name // Get chunk name
$name = $file->getClientOriginalName(); $name = $file->getClientOriginalName();
@@ -26,7 +26,7 @@ class StoreFileChunksAction
File::append($path, $file->get()); File::append($path, $file->get());
// If last chunk, then return file path // If last chunk, then return file path
if ($request->boolean('is_last')) { if ($request->boolean('is_last_chunk')) {
return "chunks/$name"; return "chunks/$name";
} }
} }
@@ -0,0 +1,59 @@
<?php
namespace Domain\Files\Controllers;
use Storage;
use Illuminate\Support\Str;
use Domain\Folders\Models\Folder;
use App\Http\Controllers\Controller;
use Domain\Files\Resources\FileResource;
use Domain\Files\Actions\ProcessFileAction;
use Domain\Files\Requests\UploadChunkRequest;
use Support\Demo\Actions\FakeUploadFileAction;
use Domain\Files\Actions\StoreFileChunksAction;
use Illuminate\Contracts\Filesystem\FileNotFoundException;
class UploadFileChunksController extends Controller
{
public function __construct(
public ProcessFileAction $processFie,
public FakeUploadFileAction $fakeUploadFile,
public StoreFileChunksAction $storeFileChunks,
) {
}
/**
* Upload file for authenticated master|editor user
*
* @throws FileNotFoundException
*/
public function __invoke(UploadChunkRequest $request)
{
if (isDemoAccount()) {
return ($this->fakeUploadFile)($request);
}
// Store file chunks
$chunkPath = ($this->storeFileChunks)($request);
// Proceed after last chunk
if ($request->boolean('is_last_chunk')) {
// Get user
$user = $request->filled('parent_id')
? Folder::find($request->input('parent_id'))
->getLatestParent()
->user
: auth()->user();
// Get file name
$name = Str::uuid() . '.' . $request->input('extension');
// Move file to user directory
Storage::disk('local')->move($chunkPath, "files/$user->id/$name");
// Process file
$file = ($this->processFie)($request, $user, $name);
return response(new FileResource($file), 201);
}
}
}
@@ -4,56 +4,43 @@ namespace Domain\Files\Controllers;
use Storage; use Storage;
use Illuminate\Support\Str; use Illuminate\Support\Str;
use Domain\Folders\Models\Folder; use Domain\Folders\Models\Folder;
use Illuminate\Http\JsonResponse;
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use Domain\Files\Requests\UploadRequest;
use Domain\Files\Resources\FileResource; use Domain\Files\Resources\FileResource;
use Domain\Files\Actions\ProcessFileAction; use Domain\Files\Actions\ProcessFileAction;
use Domain\Files\Requests\UploadFileRequest;
use Support\Demo\Actions\FakeUploadFileAction; use Support\Demo\Actions\FakeUploadFileAction;
use Domain\Files\Actions\StoreFileChunksAction;
use Illuminate\Contracts\Filesystem\FileNotFoundException;
class UploadFileController extends Controller class UploadFileController extends Controller
{ {
public function __construct( public function __construct(
public ProcessFileAction $processFie, public ProcessFileAction $processFie,
public FakeUploadFileAction $fakeUploadFile, public FakeUploadFileAction $fakeUploadFile,
public StoreFileChunksAction $storeFileChunks,
) { ) {
} }
/** public function __invoke(UploadFileRequest $request): JsonResponse
* Upload file for authenticated master|editor user
*
* @throws FileNotFoundException
*/
public function __invoke(UploadRequest $request)
{ {
if (isDemoAccount()) { if (isDemoAccount()) {
return ($this->fakeUploadFile)($request); return response()->json(($this->fakeUploadFile)($request), 201);
} }
// Store file chunks // Get user
$chunkPath = ($this->storeFileChunks)($request); $user = $request->filled('parent_id')
? Folder::find($request->input('parent_id'))
->getLatestParent()
->user
: auth()->user();
// Proceed after last chunk // Get file name
if ($request->boolean('is_last')) { $name = Str::uuid() . '.' . $request->input('extension');
// Get user
$user = $request->filled('parent_id')
? Folder::find($request->input('parent_id'))
->getLatestParent()
->user
: auth()->user();
// Get file name // Put file to user directory
$name = Str::uuid() . '.' . $request->input('extension'); Storage::disk('local')->put("files/$user->id/$name", $request->file('file')->get());
// Move file to user directory // Process file
Storage::disk('local')->move($chunkPath, "files/$user->id/$name"); $file = ($this->processFie)($request, $user, $name);
// Process file return response()->json(new FileResource($file), 201);
$file = ($this->processFie)($request, $user, $name);
return response(new FileResource($file), 201);
}
} }
} }
@@ -5,9 +5,9 @@ use Str;
use Storage; use Storage;
use Domain\Sharing\Models\Share; use Domain\Sharing\Models\Share;
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;
use Domain\Files\Requests\UploadRequest;
use Domain\Files\Resources\FileResource; use Domain\Files\Resources\FileResource;
use Domain\Files\Actions\ProcessFileAction; use Domain\Files\Actions\ProcessFileAction;
use Domain\Files\Requests\UploadChunkRequest;
use Support\Demo\Actions\FakeUploadFileAction; use Support\Demo\Actions\FakeUploadFileAction;
use Domain\Files\Actions\StoreFileChunksAction; use Domain\Files\Actions\StoreFileChunksAction;
use Domain\Sharing\Actions\ProtectShareRecordAction; use Domain\Sharing\Actions\ProtectShareRecordAction;
@@ -17,7 +17,7 @@ use Illuminate\Contracts\Filesystem\FileNotFoundException;
/** /**
* guest user upload file into shared folder * guest user upload file into shared folder
*/ */
class VisitorUploadFileController extends Controller class VisitorUploadFileChunksController extends Controller
{ {
public function __construct( public function __construct(
public ProcessFileAction $processFie, public ProcessFileAction $processFie,
@@ -32,7 +32,7 @@ class VisitorUploadFileController extends Controller
* @throws FileNotFoundException * @throws FileNotFoundException
*/ */
public function __invoke( public function __invoke(
UploadRequest $request, UploadChunkRequest $request,
Share $shared, Share $shared,
) { ) {
if (isDemoAccount()) { if (isDemoAccount()) {
@@ -54,7 +54,7 @@ class VisitorUploadFileController extends Controller
$chunkPath = ($this->storeFileChunks)($request); $chunkPath = ($this->storeFileChunks)($request);
// Proceed after last chunk // Proceed after last chunk
if ($request->boolean('is_last')) { if ($request->boolean('is_last_chunk')) {
// Get file name // Get file name
$name = Str::uuid() . '.' . $request->input('extension'); $name = Str::uuid() . '.' . $request->input('extension');
@@ -0,0 +1,35 @@
<?php
namespace Domain\Files\Requests;
use Domain\Admin\Rules\DisabledMimetypes;
use Illuminate\Foundation\Http\FormRequest;
class UploadChunkRequest extends FormRequest
{
/**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize()
{
return true;
}
/**
* Get the validation rules that apply to the request.
*
* @return array
*/
public function rules()
{
return [
'name' => 'required|string',
'parent_id' => 'sometimes|uuid',
'path' => 'sometimes|string',
'is_last_chunk' => 'required|boolean',
'extension' => 'required|string|nullable',
'chunk' => ['required', 'file', new DisabledMimetypes],
];
}
}
@@ -4,7 +4,7 @@ namespace Domain\Files\Requests;
use Domain\Admin\Rules\DisabledMimetypes; use Domain\Admin\Rules\DisabledMimetypes;
use Illuminate\Foundation\Http\FormRequest; use Illuminate\Foundation\Http\FormRequest;
class UploadRequest extends FormRequest class UploadFileRequest extends FormRequest
{ {
/** /**
* Determine if the user is authorized to make this request. * Determine if the user is authorized to make this request.
@@ -24,12 +24,11 @@ class UploadRequest extends FormRequest
public function rules() public function rules()
{ {
return [ return [
'name' => 'required|string', 'name' => 'required|string',
'parent_id' => 'nullable|uuid', 'parent_id' => 'sometimes|uuid',
'path' => 'sometimes|string', 'path' => 'sometimes|string',
'is_last' => 'sometimes|string', 'extension' => 'required|string|nullable',
'extension' => 'sometimes|string|nullable', 'file' => ['required', 'file', new DisabledMimetypes],
'file' => ['required', 'file', new DisabledMimetypes],
]; ];
} }
} }
@@ -1,51 +1,21 @@
<?php <?php
namespace Domain\Homepage\Controllers; namespace Domain\Homepage\Controllers;
use DB; use Domain\Settings\Actions\GetConfigAction;
use PDOException;
use Domain\Pages\Models\Page;
use Illuminate\Contracts\View\View; use Illuminate\Contracts\View\View;
use Illuminate\Contracts\View\Factory;
use Illuminate\Contracts\Foundation\Application;
use Support\Status\Actions\GetServerSetupStatusAction;
class IndexController class IndexController
{ {
public function __construct( public function __construct(
public GetServerSetupStatusAction $getServerSetupStatus, public GetConfigAction $getConfig,
) { ) {}
}
/** /**
* Show index page * Show index page
*/ */
public function __invoke(): Application|Factory|View public function __invoke(): View
{ {
$setup_status = 'installation-needed';
try {
// Try to connect to database
DB::getPdo();
// Get setup status
$setup_status = get_setup_status();
// Get app pages
$pages = Page::all();
// Get all settings
$settings = get_settings_in_json();
} catch (PDOException $e) {
}
if ($setup_status === 'installation-needed') {
$status_check = ($this->getServerSetupStatus)();
}
return view('index') return view('index')
->with('status_check', $status_check ?? []) ->with('config', json_decode(json_encode(($this->getConfig)())));
->with('settings', $settings ?? null)
->with('legal', $pages ?? null)
->with('installation', $setup_status);
} }
} }
@@ -0,0 +1,193 @@
<?php
namespace Domain\Settings\Actions;
use DB;
use Domain\Pages\Models\Page;
use Domain\Settings\Controllers\GetServerStatusController;
use Monolog\Handler\MissingExtensionException;
use PDOException;
use VueFileManager\Subscription\Domain\Plans\Models\Plan;
use VueFileManager\Subscription\Domain\Subscriptions\Models\Subscription;
use VueFileManager\Subscription\Domain\Transactions\Models\Transaction;
class GetConfigAction
{
public function __construct(
public GetServerStatusController $getServerSetupStatus,
) {}
public function __invoke(): array
{
$setupStatus = 'installation-needed';
$serverInfo = [];
$settings = null;
try {
// Try to connect to database
DB::getPdo();
// Get setup status
$setupStatus = getInstallationStatus();
// Get all settings
$settings = getAllSettings();
// Get app pages
$pages = Page::all();
// Subscription
$isEmptySubscriptions = Subscription::count() === 0;
$isEmptyTransactions = Transaction::count() === 0;
$isEmptyPlans = Plan::count() === 0;
$plan = Plan::where('status', 'active')
->where('type', 'metered');
// User
$isUser = auth()->check();
$user = auth()->user();
// Default user settings
$defaultEmoji = $isUser ? $user->settings->emoji_type : 'twemoji';
$defaultThemeMode = $isUser ? $user->settings->theme_mode : 'system';
} catch (PDOException $e) {
[$isUser, $isEmptyPlans, $isEmptyTransactions, $isEmptySubscriptions] = false;
$pages = null;
$plan = null;
$defaultEmoji = 'twemoji';
$defaultThemeMode = 'system';
}
if ($setupStatus === 'installation-needed') {
$serverInfo = ($this->getServerSetupStatus)();
}
// Bcmath Extension
try {
$storageDefaultSpaceFormatted = isset($settings->default_max_storage_amount)
? toGigabytes($settings->default_max_storage_amount)
: toGigabytes(5);
$uploadLimit = isset($settings->upload_limit)
? toBytes($settings->upload_limit)
: 'undefined';
$chunkSize = isset($settings->chunk_size)
? toBytes($settings->chunk_size)
: toBytes(64);
$uploadLimitFormatted = isset($settings->upload_limit)
? toMegabytes($settings->upload_limit)
: null;
} catch (MissingExtensionException $e) {
$storageDefaultSpaceFormatted = '5GB';
$uploadLimit = 'undefined';
$uploadLimitFormatted = 5;
$chunkSize = 64000000;
}
return [
// App
'host' => url('/'),
'api' => url('/api'),
'locale' => app()->getLocale(),
'isDev' => is_dev() ? 1 : 0,
'isDemo' => config('vuefilemanager.is_demo') ? 1 : 0,
'isSaaS' => $settings && optional($settings)->license === 'extended' ? 1 : 0,
'isAuthenticated' => $isUser ? 1 : 0,
'isSetupWizardDemo' => config('vuefilemanager.is_setup_wizard_demo') ? 1 : 0,
'isSetupWizardDebug' => config('vuefilemanager.is_setup_wizard_debug') ? 1 : 0,
'isAdminVueFileManagerBar' => config('vuefilemanager.is_admin_vuefilemanager_bar', 1) ? 1 : 0,
'installation' => $setupStatus ?? 'initial',
'statusCheck' => json_encode($serverInfo) ?? 'undefined',
// Broadcasting
'broadcasting' => config('broadcasting.default'),
'broadcastingKey' => config('broadcasting.connections.pusher.key'),
'broadcastingHost' => config('broadcasting.connections.pusher.options.host'),
'broadcastingPort' => config('broadcasting.connections.pusher.options.port'),
'broadcastingCluster' => config('broadcasting.connections.pusher.options.cluster'),
// App Logos
'app_logo' => $settings->app_logo ?? null,
'app_logo_dark' => $settings->app_logo_dark ?? null,
'app_logo_horizontal' => $settings->app_logo_horizontal ?? null,
'app_logo_horizontal_dark' => $settings->app_logo_horizontal_dark ?? null,
// App theme
'app_color' => $settings->app_color ?? '#00BC7E',
'app_footer' => $settings->footer_content ?? null,
// App title & name
'app_name' => $settings->app_title ?? 'VueFileManager',
'app_description' => $settings->app_description ?? __t('app_description'),
'defaultEmoji' => $defaultEmoji,
'defaultThemeMode' => $defaultThemeMode,
// Upload settings
'mimetypesBlacklist' => isset($settings->mimetypes_blacklist) ? $settings->mimetypes_blacklist : null,
'storageDefaultSpace' => $settings->default_max_storage_amount ?? 5,
'storageLimit' => $settings->storage_limitation ?? 1,
'storageDefaultSpaceFormatted' => $storageDefaultSpaceFormatted,
'uploadLimitFormatted' => $uploadLimitFormatted,
'uploadLimit' => $uploadLimit,
'chunkSize' => $chunkSize,
// Metered billings
'allowed_registration_bonus' => $settings->allowed_registration_bonus ?? 0,
'registration_bonus_amount' => $settings->registration_bonus_amount ?? 0,
'isCreatedMeteredPlan' => $plan && $plan->exists() ? 1 : 0,
'meteredPlanId' => $plan && $plan->exists() ? $plan->first()->id : null,
// Payments setup
'allowed_payments' => $settings->allowed_payments ?? 0,
'subscriptionType' => $settings->subscription_type ?? 'none',
'isEmptyPlans' => $isEmptyPlans ? 1 : 0,
'isEmptyTransactions' => $isEmptyTransactions ? 1 : 0,
'isEmptySubscriptions' => $isEmptySubscriptions ? 1 : 0,
// Payment gateways
'isPayPal' => $settings->allowed_paypal ?? 0,
'isPaystack' => $settings->allowed_paystack ?? 0,
'isStripe' => $settings->allowed_stripe ?? 0,
'isPayPalLive' => config('subscription.credentials.paypal.is_live') ? 1 : 0,
'paypal_client_id' => config('subscription.credentials.paypal.id'),
'paystack_public_key' => config('subscription.credentials.paystack.public_key'),
'stripe_public_key' => config('subscription.credentials.stripe.public_key'),
'paypal_payment_description' => $settings->paypal_payment_description ?? null,
'paystack_payment_description' => $settings->paystack_payment_description ?? null,
'stripe_payment_description' => $settings->stripe_payment_description ?? null,
// Google reCaptcha
'allowedRecaptcha' => $settings->allowed_recaptcha ?? 0,
'recaptcha_client_id' => config('services.recaptcha.client_id'),
'isRecaptchaConfigured' => config('services.recaptcha.client_id') ? 1 : 0,
// Social Authentication
'allowedFacebookLogin' => $settings->allowed_facebook_login ?? 0,
'allowedGoogleLogin' => $settings->allowed_google_login ?? 0,
'allowedGithubLogin' => $settings->allowed_github_login ?? 0,
'isFacebookLoginConfigured' => config('services.facebook.client_id') ? 1 : 0,
'isGoogleLoginConfigured' => config('services.google.client_id') ? 1 : 0,
'isGithubLoginConfigured' => config('services.github.client_id') ? 1 : 0,
// Google Adsense
'allowedAdsense' => $settings?->allowed_adsense ?? 0,
'adsenseClientId' => $settings->adsense_client_id ?? null,
'adsenseBanner01' => $settings->adsense_banner_01 ?? null,
'adsenseBanner02' => $settings->adsense_banner_02 ?? null,
'adsenseBanner03' => $settings->adsense_banner_03 ?? null,
// Registration
'userRegistration' => $settings->registration ?? 1,
'userVerification' => $settings->user_verification ?? 0,
// Public Pages
'allowHomepage' => $settings->allow_homepage ?? 1,
'teamsDefaultMembers' => $settings->default_max_team_member ?? 10,
'legal' => $pages ? json_encode($pages) : 'undefined',
];
}
}
@@ -0,0 +1,20 @@
<?php
namespace Domain\Settings\Controllers;
use Domain\Settings\Actions\GetConfigAction;
use App\Http\Controllers\Controller;
use Illuminate\Http\JsonResponse;
class GetConfigController extends Controller
{
public function __construct(
public GetConfigAction $getConfigAction,
) {}
public function __invoke(): JsonResponse
{
return response()->json(($this->getConfigAction)());
}
}
@@ -30,7 +30,7 @@ class WebCrawlerOpenGraphController extends Controller
} }
return view('vuefilemanager.crawler.og-view') return view('vuefilemanager.crawler.og-view')
->with('settings', get_settings_in_json()) ->with('settings', getAllSettings())
->with('metadata', [ ->with('metadata', [
'url' => url('/share', ['token' => $share->token]), 'url' => url('/share', ['token' => $share->token]),
'is_protected' => (int) $share->is_protected, 'is_protected' => (int) $share->is_protected,
@@ -7,11 +7,12 @@ use Illuminate\Support\Str;
use Domain\Folders\Models\Folder; use Domain\Folders\Models\Folder;
use Domain\Files\Resources\FileResource; use Domain\Files\Resources\FileResource;
use Domain\Files\Actions\ProcessFileAction; use Domain\Files\Actions\ProcessFileAction;
use Domain\Files\Requests\UploadChunkRequest;
use Domain\UploadRequest\Models\UploadRequest; use Domain\UploadRequest\Models\UploadRequest;
use Domain\Files\Actions\StoreFileChunksAction; use Domain\Files\Actions\StoreFileChunksAction;
use Illuminate\Contracts\Filesystem\FileNotFoundException; use Illuminate\Contracts\Filesystem\FileNotFoundException;
class UploadFilesForUploadRequestController class UploadFileChunksForUploadRequestController
{ {
public function __construct( public function __construct(
private ProcessFileAction $processFie, private ProcessFileAction $processFie,
@@ -22,7 +23,7 @@ class UploadFilesForUploadRequestController
/** /**
* @throws FileNotFoundException * @throws FileNotFoundException
*/ */
public function __invoke(\Domain\Files\Requests\UploadRequest $request, UploadRequest $uploadRequest) public function __invoke(UploadChunkRequest $request, UploadRequest $uploadRequest)
{ {
// Get upload request root folder query // Get upload request root folder query
$folder = Folder::where('id', $uploadRequest->id); $folder = Folder::where('id', $uploadRequest->id);
@@ -41,7 +42,7 @@ class UploadFilesForUploadRequestController
$chunkPath = ($this->storeFileChunks)($request); $chunkPath = ($this->storeFileChunks)($request);
// Proceed after last chunk // Proceed after last chunk
if ($request->boolean('is_last')) { if ($request->boolean('is_last_chunk')) {
// Get file name // Get file name
$name = Str::uuid() . '.' . $request->input('extension'); $name = Str::uuid() . '.' . $request->input('extension');
@@ -3,7 +3,8 @@ namespace Support\Demo\Actions;
use ByteUnits\Metric; use ByteUnits\Metric;
use Illuminate\Support\Str; use Illuminate\Support\Str;
use Domain\Files\Requests\UploadRequest; use Domain\Files\Requests\UploadFileRequest;
use Domain\Files\Requests\UploadChunkRequest;
class FakeUploadFileAction class FakeUploadFileAction
{ {
@@ -11,7 +12,7 @@ class FakeUploadFileAction
* Upload file * Upload file
*/ */
public function __invoke( public function __invoke(
UploadRequest $request UploadChunkRequest|UploadFileRequest $request
): array { ): array {
$file = $request->file('file'); $file = $request->file('file');
$thumbnail = 'data:' . $request->file('file')->getMimeType() . ';base64, ' . base64_encode(file_get_contents($request->file('file'))); $thumbnail = 'data:' . $request->file('file')->getMimeType() . ';base64, ' . base64_encode(file_get_contents($request->file('file')));
+10 -10
View File
@@ -142,11 +142,11 @@ if (! function_exists('get_settings')) {
} }
} }
if (! function_exists('get_settings_in_json')) { if (! function_exists('getAllSettings')) {
/** /**
* Get all app settings and return them as json * Get all app settings and return them as json
*/ */
function get_settings_in_json() function getAllSettings()
{ {
return json_decode( return json_decode(
Setting::all() Setting::all()
@@ -156,13 +156,13 @@ if (! function_exists('get_settings_in_json')) {
} }
} }
if (! function_exists('get_setup_status')) { if (! function_exists('getInstallationStatus')) {
/** /**
* Check if setup wizard was passed * Check if setup wizard was passed
* *
* @return string * @return string
*/ */
function get_setup_status() function getInstallationStatus()
{ {
$setup_success = get_settings('setup_wizard_success'); $setup_success = get_settings('setup_wizard_success');
@@ -501,14 +501,14 @@ if (! function_exists('make_single_input')) {
} }
} }
if (! function_exists('format_gigabytes')) { if (! function_exists('toGigabytes')) {
/** /**
* Format integer to gigabytes * Format integer to gigabytes
* *
* @param $gigabytes * @param $gigabytes
* @return string * @return string
*/ */
function format_gigabytes($gigabytes) function toGigabytes($gigabytes)
{ {
if ($gigabytes >= 1000) { if ($gigabytes >= 1000) {
return Metric::gigabytes($gigabytes)->format('Tb/'); return Metric::gigabytes($gigabytes)->format('Tb/');
@@ -518,14 +518,14 @@ if (! function_exists('format_gigabytes')) {
} }
} }
if (! function_exists('format_megabytes')) { if (! function_exists('toMegabytes')) {
/** /**
* Format string to formated megabytes string * Format string to formated megabytes string
* *
* @param $megabytes * @param $megabytes
* @return string * @return string
*/ */
function format_megabytes($megabytes) function toMegabytes($megabytes)
{ {
if ($megabytes >= 1000) { if ($megabytes >= 1000) {
return $megabytes / 1000 . 'GB'; return $megabytes / 1000 . 'GB';
@@ -539,14 +539,14 @@ if (! function_exists('format_megabytes')) {
} }
} }
if (! function_exists('format_bytes')) { if (! function_exists('toBytes')) {
/** /**
* Convert megabytes to bytes * Convert megabytes to bytes
* *
* @param $megabytes * @param $megabytes
* @return int|string * @return int|string
*/ */
function format_bytes($megabytes) function toBytes($megabytes)
{ {
return Metric::megabytes($megabytes)->numberOfBytes(); return Metric::megabytes($megabytes)->numberOfBytes();
} }
@@ -109,26 +109,32 @@ class FixedBillingRestrictionsTest extends TestCase
'name' => 'Company Project', 'name' => 'Company Project',
'invitations' => [ 'invitations' => [
[ [
'type' => 'invitation',
'email' => 'test@doe.com', 'email' => 'test@doe.com',
'permission' => 'can-edit', 'permission' => 'can-edit',
], ],
[ [
'type' => 'invitation',
'email' => 'test2@doe.com', 'email' => 'test2@doe.com',
'permission' => 'can-edit', 'permission' => 'can-edit',
], ],
[ [
'type' => 'invitation',
'email' => 'test3@doe.com', 'email' => 'test3@doe.com',
'permission' => 'can-edit', 'permission' => 'can-edit',
], ],
[ [
'type' => 'invitation',
'email' => 'test4@doe.com', 'email' => 'test4@doe.com',
'permission' => 'can-edit', 'permission' => 'can-edit',
], ],
[ [
'type' => 'invitation',
'email' => 'test5@doe.com', 'email' => 'test5@doe.com',
'permission' => 'can-edit', 'permission' => 'can-edit',
], ],
[ [
'type' => 'invitation',
'email' => 'test6@doe.com', 'email' => 'test6@doe.com',
'permission' => 'can-edit', 'permission' => 'can-edit',
], ],
@@ -143,6 +149,7 @@ class FixedBillingRestrictionsTest extends TestCase
'name' => 'Company Project', 'name' => 'Company Project',
'invitations' => [ 'invitations' => [
[ [
'type' => 'invitation',
'email' => $members[0]->email, 'email' => $members[0]->email,
'permission' => 'can-edit', 'permission' => 'can-edit',
], ],
+1 -1
View File
@@ -46,7 +46,7 @@ class PersonalAccessTokenTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->deleteJson("/api/user/tokens/$token_id") ->deleteJson("/api/user/tokens/$token_id")
->assertStatus(204); ->assertStatus(200);
$this->assertDatabaseMissing('personal_access_tokens', [ $this->assertDatabaseMissing('personal_access_tokens', [
'id' => $token_id, 'id' => $token_id,
+1 -1
View File
@@ -309,7 +309,7 @@ class SignFlowTest extends TestCase
$user = User::factory() $user = User::factory()
->create(['email' => 'john@doe.com']); ->create(['email' => 'john@doe.com']);
$this->postJson('/api/password/email', [ $this->postJson('/api/password/recover', [
'email' => $user->email, 'email' => $user->email,
])->assertStatus(200); ])->assertStatus(200);
+10 -6
View File
@@ -74,7 +74,7 @@ class UserAccountTest extends TestCase
'current' => 'secret', 'current' => 'secret',
'password' => 'VerySecretPassword', 'password' => 'VerySecretPassword',
'password_confirmation' => 'VerySecretPassword', 'password_confirmation' => 'VerySecretPassword',
])->assertStatus(204); ])->assertStatus(200);
$this $this
->actingAs($user) ->actingAs($user)
@@ -101,7 +101,7 @@ class UserAccountTest extends TestCase
->patchJson('/api/user/settings', [ ->patchJson('/api/user/settings', [
'name' => 'address', 'name' => 'address',
'value' => 'Jantar', 'value' => 'Jantar',
])->assertStatus(204); ])->assertStatus(200);
$this->assertDatabaseHas('user_settings', [ $this->assertDatabaseHas('user_settings', [
'address' => 'Jantar', 'address' => 'Jantar',
@@ -122,9 +122,13 @@ class UserAccountTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->patchJson('/api/user/settings', [ ->postJson('/api/user/avatar', [
'avatar' => $avatar, 'avatar' => $avatar,
])->assertStatus(204); ])
->assertStatus(200)
->assertJsonFragment([
'message' => 'The avatar was successfully updated.',
]);
collect(config('vuefilemanager.avatar_sizes')) collect(config('vuefilemanager.avatar_sizes'))
->each( ->each(
@@ -246,10 +250,10 @@ class UserAccountTest extends TestCase
'email_verified_at' => null, 'email_verified_at' => null,
]); ]);
$this->postJson('/api/user/email/verify/resend', [ $this->postJson('/api/user/verify', [
'email' => $user->email, 'email' => $user->email,
]) ])
->assertStatus(204); ->assertStatus(200);
Notification::assertTimesSent(1, VerifyEmail::class); Notification::assertTimesSent(1, VerifyEmail::class);
} }
+7 -9
View File
@@ -278,13 +278,11 @@ class AdminTest extends TestCase
$file = UploadedFile::fake() $file = UploadedFile::fake()
->create("fake-file-$index.pdf", 1200, 'application/pdf'); ->create("fake-file-$index.pdf", 1200, 'application/pdf');
$this->postJson('/api/upload', [ $this->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => "/$file->name",
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
}); });
@@ -295,9 +293,9 @@ class AdminTest extends TestCase
$avatar = UploadedFile::fake() $avatar = UploadedFile::fake()
->image('fake-image.jpg'); ->image('fake-image.jpg');
$this->patchJson('/api/user/settings', [ $this->postJson('/api/user/avatar', [
'avatar' => $avatar, 'avatar' => $avatar,
])->assertStatus(204); ])->assertStatus(200);
$user = User::whereRole('user') $user = User::whereRole('user')
->first(); ->first();
+29 -41
View File
@@ -39,13 +39,11 @@ class FileTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => '.jpg', 'extension' => '.jpg',
'file' => $file, 'chunk' => $file,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => "/$file->name",
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$file = File::first(); $file = File::first();
@@ -80,13 +78,11 @@ class FileTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => "/$file->name",
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$disk = Storage::disk('local'); $disk = Storage::disk('local');
@@ -126,13 +122,11 @@ class FileTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'jpeg', 'extension' => 'jpeg',
'file' => $file, 'chunk' => $file,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => "/$file->name",
'is_last' => 'true',
])->assertStatus(401); ])->assertStatus(401);
Storage::disk('local')->assertMissing( Storage::disk('local')->assertMissing(
@@ -159,12 +153,10 @@ class FileTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'file' => $file, 'chunk' => $file,
'extension' => 'pdf', 'extension' => 'pdf',
'parent_id' => null, 'is_last_chunk' => 1,
'path' => "/$file->name",
'is_last' => 'true',
])->assertStatus(422); ])->assertStatus(422);
Storage::disk('local') Storage::disk('local')
@@ -351,13 +343,11 @@ class FileTest extends TestCase
$file = UploadedFile::fake() $file = UploadedFile::fake()
->create("fake-file-$index.pdf", 1200, 'application/pdf'); ->create("fake-file-$index.pdf", 1200, 'application/pdf');
$this->postJson('/api/upload', [ $this->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => "/$file->name",
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
}); });
@@ -405,13 +395,11 @@ class FileTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'jpg', 'extension' => 'jpg',
'file' => $file, 'chunk' => $file,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => '/' . $file->name,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$file = File::first(); $file = File::first();
+2 -2
View File
@@ -21,7 +21,7 @@ class FavouriteFolderTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/folders/favourites', [ ->postJson('/api/favourites', [
'ids' => [ 'ids' => [
$folder->id, $folder->id,
], ],
@@ -51,7 +51,7 @@ class FavouriteFolderTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->deleteJson("/api/folders/favourites/$folder->id") ->deleteJson("/api/favourites/$folder->id")
->assertStatus(201); ->assertStatus(201);
$this->assertDatabaseMissing('favourite_folder', [ $this->assertDatabaseMissing('favourite_folder', [
+6 -7
View File
@@ -370,13 +370,12 @@ class FolderTest extends TestCase
$file = UploadedFile::fake() $file = UploadedFile::fake()
->create("fake-file-$index.pdf", 1200, 'application/pdf'); ->create("fake-file-$index.pdf", 1200, 'application/pdf');
$this->postJson('/api/upload', [ $this->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => $folder->id, 'parent_id' => $folder->id,
'path' => "/$file->name", 'is_last_chunk' => 1,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
}); });
+36 -43
View File
@@ -29,13 +29,12 @@ class FolderUploadTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'path' => '/', 'parent_id' => $folder->id,
'parent_id' => $folder->id, 'is_last_chunk' => 1,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$file = File::first(); $file = File::first();
@@ -59,24 +58,22 @@ class FolderUploadTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'path' => "/level_1/level_2/level_3/$file->name", 'path' => "/level_1/level_2/level_3/$file->name",
'parent_id' => null, 'is_last_chunk' => 1,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'path' => "/level_1/level_2/level_3/$file->name", 'path' => "/level_1/level_2/level_3/$file->name",
'parent_id' => null, 'is_last_chunk' => 1,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$file = File::first(); $file = File::first();
@@ -107,7 +104,6 @@ class FolderUploadTest extends TestCase
->create([ ->create([
'name' => 'level_1', 'name' => 'level_1',
'user_id' => $user->id, 'user_id' => $user->id,
'parent_id' => null,
]); ]);
$level_2 = Folder::factory() $level_2 = Folder::factory()
@@ -129,13 +125,12 @@ class FolderUploadTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'path' => "/another_folder/level_2/level_3/$file->name", 'path' => "/another_folder/level_2/level_3/$file->name",
'parent_id' => null, 'is_last_chunk' => 1,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
// Root folders // Root folders
@@ -166,24 +161,22 @@ class FolderUploadTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $brother->name, 'name' => $brother->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $brother, 'chunk' => $brother,
'path' => "/Folder/Brother/$brother->name", 'path' => "/Folder/Brother/$brother->name",
'parent_id' => null, 'is_last_chunk' => 1,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $sister->name, 'name' => $sister->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $sister, 'chunk' => $sister,
'path' => "/Folder/Sister/$sister->name", 'path' => "/Folder/Sister/$sister->name",
'parent_id' => null, 'is_last_chunk' => 1,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$brotherFile = File::where('name', 'brother.pdf')->first(); $brotherFile = File::where('name', 'brother.pdf')->first();
@@ -42,7 +42,7 @@ class NotificationsTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->getJson('/api/user/notifications') ->getJson('/api/notifications')
->assertJsonFragment([ ->assertJsonFragment([
'category' => 'file-request', 'category' => 'file-request',
]) ])
@@ -83,8 +83,8 @@ class NotificationsTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/user/notifications/read') ->postJson('/api/notifications/read')
->assertStatus(204); ->assertStatus(200);
$this->assertDatabaseHas('notifications', [ $this->assertDatabaseHas('notifications', [
'read_at' => now(), 'read_at' => now(),
@@ -125,8 +125,8 @@ class NotificationsTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->deleteJson('/api/user/notifications') ->deleteJson('/api/notifications')
->assertStatus(204); ->assertStatus(200);
$this->assertDatabaseCount('notifications', 0); $this->assertDatabaseCount('notifications', 0);
} }
@@ -329,25 +329,23 @@ class VisitorManipulatingTest extends TestCase
$this $this
->withUnencryptedCookies($cookie) ->withUnencryptedCookies($cookie)
->post("/api/editor/upload/$share->token", [ ->post("/api/editor/upload/chunks/$share->token", [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => $folder->id, 'parent_id' => $folder->id,
'path' => "/$file->name", 'is_last_chunk' => 1,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
} }
// Check public shared item // Check public shared item
if (! $is_protected) { if (! $is_protected) {
$this->postJson("/api/editor/upload/$share->token", [ $this->postJson("/api/editor/upload/chunks/$share->token", [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => $folder->id, 'parent_id' => $folder->id,
'path' => "/$file->name", 'is_last_chunk' => 1,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
} }
+12 -14
View File
@@ -31,13 +31,12 @@ class TeamFileAccessTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => $folder->id, 'parent_id' => $folder->id,
'path' => "/$file->name", 'is_last_chunk' => 1,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
}); });
@@ -80,13 +79,12 @@ class TeamFileAccessTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => $folder->id, 'parent_id' => $folder->id,
'path' => "/$file->name", 'is_last_chunk' => 1,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
}); });
+9 -5
View File
@@ -86,7 +86,7 @@ class TeamManagementTest extends TestCase
$this $this
->actingAs($member) ->actingAs($member)
->putJson("/api/teams/invitations/{$invitation->id}") ->putJson("/api/teams/invitations/{$invitation->id}")
->assertNoContent(); ->assertOk();
// Get notification // Get notification
$notification = json_decode(DB::table('notifications')->first()->data); $notification = json_decode(DB::table('notifications')->first()->data);
@@ -124,7 +124,7 @@ class TeamManagementTest extends TestCase
$this $this
->putJson("/api/teams/invitations/{$invitation->id}") ->putJson("/api/teams/invitations/{$invitation->id}")
->assertNoContent(); ->assertOk();
$this $this
->assertDatabaseHas('team_folder_invitations', [ ->assertDatabaseHas('team_folder_invitations', [
@@ -228,7 +228,7 @@ class TeamManagementTest extends TestCase
$this $this
->actingAs($member) ->actingAs($member)
->deleteJson("/api/teams/invitations/{$invitation->id}") ->deleteJson("/api/teams/invitations/{$invitation->id}")
->assertNoContent(); ->assertOk();
// Get notification // Get notification
$notification = json_decode(DB::table('notifications')->first()->data); $notification = json_decode(DB::table('notifications')->first()->data);
@@ -300,11 +300,13 @@ class TeamManagementTest extends TestCase
], ],
'invitations' => [ 'invitations' => [
[ [
'type' => 'invitation',
'id' => null, 'id' => null,
'email' => 'existing@member.com', 'email' => 'existing@member.com',
'permission' => 'can-edit', 'permission' => 'can-edit',
], ],
[ [
'type' => 'invitation',
'id' => null, 'id' => null,
'email' => 'added@member.com', 'email' => 'added@member.com',
'permission' => 'can-view', 'permission' => 'can-view',
@@ -385,6 +387,7 @@ class TeamManagementTest extends TestCase
], ],
'invitations' => [ 'invitations' => [
[ [
'type' => 'invitation',
'id' => null, 'id' => null,
'email' => 'existing@member.com', 'email' => 'existing@member.com',
'permission' => 'can-view', 'permission' => 'can-view',
@@ -482,6 +485,7 @@ class TeamManagementTest extends TestCase
'members' => [], 'members' => [],
'invitations' => [ 'invitations' => [
[ [
'type' => 'invitation',
'id' => null, 'id' => null,
'email' => 'existing@member.com', 'email' => 'existing@member.com',
'permission' => 'can-edit', 'permission' => 'can-edit',
@@ -654,7 +658,7 @@ class TeamManagementTest extends TestCase
$this $this
->actingAs($user) ->actingAs($user)
->deleteJson("/api/teams/folders/{$folder->id}") ->deleteJson("/api/teams/folders/{$folder->id}")
->assertNoContent(); ->assertOk();
$this $this
->assertDatabaseCount('team_folder_members', 0) ->assertDatabaseCount('team_folder_members', 0)
@@ -698,7 +702,7 @@ class TeamManagementTest extends TestCase
$this $this
->actingAs($member) ->actingAs($member)
->deleteJson("/api/teams/folders/{$folder->id}/leave") ->deleteJson("/api/teams/folders/{$folder->id}/leave")
->assertNoContent(); ->assertOk();
$this $this
->assertDatabaseMissing('team_folder_members', [ ->assertDatabaseMissing('team_folder_members', [
+10 -7
View File
@@ -56,10 +56,12 @@ class TeamsTest extends TestCase
'name' => 'Company Project', 'name' => 'Company Project',
'invitations' => [ 'invitations' => [
[ [
'type' => 'invitation',
'email' => 'john@internal.com', 'email' => 'john@internal.com',
'permission' => 'can-edit', 'permission' => 'can-edit',
], ],
[ [
'type' => 'invitation',
'email' => 'jane@external.com', 'email' => 'jane@external.com',
'permission' => 'can-view', 'permission' => 'can-view',
], ],
@@ -139,10 +141,12 @@ class TeamsTest extends TestCase
->post("/api/teams/folders/{$folder->id}/convert", [ ->post("/api/teams/folders/{$folder->id}/convert", [
'invitations' => [ 'invitations' => [
[ [
'type' => 'invitation',
'email' => 'john@internal.com', 'email' => 'john@internal.com',
'permission' => 'can-edit', 'permission' => 'can-edit',
], ],
[ [
'type' => 'invitation',
'email' => 'jane@external.com', 'email' => 'jane@external.com',
'permission' => 'can-view', 'permission' => 'can-view',
], ],
@@ -282,13 +286,12 @@ class TeamsTest extends TestCase
$this $this
->actingAs($member) ->actingAs($member)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => $folder->id, 'parent_id' => $folder->id,
'path' => "/$file->name", 'is_last_chunk' => 1,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$this->assertDatabaseHas('files', [ $this->assertDatabaseHas('files', [
+21 -24
View File
@@ -36,12 +36,11 @@ class TrafficTest extends TestCase
{ {
$this $this
->actingAs($this->user) ->actingAs($this->user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $this->file->name, 'name' => $this->file->name,
'file' => $this->file, 'chunk' => $this->file,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => '/' . $this->file->name, 'extension' => 'jpg',
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$this->assertDatabaseHas('traffic', [ $this->assertDatabaseHas('traffic', [
@@ -57,12 +56,11 @@ class TrafficTest extends TestCase
{ {
$this $this
->actingAs($this->user) ->actingAs($this->user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $this->file->name, 'name' => $this->file->name,
'file' => $this->file, 'chunk' => $this->file,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => '/' . $this->file->name, 'extension' => 'jpg',
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$this->assertDatabaseHas('traffic', [ $this->assertDatabaseHas('traffic', [
@@ -78,12 +76,11 @@ class TrafficTest extends TestCase
$this $this
->actingAs($this->user) ->actingAs($this->user)
->postJson('/api/upload', [ ->postJson('/api/upload/chunks', [
'name' => $secondFile->name, 'name' => $secondFile->name,
'file' => $secondFile, 'chunk' => $secondFile,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => '/' . $secondFile->name, 'extension' => 'jpg',
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$this->assertDatabaseHas('traffic', [ $this->assertDatabaseHas('traffic', [
@@ -116,12 +113,12 @@ class TrafficTest extends TestCase
]); ]);
// Check public shared item // Check public shared item
$this->postJson("/api/editor/upload/$share->token", [ $this->postJson("/api/editor/upload/chunks/$share->token", [
'name' => $this->file->name, 'name' => $this->file->name,
'file' => $this->file, 'chunk' => $this->file,
'parent_id' => $folder->id, 'parent_id' => $folder->id,
'path' => '/' . $this->file->name, 'extension' => 'jpg',
'is_last' => 'true', 'is_last_chunk' => 1,
])->assertStatus(201); ])->assertStatus(201);
$this->assertDatabaseHas('traffic', [ $this->assertDatabaseHas('traffic', [
+5 -6
View File
@@ -74,12 +74,11 @@ class TrashTest extends TestCase
$image = UploadedFile::fake() $image = UploadedFile::fake()
->image('fake-image.jpg'); ->image('fake-image.jpg');
$this->postJson('/api/upload', [ $this->postJson('/api/upload/chunks', [
'name' => $image->name, 'name' => $image->name,
'file' => $image, 'chunk' => $image,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => '/' . $image->name, 'extension' => 'jpg',
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$file = File::first(); $file = File::first();
@@ -6,6 +6,7 @@ use Notification;
use Tests\TestCase; use Tests\TestCase;
use App\Users\Models\User; use App\Users\Models\User;
use Domain\Files\Models\File; use Domain\Files\Models\File;
use Domain\Folders\Models\Folder;
use Illuminate\Http\UploadedFile; use Illuminate\Http\UploadedFile;
use Domain\UploadRequest\Models\UploadRequest; use Domain\UploadRequest\Models\UploadRequest;
use Support\Scheduler\Actions\ExpireUnfilledUploadRequestAction; use Support\Scheduler\Actions\ExpireUnfilledUploadRequestAction;
@@ -34,17 +35,22 @@ class UploadRequestTest extends TestCase
->hasSettings() ->hasSettings()
->create(); ->create();
$folder = Folder::factory()
->create([
'user_id' => $user->id,
]);
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload-request', [ ->postJson('/api/upload-request', [
'folder_id' => '00cacdb9-1d09-4a32-8ad7-c0d45d66b758', 'folder_id' => $folder->id,
'email' => 'howdy@hi5ve.digital', 'email' => 'howdy@hi5ve.digital',
'notes' => 'Please send me your files...', 'notes' => 'Please send me your files...',
]) ])
->assertCreated(); ->assertCreated();
$this->assertDatabasehas('upload_requests', [ $this->assertDatabasehas('upload_requests', [
'folder_id' => '00cacdb9-1d09-4a32-8ad7-c0d45d66b758', 'folder_id' => $folder->id,
'email' => 'howdy@hi5ve.digital', 'email' => 'howdy@hi5ve.digital',
'notes' => 'Please send me your files...', 'notes' => 'Please send me your files...',
]); ]);
@@ -61,16 +67,21 @@ class UploadRequestTest extends TestCase
->hasSettings() ->hasSettings()
->create(); ->create();
$folder = Folder::factory()
->create([
'user_id' => $user->id,
]);
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload-request', [ ->postJson('/api/upload-request', [
'folder_id' => '00cacdb9-1d09-4a32-8ad7-c0d45d66b758', 'folder_id' => $folder->id,
'notes' => 'Please send me your files...', 'notes' => 'Please send me your files...',
]) ])
->assertCreated(); ->assertCreated();
$this->assertDatabasehas('upload_requests', [ $this->assertDatabasehas('upload_requests', [
'folder_id' => '00cacdb9-1d09-4a32-8ad7-c0d45d66b758', 'folder_id' => $folder->id,
'notes' => 'Please send me your files...', 'notes' => 'Please send me your files...',
'email' => null, 'email' => null,
]); ]);
@@ -87,17 +98,22 @@ class UploadRequestTest extends TestCase
->hasSettings() ->hasSettings()
->create(); ->create();
$folder = Folder::factory()
->create([
'user_id' => $user->id,
]);
$this $this
->actingAs($user) ->actingAs($user)
->postJson('/api/upload-request', [ ->postJson('/api/upload-request', [
'folder_id' => '00cacdb9-1d09-4a32-8ad7-c0d45d66b758', 'folder_id' => $folder->id,
'notes' => 'Please send me your files...', 'notes' => 'Please send me your files...',
'name' => 'My name', 'name' => 'My name',
]) ])
->assertCreated(); ->assertCreated();
$this->assertDatabasehas('upload_requests', [ $this->assertDatabasehas('upload_requests', [
'folder_id' => '00cacdb9-1d09-4a32-8ad7-c0d45d66b758', 'folder_id' => $folder->id,
'notes' => 'Please send me your files...', 'notes' => 'Please send me your files...',
'email' => null, 'email' => null,
'name' => 'My name', 'name' => 'My name',
@@ -149,13 +165,11 @@ class UploadRequestTest extends TestCase
->create('fake-file.pdf', 12000000, 'application/pdf'); ->create('fake-file.pdf', 12000000, 'application/pdf');
$this $this
->postJson("/api/upload-request/$uploadRequest->id/upload", [ ->postJson("/api/upload-request/$uploadRequest->id/upload/chunks", [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => "/$file->name",
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$this $this
@@ -195,13 +209,11 @@ class UploadRequestTest extends TestCase
->create('fake-file.pdf', 12000000, 'application/pdf'); ->create('fake-file.pdf', 12000000, 'application/pdf');
$this $this
->postJson("/api/upload-request/$uploadRequest->id/upload", [ ->postJson("/api/upload-request/$uploadRequest->id/upload/chunks", [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => "/$file->name",
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
$this $this
@@ -240,12 +252,10 @@ class UploadRequestTest extends TestCase
->create('fake-file.pdf', 12000000, 'application/pdf'); ->create('fake-file.pdf', 12000000, 'application/pdf');
$this $this
->postJson("/api/upload-request/$uploadRequest->id/upload", [ ->postJson("/api/upload-request/$uploadRequest->id/upload/chunks", [
'name' => $file->name, 'name' => $file->name,
'file' => $file, 'file' => $file,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => "/$file->name",
'is_last' => 'true',
])->assertStatus(410); ])->assertStatus(410);
} }
@@ -313,13 +323,11 @@ class UploadRequestTest extends TestCase
->create('fake-file.pdf', 12000000, 'application/pdf'); ->create('fake-file.pdf', 12000000, 'application/pdf');
$this $this
->postJson("/api/upload-request/$uploadRequest->id/upload", [ ->postJson("/api/upload-request/$uploadRequest->id/upload/chunks", [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => "/$file->name",
'is_last' => 'true',
])->assertCreated(); ])->assertCreated();
$this->travel(3)->hours(); $this->travel(3)->hours();
+17 -21
View File
@@ -31,13 +31,12 @@ class UserZippingTest extends TestCase
$file = UploadedFile::fake() $file = UploadedFile::fake()
->create("fake-inner-file-$index.pdf", 1200, 'application/pdf'); ->create("fake-inner-file-$index.pdf", 1200, 'application/pdf');
$this->postJson('/api/upload', [ $this->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => $folder->id, 'parent_id' => $folder->id,
'path' => "/$file->name", 'is_last_chunk' => 1,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
}); });
@@ -46,13 +45,11 @@ class UserZippingTest extends TestCase
$file = UploadedFile::fake() $file = UploadedFile::fake()
->create("fake-file-$index.pdf", 1200, 'application/pdf'); ->create("fake-file-$index.pdf", 1200, 'application/pdf');
$this->postJson('/api/upload', [ $this->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => null, 'is_last_chunk' => 1,
'path' => "/$file->name",
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
}); });
@@ -88,13 +85,12 @@ class UserZippingTest extends TestCase
$file = UploadedFile::fake() $file = UploadedFile::fake()
->create("fake-file-$index.pdf", 1200, 'application/pdf'); ->create("fake-file-$index.pdf", 1200, 'application/pdf');
$this->postJson('/api/upload', [ $this->postJson('/api/upload/chunks', [
'name' => $file->name, 'name' => $file->name,
'extension' => 'pdf', 'extension' => 'pdf',
'file' => $file, 'chunk' => $file,
'parent_id' => $folder->id, 'parent_id' => $folder->id,
'path' => "/$file->name", 'is_last_chunk' => 1,
'is_last' => 'true',
])->assertStatus(201); ])->assertStatus(201);
}); });