ruleset = new Ruleset(strict: true); $this->ruleset->GET([ (new Rules(WorkModel::ID->value)) ->type(Type::STRING) ->min(1) ->max(parent::MYSQL_VARCHAR_MAX_LENGTH), (new Rules(WorkModel::TITLE->value)) ->type(Type::STRING) ->min(3) ->max(parent::MYSQL_VARCHAR_MAX_LENGTH), (new Rules(WorkModel::SUMMARY->value)) ->type(Type::STRING) ->min(1) ->max(parent::MYSQL_TEXT_MAX_LENGTH), (new Rules(WorkModel::IS_LISTABLE->value)) ->type(Type::BOOLEAN) ->default(true), (new Rules(WorkModel::IS_READABLE->value)) ->type(Type::BOOLEAN) ->default(true), (new Rules(WorkModel::DATE_MODIFIED->value)) ->type(Type::NUMBER) ->min(1) ->max(parent::MYSQL_INT_MAX_LENGHT), (new Rules(WorkModel::DATE_CREATED->value)) ->type(Type::NUMBER) ->min(1) ->max(parent::MYSQL_INT_MAX_LENGHT) ]); parent::__construct($this->ruleset); } public function main(): Response { $response = $this->db->for(WorkModel::TABLE) ->where($_GET) ->select([ WorkModel::ID->value, WorkModel::TITLE->value, WorkModel::SUMMARY->value, WorkModel::IS_LISTABLE->value, WorkModel::IS_READABLE->value, WorkModel::DATE_MODIFIED->value, WorkModel::DATE_CREATED->value ]); return $response->num_rows > 0 ? new Response($response->fetch_all(MYSQLI_ASSOC)) : new Response([], 404); } }