diff --git a/.php_cs b/.php_cs new file mode 100644 index 0000000..e691cb4 --- /dev/null +++ b/.php_cs @@ -0,0 +1,46 @@ + + +For the full copyright and license information, please view the LICENSE +file that was distributed with this source code. +EOF; + +Symfony\CS\Fixer\Contrib\HeaderCommentFixer::setHeader($header); + +$finder = Symfony\CS\Finder\DefaultFinder::create() + ->exclude('vendor') + ->exclude('tests') + ->exclude('var') + ->exclude('node_modules') + ->ignoreDotFiles(true) + ->ignoreVCS(true) + ->name('*.php') + ->in(__DIR__) + ; + + +return Symfony\CS\Config\Config::create() + ->level(Symfony\CS\FixerInterface::PSR2_LEVEL) + ->fixers( + [ + 'header_comment', + 'ordered_use', + 'php_unit_construct', + 'php_unit_strict', + 'strict', + 'strict_param', + 'symfony', + 'newline_after_open_tag', + 'phpdoc_order', + 'short_array_syntax', + 'short_echo_tag', + + + ] + ) + ->finder($finder) + ; \ No newline at end of file diff --git a/app/App.php b/app/App.php index 1b64e50..9cd296b 100644 --- a/app/App.php +++ b/app/App.php @@ -1,6 +1,17 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + use Sikofitt\Config\ConfigTrait; +use Sikofitt\Json\JsonFileTrait; +use Sikofitt\Json\JsonTrait; use Silex\Application; require '../vendor/autoload.php'; @@ -8,16 +19,17 @@ require '../vendor/autoload.php'; /** * Class App */ -class App extends Application { +class App extends Application +{ - use ConfigTrait; - use Application\TwigTrait; - use Application\MonologTrait; - use Application\SwiftmailerTrait; - use Application\TranslationTrait; - use Application\UrlGeneratorTrait; - - public $conf; + use ConfigTrait; + use JsonTrait; + use JsonFileTrait; + use Application\TwigTrait; + use Application\MonologTrait; + use Application\SwiftmailerTrait; + use Application\TranslationTrait; + use Application\UrlGeneratorTrait; /** * Returns the application directory. @@ -25,9 +37,10 @@ class App extends Application { * @return string * The main application directory. */ - public function getAppDirectory() { - $r = new ReflectionClass($this); - return dirname($r->getFileName()); + public function getAppDirectory() + { + $r = new ReflectionClass($this); + return dirname($r->getFileName()); } /** @@ -36,38 +49,48 @@ class App extends Application { * @return string * The root directory of the application. */ - public function getRootDirectory() { - return dirname($this->getAppDirectory()); + public function getRootDirectory() + { + return dirname($this->getAppDirectory()); } /** * @return string */ - public function getConfDirectory() { - return $this->getAppDirectory() . '/config'; + public function getConfDirectory() + { + return $this->getAppDirectory() . '/config'; } /** * @return string */ - public function getDataDirectory() { - return $this->getRootDirectory() . '/data'; + public function getDataDirectory() + { + return $this->getRootDirectory() . '/data'; } /** * @return string */ - public function getResumeJson() { - return $this->getDataDirectory() . '/resume.json'; + public function getResumeJson() + { + return $this->getDataDirectory() . '/resume.json'; } /** * @return string */ - public function getResumeSchema() { - return $this->getDataDirectory() . '/resume.schema.json'; + public function getResumeSchema() + { + return $this->getDataDirectory() . '/resume.schema.json'; } + public function getLogDirectory() + { + return $this->getDataDirectory() . '/logs'; + } + /** * Registers media icons * @@ -77,15 +100,64 @@ class App extends Application { { $this->config(sprintf('app.icons.%s', $icon->getName()), ['icon' => $icon->getIcon(), 'url' => $icon->getDefaultUrl()]); } + public function setDebug() + { + $this['debug'] = null !== $this->config('app.debug') ? $this->config('app.debug') : true; + $this['env'] = getenv('PHP_ENV'); + if (!$this['env']) { + $this['env'] = null !== $this->config('app.environment') ? $this->config('app.environment') : 'dev'; + } + } + public function registerExtenders() + { + if (!$this['debug']) { + $this->error(function (\Exception $e, \Symfony\Component\HttpFoundation\Request $request, $code) { + switch ($code) { + case 405: - public function boot() { - // register default icons - $this->registerIcon(new \Sikofitt\Image\Profile\TwitterProfileIcon()); - $this->registerIcon(new \Sikofitt\Image\Profile\FacebookProfileIcon()); - $this->registerIcon(new \Sikofitt\Image\Profile\GithubProfileIcon()); - $this->registerIcon(new \Sikofitt\Image\Profile\GitlabProfileIcon()); - $this->registerIcon(new \Sikofitt\Image\Profile\LinkedinProfileIcon()); - return parent::boot(); + + preg_match('/\(Allow\:(.+)\)/', $e->getMessage(), $matches); + if(isset($matches[1])) { + $matches = trim($matches[1]); + } elseif(isset($matches[0])) { + $matches = trim($matches[0]); + } else { + $matches = 'Available methods are unknown.'; + } + $message = json_encode(['status' => 'error', 'message' => 'Method not allowed', 'allowedMethods' => $matches, 'requestedMethod' => $request->getMethod(), 'code' => $code]); + //$message = 'Sorry bout that.
' . $e->getMessage(); + break; + default: + $message = $this['twig']->render('error500.html.twig'); + } + return new \Symfony\Component\HttpFoundation\Response($message, $code); + }); + } + $this->extend('twig', function (\Twig_Environment $twig) { + if ($this['debug']) { + $twig->enableDebug(); + } + $twig->addExtension(new Twig_Extensions_Extension_Date()); + $twig->addExtension(new Sikofitt\Twig\Date()); + $twig->addExtension(new Sikofitt\Twig\RenderProfile()); + $twig->addGlobal('config', $this->config('all')); + return $twig; + }); } -} + public function boot() + { + $this->registerExtenders(); + // register default icons + $this->registerDefaultIcons(); + return parent::boot(); + } + public function registerDefaultIcons() + { + $this->registerIcon(new \Sikofitt\Image\Profile\TwitterProfileIcon()); + $this->registerIcon(new \Sikofitt\Image\Profile\FacebookProfileIcon()); + $this->registerIcon(new \Sikofitt\Image\Profile\GithubProfileIcon()); + $this->registerIcon(new \Sikofitt\Image\Profile\GitlabProfileIcon()); + $this->registerIcon(new \Sikofitt\Image\Profile\LinkedinProfileIcon()); + } +} diff --git a/app/config/config.yml b/app/config/config.yml index 263a067..82ffeed 100644 --- a/app/config/config.yml +++ b/app/config/config.yml @@ -1,7 +1,10 @@ app: - debug: true - environment: dev + debug: false + environment: prod title: R. Eric Wheeler | Resume + email: eric@rewiv.com + phone: 510-646-2135 + schema: https://raw.githubusercontent.com/jsonresume/resume-schema/v1.0.0/schema.json twig: paths: - views diff --git a/app/config/default/config.php b/app/config/default/config.php index 1e0fc24..e0e9429 100644 --- a/app/config/default/config.php +++ b/app/config/default/config.php @@ -1,5 +1,14 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + return [ 'app' => 'neat', -]; \ No newline at end of file +]; diff --git a/app/providers.php b/app/providers.php new file mode 100644 index 0000000..e8d14f6 --- /dev/null +++ b/app/providers.php @@ -0,0 +1,51 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +$app->register(new \Sikofitt\Config\ConfigServiceProvider(), [ + 'config.path' => $app->getConfDirectory(), +]); + +$app->setDebug(); + +if (null === $app->config('app.schema')) { + $app->config('app.schema', 'https://raw.githubusercontent.com/jsonresume/resume-schema/v1.0.0/schema.json'); +} + +$app->register(new \Silex\Provider\TwigServiceProvider(), [ + 'twig.path' => [ + $app->getRootDirectory() . '/app/views', + ], +]); +$app->register(new \Sikofitt\Json\JsonServiceProvider()); + + +$app->register(new \Silex\Provider\AssetServiceProvider()); +$app->register(new \Silex\Provider\MonologServiceProvider()); +$app->register(new \Silex\Provider\SessionServiceProvider()); +$app->register(new \Silex\Provider\HttpKernelServiceProvider()); +$app->register(new \Silex\Provider\FormServiceProvider()); + + +$app->register(new \Silex\Provider\MonologServiceProvider(), + [ + 'monolog.logfile' => sprintf('%s/%s.log', $app->getLogDirectory(), $app['env']), + ] +); +$app->register(new \Silex\Provider\RoutingServiceProvider()); +$app->register(new \Silex\Provider\ServiceControllerServiceProvider()); +$app->register(new \Silex\Provider\HttpFragmentServiceProvider()); +if ($app['debug'] || 0 === strcasecmp($app['env'], 'dev')) { + $app->register(new \Silex\Provider\WebProfilerServiceProvider(), [ + 'profiler.cache_dir' => $app->getDataDirectory() . '/cache/profiler', + ]); + $app->register(new \WhoopsSilex\WhoopsServiceProvider()); + $app->register(new \Silex\Provider\VarDumperServiceProvider()); +} diff --git a/app/views/resume.html.twig b/app/views/resume.html.twig index f4a8671..bc14edd 100644 --- a/app/views/resume.html.twig +++ b/app/views/resume.html.twig @@ -5,7 +5,6 @@ {% endblock %} {% block body %} -

@@ -62,7 +61,7 @@
Highlights
{% for highlight in position.highlights %} -
{{ highlight|raw }}
+
{{ highlight|raw }} {# raw is deprecated in 2.0 #}
{% endfor %}
{% endif %} @@ -73,6 +72,7 @@

+
@@ -86,12 +86,10 @@
+
+
+
+ + +
+ +
+

Verify

+
+

Verify that you are a human please.

+
+
+
+
+
+ +
+
+ +
+
+
+
@@ -179,5 +201,36 @@
+
+{% endblock %} + {% block javascripts_foot %} + + {% endblock %} +{% block inline_js_foot %} + {% endblock %} \ No newline at end of file diff --git a/app/views/uikit.html.twig b/app/views/uikit.html.twig index 0d175df..964644d 100644 --- a/app/views/uikit.html.twig +++ b/app/views/uikit.html.twig @@ -18,6 +18,7 @@ + {% block javascripts_head %}{% endblock %} {% block inline_js_head %}{% endblock %} diff --git a/bower.json b/bower.json index 1177b88..63ccc61 100644 --- a/bower.json +++ b/bower.json @@ -31,7 +31,8 @@ "**/scrollspy.min.js", "**/parallax.min.js", "**/offcanvas.min.js", - "**/sticky.min.js" + "**/sticky.min.js", + "**/notify.min.js" ] }, "jquery": { diff --git a/composer.json b/composer.json index f39529b..f9f2a27 100644 --- a/composer.json +++ b/composer.json @@ -49,11 +49,13 @@ "symfony/var-dumper": "^3.1", "symfony/console": "^3.1", "texthtml/whoops-silex": "^1.0", - "symfony/debug-bundle": "^3.1" + "symfony/debug-bundle": "^3.1", + "friendsofphp/php-cs-fixer": "^1.11" }, "autoload": { "psr-4": { "Sikofitt\\": "src/Sikofitt" - } + }, + "classmap": ["app/App.php"] } } diff --git a/composer.lock b/composer.lock index 4cd9c73..e9f5494 100644 --- a/composer.lock +++ b/composer.lock @@ -4,8 +4,8 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file", "This file is @generated automatically" ], - "hash": "2e202af761710c5e2279e9f5b83a5192", - "content-hash": "3c41da3f56c72d6c1bc86d0a1889d6d9", + "hash": "84ec84a01cd2f9b1398d356bc5e7dc63", + "content-hash": "d91f02739d0cdaa4d0346a6c0f765fc3", "packages": [ { "name": "google/recaptcha", @@ -719,23 +719,23 @@ }, { "name": "swiftmailer/swiftmailer", - "version": "v5.4.2", + "version": "v5.4.3", "source": { "type": "git", "url": "https://github.com/swiftmailer/swiftmailer.git", - "reference": "d8db871a54619458a805229a057ea2af33c753e8" + "reference": "4cc92842069c2bbc1f28daaaf1d2576ec4dfe153" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/swiftmailer/swiftmailer/zipball/d8db871a54619458a805229a057ea2af33c753e8", - "reference": "d8db871a54619458a805229a057ea2af33c753e8", + "url": "https://api.github.com/repos/swiftmailer/swiftmailer/zipball/4cc92842069c2bbc1f28daaaf1d2576ec4dfe153", + "reference": "4cc92842069c2bbc1f28daaaf1d2576ec4dfe153", "shasum": "" }, "require": { "php": ">=5.3.3" }, "require-dev": { - "mockery/mockery": "~0.9.1,<0.9.4" + "mockery/mockery": "~0.9.1" }, "type": "library", "extra": { @@ -768,7 +768,7 @@ "mail", "mailer" ], - "time": "2016-05-01 08:45:47" + "time": "2016-07-08 11:51:25" }, { "name": "symfony/asset", @@ -2506,6 +2506,116 @@ ], "time": "2016-04-07 06:16:25" }, + { + "name": "friendsofphp/php-cs-fixer", + "version": "v1.11.5", + "source": { + "type": "git", + "url": "https://github.com/FriendsOfPHP/PHP-CS-Fixer.git", + "reference": "d3d08b76753092a232a4d8c3b94095ac06898719" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/FriendsOfPHP/PHP-CS-Fixer/zipball/d3d08b76753092a232a4d8c3b94095ac06898719", + "reference": "d3d08b76753092a232a4d8c3b94095ac06898719", + "shasum": "" + }, + "require": { + "ext-tokenizer": "*", + "php": ">=5.3.6", + "sebastian/diff": "~1.1", + "symfony/console": "~2.3|~3.0", + "symfony/event-dispatcher": "~2.1|~3.0", + "symfony/filesystem": "~2.1|~3.0", + "symfony/finder": "~2.1|~3.0", + "symfony/process": "~2.3|~3.0", + "symfony/stopwatch": "~2.5|~3.0" + }, + "conflict": { + "hhvm": "<3.9" + }, + "require-dev": { + "phpunit/phpunit": "^4.5|^5", + "satooshi/php-coveralls": "^0.7.1" + }, + "bin": [ + "php-cs-fixer" + ], + "type": "application", + "autoload": { + "psr-4": { + "Symfony\\CS\\": "Symfony/CS/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Dariusz RumiƄski", + "email": "dariusz.ruminski@gmail.com" + }, + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + } + ], + "description": "A tool to automatically fix PHP code style", + "time": "2016-07-06 22:49:35" + }, + { + "name": "sebastian/diff", + "version": "1.4.1", + "source": { + "type": "git", + "url": "https://github.com/sebastianbergmann/diff.git", + "reference": "13edfd8706462032c2f52b4b862974dd46b71c9e" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/sebastianbergmann/diff/zipball/13edfd8706462032c2f52b4b862974dd46b71c9e", + "reference": "13edfd8706462032c2f52b4b862974dd46b71c9e", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "require-dev": { + "phpunit/phpunit": "~4.8" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "1.4-dev" + } + }, + "autoload": { + "classmap": [ + "src/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Kore Nordmann", + "email": "mail@kore-nordmann.de" + }, + { + "name": "Sebastian Bergmann", + "email": "sebastian@phpunit.de" + } + ], + "description": "Diff implementation", + "homepage": "https://github.com/sebastianbergmann/diff", + "keywords": [ + "diff" + ], + "time": "2015-12-08 07:14:41" + }, { "name": "symfony/console", "version": "v3.1.2", @@ -2627,6 +2737,104 @@ "homepage": "https://symfony.com", "time": "2016-02-13 09:24:02" }, + { + "name": "symfony/filesystem", + "version": "v3.1.2", + "source": { + "type": "git", + "url": "https://github.com/symfony/filesystem.git", + "reference": "322da5f0910d8aa0b25fa65ffccaba68dbddb890" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/filesystem/zipball/322da5f0910d8aa0b25fa65ffccaba68dbddb890", + "reference": "322da5f0910d8aa0b25fa65ffccaba68dbddb890", + "shasum": "" + }, + "require": { + "php": ">=5.5.9" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "3.1-dev" + } + }, + "autoload": { + "psr-4": { + "Symfony\\Component\\Filesystem\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony Filesystem Component", + "homepage": "https://symfony.com", + "time": "2016-06-29 05:41:56" + }, + { + "name": "symfony/finder", + "version": "v3.1.2", + "source": { + "type": "git", + "url": "https://github.com/symfony/finder.git", + "reference": "8201978de88a9fa0923e18601bb17f1df9c721e7" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/finder/zipball/8201978de88a9fa0923e18601bb17f1df9c721e7", + "reference": "8201978de88a9fa0923e18601bb17f1df9c721e7", + "shasum": "" + }, + "require": { + "php": ">=5.5.9" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "3.1-dev" + } + }, + "autoload": { + "psr-4": { + "Symfony\\Component\\Finder\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony Finder Component", + "homepage": "https://symfony.com", + "time": "2016-06-29 05:41:56" + }, { "name": "symfony/phpunit-bridge", "version": "v3.1.2", diff --git a/data/bad.schema.json b/data/schema/bad.schema.json similarity index 100% rename from data/bad.schema.json rename to data/schema/bad.schema.json diff --git a/data/resume.schema.json b/data/schema/schema.v1.json similarity index 100% rename from data/resume.schema.json rename to data/schema/schema.v1.json diff --git a/dump.php b/dump.php index 81c0245..9366a91 100644 --- a/dump.php +++ b/dump.php @@ -1,5 +1,14 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + require_once 'vendor/autoload.php'; @@ -8,5 +17,3 @@ $decoder = new Webmozart\Json\JsonDecoder(); $json = $decoder->decodeFile('data/resume.json'); dump($json); - - diff --git a/src/Sikofitt/Command/SchemaValidationCommand.php b/src/Sikofitt/Command/SchemaValidationCommand.php index 0fe4317..4b121be 100644 --- a/src/Sikofitt/Command/SchemaValidationCommand.php +++ b/src/Sikofitt/Command/SchemaValidationCommand.php @@ -1,4 +1,14 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + /** * Created by PhpStorm. * User: eric @@ -8,7 +18,6 @@ namespace Sikofitt\Command; - use Symfony\Component\Console\Command\Command; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Output\OutputInterface; @@ -29,11 +38,11 @@ class SchemaValidationCommand extends Command * Configures the command. * */ - public function configure () + public function configure() { - $this->setName ('resume:schema:validate') - ->setDescription ('Validates resume.json schema') - ->setProcessTitle ('Validating Schema'); + $this->setName('resume:schema:validate') + ->setDescription('Validates resume.json schema') + ->setProcessTitle('Validating Schema'); } /** @@ -42,13 +51,11 @@ class SchemaValidationCommand extends Command * @param InputInterface $input * @param OutputInterface $output */ - public function interact (InputInterface $input, OutputInterface $output) + public function interact(InputInterface $input, OutputInterface $output) { - $io = new SymfonyStyle($input, $output); $this->file = $io->ask('Path to file? '); $this->schema = $io->ask('Path to schema? '); - } /** @@ -59,7 +66,7 @@ class SchemaValidationCommand extends Command * * @return void */ - public function execute (InputInterface $input, OutputInterface $output) + public function execute(InputInterface $input, OutputInterface $output) { $validator = new JsonValidator(); $decoder = new JsonDecoder(); @@ -68,20 +75,16 @@ class SchemaValidationCommand extends Command try { $decoded = $decoder->decodeFile($dataDir . $this->file); - $errors = $validator->validate ($decoded, $dataDir . $this->schema); - } catch(\Exception $e) { + $errors = $validator->validate($decoded, $dataDir . $this->schema); + } catch (\Exception $e) { $class = new \ReflectionClass($e); $io->block([$class->getName(), $e->getMessage()], 'Exception', 'error'); exit(255); } - if(isset($errors) && !empty($errors)) { + if (isset($errors) && !empty($errors)) { $io->block($errors, 'Error', 'error'); } else { $io->block([$this->file, 'There were no errors reported.'], 'Valid Schema', 'fg=black;bg=green'); - - } } - - -} \ No newline at end of file +} diff --git a/src/Sikofitt/Config/ConfigServiceProvider.php b/src/Sikofitt/Config/ConfigServiceProvider.php index 24a1f06..e31865f 100644 --- a/src/Sikofitt/Config/ConfigServiceProvider.php +++ b/src/Sikofitt/Config/ConfigServiceProvider.php @@ -1,14 +1,20 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. */ namespace Sikofitt\Config; +use Noodlehaus\Config; use Pimple\Container; use Pimple\ServiceProviderInterface; use Silex\Application; -use Noodlehaus\Config; /** * Class ConfigServiceProvider @@ -19,11 +25,11 @@ class ConfigServiceProvider implements ServiceProviderInterface /** * @param Container $app */ - public function register (Container $app) + public function register(Container $app) { - $app['config'] = function($app) { + $app['config'] = function ($app) { $config = Config::load($app['config.path']); return $config; }; } -} \ No newline at end of file +} diff --git a/src/Sikofitt/Config/ConfigTrait.php b/src/Sikofitt/Config/ConfigTrait.php index 4675d19..ed7efca 100644 --- a/src/Sikofitt/Config/ConfigTrait.php +++ b/src/Sikofitt/Config/ConfigTrait.php @@ -1,4 +1,14 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + /** * */ @@ -12,15 +22,15 @@ trait ConfigTrait * @param null $value * @return mixed */ - public function config($name, $value = null) { - if(strcasecmp($name, 'all') === 0) { + public function config($name, $value = null) + { + if (strcasecmp($name, 'all') === 0) { return $this['config']->all(); } - if(null === $value) { - return $this['config']->get ($name); + if (null === $value) { + return $this['config']->get($name); } else { $this['config']->set($name, $value); } } - -} \ No newline at end of file +} diff --git a/src/Sikofitt/Controller/ApiControllerProvider.php b/src/Sikofitt/Controller/ApiControllerProvider.php new file mode 100644 index 0000000..55e2efa --- /dev/null +++ b/src/Sikofitt/Controller/ApiControllerProvider.php @@ -0,0 +1,76 @@ + + * + * 7/8/16 / 10:11 AM + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Sikofitt\Controller; + +use ReCaptcha\ReCaptcha; +use Silex\Application; +use Silex\Api\ControllerProviderInterface; +use Symfony\Component\HttpFoundation\JsonResponse; +use Symfony\Component\HttpFoundation\Request; + +class ApiControllerProvider implements ControllerProviderInterface { + + public function connect(Application $app) { + $controllers = $app['controllers_factory']; + + $controllers->get('/v1/schema', function() { + return new \Symfony\Component\HttpFoundation\Response('Success!'); + }); + + $controllers->post('/v1/captcha', function(Request $request) use ($app) { + $captcha = new ReCaptcha('6LcvmSQTAAAAAITkvYJjgLar1LqGGLz-ic0ZMiXo'); + + $valid = $captcha->verify( + $request->request->get('g-recaptcha-response'), + $request->server->get('REMOTE_ADDR') + ); + if($valid->isSuccess()) { + $return = [ + 'valid' => true, + 'message' => [ + 'email' => null !== $app->config('app.email') ? $app->config('app.email') : 'No email has been set in the configuration. Please let the owner know.', + 'phone' => null !== $app->config('app.phone') ? $app->config('app.phone') : 'No phone has been set in the configuration. Please let the owner know.', + ], + ]; + } else { + + $errorCodes = [ + 'missing-input-secret' => 'The secret parameter is missing.', + 'invalid-input-secret' => 'The secret parameter is invalid or malformed.', + 'missing-input-response' =>'The response parameter is missing.', + 'invalid-input-response' => 'The response parameter is invalid or malformed.' + ]; + + foreach($valid->getErrorCodes() as $code) + { + if(array_key_exists($code, $errorCodes)) { + $errors[] = $errorCodes[$code]; + } + } + if(!isset($errors)) { + $errors[] = 'An unknown error occurred.'; + } + $return = [ + 'valid' => false, + 'message' => $errors, + ]; + } + + return new JsonResponse(json_encode($return)); + }); + + return $controllers; + } +} \ No newline at end of file diff --git a/src/Sikofitt/Controller/ResumeControllerProvider.php b/src/Sikofitt/Controller/ResumeControllerProvider.php new file mode 100644 index 0000000..229c710 --- /dev/null +++ b/src/Sikofitt/Controller/ResumeControllerProvider.php @@ -0,0 +1,145 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Sikofitt\Controller; + +use ReCaptcha\ReCaptcha; +use Silex\Api\ControllerProviderInterface; +use Silex\Application; +use Symfony\Component\HttpFoundation\Request; + +/** + * Class ResumeControllerProvider + * @package Sikofitt\Controller + */ +class ResumeControllerProvider implements ControllerProviderInterface +{ + + /** + * @var object + */ + private $resumeData; + + /** + * @param Application $app + * @return mixed + */ + public function connect(Application $app) + { + $this->resumeData = $app->decodeFile( + $app->getDataDirectory() . '/resume.json', + $app->getDataDirectory() . '/schema/schema.v1.json' + ); + + + $controllers = $app['controllers_factory']; + + $controllers->get('/', function (Request $request) use ($app) { + + return $app['twig']->render('resume.html.twig', [ + + 'fullData' => $this->resumeData, + 'basics' => $this->getResumeBasics(), + 'work' => $this->getResumeWork(), + 'volunteer' => $this->getResumeVolunteer(), + 'education' => $this->getResumeEducation(), + 'awards' => $this->getResumeAwards(), + 'publications' => $this->getResumePublications(), + 'skills' => $this->getResumeSkills(), + 'languages' => $this->getResumeLanguages(), + 'interests' => $this->getResumeInterests(), + 'references' => $this->getResumeReferences(), + ]); + }); + + return $controllers; + } + + /** + * @return null + */ + public function getResumeBasics() + { + return (isset($this->resumeData->basics) && count($this->resumeData->basics) > 0) ? $this->resumeData->basics : null; + } + + /** + * @return null + */ + public function getResumeWork() + { + return (isset($this->resumeData->work) && count($this->resumeData->work) > 0) ? $this->resumeData->work : null; + } + + /** + * @return null + */ + public function getResumeVolunteer() + { + return (isset($this->resumeData->volunteer) && count($this->resumeData->volunteer) > 0) ? $this->resumeData->volunteer : null; + } + + /** + * @return null + */ + public function getResumeEducation() + { + return (isset($this->resumeData->education) && count($this->resumeData->education) > 0) ? $this->resumeData->education : null; + } + + /** + * @return null + */ + public function getResumeAwards() + { + return (isset($this->resumeData->awards) && count($this->resumeData->awards) > 0) ? $this->resumeData->awards : null; + } + + /** + * @return null + */ + public function getResumePublications() + { + return (isset($this->resumeData->publications) && count($this->resumeData->publications) > 0) ? $this->resumeData->publications : null; + } + + /** + * @return null + */ + public function getResumeSkills() + { + return (isset($this->resumeData->skills) && count($this->resumeData->skills) > 0) ? $this->resumeData->skills : null; + } + + /** + * @return null + */ + public function getResumeLanguages() + { + return (isset($this->resumeData->languages) && count($this->resumeData->languages) > 0) ? $this->resumeData->languages : null; + } + + /** + * @return null + */ + public function getResumeInterests() + { + return (isset($this->resumeData->interests) && count($this->resumeData->interests) > 0) ? $this->resumeData->interests : null; + } + + /** + * @return null + */ + public function getResumeReferences() + { + return (isset($this->resumeData->references) && count($this->resumeData->references) > 0) ? $this->resumeData->references : null; + } +} diff --git a/src/Sikofitt/Image/Profile/FacebookProfileIcon.php b/src/Sikofitt/Image/Profile/FacebookProfileIcon.php index a0b0231..aff9616 100644 --- a/src/Sikofitt/Image/Profile/FacebookProfileIcon.php +++ b/src/Sikofitt/Image/Profile/FacebookProfileIcon.php @@ -1,4 +1,14 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + /** * This file is part of resume. * @@ -14,18 +24,21 @@ namespace Sikofitt\Image\Profile; +class FacebookProfileIcon implements ProfileIconInterface +{ -class FacebookProfileIcon implements ProfileIconInterface { + public function getName() + { + return 'facebook'; + } - public function getName() { - return 'facebook'; - } + public function getDefaultUrl() + { + return 'https://facebook.com'; + } - public function getDefaultUrl() { - return 'https://facebook.com'; - } - - public function getIcon() { - return ''; - } -} \ No newline at end of file + public function getIcon() + { + return ''; + } +} diff --git a/src/Sikofitt/Image/Profile/GithubProfileIcon.php b/src/Sikofitt/Image/Profile/GithubProfileIcon.php index 35269f5..4e9ca06 100644 --- a/src/Sikofitt/Image/Profile/GithubProfileIcon.php +++ b/src/Sikofitt/Image/Profile/GithubProfileIcon.php @@ -1,4 +1,14 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + /** * This file is part of test. * @@ -20,21 +30,24 @@ namespace Sikofitt\Image\Profile; */ class GithubProfileIcon implements ProfileIconInterface { - /** + /** * {@inheritdoc} */ - public function getName() { - return 'github'; + public function getName() + { + return 'github'; } - public function getDefaultUrl() { - return 'https://github.com'; - } + public function getDefaultUrl() + { + return 'https://github.com'; + } /** * {@inheritdoc} */ - public function getIcon() { + public function getIcon() + { return ''; } -} \ No newline at end of file +} diff --git a/src/Sikofitt/Image/Profile/GitlabProfileIcon.php b/src/Sikofitt/Image/Profile/GitlabProfileIcon.php index 11cad28..f4f5869 100644 --- a/src/Sikofitt/Image/Profile/GitlabProfileIcon.php +++ b/src/Sikofitt/Image/Profile/GitlabProfileIcon.php @@ -1,4 +1,14 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + /** * This file is part of test. * @@ -18,23 +28,27 @@ namespace Sikofitt\Image\Profile; * Class GitlabProfileIcon * @package Sikofitt\Image\Profile */ -class GitlabProfileIcon implements ProfileIconInterface { +class GitlabProfileIcon implements ProfileIconInterface +{ + + /** + * {@inheritdoc} + */ + public function getName() + { + return 'gitlab'; + } + + public function getDefaultUrl() + { + return 'https://gitlab.com'; + } /** * {@inheritdoc} */ - public function getName() { - return 'gitlab'; + public function getIcon() + { + return ''; } - - public function getDefaultUrl() { - return 'https://gitlab.com'; - } - - /** - * {@inheritdoc} - */ - public function getIcon() { - return ''; - } -} \ No newline at end of file +} diff --git a/src/Sikofitt/Image/Profile/LinkedinProfileIcon.php b/src/Sikofitt/Image/Profile/LinkedinProfileIcon.php index 31cd0c6..0d44e74 100644 --- a/src/Sikofitt/Image/Profile/LinkedinProfileIcon.php +++ b/src/Sikofitt/Image/Profile/LinkedinProfileIcon.php @@ -1,4 +1,14 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + /** * This file is part of test. * @@ -14,18 +24,21 @@ namespace Sikofitt\Image\Profile; +class LinkedinProfileIcon implements ProfileIconInterface +{ -class LinkedinProfileIcon implements ProfileIconInterface { + public function getName() + { + return 'linkedin'; + } - public function getName() { - return 'linkedin'; - } + public function getDefaultUrl() + { + return 'https://linkedin.com/in'; + } - public function getDefaultUrl() { - return 'https://linkedin.com/in'; - } - - public function getIcon() { - return ''; - } -} \ No newline at end of file + public function getIcon() + { + return ''; + } +} diff --git a/src/Sikofitt/Image/Profile/ProfileIconInterface.php b/src/Sikofitt/Image/Profile/ProfileIconInterface.php index 1489c36..0faefff 100644 --- a/src/Sikofitt/Image/Profile/ProfileIconInterface.php +++ b/src/Sikofitt/Image/Profile/ProfileIconInterface.php @@ -1,4 +1,14 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + /** * This file is part of resume. * @@ -18,9 +28,10 @@ namespace Sikofitt\Image\Profile; * Interface ProfileIconInterface * @package Sikofitt\Image\Profile */ -interface ProfileIconInterface { +interface ProfileIconInterface +{ - /** + /** * @return string * The name of the network. */ @@ -38,5 +49,4 @@ interface ProfileIconInterface { * Can be a url, a relative path, or base64 encoded uri. */ public function getIcon(); - -} \ No newline at end of file +} diff --git a/src/Sikofitt/Image/Profile/TwitterProfileIcon.php b/src/Sikofitt/Image/Profile/TwitterProfileIcon.php index 7392aa6..c0eaf19 100644 --- a/src/Sikofitt/Image/Profile/TwitterProfileIcon.php +++ b/src/Sikofitt/Image/Profile/TwitterProfileIcon.php @@ -1,4 +1,14 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + /** * This file is part of resume. * @@ -14,19 +24,20 @@ namespace Sikofitt\Image\Profile; +class TwitterProfileIcon implements ProfileIconInterface +{ -class TwitterProfileIcon implements ProfileIconInterface { + public function getName() + { + return 'twitter'; + } + public function getDefaultUrl() + { + return 'https://twitter.com'; + } - public function getName() - { - return 'twitter'; - } - public function getDefaultUrl() { - return 'https://twitter.com'; - } - - public function getIcon() { - return ''; - } - -} \ No newline at end of file + public function getIcon() + { + return ''; + } +} diff --git a/src/Sikofitt/Json/JsonFileTrait.php b/src/Sikofitt/Json/JsonFileTrait.php new file mode 100644 index 0000000..392c7a9 --- /dev/null +++ b/src/Sikofitt/Json/JsonFileTrait.php @@ -0,0 +1,39 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +/** + * This file is part of test. + * + * @file JsonFileTrait.php + * + * R. Eric Wheeler + * + * 7/8/16 / 8:12 AM + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Sikofitt\Json; + +trait JsonFileTrait +{ + + public function encodeFile($array, $file, $schema = null) + { + return $this['json.encode']->encodeFile($array, $file, $schema); + } + + public function decodeFile($file, $schema = null) + { + return $this['json.decode']->decodeFile($file, $file, $schema); + } +} diff --git a/src/Sikofitt/Json/JsonServiceProvider.php b/src/Sikofitt/Json/JsonServiceProvider.php new file mode 100644 index 0000000..fb91636 --- /dev/null +++ b/src/Sikofitt/Json/JsonServiceProvider.php @@ -0,0 +1,42 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Sikofitt\Json; + +use Pimple\Container; +use Pimple\ServiceProviderInterface; +use Webmozart\Json\JsonDecoder; +use Webmozart\Json\JsonEncoder; +use Webmozart\Json\JsonValidator; + +/** + * Class JsonServiceProvider + * @package Sikofitt\Json + */ +class JsonServiceProvider implements ServiceProviderInterface +{ + + /** + * @param Container $app + */ + public function register(Container $app) + { + $app['json.encode'] = function ($app) { + return new JsonEncoder(); + }; + $app['json.decode'] = function ($app) { + return new JsonDecoder(); + }; + $app['json.validate'] = function ($app) { + return new JsonValidator(); + }; + } +} diff --git a/src/Sikofitt/Json/JsonTrait.php b/src/Sikofitt/Json/JsonTrait.php new file mode 100644 index 0000000..90e3625 --- /dev/null +++ b/src/Sikofitt/Json/JsonTrait.php @@ -0,0 +1,50 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Sikofitt\Json; + +/** + * Class JsonTrait + * @package Sikofitt\Json + */ +trait JsonTrait +{ + + /** + * @param $array + * @param null $schema + * @return mixed + */ + public function encode($array, $schema = null) + { + return $this['json.encode']->encode($array, $schema); + } + + /** + * @param $json + * @param null $schema + * @return mixed + */ + public function decode($json, $schema = null) + { + return $this['json.decode']->decode($json, $schema); + } + + /** + * @param $json + * @param $schema + * @return mixed + */ + public function validate($json, $schema) + { + return $this['json.validate']->validate($json, $schema); + } +} diff --git a/src/Sikofitt/Json/ResumeBuilder.php b/src/Sikofitt/Json/ResumeBuilder.php index 0b55be1..87ab20a 100644 --- a/src/Sikofitt/Json/ResumeBuilder.php +++ b/src/Sikofitt/Json/ResumeBuilder.php @@ -1,4 +1,14 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + /** * Created by PhpStorm. * User: eric @@ -8,17 +18,16 @@ namespace Sikofitt\Json; - - -use Webmozart\Json\JsonDecoder; -use Webmozart\Json\JsonEncoder; +use App; use Webmozart\Json\DecodingFailedException; use Webmozart\Json\EncodingFailedException; -use Webmozart\Json\JsonValidator; -use Webmozart\Json\ValidationFailedException; use Webmozart\Json\FileNotFoundException; use Webmozart\Json\IOException; -use App; +use Webmozart\Json\JsonDecoder; +use Webmozart\Json\JsonEncoder; +use Webmozart\Json\JsonValidator; +use Webmozart\Json\ValidationFailedException; + /** * Class ResumeBuilder * @package Sikofitt\Json @@ -27,38 +36,34 @@ class ResumeBuilder { private $app; - public function __construct (App $app) + public function __construct(App $app) { $this->app = $app; } - public function toJson ($resumeArray, array $options = array ()) + public function toJson($resumeArray, array $options = []) { $encoder = new JsonEncoder(); $validator = new JsonValidator(); - if(!isset($options['file'])) { + if (!isset($options['file'])) { throw new \InvalidArgumentException('file is a required argument.'); } $errors = $validator->validate((object)$resumeArray, $options['app']->getResumeSchema()); dump($errors); try { - // $encoder->encodeFile ($resumeArray, 'test.json'); - + // $encoder->encodeFile ($resumeArray, 'test.json'); } catch (\Exception $e) { $r = new \ReflectionClass($e); $exceptionClass = $r->getName(); return new $exceptionClass($e->getMessage()); } - - - } - public function fromJson ($resumeJson, array $options = array ()) + public function fromJson($resumeJson, array $options = []) { $decoder = new JsonDecoder(); $resumeObject = $decoder->decodeFile($this->app->getResumeJson(), $this->app->getResumeSchema()); return $resumeObject; } -} \ No newline at end of file +} diff --git a/src/Sikofitt/Resume/ResumeParser.php b/src/Sikofitt/Resume/ResumeParser.php index c6a068a..c13ea7c 100644 --- a/src/Sikofitt/Resume/ResumeParser.php +++ b/src/Sikofitt/Resume/ResumeParser.php @@ -1,4 +1,14 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + /** * Created by PhpStorm. * User: eric @@ -8,7 +18,6 @@ namespace Sikofitt\Resume; - use Webmozart\Json\Conversion\JsonConverter; /** @@ -23,7 +32,7 @@ class ResumeParser implements JsonConverter * * @return void */ - public function fromJson ($jsonData, array $options = array ()) + public function fromJson($jsonData, array $options = []) { // TODO: Implement fromJson() method. } @@ -34,10 +43,8 @@ class ResumeParser implements JsonConverter * * @return void */ - public function toJson ($data, array $options = array ()) + public function toJson($data, array $options = []) { // TODO: Implement toJson() method. } - - -} \ No newline at end of file +} diff --git a/src/Sikofitt/Twig/Date.php b/src/Sikofitt/Twig/Date.php index bb38309..c759603 100644 --- a/src/Sikofitt/Twig/Date.php +++ b/src/Sikofitt/Twig/Date.php @@ -1,4 +1,14 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + /** * This file is part of resume. * @@ -14,12 +24,13 @@ namespace Sikofitt\Twig; +class Date extends \Twig_Extension +{ -class Date extends \Twig_Extension { - - public function getName() { - return 'date_diff'; - } + public function getName() + { + return 'date_diff'; + } /** * @return array @@ -27,7 +38,7 @@ class Date extends \Twig_Extension { */ public function getFilters() { - return [ + return [ new \Twig_SimpleFilter('date_diff', [$this, 'dateDiff']), ]; } @@ -42,9 +53,8 @@ class Date extends \Twig_Extension { */ public function dateDiff($startDate, $endDate = 'now') { - $dt = new \DateTimeImmutable($startDate); - $dateDifference = $dt->diff(new \DateTime($endDate)); - return $dateDifference->format('%y years'); - + $dt = new \DateTimeImmutable($startDate); + $dateDifference = $dt->diff(new \DateTime($endDate)); + return $dateDifference->format('%y years'); } -} \ No newline at end of file +} diff --git a/src/Sikofitt/Twig/RenderProfile.php b/src/Sikofitt/Twig/RenderProfile.php index 6eb7b66..4b808ee 100644 --- a/src/Sikofitt/Twig/RenderProfile.php +++ b/src/Sikofitt/Twig/RenderProfile.php @@ -1,4 +1,14 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + /** * This file is part of test. * @@ -14,41 +24,42 @@ namespace Sikofitt\Twig; +class RenderProfile extends \Twig_Extension +{ -class RenderProfile extends \Twig_Extension { + public function getName() + { + return 'render_profile'; + } - public function getName() { - return 'render_profile'; - } - - public function getFunctions() { - return [ + public function getFunctions() + { + return [ new \Twig_SimpleFunction('render_profile', [$this, 'renderProfile'], ['needs_context' => true]), ]; - } + } - public function renderProfile($context, $iconData) - { - $imageData = ''; + public function renderProfile($context, $iconData) + { + $imageData = ''; //network": "Twitter" +"username": "sikofitt" +"url": "" $icons = $context['app']->config('app.icons'); - $network = strtolower($iconData->network); - $haveNetwork = isset($icons[$network]); - if($haveNetwork) { - $imageData = $icons[strtolower($iconData->network)]; - } else { - return; + $network = strtolower($iconData->network); + $haveNetwork = isset($icons[$network]); + if ($haveNetwork) { + $imageData = $icons[strtolower($iconData->network)]; + } else { + return; + } + if (!isset($iconData->url) || empty($iconData->url)) { + $iconData->url = $icons[strtolower($iconData->network)]['url'] . '/' . $iconData->username; + } + $imageUrl = sprintf('%s', $imageData['icon'], $iconData->network); + if (isset($iconData->url) && !empty($iconData->url)) { + return sprintf('%s', $iconData->url, $iconData->network, $imageUrl); + } else { + return $imageUrl; + } } - if(!isset($iconData->url) || empty($iconData->url)) - { - $iconData->url = $icons[strtolower($iconData->network)]['url'] . '/' . $iconData->username; - } - $imageUrl = sprintf('%s', $imageData['icon'], $iconData->network); - if(isset($iconData->url) && !empty($iconData->url)) { - return sprintf('%s', $iconData->url, $iconData->network,$imageUrl); - } else { - return $imageUrl; - } - } -} \ No newline at end of file +} diff --git a/src/Sikofitt/less/resume.less b/src/Sikofitt/less/resume.less index e202587..6cd3e96 100644 --- a/src/Sikofitt/less/resume.less +++ b/src/Sikofitt/less/resume.less @@ -1,4 +1,5 @@ @import 'uikit.less'; +@import 'components/notify.less'; @import 'https://fonts.googleapis.com/css?family=Lato:300|Eczar'; @base-body-font-family : 'Lato'; diff --git a/web/index.php b/web/index.php index 4301a9c..8d1abd2 100644 --- a/web/index.php +++ b/web/index.php @@ -1,106 +1,20 @@ + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ require_once __DIR__ . '/../vendor/autoload.php'; -require_once __DIR__ . '/../app/App.php'; -define('APP_ROOT', __DIR__ . '/../'); -define('SCHEMA_URL', 'https://raw.githubusercontent.com/jsonresume/resume-schema/v1.0.0/schema.json'); $app = new App(); -$app['debug'] = true; -$app->register(new Sikofitt\Config\ConfigServiceProvider(), [ - 'config.path' => $app->getConfDirectory(), -]); -$app->register(new TwigServiceProvider(), [ - 'twig.path' => [ - APP_ROOT . 'app/views', - APP_ROOT . 'vendor/symfony/web-profiler-bundle/Resources/views/Profiler' - ], -]); -$app->register(new WhoopsServiceProvider()); -$app->register(new \Silex\Provider\AssetServiceProvider()); -$app->register(new \Silex\Provider\MonologServiceProvider()); - -$app->register(new \Silex\Provider\HttpKernelServiceProvider()); -$app->register(new \Silex\Provider\AssetServiceProvider()); -$app->register(new \Silex\Provider\FormServiceProvider()); -$app->register(new \Silex\Provider\HttpFragmentServiceProvider()); -$app->register(new \Silex\Provider\ServiceControllerServiceProvider()); -$app->register(new \Silex\Provider\RoutingServiceProvider()); -$app->register(new \Silex\Provider\VarDumperServiceProvider(), array( - 'var_dumper.dump_destination' => new \Symfony\Component\VarDumper\Cloner\VarCloner(), -)); - -$app->register(new \Silex\Provider\MonologServiceProvider(), array( - 'monolog.logfile' => $app->getDataDirectory() . '/logs/' . (null !== $app->config('app.environment') ? $app->config('app.environment') . '.log' : 'dev.log'), -)); - -$app->register(new \Silex\Provider\SessionServiceProvider()); -$app->register(new \Silex\Provider\WebProfilerServiceProvider(), array( - 'profiler.cache_dir' => $app->getDataDirectory() . '/cache/profiler', -)); -$app->extend('twig', function (\Twig_Environment $twig, $app) { - $twig->enableDebug(); - $twig->addExtension(new Twig_Extensions_Extension_Date()); - $twig->addExtension(new Sikofitt\Twig\Date()); - $twig->addExtension(new Sikofitt\Twig\RenderProfile()); - $twig->addGlobal('config', $app['config']->all()); - return $twig; -}); -$app->error(function (\Exception $e, $code) use ($app) { - switch ($code) { - case 404: - $message = $app['twig']->render('error404.html.twig'); - break; - default: - $message = $app['twig']->render('error500.html.twig'); - } - return new Response($message, $code); -}); - -$app['json.decoder'] = function ($app) { - return new Webmozart\Json\JsonDecoder(); -}; -$app['json.encoder'] = function ($app) { - return new Webmozart\Json\JsonEncoder(); -}; -$app['json.validator'] = function ($app) { - return new Webmozart\Json\JsonValidator(); -}; - -$app->get('/', function () use ($app) { - $resumeData = $app['json.decoder']->decodeFile($app->getDataDirectory() . '/resume.json', $app->getDataDirectory() . '/resume.schema.json'); - $basics = (isset($resumeData->basics) && count($resumeData->basics) > 0) ? $resumeData->basics : null; - $work = (isset($resumeData->work) && count($resumeData->work) > 0) ? $resumeData->work : null; - $volunteer = (isset($resumeData->volunteer) && count($resumeData->volunteer) > 0) ? $resumeData->volunteer : null; - $education = (isset($resumeData->education) && count($resumeData->education) > 0) ? $resumeData->education : null; - $awards = (isset($resumeData->awards) && count($resumeData->awards) > 0) ? $resumeData->awards : null; - $publications = (isset($resumeData->publications) && count($resumeData->publications) > 0) ? $resumeData->publications : null; - $skills = (isset($resumeData->skills) && count($resumeData->skills) > 0) ? $resumeData->skills : null; - $languages = (isset($resumeData->languages) && count($resumeData->languages) > 0) ? $resumeData->languages : null; - $interests = (isset($resumeData->interests) && count($resumeData->interests) > 0) ? $resumeData->interests : null; - $references = (isset($resumeData->references) && count($resumeData->references) > 0) ? $resumeData->references : null; - - - return $app['twig']->render('resume.html.twig', [ - 'basics' => $basics, - 'work' => $work, - 'volunteer' => $volunteer, - 'education' => $education, - 'awards' => $awards, - 'publications' => $publications, - 'skills' => $skills, - 'languages' => $languages, - 'interests' => $interests, - 'references' => $references, - ]); -}); +require_once $app->getAppDirectory() . '/providers.php'; +$app->mount('/', new \Sikofitt\Controller\ResumeControllerProvider()); +$app->mount('/api', new \Sikofitt\Controller\ApiControllerProvider()); $app->run();