ytake/laravel-voltdb

VoltDB providers for Laravel

Downloads

33

Stars

4

Version

1.0.1

Laravel.VoltDB

VoltDB providers for Laravel
License Latest Version Total Downloads Dependency Status

Scrutinizer Code Quality Code Coverage Build Status

##for laravel5 Laravel4 Laravel.VoltDB

#Install required ext-voltdb, ext-curl
Add the package to your composer.json and run composer update.

"require": {
    "php": ">=5.4.0",
    "ytake/laravel-voltdb": "1.*"
},

Add the service provider in app/config/app.php:

'providers' => [
    'Ytake\LaravelVoltDB\VoltDBServiceProvider',
];

Add the aliases in app/config/app.php:

'aliases' => [
    'VoltDBApi' => 'Ytake\LaravelVoltDB\VoltDBFacade',
];

The service provider will register a voltdb database extension
not supported Eloquent, QueryBuilder
(VoltDB supports PHP client application development using VoltDB PHP client library.)

#Configure Add database connection

'voltdb' => [
    'driver' => 'voltdb',
    'host' => 'localhost',
    'username' => '',
    'password' => '',
    'port' => 21212
],

by default .env

DB_HOST=localhost
DB_DATABASE=voltdb
DB_USERNAME=username
DB_PASSWORD=secret

CACHE_DRIVER=voltdb
SESSION_DRIVER=voltdb

publish

$ php artisan vendor:publish 

#Database Extension ##@AdHoc query

$sql = "INSERT INTO users (user_id, username, password, remember_token, created_at)"
    ." VALUES (" . rand() . ", 'voltdb', '" . $pass . "', null, '" . date("Y-m-d H:i:s") . "')";
\DB::connection('voltdb')->exec($sql);
$sql = "SELECT * FROM users";
\DB::connection('voltdb')->select($sql);

not supported prepared statement
Recommended stored procedure ##stored procedure

\DB::connection('voltdb')->procedure('Auth_findUser', [1]);

#Auth include voltdb auth driver
in config/auth.php:

 'driver' => 'voltdb',

or .env

#Cache include voltdb cache driver
in config/cache.php:

'driver' => 'voltdb',
'voltdb' => [
  'driver' => 'voltdb',
],

#Session include voltdb session driver
in app/config/session.php:

 'driver' => 'voltdb',

Auth, Cache, Session use Stored Procedure(see schema/ddl.sql)

#publish for auth, cache, session ddl.sql

$ php artisan ytake:voltdb-schema-publish

Options:
--publish (-p) Publish to a specific directory
default storage/schema/ddl.sql

###DDL default ddl

CREATE TABLE users (
   user_id INTEGER UNIQUE NOT NULL,
   username VARCHAR(40) NOT NULL,
   password VARCHAR(64) NOT NULL,
   remember_token VARCHAR(128) DEFAULT NULL,
   created_at TIMESTAMP NOT NULL,
   PRIMARY KEY(user_id)
);
CREATE INDEX UsersIndex ON users (username, password, remember_token);
CREATE TABLE caches (
  key VARCHAR(255) UNIQUE NOT NULL,
  value VARCHAR(262144),
  expiration INTEGER DEFAULT 0 NOT NULL,
  CONSTRAINT PK_cache PRIMARY KEY (key)
);
CREATE INDEX IX_cache_expires ON cache (expiration);
CREATE TABLE sessions (
  id VARCHAR(255) UNIQUE NOT NULL,
  payload VARCHAR(65535),
  last_activity INTEGER DEFAULT 0 NOT NULL
);
CREATE INDEX IX_session_id ON sessions (id);
CREATE INDEX IX_activity ON sessions (last_activity);

#Facades supported for json interface API

// call stored procedure @SystemInformation
\VoltDBApi::request()->info()->getResult();

// basic
\VoltDBApi::request()->post([
    'Procedure' => 'addUser',
    'Parameters' => [1, "voltdb"]
])->getResult();

###Async Stored Procedure see VoltDB.PHPClientWrapper

#Console ytake:voltdb-schema-publish publish DDL for auth, cache driver
ytake:voltdb-info information about ytake/laravel-voltdb
ytake:voltdb-system-catalog renderer system catalog
##voltdb-system-catalog Options:
--component (-c) returns information about the schema of the VoltDB database, depending upon the component keyword you specify. alt text

example
Such as MySQL SHOW COLUMNS

$ php artisan ytake:voltdb-system-catalog -c COLUMNS

alt text