diff options
author | Marco Nassabain <marco.nassabain@hotmail.com> | 2021-03-18 22:29:13 +0100 |
---|---|---|
committer | Sean Molenaar <SMillerDev@users.noreply.github.com> | 2021-04-08 22:31:21 +0200 |
commit | 7306370ececd6ada186061af7deb9437d6182be6 (patch) | |
tree | a522220b7c5cc2e381dbc8ed6857723f661d641b /lib | |
parent | 8674d558fca1e90e7d7425e9d794b1cd01a87ad0 (diff) |
✨ Item: add sharer display name in findEntities
Signed-off-by: Marco Nassabain <marco.nassabain@hotmail.com>
Diffstat (limited to 'lib')
-rw-r--r-- | lib/Db/ItemMapperV2.php | 37 |
1 files changed, 36 insertions, 1 deletions
diff --git a/lib/Db/ItemMapperV2.php b/lib/Db/ItemMapperV2.php index 44d1740cd..c6c969e01 100644 --- a/lib/Db/ItemMapperV2.php +++ b/lib/Db/ItemMapperV2.php @@ -22,6 +22,7 @@ use OCP\AppFramework\Db\MultipleObjectsReturnedException; use OCP\DB\Exception as DBException; use OCP\DB\QueryBuilder\IQueryBuilder; use OCP\IDBConnection; +use OCP\IUserManager; /** * Class ItemMapper @@ -33,14 +34,48 @@ class ItemMapperV2 extends NewsMapperV2 const TABLE_NAME = 'news_items'; /** + * @var IUserManager + */ + private $userManager; + + /** * ItemMapper constructor. * * @param IDBConnection $db * @param Time $time */ - public function __construct(IDBConnection $db, Time $time) + public function __construct(IDBConnection $db, Time $time, IUserManager $userManager) { parent::__construct($db, $time, Item::class); + $this->userManager = $userManager; + } + + /** + * Override parent constructor to insert sharer display names for shared items + * + * @param IQueryBuilder $query + * @return Entity[] all fetched entities + */ + public function findEntities(IQueryBuilder $query): array { + $entities = parent::findEntities($query); + + foreach ($entities as $entity) { + $sharedBy = $entity->getSharedBy(); + $sharedByDisplayName = null; + + // Get user display name + if (!is_null($sharedBy)) { + $user = $this->userManager->get($sharedBy); + if (!is_null($user)) { + $sharedByDisplayName = $user->getDisplayName(); + } + } + + // Set sharer display name + $entity->setSharedByDisplayName($sharedByDisplayName); + } + + return $entities; } /** |