aboutsummaryrefslogtreecommitdiffstats
path: root/public/catalog/model/account/download.php
diff options
context:
space:
mode:
Diffstat (limited to 'public/catalog/model/account/download.php')
-rw-r--r--public/catalog/model/account/download.php64
1 files changed, 64 insertions, 0 deletions
diff --git a/public/catalog/model/account/download.php b/public/catalog/model/account/download.php
new file mode 100644
index 0000000..a58d89c
--- /dev/null
+++ b/public/catalog/model/account/download.php
@@ -0,0 +1,64 @@
+<?php
+class ModelAccountDownload extends Model {
+ public function getDownload($download_id) {
+ $implode = array();
+
+ $order_statuses = $this->config->get('config_complete_status');
+
+ foreach ($order_statuses as $order_status_id) {
+ $implode[] = "o.order_status_id = '" . (int)$order_status_id . "'";
+ }
+
+ if ($implode) {
+ $query = $this->db->query("SELECT d.filename, d.mask FROM `" . DB_PREFIX . "order` o LEFT JOIN " . DB_PREFIX . "order_product op ON (o.order_id = op.order_id) LEFT JOIN " . DB_PREFIX . "product_to_download p2d ON (op.product_id = p2d.product_id) LEFT JOIN " . DB_PREFIX . "download d ON (p2d.download_id = d.download_id) WHERE o.customer_id = '" . (int)$this->customer->getId() . "' AND (" . implode(" OR ", $implode) . ") AND d.download_id = '" . (int)$download_id . "'");
+
+ return $query->row;
+ } else {
+ return;
+ }
+ }
+
+ public function getDownloads($start = 0, $limit = 20) {
+ if ($start < 0) {
+ $start = 0;
+ }
+
+ if ($limit < 1) {
+ $limit = 20;
+ }
+
+ $implode = array();
+
+ $order_statuses = $this->config->get('config_complete_status');
+
+ foreach ($order_statuses as $order_status_id) {
+ $implode[] = "o.order_status_id = '" . (int)$order_status_id . "'";
+ }
+
+ if ($implode) {
+ $query = $this->db->query("SELECT DISTINCT d.download_id, o.order_id, o.date_added, dd.name, d.filename FROM `" . DB_PREFIX . "order` o LEFT JOIN " . DB_PREFIX . "order_product op ON (o.order_id = op.order_id) LEFT JOIN " . DB_PREFIX . "product_to_download p2d ON (op.product_id = p2d.product_id) LEFT JOIN " . DB_PREFIX . "download d ON (p2d.download_id = d.download_id) LEFT JOIN " . DB_PREFIX . "download_description dd ON (d.download_id = dd.download_id) WHERE o.customer_id = '" . (int)$this->customer->getId() . "' AND dd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND (" . implode(" OR ", $implode) . ") ORDER BY o.date_added DESC LIMIT " . (int)$start . "," . (int)$limit);
+
+ return $query->rows;
+ } else {
+ return array();
+ }
+ }
+
+ public function getTotalDownloads() {
+ $implode = array();
+
+ $order_statuses = $this->config->get('config_complete_status');
+
+ foreach ($order_statuses as $order_status_id) {
+ $implode[] = "o.order_status_id = '" . (int)$order_status_id . "'";
+ }
+
+ if ($implode) {
+ $query = $this->db->query("SELECT COUNT(*) AS total FROM `" . DB_PREFIX . "order` o LEFT JOIN " . DB_PREFIX . "order_product op ON (o.order_id = op.order_id) LEFT JOIN " . DB_PREFIX . "product_to_download p2d ON (op.product_id = p2d.product_id) WHERE o.customer_id = '" . (int)$this->customer->getId() . "' AND (" . implode(" OR ", $implode) . ")");
+
+ return $query->row['total'];
+ } else {
+ return 0;
+ }
+ }
+} \ No newline at end of file