summaryrefslogtreecommitdiff
path: root/app/Controller
diff options
context:
space:
mode:
Diffstat (limited to 'app/Controller')
-rw-r--r--app/Controller/TaskImport.php73
-rw-r--r--app/Controller/UserImport.php67
2 files changed, 140 insertions, 0 deletions
diff --git a/app/Controller/TaskImport.php b/app/Controller/TaskImport.php
new file mode 100644
index 00000000..0343b1dc
--- /dev/null
+++ b/app/Controller/TaskImport.php
@@ -0,0 +1,73 @@
+<?php
+
+namespace Controller;
+
+use Core\Csv;
+
+/**
+ * Task Import controller
+ *
+ * @package controller
+ * @author Frederic Guillot
+ */
+class TaskImport extends Base
+{
+ /**
+ * Upload the file and ask settings
+ *
+ */
+ public function step1(array $values = array(), array $errors = array())
+ {
+ $project = $this->getProject();
+
+ $this->response->html($this->projectLayout('task_import/step1', array(
+ 'project' => $project,
+ 'values' => $values,
+ 'errors' => $errors,
+ 'max_size' => ini_get('upload_max_filesize'),
+ 'delimiters' => Csv::getDelimiters(),
+ 'enclosures' => Csv::getEnclosures(),
+ 'title' => t('Import tasks from CSV file'),
+ )));
+ }
+
+ /**
+ * Process CSV file
+ *
+ */
+ public function step2()
+ {
+ $project = $this->getProject();
+ $values = $this->request->getValues();
+ $filename = $this->request->getFilePath('file');
+
+ if (! file_exists($filename)) {
+ $this->step1($values, array('file' => array(t('Unable to read your file'))));
+ }
+
+ $this->taskImport->projectId = $project['id'];
+
+ $csv = new Csv($values['delimiter'], $values['enclosure']);
+ $csv->setColumnMapping($this->taskImport->getColumnMapping());
+ $csv->read($filename, array($this->taskImport, 'import'));
+
+ if ($this->taskImport->counter > 0) {
+ $this->session->flash(t('%d task(s) have been imported successfully.', $this->taskImport->counter));
+ }
+ else {
+ $this->session->flashError(t('Nothing have been imported!'));
+ }
+
+ $this->response->redirect($this->helper->url->to('taskImport', 'step1', array('project_id' => $project['id'])));
+ }
+
+ /**
+ * Generate template
+ *
+ */
+ public function template()
+ {
+ $this->response->forceDownload('tasks.csv');
+ $this->response->csv(array($this->taskImport->getColumnMapping()));
+ }
+}
diff --git a/app/Controller/UserImport.php b/app/Controller/UserImport.php
new file mode 100644
index 00000000..9c27aa06
--- /dev/null
+++ b/app/Controller/UserImport.php
@@ -0,0 +1,67 @@
+<?php
+
+namespace Controller;
+
+use Core\Csv;
+
+/**
+ * User Import controller
+ *
+ * @package controller
+ * @author Frederic Guillot
+ */
+class UserImport extends Base
+{
+ /**
+ * Upload the file and ask settings
+ *
+ */
+ public function step1(array $values = array(), array $errors = array())
+ {
+ $this->response->html($this->template->layout('user_import/step1', array(
+ 'values' => $values,
+ 'errors' => $errors,
+ 'max_size' => ini_get('upload_max_filesize'),
+ 'delimiters' => Csv::getDelimiters(),
+ 'enclosures' => Csv::getEnclosures(),
+ 'title' => t('Import users from CSV file'),
+ )));
+ }
+
+ /**
+ * Process CSV file
+ *
+ */
+ public function step2()
+ {
+ $values = $this->request->getValues();
+ $filename = $this->request->getFilePath('file');
+
+ if (! file_exists($filename)) {
+ $this->step1($values, array('file' => array(t('Unable to read your file'))));
+ }
+
+ $csv = new Csv($values['delimiter'], $values['enclosure']);
+ $csv->setColumnMapping($this->userImport->getColumnMapping());
+ $csv->read($filename, array($this->userImport, 'import'));
+
+ if ($this->userImport->counter > 0) {
+ $this->session->flash(t('%d user(s) have been imported successfully.', $this->userImport->counter));
+ }
+ else {
+ $this->session->flashError(t('Nothing have been imported!'));
+ }
+
+ $this->response->redirect($this->helper->url->to('userImport', 'step1'));
+ }
+
+ /**
+ * Generate template
+ *
+ */
+ public function template()
+ {
+ $this->response->forceDownload('users.csv');
+ $this->response->csv(array($this->userImport->getColumnMapping()));
+ }
+}