Fix_MySQL_No_Zero_Date.php 2.39 KB
Newer Older
Thomas Citharel's avatar
Thomas Citharel committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
<?php
/**
 * This software is governed by the CeCILL-B license. If a copy of this license
 * is not distributed with this file, you can obtain one at
 * http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.txt
 *
 * Authors of STUdS (initial project): Guilhem BORGHESI (borghesi@unistra.fr) and Raphaël DROZ
 * Authors of Framadate/OpenSondage: Framasoft (https://github.com/framasoft)
 *
 * =============================
 *
 * Ce logiciel est régi par la licence CeCILL-B. Si une copie de cette licence
 * ne se trouve pas avec ce fichier vous pouvez l'obtenir sur
 * http://www.cecill.info/licences/Licence_CeCILL-B_V1-fr.txt
 *
 * Auteurs de STUdS (projet initial) : Guilhem BORGHESI (borghesi@unistra.fr) et Raphaël DROZ
 * Auteurs de Framadate/OpenSondage : Framasoft (https://github.com/framasoft)
 */
namespace Framadate\Migration;

use Framadate\Utils;

/**
 * This migration sets Poll.end_date to NULL by default
 *
 * @package Framadate\Migration
 * @version 1.1
 */
class Fix_MySQL_No_Zero_Date implements Migration {
    function __construct() {
    }

    /**
     * This method should describe in english what is the purpose of the migration class.
     *
     * @return string The description of the migration class
     */
    function description() {
        return 'Sets Poll end_date to NULL by default (work around MySQL NO_ZERO_DATE)';
    }

    /**
     * This method could check if the execute method should be called.
     * It is called before the execute method.
     *
     * @param \PDO $pdo The connection to database
47
     * @return bool true if the Migration should be executed.
Thomas Citharel's avatar
Thomas Citharel committed
48
49
50
51
52
53
54
55
     */
    function preCondition(\PDO $pdo) {
        $stmt = $pdo->prepare("SELECT Column_Default from Information_Schema.Columns where Table_Name = ? AND Column_Name = ?;");
        $stmt->bindValue(1, Utils::table('poll'));
        $stmt->bindValue(2, 'end_date');
        $stmt->execute();
        $default = $stmt->fetch(\PDO::FETCH_COLUMN);

56
57
58
        $driver_name = $pdo->getAttribute(\PDO::ATTR_DRIVER_NAME);

        return $default !== null && $driver_name === 'mysql';
Thomas Citharel's avatar
Thomas Citharel committed
59
60
61
62
63
64
    }

    /**
     * This method is called only one time in the migration page.
     *
     * @param \PDO $pdo The connection to database
65
     * @return bool|void if the execution succeeded
Thomas Citharel's avatar
Thomas Citharel committed
66
67
     */
    function execute(\PDO $pdo) {
68
        $pdo->exec('ALTER TABLE ' . Utils::table('poll') . ' MODIFY end_date TIMESTAMP NULL DEFAULT NULL;');
Thomas Citharel's avatar
Thomas Citharel committed
69
70
    }
}