clntdev/scrubber-laravel 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

clntdev/scrubber-laravel

最新稳定版本:1.0.5

Composer 安装命令:

composer require clntdev/scrubber-laravel

包简介

A Laravel package for scrubbing data from defined fields in a database

README 文档

README

Stable Build CI Status

Scrubber (Laravel Wrapper) is a simple Laravel wrapper that adds in a Facade and some useful artisan commands around a minimal PHP package called Scrubber, this allows you to define a PHP configuration file which can help update database fields with various predefined or random values.

This is perfect for when you need a copy of a production database to work on and need to erase sensitive content.

Installation

Install via composer by running: composer require clntdev/scrubber-laravel

Publish the package configuration to config/scrubber.php by running: php artisan vendor:publish --tag=scrubber

Usage

The package relies on a valid PHP configuration file to function correctly, this file returns a simple array which maps out the tables, fields and their details so it knows which handler to use.

If using the default location, create a scrubber.php file at the root of your Laravel project. If using an alternative then set the absolute path in the config/scrubber.php file.

  • A field can have a primary_key defined on it if you want to use an alternative column to fetch database records, the default is id.
  • A field can have a handler defined on it if you wish to override the detected handler.
  • A field can have a type defined on it which can be used to define the field as a certain data type such as pid for GDPR purposes (this is useful in the methods listed further down)

Here is an example configuration used in the unit tests:

<?php

use ClntDev\Scrubber\Handlers\FakerHandler;

return [
    'users' => [
        'first_name' => [
            'primary_key' => 'id',
            'value' => 'faker.firstName',
            'type' => 'pid',
        ],
        'last_name' => [
            'value' => 'faker.lastName',
            'type' => 'pid',
        ],
        'email' => [
            'value' => 'faker.email',
            'handler' => FakerHandler::class,
            'type' => 'pid',
        ],
        'toggle' => [
            'value' => static fn (): bool => true,
        ],
    ],
];

Facade

The scrubber package methods can be accessed through the ClntDev\LaravelScrubber\Facades\Scrubber class.

This wrapper uses the DB facade to perform any database updates and Illuminate\Log\Logger to log any error messages. These are bound to the contracts detailed in the base package documentation which can be found here.

Methods

Scrubber::run() - This is the main method and will run all of the handlers from the parsed configuration file modifying the database.

Scrubber::getFieldList(string $type = 'pid') - This method will return an array of fields for the given type, this defaults to pid.

Scrubber::getFieldListAsString(string $type = 'pid') - This method will return a comma separated string of fields for the given type, this defaults to pid.

Commands

scrubber:run - This command will run the run() scrubber method on the database.

scrubber:fields --type=pid - This command will return a comma separated string for the given type, if no type argument is specified then it will default to pid.

统计信息

  • 总下载量: 34
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 4
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 4
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-11-25

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固