mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-28 19:10:40 +00:00
MeteredBillingRestrictionsEngine update with the new rule for dunning
This commit is contained in:
@@ -46,6 +46,10 @@ class AppServiceProvider extends ServiceProvider
|
|||||||
|
|
||||||
private function setSubscriptionConfig(): void
|
private function setSubscriptionConfig(): void
|
||||||
{
|
{
|
||||||
|
if (app()->runningUnitTests()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
$settings = getAllSettings();
|
$settings = getAllSettings();
|
||||||
|
|
||||||
config([
|
config([
|
||||||
|
|||||||
@@ -8,26 +8,46 @@ class MeteredBillingRestrictionsEngine implements RestrictionsEngine
|
|||||||
{
|
{
|
||||||
public function canUpload(User $user, int $fileSize = 0): bool
|
public function canUpload(User $user, int $fileSize = 0): bool
|
||||||
{
|
{
|
||||||
|
// Check the count of the dunning emails
|
||||||
|
if ($this->getDunningSequenceCount($user) === 3) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// Disable upload when user has more than 3 failed payments
|
// Disable upload when user has more than 3 failed payments
|
||||||
return ! ($user->failedPayments()->count() >= 3);
|
return $this->checkFailedPayments($user);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function canDownload(User $user): bool
|
public function canDownload(User $user): bool
|
||||||
{
|
{
|
||||||
|
// Check the count of the dunning emails
|
||||||
|
if ($this->getDunningSequenceCount($user) === 3) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// Disable download when user has more than 3 failed payments
|
// Disable download when user has more than 3 failed payments
|
||||||
return ! ($user->failedPayments()->count() >= 3);
|
return $this->checkFailedPayments($user);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function canCreateFolder(User $user): bool
|
public function canCreateFolder(User $user): bool
|
||||||
{
|
{
|
||||||
|
// Check the count of the dunning emails
|
||||||
|
if ($this->getDunningSequenceCount($user) === 3) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// Disable create folder when user has more than 3 failed payments
|
// Disable create folder when user has more than 3 failed payments
|
||||||
return ! ($user->failedPayments()->count() >= 3);
|
return $this->checkFailedPayments($user);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function canCreateTeamFolder(User $user): bool
|
public function canCreateTeamFolder(User $user): bool
|
||||||
{
|
{
|
||||||
|
// Check the count of the dunning emails
|
||||||
|
if ($this->getDunningSequenceCount($user) === 3) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// Disable create folder when user has more than 3 failed payments
|
// Disable create folder when user has more than 3 failed payments
|
||||||
return ! ($user->failedPayments()->count() >= 3);
|
return $this->checkFailedPayments($user);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function canInviteTeamMembers(User $user, array $newInvites = []): bool
|
public function canInviteTeamMembers(User $user, array $newInvites = []): bool
|
||||||
@@ -37,7 +57,22 @@ class MeteredBillingRestrictionsEngine implements RestrictionsEngine
|
|||||||
|
|
||||||
public function canVisitShared(User $user): bool
|
public function canVisitShared(User $user): bool
|
||||||
{
|
{
|
||||||
|
// Check the count of the dunning emails
|
||||||
|
if ($this->getDunningSequenceCount($user) === 3) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// Disable share visit when user has more than 3 failed payments
|
// Disable share visit when user has more than 3 failed payments
|
||||||
return ! ($user->failedPayments()->count() >= 3);
|
return $this->checkFailedPayments($user);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getDunningSequenceCount(User $user): int
|
||||||
|
{
|
||||||
|
return cache()->remember("dunning-count.$user->id", 3600, fn () => $user?->dunning->sequence ?? 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function checkFailedPayments(User $user): bool
|
||||||
|
{
|
||||||
|
return cache()->remember("failed-payments-count.$user->id", 3600, fn () => !($user->failedPayments()->count() >= 3));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace Tests\App\Restrictions;
|
namespace Tests\App\Restrictions;
|
||||||
|
|
||||||
use Illuminate\Http\UploadedFile;
|
use Illuminate\Http\UploadedFile;
|
||||||
@@ -9,6 +10,7 @@ use App\Users\Models\User;
|
|||||||
use Domain\Files\Models\File;
|
use Domain\Files\Models\File;
|
||||||
use Domain\Sharing\Models\Share;
|
use Domain\Sharing\Models\Share;
|
||||||
use Domain\Settings\Models\Setting;
|
use Domain\Settings\Models\Setting;
|
||||||
|
use VueFileManager\Subscription\Domain\DunningEmails\Models\Dunning;
|
||||||
|
|
||||||
class MeteredBillingRestrictionsTest extends TestCase
|
class MeteredBillingRestrictionsTest extends TestCase
|
||||||
{
|
{
|
||||||
@@ -17,7 +19,7 @@ class MeteredBillingRestrictionsTest extends TestCase
|
|||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
|
||||||
Setting::updateOrCreate([
|
Setting::updateOrCreate([
|
||||||
'name' => 'subscription_type',
|
'name' => 'subscription_type',
|
||||||
], [
|
], [
|
||||||
'value' => 'metered',
|
'value' => 'metered',
|
||||||
]);
|
]);
|
||||||
@@ -32,6 +34,13 @@ class MeteredBillingRestrictionsTest extends TestCase
|
|||||||
->hasFailedpayments(2)
|
->hasFailedpayments(2)
|
||||||
->create();
|
->create();
|
||||||
|
|
||||||
|
Dunning::factory()
|
||||||
|
->createOneQuietly([
|
||||||
|
'type' => 'limit_usage_in_new_accounts',
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'sequence' => 2,
|
||||||
|
]);
|
||||||
|
|
||||||
$this->assertEquals(true, $user->canUpload());
|
$this->assertEquals(true, $user->canUpload());
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -47,6 +56,24 @@ class MeteredBillingRestrictionsTest extends TestCase
|
|||||||
$this->assertEquals(false, $user->canUpload());
|
$this->assertEquals(false, $user->canUpload());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function it_cant_upload_because_user_has_3_dunning_mails()
|
||||||
|
{
|
||||||
|
$user = User::factory()
|
||||||
|
->create();
|
||||||
|
|
||||||
|
Dunning::factory()
|
||||||
|
->createOneQuietly([
|
||||||
|
'type' => 'limit_usage_in_new_accounts',
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'sequence' => 3,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->assertEquals(false, $user->canUpload());
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
@@ -117,6 +144,47 @@ class MeteredBillingRestrictionsTest extends TestCase
|
|||||||
$this->assertDatabaseCount('folders', 0);
|
$this->assertDatabaseCount('folders', 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function it_cant_create_new_folder_because_user_has_3_dunning_mails()
|
||||||
|
{
|
||||||
|
$user = User::factory()
|
||||||
|
->create();
|
||||||
|
|
||||||
|
Dunning::factory()
|
||||||
|
->createOneQuietly([
|
||||||
|
'type' => 'limit_usage_in_new_accounts',
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'sequence' => 3,
|
||||||
|
]);
|
||||||
|
|
||||||
|
// Create basic folder
|
||||||
|
$this
|
||||||
|
->actingAs($user)
|
||||||
|
->postJson('/api/create-folder', [
|
||||||
|
'name' => 'New Folder',
|
||||||
|
])
|
||||||
|
->assertStatus(401);
|
||||||
|
|
||||||
|
// Create team folder
|
||||||
|
$this
|
||||||
|
->actingAs($user)
|
||||||
|
->postJson('/api/teams/folders', [
|
||||||
|
'name' => 'New Folder',
|
||||||
|
'invitations' => [
|
||||||
|
[
|
||||||
|
'email' => 'john@doe.com',
|
||||||
|
'permission' => 'can-edit',
|
||||||
|
'type' => 'invitation',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
])
|
||||||
|
->assertStatus(401);
|
||||||
|
|
||||||
|
$this->assertDatabaseCount('folders', 0);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
@@ -139,6 +207,34 @@ class MeteredBillingRestrictionsTest extends TestCase
|
|||||||
->assertStatus(401);
|
->assertStatus(401);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function it_cant_get_private_file_because_user_has_3_dunning_mails()
|
||||||
|
{
|
||||||
|
$user = User::factory()
|
||||||
|
->create();
|
||||||
|
|
||||||
|
Dunning::factory()
|
||||||
|
->createOneQuietly([
|
||||||
|
'type' => 'limit_usage_in_new_accounts',
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'sequence' => 3,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$file = File::factory()
|
||||||
|
->create([
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'basename' => 'fake-file.pdf',
|
||||||
|
'name' => 'fake-file.pdf',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this
|
||||||
|
->actingAs($user)
|
||||||
|
->get("file/$file->name")
|
||||||
|
->assertStatus(401);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
@@ -160,11 +256,10 @@ class MeteredBillingRestrictionsTest extends TestCase
|
|||||||
'name' => 'fake-file.pdf',
|
'name' => 'fake-file.pdf',
|
||||||
]);
|
]);
|
||||||
|
|
||||||
// 404 but, ok, because there is not stored temporary file in test
|
|
||||||
$this
|
$this
|
||||||
->actingAs($user)
|
->actingAs($user)
|
||||||
->get("file/$file->name")
|
->get("file/$file->basename")
|
||||||
->assertStatus(404);
|
->assertStatus(200);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -196,6 +291,41 @@ class MeteredBillingRestrictionsTest extends TestCase
|
|||||||
->assertStatus(401);
|
->assertStatus(401);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function it_cant_get_shared_file_because_user_has_3_dunning_mails()
|
||||||
|
{
|
||||||
|
$user = User::factory()
|
||||||
|
->create();
|
||||||
|
|
||||||
|
Dunning::factory()
|
||||||
|
->createOneQuietly([
|
||||||
|
'type' => 'limit_usage_in_new_accounts',
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'sequence' => 3,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$file = File::factory()
|
||||||
|
->create([
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'basename' => 'fake-file.pdf',
|
||||||
|
'name' => 'fake-file.pdf',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$share = Share::factory()
|
||||||
|
->create([
|
||||||
|
'item_id' => $file->id,
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'type' => 'file',
|
||||||
|
'is_protected' => false,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this
|
||||||
|
->get("file/$file->name/shared/$share->token")
|
||||||
|
->assertStatus(401);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
@@ -234,7 +364,7 @@ class MeteredBillingRestrictionsTest extends TestCase
|
|||||||
/**
|
/**
|
||||||
* @test
|
* @test
|
||||||
*/
|
*/
|
||||||
public function it_cant_get_share_page()
|
public function it_cant_get_share_page_because_user_has_3_failed_payments()
|
||||||
{
|
{
|
||||||
$user = User::factory()
|
$user = User::factory()
|
||||||
->hasFailedpayments(3)
|
->hasFailedpayments(3)
|
||||||
@@ -250,4 +380,30 @@ class MeteredBillingRestrictionsTest extends TestCase
|
|||||||
$this->get("/share/$share->token")
|
$this->get("/share/$share->token")
|
||||||
->assertRedirect('/temporary-unavailable');
|
->assertRedirect('/temporary-unavailable');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function it_cant_get_share_page_because_user_has_3_dunning_mails()
|
||||||
|
{
|
||||||
|
$user = User::factory()
|
||||||
|
->create();
|
||||||
|
|
||||||
|
Dunning::factory()
|
||||||
|
->createOneQuietly([
|
||||||
|
'type' => 'limit_usage_in_new_accounts',
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'sequence' => 3,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$share = Share::factory()
|
||||||
|
->create([
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'type' => 'folder',
|
||||||
|
'is_protected' => false,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->get("/share/$share->token")
|
||||||
|
->assertRedirect('/temporary-unavailable');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -307,7 +307,7 @@ class AdminTest extends TestCase
|
|||||||
Sanctum::actingAs($admin);
|
Sanctum::actingAs($admin);
|
||||||
|
|
||||||
// Delete user
|
// Delete user
|
||||||
$this->deleteJson("/api/admin/users/$user->id/delete", [
|
$this->deleteJson("/api/admin/users/$user->id", [
|
||||||
'name' => $user->settings->name,
|
'name' => $user->settings->name,
|
||||||
])
|
])
|
||||||
->assertStatus(200);
|
->assertStatus(200);
|
||||||
|
|||||||
Reference in New Issue
Block a user