2017 © Pedro Peláez
 

cakephp-plugin cakephp-schema

Schema saving and loading from file for CakePHP 3.6

image

raul338/cakephp-schema

Schema saving and loading from file for CakePHP 3.6

  • Tuesday, July 24, 2018
  • by raul338
  • Repository
  • 1 Watchers
  • 0 Stars
  • 609 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 3 Forks
  • 0 Open issues
  • 9 Versions
  • 83 % Grown

The README.md

Schema plugin for CakePHP 4.x

CI codecov, (*1)

for usage in CakePHP 3.x see the 2.x branch, (*2)

Save the schema into one file and use as an automatic schema for Fixtures. The schema is automatically saved when executing cake migrations migrate. This also allows for local testing with test suite data for debugging., (*3)

Supported datasources

  • Postgres
  • MySQL
  • SQLite
  • ~~SQL Server~~ not tested yet

Installation

You can install this plugin into your CakePHP application using composer., (*4)

The recommended way to install composer packages is:, (*5)

composer require raul338/cakephp-schema

Update your Application class:, (*6)

public function bootstrapCli()
{
    // ....
    $this->addOptionalPlugin('Schema');
}

Usage

The plugin saves the schema of the default connection to the config/schema.php file. The structure is similar to the fixtures fields., (*7)

cake schema save

To load the schema back, useful for debug with test data. Run:, (*8)

cake schema load

Seed

The Schema plugin allows you to seed data from the config/seed.php file. This also is useful to save unrelated tables (like tables from acl plugin, or sphinxlog table) The seed.php file should return array of tables and rows:, (*9)

<?php
    // You can work with custom libraries here or use the Cake's ORM
    return [
        'articles' => [
            [
                'id' => 1,
                'category_id' => 1,
                'label' => 'CakePHP'
            ],
            [
                'id' => 2,
                'label' => 'Schema plugin',
                'json_type_field' => [
                    'i' => 'will convert',
                    'to' => 'json'
                ]
            ]
        ],
        'categories' => [
            [
                'id' => 2,
                'label' => 'Frameworks'
            ]
        ]
    ];

The Seed commands support the CakePHP ORM's type mapping. So for example, if you're using the JsonType example from the cookbook, the seed commands will automatically convert an array to JSON., (*10)

You can use the schema generateseed command to automatically generate a seed.php file based on your database contents., (*11)

Use schema seed for importing the contents of the seed.php into your DB., (*12)

Seed commands will take the following options:, (*13)

  • connection Database connection to use.
  • seed Path to the seed file to generate (Defaults to "config/seed.php")
  • path Path to the schema.php file (Defaults to "config/schema.php")

Other examples

cake schema save --connection test
cake schema save --path config/schema/schema.lock
cake schema load --connection test --path config/schema/schema.lock --no-interaction

To only drop all tables in database, (*14)

cake schema drop
cake schema drop --connection test

Seeding Examples, (*15)

cake schema seed --truncate
cake schema generateseed --seed config/my_seed.php

In case you are using Tree Behavior in your table, you can recover the tree from seed data: (it will recalculate lft & rght values), (*16)

cake recover_tree categories

Fixture generation

This plugins allows to use generated schema and seeds as fixture model and data, by using a SchemaFixture. You can extend your fixtures just like the book indicates., (*17)

Example usage:, (*18)

bin/cake bake fixture --theme Schema Users
<?php
declare(strict_types=1);

namespace App\Test\Fixture;

use Schema\TestSuite\Fixture\SchemaFixture;

class UsersFixture extends SchemaFixture
{
    // This class reads schema from users key in config/schema.php
    // and reads records from users key in config/seed.php if exists
}

TODO

  • [x] Auto-creation of the schema.php file after cake migrations migrate
  • [x] Data seeding
  • [x] Tests
  • [ ] More options and configuration
  • [ ] Refactoring and cleaning the code

The Versions

24/07 2018

dev-migrations2.0

dev-migrations2.0 https://github.com/scherersoftware/cakephp-schema

Schema saving and loading from file for CakePHP 3.6

  Sources   Download

MIT

The Requires

 

The Development Requires

by Ladislav Gallay
by Robert Scherer
by Raúl Arellano

orm database migrations schema cakephp

15/06 2018

dev-master

9999999-dev https://github.com/scherersoftware/cakephp-schema

Schema saving and loading from file for CakePHP 3.6

  Sources   Download

MIT

The Requires

 

The Development Requires

by Ladislav Gallay
by Robert Scherer

orm database migrations schema cakephp

15/06 2018

2.0

2.0.0.0 https://github.com/scherersoftware/cakephp-schema

Schema saving and loading from file for CakePHP 3.6

  Sources   Download

MIT

The Requires

 

The Development Requires

by Ladislav Gallay
by Robert Scherer

orm database migrations schema cakephp

31/01 2018

1.1

1.1.0.0 https://github.com/scherersoftware/cakephp-schema

Schema saving and loading from file for CakePHP 3.0

  Sources   Download

MIT

The Requires

 

The Development Requires

by Ladislav Gallay
by Robert Scherer

orm database migrations schema cakephp

17/01 2018

v1.0.2

1.0.2.0 https://github.com/scherersoftware/cakephp-schema

Schema saving and loading from file for CakePHP 3.0

  Sources   Download

MIT

The Requires

 

The Development Requires

by Ladislav Gallay
by Robert Scherer

orm database migrations schema cakephp

29/11 2017

dev-current_connection

dev-current_connection https://github.com/scherersoftware/cakephp-schema

Schema saving and loading from file for CakePHP 3.0

  Sources   Download

MIT

The Requires

 

The Development Requires

by Ladislav Gallay
by Robert Scherer

orm database migrations schema cakephp

18/05 2016

v1.0.1

1.0.1.0 https://github.com/scherersoftware/cakephp-schema

Schema saving and loading from file for CakePHP 3.0

  Sources   Download

MIT

The Requires

 

The Development Requires

by Ladislav Gallay
by Robert Scherer

orm database migrations schema cakephp

08/10 2015

v1.0.0

1.0.0.0 https://github.com/scherersoftware/cakephp-schema

Schema saving and loading from file for CakePHP 3.0

  Sources   Download

MIT

The Requires

 

The Development Requires

by Ladislav Gallay
by Robert Scherer

orm database migrations schema cakephp

07/10 2015

v0.1

0.1.0.0 https://github.com/scherersoftware/cakephp-schema

Schema saving and loading from file for CakePHP 3.0

  Sources   Download

MIT

The Requires

 

The Development Requires

by Ladislav Gallay
by Robert Scherer

orm database migrations schema cakephp