* @author Dennis Eichhorn * @copyright Dennis Eichhorn * @license OMS License 1.0 * @version 1.0.0 * @link http://orange-management.com */ declare(strict_types=1); namespace Modules\Admin\Models; use Modules\Media\Models\MediaMapper; use phpOMS\DataStorage\Database\DataMapperAbstract; use phpOMS\DataStorage\Database\Query\Builder; use phpOMS\DataStorage\Database\Query\Column; use phpOMS\DataStorage\Database\RelationType; use phpOMS\DataStorage\Database\DatabaseType; use phpOMS\Auth\LoginReturnType; class AccountMapper extends DataMapperAbstract { /** * Columns. * * @var array * @since 1.0.0 */ protected static $columns = [ 'account_id' => ['name' => 'account_id', 'type' => 'int', 'internal' => 'id', 'autocomplete' => true], 'account_status' => ['name' => 'account_status', 'type' => 'int', 'internal' => 'status'], 'account_type' => ['name' => 'account_type', 'type' => 'int', 'internal' => 'type'], 'account_login' => ['name' => 'account_login', 'type' => 'string', 'internal' => 'login', 'autocomplete' => true], 'account_name1' => ['name' => 'account_name1', 'type' => 'string', 'internal' => 'name1', 'autocomplete' => true], 'account_name2' => ['name' => 'account_name2', 'type' => 'string', 'internal' => 'name2', 'autocomplete' => true], 'account_name3' => ['name' => 'account_name3', 'type' => 'string', 'internal' => 'name3', 'autocomplete' => true], 'account_password' => ['name' => 'account_password', 'type' => 'string', 'internal' => 'password'], 'account_email' => ['name' => 'account_email', 'type' => 'string', 'internal' => 'email', 'autocomplete' => true], //'account_tries' => ['name' => 'account_tries', 'type' => 'int', 'internal' => 'tries'], 'account_lactive' => ['name' => 'account_lactive', 'type' => 'DateTime', 'internal' => 'lastActive'], 'account_created_at' => ['name' => 'account_created_at', 'type' => 'DateTime', 'internal' => 'createdAt'], ]; /** * Primary table. * * @var string * @since 1.0.0 */ protected static $table = 'account'; /** * Primary field name. * * @var string * @since 1.0.0 */ protected static $primaryField = 'account_id'; /** * Created at column * * @var string * @since 1.0.0 */ protected static $createdAt = 'account_created_at'; /** * Create object. * * @param mixed $obj Object * @param int $relations Behavior for relations creation * * @return mixed * * @since 1.0.0 * @author Dennis Eichhorn */ public static function create($obj, int $relations = RelationType::ALL) { try { $objId = parent::create($obj, $relations); if($objId === null || !is_scalar($objId)) { return $objId; } $query = new Builder(self::$db); $query->prefix(self::$db->getPrefix()) ->insert( 'account_permission_account', 'account_permission_from', 'account_permission_for', 'account_permission_id1', 'account_permission_id2', 'account_permission_r', 'account_permission_w', 'account_permission_m', 'account_permission_d', 'account_permission_p' ) ->into('account_permission') ->values(1, 'account', 'account', 1, $objId, 1, 1, 1, 1, 1); self::$db->con->prepare($query->toSql())->execute(); } catch (\Exception $e) { var_dump($e->getMessage()); return false; } return $objId; } /** * Login user. * * @param string $login Username * @param string $password Password * * @return int Login code * * @todo move this to the admin accountMapper * * @since 1.0.0 * @author Dennis Eichhorn */ public static function login(string $login, string $password) : int { try { $result = null; switch (self::$db->getType()) { case DatabaseType::MYSQL: $sth = self::$db->con->prepare( 'SELECT `' . self::$db->prefix . 'account`.* FROM `' . self::$db->prefix . 'account` WHERE `account_login` = :login' ); $sth->bindValue(':login', $login, \PDO::PARAM_STR); $sth->execute(); $result = $sth->fetchAll(); break; } // TODO: check if user is allowed to login on THIS page (backend|frontend|etc...) if (!isset($result[0])) { return LoginReturnType::WRONG_USERNAME; } $result = $result[0]; if ($result['account_tries'] <= 0) { return LoginReturnType::WRONG_INPUT_EXCEEDED; } if (password_verify($password, $result['account_password'])) { return $result['account_id']; } return LoginReturnType::WRONG_PASSWORD; } catch (\Exception $e) { return LoginReturnType::FAILURE; } } /** * Get object. * * @param mixed $primaryKey Key * @param int $relations Load relations * @param mixed $fill Object to fill * * @return Account * * @since 1.0.0 * @author Dennis Eichhorn */ public static function get($primaryKey, int $relations = RelationType::ALL, $fill = null) { return parent::get((int) $primaryKey, $relations, $fill); } }