mirror of
https://code.mensbeam.com/MensBeam/Arsse.git
synced 2025-01-08 17:02:41 +00:00
Adjust database portion of user property manager
This commit is contained in:
parent
978929aabd
commit
fcf1260dab
5 changed files with 31 additions and 18 deletions
|
@ -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 {
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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]);
|
||||||
|
|
|
@ -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,
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue