1
1
Fork 0
mirror of https://code.mensbeam.com/MensBeam/Arsse.git synced 2024-12-22 13:12:41 +00:00

Adjust database portion of user property manager

This commit is contained in:
J. King 2020-12-05 22:13:48 -05:00
parent 978929aabd
commit fcf1260dab
5 changed files with 31 additions and 18 deletions

View file

@ -300,12 +300,17 @@ class Database {
} }
public function userPropertiesGet(string $user, bool $includeLarge = true): array { public function userPropertiesGet(string $user, bool $includeLarge = true): array {
$exclude = ["num", "admin"];
if (!$includeLarge) {
$exclude = array_merge($exclude, User::PROPERTIES_LARGE);
}
[$inClause, $inTypes, $inValues] = $this->generateIn($exclude, "str");
$meta = $this->db->prepareArray( $meta = $this->db->prepareArray(
"SELECT \"key\", value from arsse_user_meta where owner = ? and \"key\" not in ('num', 'admin') "SELECT \"key\", value from arsse_user_meta where owner = ? and \"key\" not in ($inClause)
union all select 'num', num from arsse_users where id = ? union all select 'num', num from arsse_users where id = ?
union all select 'admin', admin from arsse_users where id = ?", union all select 'admin', admin from arsse_users where id = ?",
["str", "str", "str"] ["str", $inTypes, "str", "str"]
)->run($user)->getRow(); )->run($user, $inValues, $user, $user)->getAll();
if (!$meta) { if (!$meta) {
throw new User\ExceptionConflict("doesNotExist", ["action" => __FUNCTION__, "user" => $user]); throw new User\ExceptionConflict("doesNotExist", ["action" => __FUNCTION__, "user" => $user]);
} }
@ -322,7 +327,7 @@ class Database {
$insert = ["INSERT INTO arsse_user_meta values(?, ?, ?)", "str", "strict str", "str"]; $insert = ["INSERT INTO arsse_user_meta values(?, ?, ?)", "str", "strict str", "str"];
foreach ($data as $k => $v) { foreach ($data as $k => $v) {
if ($k === "admin") { if ($k === "admin") {
$this->db->prepare("UPDATE arsse_users SET admin = ? where user = ?", "bool", "str")->run($v, $user); $this->db->prepare("UPDATE arsse_users SET admin = ? where id = ?", "bool", "str")->run($v, $user);
} elseif ($k === "num") { } elseif ($k === "num") {
continue; continue;
} else { } else {

View file

@ -26,6 +26,7 @@ class User {
'stylesheet' => V::T_STRING, 'stylesheet' => V::T_STRING,
'reading_time' => V::T_BOOL, 'reading_time' => V::T_BOOL,
]; ];
public const PROPERTIES_LARGE = ["stylesheet"];
public $id = null; public $id = null;

View file

@ -71,7 +71,7 @@ class Driver implements \JKingWeb\Arsse\User\Driver {
return Arsse::$db->userExists($user); return Arsse::$db->userExists($user);
} }
public function userPropertiesGet(string $user): array { public function userPropertiesGet(string $user, bool $includeLarge = true): array {
// do nothing: the internal database will retrieve everything for us // do nothing: the internal database will retrieve everything for us
if (!$this->userExists($user)) { if (!$this->userExists($user)) {
throw new ExceptionConflict("doesNotExist", ['action' => "userPasswordUnset", 'user' => $user]); throw new ExceptionConflict("doesNotExist", ['action' => "userPasswordUnset", 'user' => $user]);

View file

@ -13,7 +13,7 @@ create table arsse_users_new(
id text primary key not null collate nocase, -- user id id text primary key not null collate nocase, -- user id
password text, -- password, salted and hashed; if using external authentication this would be blank password text, -- password, salted and hashed; if using external authentication this would be blank
num integer unique not null, -- numeric identfier used by Miniflux num integer unique not null, -- numeric identfier used by Miniflux
admin boolean not null default 0, -- Whether the user is an administrator admin boolean not null default 0 -- Whether the user is an administrator
) without rowid; ) without rowid;
create temp table arsse_users_existing( create temp table arsse_users_existing(
id text not null, id text not null,

View file

@ -33,10 +33,11 @@ trait SeriesUser {
'rows' => [ 'rows' => [
["admin@example.net", "lang", "en"], ["admin@example.net", "lang", "en"],
["admin@example.net", "tz", "America/Toronto"], ["admin@example.net", "tz", "America/Toronto"],
["admin@example.net", "sort", "desc"], ["admin@example.net", "sort_asc", "0"],
["jane.doe@example.com", "lang", "fr"], ["jane.doe@example.com", "lang", "fr"],
["jane.doe@example.com", "tz", "Asia/Kuala_Lumpur"], ["jane.doe@example.com", "tz", "Asia/Kuala_Lumpur"],
["jane.doe@example.com", "sort", "asc"], ["jane.doe@example.com", "sort_asc", "1"],
["john.doe@example.com", "stylesheet", "body {background:lightgray}"],
], ],
], ],
]; ];
@ -118,15 +119,18 @@ trait SeriesUser {
} }
/** @dataProvider provideMetaData */ /** @dataProvider provideMetaData */
public function testGetMetadata(string $user, array $exp): void { public function testGetMetadata(string $user, bool $includeLarge, array $exp): void {
$this->assertSame($exp, Arsse::$db->userPropertiesGet($user)); $this->assertSame($exp, Arsse::$db->userPropertiesGet($user, $includeLarge));
} }
public function provideMetadata(): iterable { public function provideMetadata(): iterable {
return [ return [
["admin@example.net", ['num' => 1, 'admin' => true, 'lang' => "en", 'tz' => "America/Toronto", 'sort_asc' => false]], ["admin@example.net", true, ['lang' => "en", 'sort_asc' => "0", 'tz' => "America/Toronto", 'num' => 1, 'admin' => '1']],
["jane.doe@example.com", ['num' => 2, 'admin' => false, 'lang' => "fr", 'tz' => "Asia/Kuala_Lumpur", 'sort_asc' => true]], ["jane.doe@example.com", true, ['lang' => "fr", 'sort_asc' => "1", 'tz' => "Asia/Kuala_Lumpur", 'num' => 2, 'admin' => '0']],
["john.doe@example.com", ['num' => 3, 'admin' => false, 'lang' => null, 'tz' => "Etc/UTC", 'sort_asc' => false]], ["john.doe@example.com", true, ['stylesheet' => "body {background:lightgray}", 'num' => 3, 'admin' => '0']],
["admin@example.net", false, ['lang' => "en", 'sort_asc' => "0", 'tz' => "America/Toronto", 'num' => 1, 'admin' => '1']],
["jane.doe@example.com", false, ['lang' => "fr", 'sort_asc' => "1", 'tz' => "Asia/Kuala_Lumpur", 'num' => 2, 'admin' => '0']],
["john.doe@example.com", false, ['num' => 3, 'admin' => '0']],
]; ];
} }
@ -143,18 +147,21 @@ trait SeriesUser {
'sort_asc' => true, 'sort_asc' => true,
]; ];
$this->assertTrue(Arsse::$db->userPropertiesSet("john.doe@example.com", $in)); $this->assertTrue(Arsse::$db->userPropertiesSet("john.doe@example.com", $in));
$state = $this->primeExpectations($this->data, ['arsse_users' => ['id', 'num', 'admin', 'lang', 'tz', 'sort_asc']]); $state = $this->primeExpectations($this->data, ['arsse_users' => ['id', 'num', 'admin'], 'arsse_user_meta' => ["owner", "key", "value"]]);
$state['arsse_users']['rows'][2] = ["john.doe@example.com", 3, 1, "en-ca", "Atlantic/Reykjavik", 1]; $state['arsse_users']['rows'][2][2] = 1;
$state['arsse_user_meta']['rows'][] = ["john.doe@example.com", "lang", "en-ca"];
$state['arsse_user_meta']['rows'][] = ["john.doe@example.com", "tz", "Atlantic/Reykjavik"];
$state['arsse_user_meta']['rows'][] = ["john.doe@example.com", "sort_asc", "1"];
$this->compareExpectations(static::$drv, $state); $this->compareExpectations(static::$drv, $state);
} }
public function testSetNoMetadata(): void { public function testSetNoMetadata(): void {
$in = [ $in = [
'num' => 2112, 'num' => 2112,
'blah' => "bloo", 'stylesheet' => "body {background:lightgray}",
]; ];
$this->assertFalse(Arsse::$db->userPropertiesSet("john.doe@example.com", $in)); $this->assertTrue(Arsse::$db->userPropertiesSet("john.doe@example.com", $in));
$state = $this->primeExpectations($this->data, ['arsse_users' => ['id', 'num', 'admin', 'lang', 'tz', 'sort_asc']]); $state = $this->primeExpectations($this->data, ['arsse_users' => ['id', 'num', 'admin'], 'arsse_user_meta' => ["owner", "key", "value"]]);
$this->compareExpectations(static::$drv, $state); $this->compareExpectations(static::$drv, $state);
} }