setTable('users'); } public function create(?array $data = null): Define\Model { $map = [ 'name' => [], 'password' => [], 'enabled' => [ 'function' => function($data) { return $data['enabled'] != 0; } ] ]; return $this->parseData(new Model\User(), $data, $map); } public function save(Define\Model $model): Define\Model { $model->id = $this->saveNew(['name', 'password', 'enabled'], [$model->name, $model->password, $model->enabled ? 1 : 0]); return $model; } public function edit(Define\Model $model, array $new_data): Define\Model { return $this->update($model, ['name', 'password', 'enabled'], $new_data); } public function fetchByName(string $name): Model\User { $query = "SELECT * FROM `{$this->getTable()}` WHERE `name` = ?"; return $this->fetchOne($query, [$name]); } }