mirror of
https://code.mensbeam.com/MensBeam/Arsse.git
synced 2025-01-08 17:02:41 +00:00
Impelemented Result->getAll()
- Fixes #45 - Renamed getSingle to getValue to avoid possible confusion - Added test to ensure getValue() always returns the first datum of each row rather than going column-to-column
This commit is contained in:
parent
1dab15c20e
commit
37dad63dee
4 changed files with 33 additions and 13 deletions
|
@ -173,7 +173,7 @@ class Database {
|
||||||
|
|
||||||
public function userExists(string $user): bool {
|
public function userExists(string $user): bool {
|
||||||
if(!$this->data->user->authorize($user, __FUNCTION__)) throw new User\ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
if(!$this->data->user->authorize($user, __FUNCTION__)) throw new User\ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
||||||
return (bool) $this->db->prepare("SELECT count(*) from newssync_users where id is ?", "str")->run($user)->getSingle();
|
return (bool) $this->db->prepare("SELECT count(*) from newssync_users where id is ?", "str")->run($user)->getValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function userAdd(string $user, string $password = null): string {
|
public function userAdd(string $user, string $password = null): string {
|
||||||
|
@ -212,7 +212,7 @@ class Database {
|
||||||
public function userPasswordGet(string $user): string {
|
public function userPasswordGet(string $user): string {
|
||||||
if(!$this->data->user->authorize($user, __FUNCTION__)) throw new User\ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
if(!$this->data->user->authorize($user, __FUNCTION__)) throw new User\ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
||||||
if(!$this->userExists($user)) throw new User\Exception("doesNotExist", ["action" => __FUNCTION__, "user" => $user]);
|
if(!$this->userExists($user)) throw new User\Exception("doesNotExist", ["action" => __FUNCTION__, "user" => $user]);
|
||||||
return (string) $this->db->prepare("SELECT password from newssync_users where id is ?", "str")->run($user)->getSingle();
|
return (string) $this->db->prepare("SELECT password from newssync_users where id is ?", "str")->run($user)->getValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function userPasswordSet(string $user, string $password = null): string {
|
public function userPasswordSet(string $user, string $password = null): string {
|
||||||
|
@ -249,7 +249,7 @@ class Database {
|
||||||
|
|
||||||
public function userRightsGet(string $user): int {
|
public function userRightsGet(string $user): int {
|
||||||
if(!$this->data->user->authorize($user, __FUNCTION__)) throw new User\ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
if(!$this->data->user->authorize($user, __FUNCTION__)) throw new User\ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
||||||
return (int) $this->db->prepare("SELECT rights from newssync_users where id is ?", "str")->run($user)->getSingle();
|
return (int) $this->db->prepare("SELECT rights from newssync_users where id is ?", "str")->run($user)->getValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function userRightsSet(string $user, int $rights): bool {
|
public function userRightsSet(string $user, int $rights): bool {
|
||||||
|
@ -273,7 +273,7 @@ class Database {
|
||||||
|
|
||||||
// If the feed doesn't already exist in the database then add it to the database after determining its validity with PicoFeed.
|
// If the feed doesn't already exist in the database then add it to the database after determining its validity with PicoFeed.
|
||||||
$qFeed = $this->db->prepare("SELECT id from newssync_feeds where url is ? and username is ? and password is ?", "str", "str", "str");
|
$qFeed = $this->db->prepare("SELECT id from newssync_feeds where url is ? and username is ? and password is ?", "str", "str", "str");
|
||||||
$feed = $qFeed->run($url, $fetchUser, $fetchPassword)->getSingle();
|
$feed = $qFeed->run($url, $fetchUser, $fetchPassword)->getValue();
|
||||||
if ($feed === null) {
|
if ($feed === null) {
|
||||||
try {
|
try {
|
||||||
$reader = new Reader;
|
$reader = new Reader;
|
||||||
|
@ -310,19 +310,19 @@ class Database {
|
||||||
// TODO: Populate newssync_articles with contents of what was obtained from PicoFeed.
|
// TODO: Populate newssync_articles with contents of what was obtained from PicoFeed.
|
||||||
|
|
||||||
// Get the ID for the feed that was just added.
|
// Get the ID for the feed that was just added.
|
||||||
$feedID = $qFeed->run($url, $fetchUser, $fetchPassword)->getSingle();
|
$feedID = $qFeed->run($url, $fetchUser, $fetchPassword)->getValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add the feed to the user's subscriptions.
|
// Add the feed to the user's subscriptions.
|
||||||
$this->db->prepare("INSERT INTO newssync_subscriptions(owner,feed) values(?,?)", "str", "int")->run($user, $feedID);
|
$this->db->prepare("INSERT INTO newssync_subscriptions(owner,feed) values(?,?)", "str", "int")->run($user, $feedID);
|
||||||
$sub = $this->db->prepare("SELECT id from newssync_subscriptions where owner is ? and feed is ?", "str", "int")->run($user, $feedID)->getSingle();
|
$sub = $this->db->prepare("SELECT id from newssync_subscriptions where owner is ? and feed is ?", "str", "int")->run($user, $feedID)->getValue();
|
||||||
$this->db->commit();
|
$this->db->commit();
|
||||||
return $sub;
|
return $sub;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function subscriptionRemove(int $id): bool {
|
public function subscriptionRemove(int $id): bool {
|
||||||
$this->db->begin();
|
$this->db->begin();
|
||||||
$user = $this->db->prepare("SELECT owner from newssync_subscriptions where id is ?", "int")->run($id)->getSingle();
|
$user = $this->db->prepare("SELECT owner from newssync_subscriptions where id is ?", "int")->run($id)->getValue();
|
||||||
if($user===null) return false;
|
if($user===null) return false;
|
||||||
if(!$this->data->user->authorize($user, __FUNCTION__)) throw new User\ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
if(!$this->data->user->authorize($user, __FUNCTION__)) throw new User\ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
||||||
return (bool) $this->db->prepare("DELETE from newssync_subscriptions where id is ?", "int")->run($id)->changes();
|
return (bool) $this->db->prepare("DELETE from newssync_subscriptions where id is ?", "int")->run($id)->changes();
|
||||||
|
|
|
@ -10,6 +10,7 @@ interface Result extends \Iterator {
|
||||||
function valid();
|
function valid();
|
||||||
|
|
||||||
function get();
|
function get();
|
||||||
function getSingle();
|
function getAll();
|
||||||
|
function getValue();
|
||||||
function changes();
|
function changes();
|
||||||
}
|
}
|
|
@ -11,7 +11,7 @@ class ResultSQLite3 implements Result {
|
||||||
|
|
||||||
// actual public methods
|
// actual public methods
|
||||||
|
|
||||||
public function getSingle() {
|
public function getValue() {
|
||||||
$this->next();
|
$this->next();
|
||||||
if($this->valid()) {
|
if($this->valid()) {
|
||||||
$keys = array_keys($this->cur);
|
$keys = array_keys($this->cur);
|
||||||
|
@ -25,6 +25,15 @@ class ResultSQLite3 implements Result {
|
||||||
return ($this->valid() ? $this->cur : null);
|
return ($this->valid() ? $this->cur : null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getAll() {
|
||||||
|
$out = [];
|
||||||
|
foreach($this as $row) {
|
||||||
|
$out [] = $row;
|
||||||
|
}
|
||||||
|
if(sizeof($out) < 1) return null;
|
||||||
|
return $out;
|
||||||
|
}
|
||||||
|
|
||||||
public function changes() {
|
public function changes() {
|
||||||
return $this->rows;
|
return $this->rows;
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,10 +56,19 @@ class TestDbResultSQLite3 extends \PHPUnit\Framework\TestCase {
|
||||||
function testGetSingleValues() {
|
function testGetSingleValues() {
|
||||||
$set = $this->c->query("SELECT 1867 as year union select 1970 as year union select 2112 as year");
|
$set = $this->c->query("SELECT 1867 as year union select 1970 as year union select 2112 as year");
|
||||||
$test = new Db\ResultSQLite3($set);
|
$test = new Db\ResultSQLite3($set);
|
||||||
$this->assertEquals(1867, $test->getSingle());
|
$this->assertEquals(1867, $test->getValue());
|
||||||
$this->assertEquals(1970, $test->getSingle());
|
$this->assertEquals(1970, $test->getValue());
|
||||||
$this->assertEquals(2112, $test->getSingle());
|
$this->assertEquals(2112, $test->getValue());
|
||||||
$this->assertSame(null, $test->getSingle());
|
$this->assertSame(null, $test->getValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
function testGetFirstValuesOnly() {
|
||||||
|
$set = $this->c->query("SELECT 1867 as year, 19 as century union select 1970 as year, 20 as century union select 2112 as year, 22 as century");
|
||||||
|
$test = new Db\ResultSQLite3($set);
|
||||||
|
$this->assertEquals(1867, $test->getValue());
|
||||||
|
$this->assertEquals(1970, $test->getValue());
|
||||||
|
$this->assertEquals(2112, $test->getValue());
|
||||||
|
$this->assertSame(null, $test->getValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
function testGetRows() {
|
function testGetRows() {
|
||||||
|
@ -72,5 +81,6 @@ class TestDbResultSQLite3 extends \PHPUnit\Framework\TestCase {
|
||||||
$this->assertEquals($rows[0], $test->get());
|
$this->assertEquals($rows[0], $test->get());
|
||||||
$this->assertEquals($rows[1], $test->get());
|
$this->assertEquals($rows[1], $test->get());
|
||||||
$this->assertSame(null, $test->get());
|
$this->assertSame(null, $test->get());
|
||||||
|
$this->assertEquals($rows, $test->getAll());
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in a new issue