Fix
This commit is contained in:
0
appinfo/controller/SettingsController.php
Normal file
0
appinfo/controller/SettingsController.php
Normal file
@ -11,4 +11,4 @@
|
|||||||
<app>workflow</app>
|
<app>workflow</app>
|
||||||
<app>deck</app>
|
<app>deck</app>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
</ocl:information>
|
</ocl:information>
|
@ -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')
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
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 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) {
|
||||||
|
Reference in New Issue
Block a user