Compare commits

...

10 Commits

Author SHA1 Message Date
Christian McHugh ccc0be1432
Merge e388b708fe into 38f560b73a 2023-12-07 18:31:41 +00:00
Christian McHugh e388b708fe Require user when querying album name from DB
Signed-off-by: Christian McHugh <mchugh19@hotmail.com>
2023-12-07 18:31:29 +00:00
Christian McHugh 7b9c80e63e lint fixes
Signed-off-by: Christian McHugh <mchugh19@hotmail.com>
2023-12-06 19:15:58 +00:00
Christian McHugh c6c7651e59 improve wording slightly
Signed-off-by: Christian McHugh <mchugh19@hotmail.com>
2023-12-06 19:15:58 +00:00
Christian McHugh 1c698e1ca0 Add get album by name and simplify command logic
Signed-off-by: Christian McHugh <mchugh19@hotmail.com>
2023-12-06 19:15:58 +00:00
Christian McHugh ac181bcba5 Apply suggestions from code review
Co-authored-by: Louis <louis@chmn.me>
Signed-off-by: Christian McHugh <mchugh19@hotmail.com>
2023-12-06 19:15:58 +00:00
Christian McHugh 27c29dc217 remove empty space
Signed-off-by: Christian McHugh <mchugh19@hotmail.com>
2023-12-06 19:15:58 +00:00
Christian McHugh 34ad72fca5 Add album creation to occ
Signed-off-by: Christian McHugh <mchugh19@hotmail.com>
2023-12-06 19:15:58 +00:00
Christian McHugh 1760052822 uppercase
Signed-off-by: Christian McHugh <mchugh19@hotmail.com>
2023-12-06 19:15:58 +00:00
Christian McHugh b8bb2e76a0 Add OCC comand add-photo-to-album
Signed-off-by: Christian McHugh <mchugh19@hotmail.com>
2023-12-06 19:15:58 +00:00
4 changed files with 211 additions and 0 deletions

View File

@ -32,6 +32,8 @@
<commands>
<command>OCA\Photos\Command\UpdateReverseGeocodingFilesCommand</command>
<command>OCA\Photos\Command\AlbumAddCommand</command>
<command>OCA\Photos\Command\AlbumCreateCommand</command>
</commands>
<sabre>

View File

@ -110,6 +110,25 @@ class AlbumMapper {
return new AlbumInfo((int)$row['album_id'], $userId, $row['name'], $row['location'], (int)$row['created'], (int)$row['last_added_photo']);
}, $rows);
}
/**
* @param string $albumName
* @param string $userName
* @return AlbumInfo
*/
public function getByName(string $albumName, string $userName): ?AlbumInfo {
$query = $this->connection->getQueryBuilder();
$query->select("album_id", "location", "created", "last_added_photo")
->from("photos_albums")
->where($query->expr()->eq('name', $query->createNamedParameter($albumName)))
->andWhere($query->expr()->eq('user', $query->createNamedParameter($userName)));
$row = $query->executeQuery()->fetch();
if ($row) {
return new AlbumInfo((int)$row['album_id'], $userName, $albumName, $row['location'], (int)$row['created'], (int)$row['last_added_photo']);
} else {
return null;
}
}
/**
* @param int $fileId

View File

@ -0,0 +1,101 @@
<?php
declare(strict_types=1);
/**
* @copyright Copyright (c) 2022 Christian McHugh <mchugh19@hotmail.com>
*
* @author Christian McHugh <mchugh19@hotmail.com>
*
* @license AGPL-3.0-or-later
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
namespace OCA\Photos\Command;
use OCA\Photos\Album\AlbumMapper;
use OCP\Files\IRootFolder;
use OCP\IUserManager;
use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;
class AlbumAddCommand extends Command {
private IRootFolder $rootFolder;
private IUserManager $userManager;
private AlbumMapper $albumMapper;
public function __construct(
AlbumMapper $albumMapper,
IRootFolder $rootFolder,
IUserManager $userManager,
) {
$this->rootFolder = $rootFolder;
$this->userManager = $userManager;
$this->albumMapper = $albumMapper;
parent::__construct();
}
/**
* Configure the command
*/
protected function configure(): void {
$this->setName('photos:albums:add')
->setDescription('Add specified photo to album')
->addArgument('user', InputArgument::REQUIRED, 'User owning the album')
->addArgument('album', InputArgument::REQUIRED, 'Album name')
->addArgument('file', InputArgument::REQUIRED,
'Path of file to add to the album. It must already be scanned and available in NextCloud. Example: Photos/picture1.jpg');
}
/**
* Execute the command
*/
protected function execute(InputInterface $input, OutputInterface $output): int {
$userString = $input->getArgument('user');
$albumString = $input->getArgument('album');
$filePath = $input->getArgument('file');
$user = $this->userManager->get($userString);
if ($user === null) {
throw new \Exception("User $userString was not found");
}
$userID = $user->getUID();
try {
$pictureFileID = $this->rootFolder->getUserFolder($userID)->get($filePath)->getId();
} catch (\Exception $ex) {
$output->writeln('<error>Invalid file path</error>');
$output->writeln($ex->getMessage());
return 1;
}
$album = $this->albumMapper->getByName($albumString, $userString);
if (!$album) {
throw new \Exception("Album $albumString was not found");
}
try {
$this->albumMapper->addFile($album->getId(), $pictureFileID, $userID);
} catch (\Exception $ex) {
$output->writeln("<error>Problem adding $filePath to $albumString</error>");
$output->writeln($ex->getMessage());
return 1;
}
return 0;
}
}

View File

@ -0,0 +1,89 @@
<?php
declare(strict_types=1);
/**
* @copyright Copyright (c) 2022 Christian McHugh <mchugh19@hotmail.com>
*
* @author Christian McHugh <mchugh19@hotmail.com>
*
* @license AGPL-3.0-or-later
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
namespace OCA\Photos\Command;
use OCA\Photos\Album\AlbumMapper;
use OCP\IUserManager;
use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface;
class AlbumCreateCommand extends Command {
private IUserManager $userManager;
private AlbumMapper $albumMapper;
public function __construct(
AlbumMapper $albumMapper,
IUserManager $userManager,
) {
$this->userManager = $userManager;
$this->albumMapper = $albumMapper;
parent::__construct();
}
/**
* Configure the command
*/
protected function configure(): void {
$this->setName('photos:albums:create')
->setDescription('Create a new album for a user')
->addArgument('user', InputArgument::REQUIRED, 'User to own album')
->addArgument('album', InputArgument::REQUIRED, 'Album name')
->addOption('location', 'l', InputOption::VALUE_REQUIRED, 'Set album location (optional)', "");
}
/**
* Execute the command
*/
protected function execute(InputInterface $input, OutputInterface $output): int {
$userString = $input->getArgument('user');
$albumString = $input->getArgument('album');
$location = $input->getOption('location');
$user = $this->userManager->get($userString);
if ($user === null) {
throw new \Exception("User $userString was not found");
}
$userID = $user->getUID();
$album = $this->albumMapper->getByName($albumString, $userString);
if ($album) {
throw new \Exception("Album $albumString already exists and cannot be created.");
}
try {
$this->albumMapper->create($userID, $albumString, $location);
} catch (\Exception $ex) {
$output->writeln('<error>Problem creating album</error>');
$output->writeln($ex->getMessage());
return 1;
}
return 0;
}
}