2017 © Pedro Peláez
 

library doctrine-firebird-driver

image

kafoso/doctrine-firebird-driver

  • Friday, May 11, 2018
  • by kafoso
  • Repository
  • 2 Watchers
  • 1 Stars
  • 76 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 7 Versions
  • 300 % Grown

The README.md

Doctrine Firebird driver

Firebird driver for the Doctrine DBAL., (*1)

This library is completely separate (i.e. abstracted away) from the core Doctrine DBAL library. I.e. it is fully a plug-in., (*2)

Requirements

To utilize this library in your application code, the following is required:, (*3)

1 Only needed on remote/guest OS, e.g. a remote Ubuntu server or a VM installed through Docker, Vagrant, or XAMPP., (*4)

License & Disclaimer

See LICENSE file. Basically: Use this library at your own risk., (*5)

Limitations of Schema Manager

This library does not fully support generation through the Schema Manager, i.e.:, (*6)

  1. Generation of database tables, views, etc. from entities.
  2. Generation of entities from database tables, views, etc.

Reasons for not investing time in schema generation include that Firebird does not allow renaming of tables, which in turn makes automated schema updates annoying and over-complicated. Better results are probably achieved by writing manual migrations., (*7)

Installation

Via Composer (kafoso/doctrine-firebird-driver):, (*8)

composer install kafoso/doctrine-firebird-driver

Via Github:, (*9)

git clone git@github.com:kafoso/doctrine-firebird-driver.git

Configuration

Manual configuration

For example of configuration in PHP, see tests/tests/Test/Integration/AbstractIntegrationTest.php (in the method setUp)., (*10)

Additional help may be found at: https://www.doctrine-project.org/projects/doctrine-orm/en/2.5/reference/advanced-configuration.html, (*11)

Symfony configuration (YAML)

This driver may be used like any other Doctrine DBAL driver in Symfony. However, the driver_class option must be specified instead of simply driver. This is due to the driver not being part of the core Doctrine DBAL library., (*12)

Sample YAML configuration:, (*13)

doctrine:
    dbal:
        default_connection: default
        connections:
            default:
                driver_class:   Kafoso\DoctrineFirebirdDriver\Driver\FirebirdInterbase\Driver
                host:           "%database_host%"
                port:           "%database_port%"
                dbname:         "%database_name%"
                user:           "%database_user%"
                password:       "%database_password%"
                charset:        "UTF-8"

Tests

Test/development requirements

To run tests, fix bugs, provide features, etc. the following is required:, (*14)

You may of course install everything manually using your own VM setup. For help and a stack list (required apt-get packages), see the Vagrantfile., (*15)

Installation to run tests

A few steps are required to run all tests. Unit tests (tests/tests/Test/Unit) will run on all environments. However, integration tests (tests/tests/Test/Integration) require the following because they test against a running Firebird database in the VM:, (*16)

  1. vagrant up
    Install/provision the VM.
  2. vagrant ssh
  3. sudo su
  4. apt-get -y install firebird2.5-superclassic
    You will be prompted to install the database using a password. Please provide this password: 88fb9f307125cc397f70e59c749715e1. It is re-used when connecting through the DBAL later on.
  5. dpkg-reconfigure firebird2.5-superclassic
    Starts the Firebird database server. Provide same password as above.

Reference: https://firebirdsql.org/manual/ubusetup.html, (*17)

Running tests

Due to the database being created by the PHP bootstrap script on the fly, root is needed to run the tests on the VM., (*18)

  1. vagrant ssh
  2. sudo su
  3. apt-get install zip -y (for when installing composer packages)
  4. Install composer (on guest OS). Follow these instructions: https://getcomposer.org/download/
  5. mv composer.phar /usr/bin/composer
  6. cd /var/git/kafoso/doctrine-firebird-driver
  7. composer install1
  8. cd /var/git/kafoso/doctrine-firebird-driver/tests
  9. php ../bin/phpunit tests

1 Composer will say you shouldn't run it as root/super user. This is techically true, but it's fine in the VM., (*19)

Credits

Authors

  • Kasper Søfren
    https://github.com/kafoso
    E-mail: soefritz@gmail.com
  • Uffe Pedersen
    https://github.com/upmedia

Acknowledgements

https://github.com/doctrine/dbal

Fundamental Doctrine DBAL implementation. The driver and platform logic in this library is based on other implementations in the core library, largely \Doctrine\DBAL\Driver\PDOOracle\Driver and \Doctrine\DBAL\Platforms\OraclePlatform, and their respective parent classes., (*20)

https://github.com/helicon-os/doctrine-dbal

Whilst a great inspiration for this library - and we very much appreciate the work done by the authors - the library has a few flaws and limitations regarding the Interbase Firebird driver logic:, (*21)

  • It contains bugs. E.g. incorrect/insufficient handling of nested transactions and save points.
  • It is lacking with respect to test coverage.
  • It appears to no longer be maintained. Possibly entirely discontinued.
  • It is intermingled with the core Doctrine DBAL code, making version management and code adaptation unnecessarily complicated; a nightmare, really. It is forked from https://github.com/doctrine/dbal, although, this is not specifically stated.
  • It is not a Composer package (not on https://packagist.org).

https://github.com/ISTDK/doctrine-dbal

A fork of https://github.com/helicon-os/doctrine-dbal with a few improvements and fixes., (*22)

https://firebirdsql.org/

The main resource for Firebird documentation, syntax, downloads, etc., (*23)

The Versions

11/05 2018

dev-master

9999999-dev

  Sources   Download

MIT

The Requires

 

The Development Requires

by Kasper Søfren
by Uffe Petersen

11/05 2018

1.1.1

1.1.1.0

  Sources   Download

MIT

The Requires

 

The Development Requires

by Kasper Søfren
by Uffe Petersen

17/04 2018

1.1.0

1.1.0.0

  Sources   Download

MIT

The Requires

 

The Development Requires

by Kasper Søfren
by Uffe Petersen

03/04 2018

1.0.2

1.0.2.0

  Sources   Download

MIT

The Requires

 

The Development Requires

by Kasper Søfren
by Uffe Petersen

03/04 2018

1.0.1

1.0.1.0

  Sources   Download

MIT

The Requires

 

The Development Requires

by Kasper Søfren
by Uffe Petersen

03/04 2018

1.0.0

1.0.0.0

  Sources   Download

The Requires

 

The Development Requires

by Kasper Søfren
by Uffe Petersen

23/03 2018

dev-dev

dev-dev

  Sources   Download

The Requires

 

The Development Requires

by Kasper Søfren
by Uffe Petersen