- set default_max_team_member

- generate traffic for all users
This commit is contained in:
Čarodej
2021-11-30 17:46:21 +01:00
parent c7c81dda34
commit ca257ae113
13 changed files with 103 additions and 61 deletions

View File

@@ -24,7 +24,7 @@
"/chunks/app-language.js": "/chunks/app-language.js?id=21a381da055e57280eed",
"/chunks/app-language~chunks/dashboard~chunks/files~chunks/invoices~chunks/my-shared-items~chunks/page~7dbb6a42.js": "/chunks/app-language~chunks/dashboard~chunks/files~chunks/invoices~chunks/my-shared-items~chunks/page~7dbb6a42.js?id=3cbb19b80e635b3524e5",
"/chunks/app-language~chunks/dashboard~chunks/invoices~chunks/page-edit~chunks/pages~chunks/plan-creat~1a92dd55.js": "/chunks/app-language~chunks/dashboard~chunks/invoices~chunks/page-edit~chunks/pages~chunks/plan-creat~1a92dd55.js?id=75317652be9e911b6013",
"/chunks/app-others.js": "/chunks/app-others.js?id=d763956aafc730e5bdcb",
"/chunks/app-others.js": "/chunks/app-others.js?id=2789aac07c894eeb29ea",
"/chunks/app-payments.js": "/chunks/app-payments.js?id=8ca6c120a8ba6f3659f6",
"/chunks/app-settings.js": "/chunks/app-settings.js?id=2a96295eef59bd6c8921",
"/chunks/app-setup.js": "/chunks/app-setup.js?id=1b7698981735d7173309",
@@ -250,5 +250,6 @@
"/chunks/user-storage.0e8d7663b9f8cd40de17.hot-update.js": "/chunks/user-storage.0e8d7663b9f8cd40de17.hot-update.js",
"/chunks/user-storage.4eff070ff2a92236c8b2.hot-update.js": "/chunks/user-storage.4eff070ff2a92236c8b2.hot-update.js",
"/chunks/settings-storage.4ecc7c38e789439da637.hot-update.js": "/chunks/settings-storage.4ecc7c38e789439da637.hot-update.js",
"/chunks/user-storage.4ecc7c38e789439da637.hot-update.js": "/chunks/user-storage.4ecc7c38e789439da637.hot-update.js"
"/chunks/user-storage.4ecc7c38e789439da637.hot-update.js": "/chunks/user-storage.4ecc7c38e789439da637.hot-update.js",
"/chunks/app-others.753478462556c2b747a9.hot-update.js": "/chunks/app-others.753478462556c2b747a9.hot-update.js"
}

View File

@@ -15,7 +15,7 @@
</AppInputSwitch>
<AppInputText v-if="app.storageLimitation" :title="$t('admin_settings.others.default_storage')">
<input @input="$updateText('/admin/settings', 'default_storage_amount', app.defaultStorage)"
<input @input="$updateText('/admin/settings', 'default_max_storage_amount', app.defaultStorage)"
v-model="app.defaultStorage"
min="1"
max="999999999"
@@ -140,7 +140,7 @@
mounted() {
axios.get('/api/admin/settings', {
params: {
column: 'contact_email|google_analytics|default_storage_amount|registration|storage_limitation|mimetypes_blacklist|upload_limit|user_verification'
column: 'contact_email|google_analytics|default_max_storage_amount|registration|storage_limitation|mimetypes_blacklist|upload_limit|user_verification'
}
})
.then(response => {
@@ -149,7 +149,7 @@
this.app = {
contactMail: response.data.contact_email,
googleAnalytics: response.data.google_analytics,
defaultStorage: response.data.default_storage_amount,
defaultStorage: response.data.default_max_storage_amount,
userRegistration: parseInt(response.data.registration),
storageLimitation: parseInt(response.data.storage_limitation),
mimetypesBlacklist: response.data.mimetypes_blacklist,

View File

@@ -60,8 +60,8 @@
userRegistration: {{ $settings->registration ?? 1 }},
userVerification: {{ $settings->user_verification ?? 0 }},
storageLimit: {{ $settings->storage_limitation ?? 1 }},
storageDefaultSpace: {{ $settings->default_storage_amount ?? 5 }},
storageDefaultSpaceFormatted: '{{ isset($settings->default_storage_amount) ? format_gigabytes($settings->default_storage_amount) : format_gigabytes(5) }}',
storageDefaultSpace: {{ $settings->default_max_storage_amount ?? 5 }},
storageDefaultSpaceFormatted: '{{ isset($settings->default_max_storage_amount) ? format_gigabytes($settings->default_max_storage_amount) : format_gigabytes(5) }}',
mimetypesBlacklist: '{{ isset($settings->mimetypes_blacklist) ? $settings->mimetypes_blacklist: null}}',
uploadLimit: {{ isset($settings->upload_limit) ? format_bytes($settings->upload_limit) : 'undefined' }},
uploadLimitFormatted: '{{ isset($settings->upload_limit) ? format_megabytes($settings->upload_limit) : null }}',

View File

@@ -1,4 +1,5 @@
<?php
namespace App\Console\Commands;
use App\Users\Models\User;
@@ -38,7 +39,8 @@ class SetupDevEnvironment extends Command
private SeedDefaultSettingsAction $seedDefaultSettings,
private SeedDefaultLanguageAction $seedDefaultLanguage,
private SeedDefaultPagesAction $seedDefaultPages,
) {
)
{
parent::__construct();
$this->setUpFaker();
}
@@ -71,10 +73,10 @@ class SetupDevEnvironment extends Command
$this->info('Creating default demo content...');
$this->create_admin_default_content();
$this->generate_traffic();
$this->create_team_folders_content();
$this->create_share_with_me_team_folders_content();
$this->create_share_records();
$this->generate_traffic();
$this->info('Clearing application cache...');
$this->clear_cache();
@@ -119,23 +121,6 @@ class SetupDevEnvironment extends Command
$this->info('Default admin account created. Email: howdy@hi5ve.digital and Password: vuefilemanager');
}
private function generate_traffic(): void
{
$user = User::whereEmail('howdy@hi5ve.digital')
->first();
foreach (range(0, 45) as $day) {
DB::table('traffic')->insert([
'id' => Str::uuid(),
'user_id' => $user->id,
'upload' => random_int(1111111, 9999999),
'download' => random_int(11111111, 99999999),
'created_at' => now()->subDays($day),
'updated_at' => now()->subDays($day),
]);
}
}
/**
* Create default admin account
*/
@@ -1030,9 +1015,13 @@ class SetupDevEnvironment extends Command
'value' => 1,
],
[
'name' => 'default_storage_amount',
'name' => 'default_max_storage_amount',
'value' => 5,
],
[
'name' => 'default_max_team_member',
'value' => 10,
],
[
'name' => 'setup_wizard_success',
'value' => 1,
@@ -1091,6 +1080,30 @@ class SetupDevEnvironment extends Command
});
}
/**
* Generate demo traffic data
*/
private function generate_traffic(): void
{
$user = User::all();
foreach (range(0, 45) as $day) {
$user
->each(fn($user) => DB::table('traffic')
->insert([
'id' => Str::uuid(),
'user_id' => $user->id,
'upload' => random_int(1111111, 9999999),
'download' => random_int(11111111, 99999999),
'created_at' => now()->subDays($day),
'updated_at' => now()->subDays($day),
])
);
}
}
/**
* Migrate database and generate application keys
*/

View File

@@ -125,9 +125,13 @@ class SetupProdEnvironment extends Command
'value' => 1,
],
[
'name' => 'default_storage_amount',
'name' => 'default_max_storage_amount',
'value' => 5,
],
[
'name' => 'default_max_team_member',
'value' => 10,
],
[
'name' => 'setup_wizard_success',
'value' => 1,

View File

@@ -24,7 +24,7 @@ class CreateNewUserAction extends Controller
RegisterUserRequest $request
): Application | ResponseFactory | Response {
$settings = get_settings([
'default_storage_amount', 'registration', 'user_verification',
'default_max_storage_amount', 'registration', 'user_verification',
]);
// Check if account registration is enabled

View File

@@ -209,8 +209,8 @@ class User extends Authenticatable implements MustVerifyEmail
// Create default limitations
$user->limitations()->create([
'max_storage_amount' => get_settings('default_storage_amount') ?? 1,
'max_team_members' => 5,
'max_storage_amount' => get_settings('default_max_storage_amount') ?? 1,
'max_team_members' => get_settings('default_max_team_member') ?? 10,
]);
// Create user directory for his files

View File

@@ -61,9 +61,13 @@ class StoreAppSettingsController extends Controller
'value' => $request->input('storageLimitation'),
],
[
'name' => 'default_storage_amount',
'name' => 'default_max_storage_amount',
'value' => $request->input('defaultStorage') ?? 5,
],
[
'name' => 'default_max_team_member',
'value' => $request->input('defaultMaxTeamMember') ?? 10,
],
])->each(function ($col) {
Setting::forceCreate([
'name' => $col['name'],

View File

@@ -27,7 +27,7 @@ class SubscriptionEventSubscriber
public function handleSubscriptionWasExpired($event)
{
$event->subscription->user->limitations()->update([
'max_storage_amount' => get_settings('default_storage_amount') ?? 1,
'max_storage_amount' => get_settings('default_max_storage_amount') ?? 5,
'max_team_members' => 5,
]);
}

View File

@@ -19,7 +19,7 @@ class SignFlowTest extends TestCase
{
collect([
[
'name' => 'default_storage_amount',
'name' => 'default_max_storage_amount',
'value' => 12,
],
[

View File

@@ -95,7 +95,7 @@ class UserSubscriptionTest extends TestCase
SubscriptionWasExpired::dispatch($user->subscription);
$this->assertDatabaseHas('user_limitations', [
'max_storage_amount' => 1,
'max_storage_amount' => 5,
'max_team_members' => 5,
]);
}

View File

@@ -188,7 +188,7 @@ class SetupWizardTest extends TestCase
]);
$this->assertDatabaseHas('settings', [
'name' => 'default_storage_amount',
'name' => 'default_max_storage_amount',
'value' => '10',
]);

View File

@@ -46,6 +46,26 @@ class TeamLimitsTest extends TestCase
'email' => 'test@doe.com',
'permission' => 'can-edit',
],
[
'email' => 'test2@doe.com',
'permission' => 'can-edit',
],
[
'email' => 'test3@doe.com',
'permission' => 'can-edit',
],
[
'email' => 'test4@doe.com',
'permission' => 'can-edit',
],
[
'email' => 'test5@doe.com',
'permission' => 'can-edit',
],
[
'email' => 'test6@doe.com',
'permission' => 'can-edit',
],
],
])
->assertStatus(423);