mirror of
https://github.com/bs-community/blessing-skin-server.git
synced 2025-01-24 14:04:07 +08:00
Remove class App\Services\Database
This commit is contained in:
parent
8ceec96224
commit
5889df5b63
@ -9,7 +9,6 @@ use Schema;
|
||||
use Option;
|
||||
use Storage;
|
||||
use Artisan;
|
||||
use Database;
|
||||
use App\Models\User;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Validation\Validator;
|
||||
|
@ -2,9 +2,9 @@
|
||||
|
||||
namespace App\Providers;
|
||||
|
||||
use DB;
|
||||
use View;
|
||||
use Utils;
|
||||
use App\Services\Database;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\ServiceProvider;
|
||||
use App\Exceptions\PrettyPageException;
|
||||
@ -52,8 +52,7 @@ class BootServiceProvider extends ServiceProvider
|
||||
protected function checkDatabaseConnection()
|
||||
{
|
||||
try {
|
||||
// Check database config
|
||||
Database::prepareConnection();
|
||||
DB::connection()->getPdo();
|
||||
} catch (\Exception $e) {
|
||||
if ($this->app->runningInConsole()) {
|
||||
// Dump some useful information for debugging
|
||||
@ -64,8 +63,10 @@ class BootServiceProvider extends ServiceProvider
|
||||
]);
|
||||
}
|
||||
|
||||
$gbkErrorMsg = iconv('gbk', 'utf-8', $e->getMessage());
|
||||
|
||||
throw new PrettyPageException(
|
||||
trans('setup.database.connection-error', ['msg' => $e->getMessage()]),
|
||||
trans('setup.database.connection-error', ['msg' => $gbkErrorMsg]),
|
||||
$e->getCode()
|
||||
);
|
||||
}
|
||||
@ -95,6 +96,5 @@ class BootServiceProvider extends ServiceProvider
|
||||
View::addExtension('tpl', 'blade');
|
||||
|
||||
$this->app->singleton('options', OptionRepository::class);
|
||||
$this->app->singleton('database', Database::class);
|
||||
}
|
||||
}
|
||||
|
@ -1,233 +0,0 @@
|
||||
<?php
|
||||
|
||||
namespace App\Services;
|
||||
|
||||
use Exception;
|
||||
use InvalidArgumentException;
|
||||
|
||||
/**
|
||||
* Light-weight database helper
|
||||
*
|
||||
* @author <h@prinzeugen.net>
|
||||
*/
|
||||
class Database
|
||||
{
|
||||
/**
|
||||
* Instance of MySQLi.
|
||||
*
|
||||
* @var null
|
||||
*/
|
||||
private $connection = null;
|
||||
|
||||
/**
|
||||
* Database name.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
private $database = "";
|
||||
|
||||
/**
|
||||
* Name of table to do operations in.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
private $tableName = "";
|
||||
|
||||
/**
|
||||
* Construct with a config array.
|
||||
*
|
||||
* @param array $config
|
||||
*/
|
||||
public function __construct($config = null)
|
||||
{
|
||||
try {
|
||||
$this->connection = self::prepareConnection($config);
|
||||
} catch (Exception $e) {
|
||||
// throw with message
|
||||
throw new InvalidArgumentException("Could not connect to MySQL database. ".
|
||||
$e->getMessage(), $e->getCode());
|
||||
}
|
||||
|
||||
$this->database = array_get($config, 'database', config('database.connections.mysql.database'));
|
||||
$this->connection->query("SET names 'utf8'");
|
||||
}
|
||||
|
||||
/**
|
||||
* Try to connect to the database with given config.
|
||||
*
|
||||
* @param array $config
|
||||
* @return \mysqli
|
||||
*
|
||||
* @throws InvalidArgumentException
|
||||
*/
|
||||
public static function prepareConnection($config = null)
|
||||
{
|
||||
$config = $config ?: config('database.connections.mysql');
|
||||
|
||||
// use error control operator to hide warnings
|
||||
@$conn = new \mysqli(
|
||||
$config['host'],
|
||||
$config['username'],
|
||||
$config['password'],
|
||||
$config['database'],
|
||||
$config['port']
|
||||
);
|
||||
|
||||
if ($conn->connect_error) {
|
||||
throw new InvalidArgumentException($conn->connect_error, $conn->connect_errno);
|
||||
}
|
||||
|
||||
return $conn;
|
||||
}
|
||||
|
||||
public function table($tableName, $no_prefix = false)
|
||||
{
|
||||
if ($this->connection->real_escape_string($tableName) == $tableName) {
|
||||
|
||||
$this->tableName = $no_prefix ? "{$this->database}.$tableName" : config('database.connections.mysql.prefix').$tableName;
|
||||
return $this;
|
||||
|
||||
} else {
|
||||
throw new InvalidArgumentException('Table name contains invalid characters', 1);
|
||||
}
|
||||
}
|
||||
|
||||
public function query($sql)
|
||||
{
|
||||
// compile patterns
|
||||
$sql = str_replace('{table}', $this->tableName, $sql);
|
||||
|
||||
$result = $this->connection->query($sql);
|
||||
|
||||
if ($this->connection->error)
|
||||
throw new Exception("Database query error: ".$this->connection->error.", Statement: ".$sql, -1);
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
public function fetchArray($sql)
|
||||
{
|
||||
return $this->query($sql)->fetch_array();
|
||||
}
|
||||
|
||||
/**
|
||||
* Select records from table
|
||||
*
|
||||
* @param string $key
|
||||
* @param string $value
|
||||
* @param array $condition See function `where`
|
||||
* @param string $table Which table to operate
|
||||
* @param bool $dont_fetch_array Return resources if true
|
||||
* @return array|resources
|
||||
*/
|
||||
public function select($key, $value, $condition = null, $table = null, $dont_fetch_array = false)
|
||||
{
|
||||
$table = $table ?: $this->tableName;
|
||||
|
||||
if (isset($condition['where'])) {
|
||||
$sql = "SELECT * FROM $table".$this->where($condition);
|
||||
} else {
|
||||
$sql = "SELECT * FROM $table WHERE $key='$value'";
|
||||
}
|
||||
|
||||
if ($dont_fetch_array) {
|
||||
return $this->query($sql);
|
||||
} else {
|
||||
return $this->fetchArray($sql);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public function insert($data, $table = null)
|
||||
{
|
||||
$keys = "";
|
||||
$values = "";
|
||||
$table = $table ?: $this->tableName;
|
||||
|
||||
foreach($data as $key => $value) {
|
||||
if ($value == end($data)) {
|
||||
$keys .= '`'.$key.'`';
|
||||
$values .= '"'.$value.'"';
|
||||
} else {
|
||||
$keys .= '`'.$key.'`,';
|
||||
$values .= '"'.$value.'", ';
|
||||
}
|
||||
}
|
||||
|
||||
$sql = "INSERT INTO $table ({$keys}) VALUES ($values)";
|
||||
return $this->query($sql);
|
||||
}
|
||||
|
||||
public function has($key, $value, $table = null)
|
||||
{
|
||||
return ($this->getNumRows($key, $value, $table) != 0) ? true : false;
|
||||
}
|
||||
|
||||
public function hasTable($tableName)
|
||||
{
|
||||
$sql = "SELECT table_name FROM `INFORMATION_SCHEMA`.`TABLES` WHERE (table_name = '$tableName') AND TABLE_SCHEMA='{$this->database}'";
|
||||
|
||||
return ($this->query($sql)->num_rows != 0) ? true : false;
|
||||
}
|
||||
|
||||
public function update($key, $value, $condition = null, $table = null)
|
||||
{
|
||||
$table = $table ?: $this->tableName;
|
||||
|
||||
return $this->query("UPDATE $table SET `$key`='$value'".$this->where($condition));
|
||||
}
|
||||
|
||||
public function delete($condition = null, $table = null)
|
||||
{
|
||||
$table = $table ?: $this->tableName;
|
||||
|
||||
return $this->query("DELETE FROM $table".$this->where($condition));
|
||||
}
|
||||
|
||||
public function getNumRows($key, $value, $table = null)
|
||||
{
|
||||
$table = $table ?: $this->tableName;
|
||||
|
||||
$sql = "SELECT * FROM $table WHERE $key='$value'";
|
||||
return $this->query($sql)->num_rows;
|
||||
}
|
||||
|
||||
public function getRecordNum($table = null)
|
||||
{
|
||||
$table = $table ?: $this->tableName;
|
||||
|
||||
$sql = "SELECT * FROM $table WHERE 1";
|
||||
return $this->query($sql)->num_rows;
|
||||
}
|
||||
|
||||
/**
|
||||
* Generate where statement
|
||||
*
|
||||
* @param array $condition e.g. array('where'=>'username="shit"', 'limit'=>10, 'order'=>'uid')
|
||||
* @return string
|
||||
*/
|
||||
private function where($condition)
|
||||
{
|
||||
$statement = "";
|
||||
|
||||
if (isset($condition['where']) && $condition['where'] != "") {
|
||||
$statement .= ' WHERE '.$condition['where'];
|
||||
}
|
||||
if (isset($condition['order'])) {
|
||||
$statement .= ' ORDER BY `'.$condition['order'].'`';
|
||||
}
|
||||
if (isset($condition['limit'])) {
|
||||
$statement .= ' LIMIT '.$condition['limit'];
|
||||
}
|
||||
|
||||
return $statement;
|
||||
}
|
||||
|
||||
public function __destruct()
|
||||
{
|
||||
if (! is_null($this->connection)) {
|
||||
$this->connection->close();
|
||||
}
|
||||
}
|
||||
|
||||
}
|
@ -231,8 +231,6 @@ return [
|
||||
'Utils' => App\Services\Utils::class,
|
||||
'Minecraft' => App\Services\Minecraft::class,
|
||||
'Updater' => App\Services\Updater::class,
|
||||
'Database' => App\Services\Facades\Database::class,
|
||||
|
||||
],
|
||||
|
||||
];
|
||||
|
Loading…
Reference in New Issue
Block a user