mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-05 19:07:30 -08:00
this should work in theory - local is screwy though
This commit is contained in:
parent
4841b89109
commit
3982201d0e
|
@ -12,11 +12,13 @@ use App\Presenters\Presentable;
|
||||||
use App\Presenters\AssetPresenter;
|
use App\Presenters\AssetPresenter;
|
||||||
use Illuminate\Support\Facades\Auth;
|
use Illuminate\Support\Facades\Auth;
|
||||||
use Carbon\Carbon;
|
use Carbon\Carbon;
|
||||||
|
use Illuminate\Support\Facades\Crypt;
|
||||||
use Illuminate\Support\Facades\DB;
|
use Illuminate\Support\Facades\DB;
|
||||||
use Illuminate\Database\Eloquent\Builder;
|
use Illuminate\Database\Eloquent\Builder;
|
||||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
use Illuminate\Database\Eloquent\SoftDeletes;
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
||||||
use Illuminate\Support\Facades\Storage;
|
use Illuminate\Support\Facades\Storage;
|
||||||
|
use Illuminate\Support\Facades\Validator;
|
||||||
use Watson\Validating\ValidatingTrait;
|
use Watson\Validating\ValidatingTrait;
|
||||||
use Illuminate\Database\Eloquent\Casts\Attribute;
|
use Illuminate\Database\Eloquent\Casts\Attribute;
|
||||||
use Illuminate\Database\Eloquent\Model;
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
@ -213,14 +215,15 @@ class Asset extends Depreciable
|
||||||
$this->attributes['expected_checkin'] = $value;
|
$this->attributes['expected_checkin'] = $value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function withValidator($validator)
|
// i don't think this will work the way we'd need it to
|
||||||
{
|
//public function withValidator(Validator $validator)
|
||||||
foreach ($this->customFields as $field) {
|
//{
|
||||||
if ($field->isEncrypted()) {
|
// foreach ($this->customFields as $field) {
|
||||||
Crypt::decrypt($this->value);
|
// if ($field->field_encrypted) {
|
||||||
}
|
// return Crypt::decrypt($this->value);
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
|
//}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This handles the custom field validation for assets
|
* This handles the custom field validation for assets
|
||||||
|
|
|
@ -2,6 +2,8 @@
|
||||||
|
|
||||||
namespace App\Models;
|
namespace App\Models;
|
||||||
|
|
||||||
|
use App\Rules\AlphaEncrypted;
|
||||||
|
use App\Rules\NumericEncrypted;
|
||||||
use Gate;
|
use Gate;
|
||||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
use Illuminate\Database\Eloquent\Model;
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
@ -92,13 +94,20 @@ class CustomFieldset extends Model
|
||||||
$rule[] = 'unique_undeleted';
|
$rule[] = 'unique_undeleted';
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($field->hasFormat() && $field->isEncrypted()) {
|
|
||||||
$rule[] = $rule.'-encrypted';
|
|
||||||
}
|
|
||||||
|
|
||||||
array_push($rule, $field->attributes['format']);
|
array_push($rule, $field->attributes['format']);
|
||||||
$rules[$field->db_column_name()] = $rule;
|
$rules[$field->db_column_name()] = $rule;
|
||||||
|
|
||||||
|
|
||||||
|
if ($field->format === 'NUMERIC' && $field->field_encrypted) {
|
||||||
|
$numericKey = array_search('numeric', $rules[$field->db_column_name()]);
|
||||||
|
$rules[$field->db_column_name()][$numericKey] = new NumericEncrypted;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($field->format === 'ALPHA' && $field->field_encrypted) {
|
||||||
|
$alphaKey = array_search('alpha', $rules[$field->db_column_name()]);
|
||||||
|
$rules[$field->db_column_name()][$alphaKey] = new AlphaEncrypted;
|
||||||
|
}
|
||||||
|
|
||||||
// add not_array to rules for all fields but checkboxes
|
// add not_array to rules for all fields but checkboxes
|
||||||
if ($field->element != 'checkbox') {
|
if ($field->element != 'checkbox') {
|
||||||
$rules[$field->db_column_name()][] = 'not_array';
|
$rules[$field->db_column_name()][] = 'not_array';
|
||||||
|
@ -113,6 +122,8 @@ class CustomFieldset extends Model
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dump($rules);
|
||||||
|
|
||||||
return $rules;
|
return $rules;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
28
app/Rules/AlphaEncrypted.php
Normal file
28
app/Rules/AlphaEncrypted.php
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Rules;
|
||||||
|
|
||||||
|
use Closure;
|
||||||
|
use Illuminate\Contracts\Validation\ValidationRule;
|
||||||
|
use Illuminate\Support\Facades\Crypt;
|
||||||
|
|
||||||
|
class AlphaEncrypted implements ValidationRule
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the validation rule.
|
||||||
|
*
|
||||||
|
* @param \Closure(string): \Illuminate\Translation\PotentiallyTranslatedString $fail
|
||||||
|
*/
|
||||||
|
public function validate(string $attribute, mixed $value, Closure $fail): void
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
$decrypted = Crypt::decrypt($value);
|
||||||
|
dump($decrypted);
|
||||||
|
if (!ctype_alpha($decrypted)) {
|
||||||
|
$fail($attribute.' is not numeric.');
|
||||||
|
}
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
$fail($e->getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
28
app/Rules/NumericEncrypted.php
Normal file
28
app/Rules/NumericEncrypted.php
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Rules;
|
||||||
|
|
||||||
|
use Closure;
|
||||||
|
use Illuminate\Contracts\Encryption\DecryptException;
|
||||||
|
use Illuminate\Contracts\Validation\ValidationRule;
|
||||||
|
use Illuminate\Support\Facades\Crypt;
|
||||||
|
|
||||||
|
class NumericEncrypted implements ValidationRule
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the validation rule.
|
||||||
|
*
|
||||||
|
* @param \Closure(string): \Illuminate\Translation\PotentiallyTranslatedString $fail
|
||||||
|
*/
|
||||||
|
public function validate(string $attribute, mixed $value, Closure $fail): void
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
$value = Crypt::decrypt($value);
|
||||||
|
if (!is_numeric($value)) {
|
||||||
|
$fail($attribute.' is not numeric.');
|
||||||
|
}
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
$fail($e->getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue