This commit is contained in:
Patrick Niebeling
2025-03-12 11:00:29 +01:00
parent 054cdb70c8
commit 4e4ae2b372
5 changed files with 50 additions and 9 deletions

View File

@ -11,4 +11,4 @@
<app>workflow</app> <app>workflow</app>
<app>deck</app> <app>deck</app>
</dependencies> </dependencies>
</ocl:information> </ocl:information>

View File

@ -17,7 +17,8 @@ class Application extends App {
return new SettingsController( return new SettingsController(
$c->query('OCP\IRequest'), $c->query('OCP\IRequest'),
$c->query('OCP\IUserSession'), $c->query('OCP\IUserSession'),
$c->query('OCA\Deckflow\Service\WorkflowService') $c->query('OCA\Deckflow\Service\WorkflowService'),
$c->query('OCP\IDBConnection')
); );
}); });

View File

@ -0,0 +1,21 @@
<?php
namespace OCA\Deckflow\DB;
use OCP\DB\ISQLiteConnection;
class Migration {
/**
* Erstellt die Tabelle für Workflow-Konfigurationen
* @param ISQLiteConnection $connection
*/
public function createWorkflowConfigTable(ISQLiteConnection $connection) {
$connection->query("CREATE TABLE IF NOT EXISTS *PREFIX*deckflow_workflows (
id INTEGER PRIMARY KEY AUTOINCREMENT,
user_id TEXT NOT NULL,
deck_id TEXT NOT NULL,
source_stack_id TEXT NOT NULL,
target_stack_id TEXT NOT NULL
)");
}
}

View File

@ -4,32 +4,51 @@ namespace OCA\Deckflow\Service;
use OCP\IUserSession; use OCP\IUserSession;
use OCA\Deck\Service\DeckService; use OCA\Deck\Service\DeckService;
use OCP\ILogger; use OCP\ILogger;
use OCA\Deckflow\DB\Migration;
class WorkflowService { class WorkflowService {
private $userSession; private $userSession;
private $deckService; private $deckService;
private $logger; private $logger;
private $db;
public function __construct(IUserSession $userSession, DeckService $deckService, ILogger $logger) { public function __construct(IUserSession $userSession, DeckService $deckService, ILogger $logger, \OCP\IDBConnection $db) {
$this->userSession = $userSession; $this->userSession = $userSession;
$this->deckService = $deckService; $this->deckService = $deckService;
$this->logger = $logger; $this->logger = $logger;
$this->db = $db;
} }
/**
* Holt alle Workflows des aktuellen Benutzers
* @return array
*/
private function getUserWorkflows() {
$user = $this->userSession->getUser();
$userId = $user ? $user->getUID() : null;
// Hole alle Workflow-Konfigurationen des Benutzers aus der DB
$result = $this->db->executeQuery("SELECT * FROM *PREFIX*deckflow_workflows WHERE user_id = ?", [$userId]);
return $result->fetchAll();
}
/**
* Verschiebt überfällige Karten für alle Workflows
*/
public function moveOverdueCards() { public function moveOverdueCards() {
$user = $this->userSession->getUser(); $user = $this->userSession->getUser();
if ($user === null) { if ($user === null) {
return; return;
} }
// Hole alle Decks für den User $workflows = $this->getUserWorkflows();
$decks = $this->deckService->getDecksByUser($user->getUID());
foreach ($decks as $deck) { foreach ($workflows as $workflow) {
// Hole die Quell- und Zielstapel // Hole das Deck und die Stacks aus der Konfiguration
$sourceStack = $deck->getStackById('sourceStackId'); // Ersetze durch die Konfiguration $deck = $this->deckService->getDeckById($workflow['deck_id']);
$targetStack = $deck->getStackById('targetStackId'); // Ersetze durch die Konfiguration $sourceStack = $deck->getStackById($workflow['source_stack_id']);
$targetStack = $deck->getStackById($workflow['target_stack_id']);
// Überprüfe alle Karten im Quellstapel auf Überfälligkeit // Überprüfe alle Karten im Quellstapel auf Überfälligkeit
foreach ($sourceStack->getCards() as $card) { foreach ($sourceStack->getCards() as $card) {