Added eloquent and phinx to project to handle database interactions and migrations; added Result model for storing benchmark results
This commit is contained in:
@ -6,12 +6,17 @@ use Psr\Http\Message\ResponseInterface as Response;
|
||||
use Psr\Http\Message\ServerRequestInterface as Request;
|
||||
use Slim\Routing\RouteContext;
|
||||
use Slim\Views\Twig;
|
||||
use BitGoblin\Colossus\Models\Result;
|
||||
|
||||
class ResultController extends Controller {
|
||||
|
||||
public function getList(Request $request, Response $response): Response {
|
||||
$results = Result::all();
|
||||
|
||||
$view = Twig::fromRequest($request);
|
||||
return $view->render($response, 'result/list.twig');
|
||||
return $view->render($response, 'result/list.twig', [
|
||||
'results' => $results,
|
||||
]);
|
||||
}
|
||||
|
||||
public function getAdd(Request $request, Response $response): Response {
|
||||
@ -20,7 +25,17 @@ class ResultController extends Controller {
|
||||
}
|
||||
|
||||
public function postAdd(Request $request, Response $response): Response {
|
||||
// will add data to database later...
|
||||
$params = (array)$request->getParsedBody();
|
||||
|
||||
$result = new Result;
|
||||
$result->component = $params['result_component'];
|
||||
$result->benchmark = $params['result_benchmark'];
|
||||
$result->type = $params['result_type'];
|
||||
$result->average = $params['result_avg'];
|
||||
$result->minimum = $params['result_min'];
|
||||
$result->maximum = $params['result_max'];
|
||||
|
||||
$result->save();
|
||||
|
||||
// redirect the user back to the home page
|
||||
$routeContext = RouteContext::fromRequest($request);
|
||||
|
18
src/Models/Result.php
Normal file
18
src/Models/Result.php
Normal file
@ -0,0 +1,18 @@
|
||||
<?php
|
||||
|
||||
namespace BitGoblin\Colossus\Models;
|
||||
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
|
||||
class Result extends Model {
|
||||
|
||||
protected $fillable = [
|
||||
'component',
|
||||
'benchmark',
|
||||
'type',
|
||||
'average',
|
||||
'minimum',
|
||||
'maximum',
|
||||
];
|
||||
|
||||
}
|
13
src/app.php
13
src/app.php
@ -1,6 +1,8 @@
|
||||
<?php
|
||||
|
||||
use DI\Container;
|
||||
use Noodlehaus\Config;
|
||||
use Noodlehaus\Parser\Json;
|
||||
use Psr\Http\Message\ResponseInterface as Response;
|
||||
use Psr\Http\Message\ServerRequestInterface as Request;
|
||||
use Slim\Factory\AppFactory;
|
||||
@ -9,8 +11,17 @@ use Slim\Views\TwigMiddleware;
|
||||
|
||||
require __DIR__ . '/../vendor/autoload.php';
|
||||
|
||||
// Create Container using PHP-DI
|
||||
// Load app configuration
|
||||
$config = Config::load(__DIR__ . '/../conf/defaults.json');
|
||||
|
||||
// Create new container object and add our config object to it
|
||||
$container = new Container();
|
||||
$container->set('config', function () use ($config) {
|
||||
return $config;
|
||||
});
|
||||
|
||||
// Load database configuration
|
||||
require_once __DIR__ . '/database.php';
|
||||
|
||||
// Set container to create App with on AppFactory
|
||||
AppFactory::setContainer($container);
|
||||
|
10
src/database.php
Normal file
10
src/database.php
Normal file
@ -0,0 +1,10 @@
|
||||
<?php
|
||||
|
||||
$capsule = new \Illuminate\Database\Capsule\Manager;
|
||||
$capsule->addConnection($config->get('database'));
|
||||
$capsule->setAsGlobal();
|
||||
$capsule->bootEloquent();
|
||||
|
||||
$container->set('db', function () use ($capsule) {
|
||||
return $capsule;
|
||||
});
|
Reference in New Issue
Block a user