Files
nibiru-framework.com/core/c/settings.php
Stephan Kasdorf 86433af5bf Version 0.3 beta 04.02.2018
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;
2018-02-04 22:16:21 +01:00

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!");
}
}
}