mirror of
https://github.com/opensourcepos/opensourcepos.git
synced 2026-04-16 21:08:59 -04:00
- Merge Config and Core File Changes 4.6.3 > 4.6.4 - Merge Config and Core File Changes 4.6.4 > 4.7.0 - Added app\Config\WorkerMode.php - Merge Config and Core File Changes Not previously merged - Added app\Config\Hostnames.php - Corrected incorrect CSS property used in invoice.php view. - Corrected unknown CSS properties used in register.php view. - Used shorthand CSS in debug.css - Corrected indentation in barcode_sheet.php view. - Corrected indentation in footer.php view. - Corrected indentation in invoice_email.php view. - Replaced obsolete attributes with CSS style attributes in barcode_sheet.php - Replaced obsolete attribute in error_exception.php - Replaced obsolete attribute in invoice_email.php - Replaced obsolete attribute in quote_email.php - Replaced obsolete attributes in work_order_email.php - Fixed indentation in system_info.php - Replaced <strong> tag outside <p> tags, which isn't allowed, with style attributes. - Simplified js return logic and indentation fixes in tax_categories.php - Simplified js return logic in tax_codes.php - Simplified js return logic in tax_jurisdictions.php - Removed unnecessary labels in manage views. - Rewrite JavaScript function and PHP to be more readable in bar.php, hbar.php, line.php and pie.php - Added type declarations, return types and an import to app\Config\Services - Updated Attribute.php parameter type - Updated Receiving_lib.php parameter type - Updated Receivings.php parameter types and updated PHPdocs - Updated tabular_helper.php parameter types and updated PHPdocs - Added type declarations and corrected PHPdocs in url_helper.php - Added return types to functions - Revert $objectSrc value in ContentSecurityPolicy.php - Correct return type in Customer->get_stats() - Correct return type in Item->get_info_by_id_or_number() - Correct misspelling in border-spacing - Added missing css style semicolons - Resolve operator precedence ambiguity. - Resolve column mismatch. - Added missing escaping in view. - Updated requirement for PHP 8.2 - Resolve unresolved conflicts - Added PHP 8.2 requirement to the README.md - Fixed bugs in display of UI - Fixed duplicated `>` in app\Views\Expenses\manage.php - Removed excess whitespace at the end of some lines in table_filter_persistence.php - Added missing `>` in app\Views\Expenses\manage.php - Corrected grammar in PHPdoc in table_filter_persistence.php - Remove bug causing `\` to be injected into the new giftcard value - Fix bug causing DROPDOWN Attribute Values to not save correctly - Added check for null in $normalizedItemId - Removing < PHP 8.2 from linting and tests - Update Linter to not include PHP 8.2 and 8.1 - Remove PHP 8.1 unit test cycle. - Update Bug Report Template - Update Composer files for CodeIgniter 4.7.2 - Updated INSTALL.md to reflect changes. --------- Signed-off-by: objec <objecttothis@gmail.com>
143 lines
4.4 KiB
PHP
143 lines
4.4 KiB
PHP
<?php
|
|
|
|
namespace Config;
|
|
|
|
use CodeIgniter\Database\Config;
|
|
|
|
/**
|
|
* Database Configuration
|
|
*/
|
|
class Database extends Config
|
|
{
|
|
/**
|
|
* The directory that holds the Migrations and Seeds directories.
|
|
*/
|
|
public string $filesPath = APPPATH . 'Database' . DIRECTORY_SEPARATOR;
|
|
|
|
/**
|
|
* Lets you choose which connection group to use if no other is specified.
|
|
*/
|
|
public string $defaultGroup = 'default';
|
|
|
|
/**
|
|
* The default database connection.
|
|
*
|
|
* @var array<string, mixed>
|
|
*/
|
|
public array $default = [
|
|
'DSN' => '',
|
|
'hostname' => 'localhost',
|
|
'username' => 'admin',
|
|
'password' => 'pointofsale',
|
|
'database' => 'ospos',
|
|
'DBDriver' => 'MySQLi',
|
|
'DBPrefix' => 'ospos_',
|
|
'pConnect' => false,
|
|
'DBDebug' => (ENVIRONMENT !== 'production'),
|
|
'charset' => 'utf8mb4',
|
|
'DBCollat' => 'utf8mb4_general_ci',
|
|
'swapPre' => '',
|
|
'encrypt' => false,
|
|
'compress' => false,
|
|
'strictOn' => false,
|
|
'failover' => [],
|
|
'port' => 3306,
|
|
'numberNative' => false,
|
|
'foundRows' => false,
|
|
'dateFormat' => [
|
|
'date' => 'Y-m-d',
|
|
'datetime' => 'Y-m-d H:i:s',
|
|
'time' => 'H:i:s',
|
|
],
|
|
];
|
|
|
|
/**
|
|
* This database connection is used when running PHPUnit database tests.
|
|
*
|
|
* @var array<string, mixed>
|
|
*/
|
|
public array $tests = [
|
|
'DSN' => '',
|
|
'hostname' => 'localhost',
|
|
'username' => 'admin',
|
|
'password' => 'pointofsale',
|
|
'database' => 'ospos',
|
|
'DBDriver' => 'MySQLi',
|
|
'DBPrefix' => 'ospos_',
|
|
'pConnect' => false,
|
|
'DBDebug' => (ENVIRONMENT !== 'production'),
|
|
'charset' => 'utf8mb4',
|
|
'DBCollat' => 'utf8mb4_general_ci',
|
|
'swapPre' => '',
|
|
'encrypt' => false,
|
|
'compress' => false,
|
|
'strictOn' => false,
|
|
'failover' => [],
|
|
'port' => 3306,
|
|
'foreignKeys' => true,
|
|
'busyTimeout' => 1000,
|
|
'synchronous' => null,
|
|
'dateFormat' => [
|
|
'date' => 'Y-m-d',
|
|
'datetime' => 'Y-m-d H:i:s',
|
|
'time' => 'H:i:s',
|
|
],
|
|
];
|
|
|
|
/**
|
|
* This database connection is used when developing against non-production data.
|
|
*
|
|
* @var array
|
|
*/
|
|
public $development = [
|
|
'DSN' => '',
|
|
'hostname' => 'localhost',
|
|
'username' => 'admin',
|
|
'password' => 'pointofsale',
|
|
'database' => 'ospos',
|
|
'DBDriver' => 'MySQLi',
|
|
'DBPrefix' => 'ospos_',
|
|
'pConnect' => false,
|
|
'DBDebug' => (ENVIRONMENT !== 'production'),
|
|
'charset' => 'utf8mb4',
|
|
'DBCollat' => 'utf8mb4_general_ci',
|
|
'swapPre' => '',
|
|
'encrypt' => false,
|
|
'compress' => false,
|
|
'strictOn' => false,
|
|
'failover' => [],
|
|
'port' => 3306,
|
|
'foreignKeys' => true,
|
|
'busyTimeout' => 1000,
|
|
'dateFormat' => [
|
|
'date' => 'Y-m-d',
|
|
'datetime' => 'Y-m-d H:i:s',
|
|
'time' => 'H:i:s',
|
|
],
|
|
];
|
|
|
|
public function __construct()
|
|
{
|
|
parent::__construct();
|
|
|
|
// Ensure that we always set the database group to 'tests' if
|
|
// we are currently running an automated test suite, so that
|
|
// we don't overwrite live data on accident.
|
|
switch (ENVIRONMENT) {
|
|
case 'testing':
|
|
$this->defaultGroup = 'tests';
|
|
break;
|
|
case 'development';
|
|
$this->defaultGroup = 'development';
|
|
break;
|
|
}
|
|
|
|
foreach ([&$this->development, &$this->tests, &$this->default] as &$config) {
|
|
$config['hostname'] = !getenv('MYSQL_HOST_NAME') ? $config['hostname'] : getenv('MYSQL_HOST_NAME');
|
|
$config['username'] = !getenv('MYSQL_USERNAME') ? $config['username'] : getenv('MYSQL_USERNAME');
|
|
$config['password'] = !getenv('MYSQL_PASSWORD') ? $config['password'] : getenv('MYSQL_PASSWORD');
|
|
$config['database'] = !getenv('MYSQL_DB_NAME') ? $config['database'] : getenv('MYSQL_DB_NAME');
|
|
}
|
|
}
|
|
}
|