@@ 23-44 (lines=22) @@ | ||
20 | * @param string $coupons_table |
|
21 | * @param string $php_class |
|
22 | */ |
|
23 | public function __construct( \PDO $pdo, $coupons_table, $php_class = null) |
|
24 | { |
|
25 | $this->php_class = $php_class ?: Coupon::class; |
|
26 | ||
27 | if (!is_subclass_of($this->php_class, CouponInterface::class )) |
|
28 | throw new \InvalidArgumentException("Class name or instance of CouponInterface expected."); |
|
29 | ||
30 | $sql = "SELECT |
|
31 | -- id field twice here due to FETCH_UNIQUE |
|
32 | id, |
|
33 | id, |
|
34 | code, |
|
35 | coupon_sheet_id |
|
36 | ||
37 | FROM `{$coupons_table}` |
|
38 | ||
39 | WHERE coupon_sheet_id = :sheet_id"; |
|
40 | ||
41 | $this->stmt = $pdo->prepare( $sql ); |
|
42 | $this->stmt->setFetchMode( \PDO::FETCH_CLASS, $this->php_class ); |
|
43 | ||
44 | } |
|
45 | ||
46 | /** |
|
47 | * @param int|CouponSheetInterface $sheet_id |
@@ 23-51 (lines=29) @@ | ||
20 | * @param string $coupons_table |
|
21 | * @param string $php_class |
|
22 | */ |
|
23 | public function __construct( \PDO $pdo, $sheets_table, $coupons_table, $php_class = null) |
|
24 | { |
|
25 | $this->php_class = $php_class ?: CouponSheet::class; |
|
26 | ||
27 | if (!is_subclass_of($this->php_class, CouponSheetInterface::class )) |
|
28 | throw new \InvalidArgumentException("Class name or instance of CouponSheetInterface expected."); |
|
29 | ||
30 | $sql = "SELECT |
|
31 | Sheets.id, |
|
32 | Sheets.slug, |
|
33 | Sheets.name, |
|
34 | Sheets.quantity, |
|
35 | Sheets.valid_from, |
|
36 | Sheets.valid_until, |
|
37 | GROUP_CONCAT(Coupons.code) AS coupons |
|
38 | ||
39 | FROM `{$sheets_table}` Sheets |
|
40 | ||
41 | RIGHT JOIN `{$coupons_table}` Coupons |
|
42 | ON Coupons.coupon_sheet_id = Sheets.id |
|
43 | ||
44 | WHERE Sheets.id = :id |
|
45 | OR Sheets.slug = :id |
|
46 | LIMIT 1"; |
|
47 | ||
48 | $this->stmt = $pdo->prepare( $sql ); |
|
49 | $this->stmt->setFetchMode( \PDO::FETCH_CLASS, $this->php_class ); |
|
50 | ||
51 | } |
|
52 | ||
53 | /** |
|
54 | * @param string|int $id |