build version 400

This commit is contained in:
Mohit Panjwani
2020-12-02 17:54:08 +05:30
parent 326508e567
commit 89ee58590c
963 changed files with 62887 additions and 48868 deletions

View File

@ -0,0 +1,42 @@
<?php
namespace Crater\Rules\Backup;
use Illuminate\Contracts\Validation\Rule;
class BackupDisk implements Rule
{
/**
* Create a new rule instance.
*
* @return void
*/
public function __construct()
{
//
}
/**
* Determine if the validation rule passes.
*
* @param string $attribute
* @param mixed $value
* @return bool
*/
public function passes($attribute, $value)
{
$configuredBackupDisks = config('backup.backup.destination.disks');
return in_array($value, $configuredBackupDisks);
}
/**
* Get the validation error message.
*
* @return string
*/
public function message()
{
return 'This disk is not configured as a backup disk.';
}
}

View File

@ -0,0 +1,42 @@
<?php
namespace Crater\Rules\Backup;
use Illuminate\Contracts\Validation\Rule;
class FilesystemDisks implements Rule
{
/**
* Create a new rule instance.
*
* @return void
*/
public function __construct()
{
//
}
/**
* Determine if the validation rule passes.
*
* @param string $attribute
* @param mixed $value
* @return bool
*/
public function passes($attribute, $value)
{
$configuredFileSystemDisks = config('filesystem.disks');
return in_array($value, $configuredFileSystemDisks);
}
/**
* Get the validation error message.
*
* @return string
*/
public function message()
{
return 'This disk is not configured as a filesystem disk.';
}
}

View File

@ -0,0 +1,41 @@
<?php
namespace Crater\Rules\Backup;
use Illuminate\Contracts\Validation\Rule;
use Illuminate\Support\Str;
class PathToZip implements Rule
{
/**
* Create a new rule instance.
*
* @return void
*/
public function __construct()
{
//
}
/**
* Determine if the validation rule passes.
*
* @param string $attribute
* @param mixed $value
* @return bool
*/
public function passes($attribute, $value)
{
return Str::endsWith($value, '.zip');
}
/**
* Get the validation error message.
*
* @return string
*/
public function message()
{
return 'The given value must be a path to a zip file.';
}
}

View File

@ -0,0 +1,52 @@
<?php
namespace Crater\Rules;
use Illuminate\Contracts\Validation\Rule;
class RelationNotExist implements Rule
{
public $class;
public $relation;
/**
* Create a new rule instance.
* @param string $class
* @param string $relation
* @return void
*/
public function __construct(string $class = null, string $relation = null)
{
$this->class = $class;
$this->relation = $relation;
}
/**
* Determine if the validation rule passes.
*
* @param string $attribute
* @param mixed $value
* @return bool
*/
public function passes($attribute, $value)
{
$relation = $this->relation;
if ($this->class::find($value)->$relation()->exists()) {
return false;
}
return true;
}
/**
* Get the validation error message.
*
* @return string
*/
public function message()
{
return "Relation {$this->relation} exists.";
}
}

View File

@ -0,0 +1,60 @@
<?php
namespace Crater\Rules;
use Illuminate\Contracts\Validation\Rule;
class UniqueNumber implements Rule
{
public $id;
public $class;
/**
* Create a new rule instance.
* @param string $class
* @param int $id
* @return void
*/
public function __construct(string $class = null, int $id = null)
{
$this->class = $class;
$this->id = $id;
}
/**
* Determine if the validation rule passes.
*
* @param string $attribute
* @param mixed $value
* @return bool
*/
public function passes($attribute, $value)
{
if ($value && count(explode("-", $value)) > 2) {
$number = explode("-",$value);
$uniqueNumber = $number[0].'-'.sprintf('%06d', intval($number[1]));
} else {
$uniqueNumber = $value;
}
if ($this->id && $this->class::where('id', $this->id)->where($attribute, $uniqueNumber)->first()) {
return true;
}
if ($this->class::where($attribute, $uniqueNumber)->first()) {
return false;
}
return true;
}
/**
* Get the validation error message.
*
* @return string
*/
public function message()
{
return 'Invalid number passed.';
}
}