Skip to content

Commit

Permalink
initial release
Browse files Browse the repository at this point in the history
  • Loading branch information
Md. Touhidur Rahman authored and Md. Touhidur Rahman committed Aug 23, 2021
0 parents commit 4116da8
Show file tree
Hide file tree
Showing 17 changed files with 845 additions and 0 deletions.
Empty file added .gitattributes
Empty file.
5 changes: 5 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
.DS_Store
/vendor
/build
composer.lock
.phpunit.result.cache
17 changes: 17 additions & 0 deletions .travis.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
language: php

php:
- 7.3
- 7.4
- 8.0

env:
matrix:
- COMPOSER_FLAGS="--prefer-lowest"
- COMPOSER_FLAGS=""

before_script:
- travis_retry composer update ${COMPOSER_FLAGS}

script:
- vendor/bin/phpunit
8 changes: 8 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
# Changelog
All notable changes to this project will be documented in this file.

## [Unreleased]


## [1.0.0] - 2021-08-14
- Initial release
21 changes: 21 additions & 0 deletions LICENSE.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
MIT License

Copyright (c) Touhidur Rahman Abir

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
141 changes: 141 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,141 @@
# Laravel Model UUID

A simple package to sanitize model data to create/update table records.

## Installation

Require the package using composer:

```bash
composer require touhidurabir/laravel-model-sanitize
```

## What is does ?
The **Sanitize** package sanitize the passed **attributes** to proper model fillables at create or update.

A model has multiple table schema based attributed associated with it. When we try to create a new model record or update an existing model record, we must provide the an array attributes that is propelry mapped to those arrtibute or table columns names . For example

```php
$user = User::create([
'email' => 'somemail@test.com',
'password' => Hash::make('password')
]);
```

The above code will run without any issue as both the **email** and **password** column presents in the users table . But for the following code

```php
User::create([
'email' => 'somemail@test.com',
'password' => 'password',
'data' => 'some data'
]);
```

It will throw an **\Illuminate\Database\QueryException** if the **data** column not present in the users table.

```bash
Illuminate\Database\QueryException with message 'SQLSTATE[HY000] [2002] Connection refused (SQL: insert into `users` (`email`, `password`, `updated_at`, `created_at`) values (somemail@test.com, password, 2021-08-23 10:15:25, 2021-08-23 10:15:25))'
```

The **Sanitize** package target to make it easier to handle such case as follow by including the **Sanitizable** trait in the models

```php
$data = [
'email' => 'somemail@test.com',
'password' => 'password',
'data' => 'some data'
];

User::create($data);
```
The above code will work if the **Sanitizable** trait is used in the **User** model class. it will sanitize the passed attributed to model fillables and table columns, thus removing the extra or non useable attributes from it .

## How it will be helpful ?

A great use case of this package is where one need to create multiple model instances from validated request data . For example

```php
$validated = $request->validated();

$user = User::create($validated);

$profile = $user->profile->create($validated);
```
I personally use this appraoch in many of my laravel apps .

## Usage

Use the trait **Sanitizable** in model where uuid needed to attach

```php
use Touhidurabir\ModelSanitize\Sanitizable;
use Illuminate\Database\Eloquent\Model;

class User extends Model {

use Sanitizable;
}
```

And thats all . it will automatically work for all the following methods
- **updateOrCreate**
- **firstOrCreate**
- **firstOrNew**
- **create**
- **forceCreate**
- **update**

This package also includes some helper methods that can be used to handle the sanitization process manually.

The **sanitize** static method will sanitize the given attributes list and retuen back the useable and valid attributes as an array

```php
$data = [
'email' => 'somemail@test.com',
'password' => 'password',
'data' => 'some data',
'name' => 'Test User'
];

User::sanitize($data);
```

This will return back as such :
```php
[
'email' => 'somemail@test.com',
'password' => 'password',
'name' => 'Test User'
]
```

The **gibberish** static method will sanitize the given attributes list and retuen back the gibberish/non userbale attributes as an array

```php
$data = [
'email' => 'somemail@test.com',
'password' => 'password',
'data' => 'some data',
'name' => 'Test User'
];

User::gibberish($data);
```

This will return back as such :
```php
[
'data' => 'some data',
]
```

The **sanitize** and **gibberish** methods can be used to check or manually sanitize and evaluate the in valid data that can be passed to create/update model records.

## Contributing
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests as appropriate.

## License
[MIT](./LICENSE.md)
43 changes: 43 additions & 0 deletions composer.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
{
"name": "touhidurabir/laravel-model-sanitize",
"description": "A laravel package to handle sanitize process of model data to create/update model records.",
"type": "library",
"license": "MIT",
"authors": [
{
"name": "Touhidur Rahman",
"email": "abircse06@gmail.com"
}
],
"require": {
"php": ">=7.2.0"
},
"autoload" : {
"psr-4" : {
"Touhidurabir\\ModelSanitize\\": "src/"
}
},
"autoload-dev" : {
"psr-4" : {
"Touhidurabir\\ModelSanitize\\Tests\\": "tests/"
}
},
"require-dev": {
"phpunit/phpunit": "^9.5",
"orchestra/testbench": "^6.20",
"illuminate/support": "^8.54",
"illuminate/container": "^8.54",
"illuminate/database": "^8.54",
"illuminate/events": "^8.54"
},
"extra": {
"laravel": {
"providers": [
"Touhidurabir\\ModelSanitize\\ModelSanitizeServiceProvider"
],
"aliases": {
"ModelUuid": "Touhidurabir\\ModelSanitize\\Facades\\ModelSanitize"
}
}
}
}
36 changes: 36 additions & 0 deletions phpunit.xml.dist
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
<?xml version="1.0" encoding="UTF-8"?>
<phpunit bootstrap="vendor/autoload.php"
backupGlobals="false"
backupStaticAttributes="false"
colors="true"
verbose="true"
convertErrorsToExceptions="true"
convertNoticesToExceptions="true"
convertWarningsToExceptions="true"
processIsolation="false"
stopOnFailure="false">
<testsuites>
<testsuite name="Laravel Model Sanitize TestSuite">
<directory>tests</directory>
</testsuite>
</testsuites>
<coverage processUncoveredFiles="true">
<include>
<directory suffix=".php">src/</directory>
</include>
</coverage>
<php>
<env name="APP_ENV" value="testing"/>
<env name="DB_CONNECTION" value="sqlite"/>
<env name="DB_DATABASE" value=":memory:"/>
<env name="CACHE_DRIVER" value="array"/>
<env name="SESSION_DRIVER" value="array"/>
<env name="QUEUE_DRIVER" value="sync"/>
</php>
<logging>
<log type="tap" target="build/report.tap"/>
<log type="junit" target="build/report.junit.xml"/>
<log type="coverage-text" target="build/coverage.txt"/>
<log type="coverage-clover" target="build/logs/clover.xml"/>
</logging>
</phpunit>
82 changes: 82 additions & 0 deletions src/Builder/SanitizableQueryBuilder.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
<?php

namespace Touhidurabir\ModelSanitize\Builder;

use Illuminate\Database\Eloquent\Builder as BaseBuilder;

class SanitizableQueryBuilder extends BaseBuilder {

/**
* Create or update a record matching the attributes, and fill it with values.
*
* @param array $attributes
* @param array $values
* @return \Illuminate\Database\Eloquent\Model|static
*/
public function updateOrCreate(array $attributes, array $values = [])
{
return parent::updateOrCreate($attributes, $this->model->sanitizeToModelFillable($values));
}


/**
* Get the first record matching the attributes or create it.
*
* @param array $attributes
* @param array $values
* @return \Illuminate\Database\Eloquent\Model|static
*/
public function firstOrCreate(array $attributes = [], array $values = [])
{
return parent::firstOrCreate($attributes, $this->model->sanitizeToModelFillable($values));
}


/**
* Get the first record matching the attributes or instantiate it.
*
* @param array $attributes
* @param array $values
* @return \Illuminate\Database\Eloquent\Model|static
*/
public function firstOrNew(array $attributes = [], array $values = [])
{
return parent::firstOrNew($attributes, $this->model->sanitizeToModelFillable($values));
}


/**
* Save a new model and return the instance.
*
* @param array $attributes
* @return \Illuminate\Database\Eloquent\Model|$this
*/
public function create(array $attributes = [])
{
return parent::create($this->model->sanitizeToModelFillable($attributes));
}


/**
* Save a new model and return the instance. Allow mass-assignment.
*
* @param array $attributes
* @return \Illuminate\Database\Eloquent\Model|$this
*/
public function forceCreate(array $attributes)
{
return parent::forceCreate($this->model->sanitizeToModelFillable($attributes));
}


/**
* Update records in the database.
*
* @param array $values
* @return int
*/
public function update(array $values)
{
return parent::update($this->model->sanitizeToModelFillable($values));
}
}
18 changes: 18 additions & 0 deletions src/Facades/ModelSanitize.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
<?php

namespace Touhidurabir\ModelSanitize\Facades;

use Illuminate\Support\Facades\Facade;

class ModelSanitize extends Facade {

/**
* Get the registered name of the component.
*
* @return string
*/
protected static function getFacadeAccessor() {

return 'model-sanitize';
}
}
Loading

0 comments on commit 4116da8

Please sign in to comment.