aryelgois / yasql-php
A PHP implementation for YAML Ain't SQL
Requires
- php: ^7.0
- symfony/yaml: ^3.4
This package is not auto-updated.
Last update: 2024-11-10 05:19:37 UTC
README
Index:
Intro
This is a PHP implementation for YAML Ain't SQL, whose specification can be found in aryelgois/yasql.
Install
Enter the terminal, navigate to your project root and run:
composer require aryelgois/yasql-php
Setup
This package provides CLI tools to work with YASQL files. To use them, add the
following in your composer.json
:
{ "scripts": { "yasql-build": "aryelgois\\YaSql\\Composer::build", "yasql-generate": "aryelgois\\YaSql\\Composer::generate" } }
You also need a config file for the builder command. The default is to place
it in config/databases.yml
, but you can choose another place or have more than
one configuration.
(see Builder specifications)
Usage
yasql-build
First, create databases following the YASQL schema and list them in your config file. Then run the following command in your project root:
composer yasql-build -- [ config=path/to/config_file.yml | -c ] [ output=path/to/output/ ] [ vendor=vendor/package ]
config
: Lists YASQL databases to be built and vendors to include- The
-c
flag indicates that you do not want any config file. It is useful when usingvendor
arguments. It is the same asconfig=''
- The
output
: Directory where files are generatedvendor
: Additional vendor to include (using default config file location)
Notes:
- Paths in the command line are relative to the project root
- Paths in the config file are relative to the file itself
- Absolut paths are absolut (they start with
/
) - Vendors are located in Composer's
vendor dir
- You can omit
config
for using the defaultconfig/databases.yml
- You can omit
output
for using the defaultbuild/
- You can add multiple
vendor
arguments - It might be a good idea to add the output directory to your .gitignore
This command creates .sql
files in the output directory, so you can import
them into your sql server.
yasql-generate
If you only want to generate the SQL from one YASQL schema, run the following command:
composer yasql-generate -- path/to/yasql.yml [ indentation ]
The first argument is the path to a YASQL file, the second is a optional indentation to be used (default is 2 spaces).
It will output to stdout, so you can add something like > output_database.sql
to write the result in a file.
API
This package provides some classes to parse YASQL and generate SQL. They are
under the namespace aryelgois\YaSql
.
Composer
Provides Composer scripts to use this package from the command line.
(see how to configure the commands in Setup)
-
static build( Event $event )
It accepts arguments described in yasql-build.
-
static generate( Event $event )
It accepts arguments described in yasql-generate.
Controller
This class wrapps others, to make them easier to use.
-
static build( string $output , string $config , string $vendor [, array $vendors ] )
Use this method to build your databases into a specific directory.
(see Builder) -
static generate( string $yasql [, int $indent ] )
Use this to generate the SQL from a YASQL and get the result in a string.
(see Generator) -
static parse( string $yasql )
Use it to dump the parsed data from a YASQL. Basically, good for debugging.
(see Parser)
Parser
-
__construct( string $yasql )
It parses a YASQL and extracts some data from each column, making them ready for the Generator.
See the
$yasql
specification here. -
getData()
Retrieves the parsed data in a multidimensional array.
Generator
-
__construct( Parser $parser [, int $indent ] )
Produces SQL that generates a database. It asks for a Parser object to ensure the data is valid.
-
output()
Retrieves the generated SQL in a multi line string.
Builder
-
__construct( [ string $output [, string $vendor ] ] )
Creates a new Builder object. Databases will go into
$output
, and vendors are searched in$vendors
. Both paths can be absolut or relative, and default tobuild/
andvendor/
in the current working directory, respectively. -
build( string $config [, array $vendors ] )
Generates a list of databases listed in
$config
file into the object's output directory. -
getLog()
Retrieves log information from the build process.
config file
A YAML with the following keys: (all are optional)
-
databases
: sequence of files with YASQL database schemas. It can be a string or a mapping of the YASQLpath
and apost
sql (or a sequence of post files)Also, a
name
can be defined to overwrite the database's name. It is useful when you want to combine multiple database schemas in a single database. Just be careful with conflicting tables. Also note that external foreigns require special care in the file order that you run in the sql server -
indentation
: used during the sql generation -
vendors
: a map of vendors installed by Composer to config files inside them. It can be a string (for a single config) or a sequence of paths. They are relative to the vendor package root. Using~
(yaml null) denotes the default config file path
Example:
databases: - ../tests/example.yml - path: ../data/mydatabase.yml post: ../data/mydatabase_populate.sql name: AwesomeExample indentation: 4 vendors: someone/package: config/databases.yml
The post file is useful for pre populated rows or to apply sql commands not covered by YASQL specification. Its content is appended to the generated sql.
Populator
A helper class for Builder. Use it to generate INSERT INTO
statements to
populate your databases.
This class is abstract, so you have to write a class that extends it. The reason is that the YAML with the data might be in a arbitrary layout, depending on your database schema.
To use it, you need a special post in the builder config:
Example from aryelgois/databases:
databases: - path: ../data/address.yml post: - ../data/address/populate_countries.sql - call: aryelgois\Databases\AddressPopulator with: - ../data/address/source/Brazil.yml
The post must map to a sequence, and the desired item is a map of:
call
: a fully qualified class that extends Populator, autoloadable by Composerwith
: path to a YAML with the data to be processed. It can be a sequence
Utils
There is also a class with utility methods. They are used internally and can be used by whoever requires this package.
-
arrayAppendLast( array $array , string $last [, string $others ] )
Appends a string to the last item. Optionally, appends a string to the others. It is useful to generate sql statements with a list of comma separated items, and a semicolon at the last item.