Improved: The Router now accepts actions, either trough the _action as parameter, or on the URL pattern after the controller name Example: http://youdomain/[controllername]/[actionname]/ It is now possible to load as many navigations on the page as wanted by passing the name to the JsonNavigation::getInstance()->loadJsonNavigationArray('[NAME]'); call in the navigationAction of the Controller Building forms by simple adding the namespace use Nibiru\Factory\Form; and calling Example: Form::addInputTypeText( array( 'name' => 'lastname', 'value' => 'placeholder' ) ); To finalize the form the last call should be something like this: Form::addForm( array('name' => 'testform', 'method' => 'post', 'action' => '/' . Router::getInstance()->currentPage(), 'target' => '_self') ); The Database design has fully been refactored, now it contains an autoloading mechanism which can be triggert by createing a database folder in the application folder, a Example file is in the folder applicatoin/database The Database access can now be implemented anywhere in your application by adding the namespace to your database accessing Logic: use Nibiru\Factory\Db;
94 lines
2.0 KiB
PHP
94 lines
2.0 KiB
PHP
<?php
|
|
namespace Nibiru;
|
|
/**
|
|
* User - stephan
|
|
* Date - 24.01.17
|
|
* Time - 20:16
|
|
* @author - Stephan Kasdorf
|
|
* @category - [PLEASE SPECIFIY]
|
|
* @license - BSD License
|
|
*/
|
|
class Settings
|
|
{
|
|
const SETTINGS_FILE = "settings.ENV.ini";
|
|
const SETTINGS_PATH = "application/settings/config/";
|
|
|
|
private static $_config;
|
|
private static $_instance;
|
|
private static $_is_db_connection = false;
|
|
|
|
protected function __construct()
|
|
{
|
|
|
|
}
|
|
|
|
public static function getInstance()
|
|
{
|
|
$className = get_called_class();
|
|
if(self::$_instance==null) self::$_instance = new $className();
|
|
return self::$_instance;
|
|
}
|
|
/**
|
|
* @return mixed
|
|
*/
|
|
public function getConfig( )
|
|
{
|
|
return self::$_config;
|
|
}
|
|
|
|
/**
|
|
* in order to have the class serve connection
|
|
* details switch to db connection
|
|
*/
|
|
public static function setToDbConnection()
|
|
{
|
|
self::$_is_db_connection = true;
|
|
}
|
|
|
|
/**
|
|
* in order to switch back from a database
|
|
* connection
|
|
*/
|
|
public static function unsetFromDbConnection()
|
|
{
|
|
self::$_is_db_connection = false;
|
|
}
|
|
/**
|
|
* @param mixed $config
|
|
*/
|
|
public static function setConfig( $env )
|
|
{
|
|
if($env)
|
|
{
|
|
$current_settings_file = str_replace('.ENV.', '.'.$env.'.', self::SETTINGS_FILE);
|
|
if(file_exists(self::SETTINGS_PATH . $current_settings_file))
|
|
{
|
|
self::$_config = parse_ini_file(self::SETTINGS_PATH . $current_settings_file, "SETTINGS");
|
|
}
|
|
elseif(file_exists('../' . self::SETTINGS_PATH . $current_settings_file))
|
|
{
|
|
if($env==config::CLI_SYSTEM)
|
|
{
|
|
if(self::$_is_db_connection)
|
|
{
|
|
self::$_config = parse_ini_file('../' . self::SETTINGS_PATH . $current_settings_file, "SETTINGS");
|
|
}
|
|
else
|
|
{
|
|
self::$_config = parse_ini_file('../' . self::SETTINGS_PATH . $current_settings_file, "EMAIL");
|
|
}
|
|
}
|
|
else
|
|
{
|
|
self::$_config = parse_ini_file('../' . self::SETTINGS_PATH . $current_settings_file, View::NIBIRU_SETTINGS);
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
throw new Exception("ERROR: The environment is unknown, please check with the server Administrator!");
|
|
}
|
|
}
|
|
|
|
|
|
} |