Fix
This commit is contained in:
@ -17,7 +17,8 @@ class Application extends App {
|
||||
return new SettingsController(
|
||||
$c->query('OCP\IRequest'),
|
||||
$c->query('OCP\IUserSession'),
|
||||
$c->query('OCA\Deckflow\Service\WorkflowService')
|
||||
$c->query('OCA\Deckflow\Service\WorkflowService'),
|
||||
$c->query('OCP\IDBConnection')
|
||||
);
|
||||
});
|
||||
|
||||
|
21
lib/AppInfo/DB/migration.php
Normal file
21
lib/AppInfo/DB/migration.php
Normal 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
|
||||
)");
|
||||
}
|
||||
}
|
@ -4,32 +4,51 @@ namespace OCA\Deckflow\Service;
|
||||
use OCP\IUserSession;
|
||||
use OCA\Deck\Service\DeckService;
|
||||
use OCP\ILogger;
|
||||
use OCA\Deckflow\DB\Migration;
|
||||
|
||||
class WorkflowService {
|
||||
|
||||
private $userSession;
|
||||
private $deckService;
|
||||
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->deckService = $deckService;
|
||||
$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() {
|
||||
$user = $this->userSession->getUser();
|
||||
if ($user === null) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Hole alle Decks für den User
|
||||
$decks = $this->deckService->getDecksByUser($user->getUID());
|
||||
$workflows = $this->getUserWorkflows();
|
||||
|
||||
foreach ($decks as $deck) {
|
||||
// Hole die Quell- und Zielstapel
|
||||
$sourceStack = $deck->getStackById('sourceStackId'); // Ersetze durch die Konfiguration
|
||||
$targetStack = $deck->getStackById('targetStackId'); // Ersetze durch die Konfiguration
|
||||
foreach ($workflows as $workflow) {
|
||||
// Hole das Deck und die Stacks aus der Konfiguration
|
||||
$deck = $this->deckService->getDeckById($workflow['deck_id']);
|
||||
$sourceStack = $deck->getStackById($workflow['source_stack_id']);
|
||||
$targetStack = $deck->getStackById($workflow['target_stack_id']);
|
||||
|
||||
// Überprüfe alle Karten im Quellstapel auf Überfälligkeit
|
||||
foreach ($sourceStack->getCards() as $card) {
|
||||
|
Reference in New Issue
Block a user