Subversion Repository Public Repository

Nextrek

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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
<?php
    session_start();

    header("Access-Control-Allow-Origin: *");
    header('Content-Type: application/json; charset=UTF-8');

    require_once("constants.php");

    require_once("repositories/LocalRepository.php");
    require_once("repositories/UserRepository.php");
    require_once("repositories/CommentRepository.php");

    /*$servername = "localhost";
    $username = "smartcharging";
    $password = "LXRLBaEAuRr7M7jY";*/

    //$params = json_decode($_REQUEST["params"], true);

    //$input = file_get_contents('php://input');
    $params = json_decode(file_get_contents('php://input'), true);

    $conn;
    $risposta = array();
    $repo;

    $user_id;
    $is_admin = false;

    try {
        $conn = new PDO("mysql:host=".DB_SERVERNAME.";dbname=".DB_NAME, DB_USERNAME, DB_PASSWORD);
        $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        //echo "Connesso con successo al DB";

        if (!array_key_exists("token", $params) || $params["token"] === "") {
            $risposta = createErrorMessage(-1, "Parametro \"token\" non valido");
            //$risposta["return"] = -1;
            echo json_encode($risposta);
            die();
        }

        $user_id = UserRepository::getUserByToken($params["token"], $conn);

        if ($user_id == -1) {
            $is_admin = UserRepository::checkAdminByToken($params["token"], $conn);
            if (!$is_admin) { //controlla che l'utente sia amministratore
                $risposta = createErrorMessage(-1, "Token non valido");
                //$risposta["return"] = -1;
                echo json_encode($risposta);
                die();
            }
        }

        /* ============= SUPPORTO IMMAGINI NEI COMMENTI DROPPATO =============== */

        /*$type = $params["type"];

        if ($type=="local") {
            $repo = new LocalRepository($conn);
        } else if ($type=="comment") {
            $repo = new CommentRepository($conn);
        } else {
            //$risposta["return"] = 1;
            $risposta = createErrorMessage(1, "Parametro \"type\" non valido");
            echo json_encode($risposta);
            die();
        }*/

        /* =========== FINE SUPPORTO IMMAGINI NEI COMMENTI DROPPATO ============= */

        $repo = new LocalRepository($conn);

        if (!$is_admin) { //nel caso non sia ammministratore --> effettua controllo sull'utente
            $oldContent = $repo->getFullLocalInfo($params["id"]);

            if ($oldContent->id_utente_owner != $user_id) { //l'utente non gestisce il locale
                $risposta = createErrorMessage(-1, "Token non valido");
                //$risposta["return"] = -1;
                echo json_encode($risposta);
                die();
            }
        }

        $imgs = array_key_exists("imgs", $params) ? $params["imgs"] : null;

        if (count($imgs)) {
            foreach($imgs as $image) {
                //rename($_SERVER['DOCUMENT_ROOT'].TEMP_IMAGES_PATH.session_id()."/".$image, $_SERVER['DOCUMENT_ROOT'].IMAGES_PATH.$image);
                rename($_SERVER['DOCUMENT_ROOT'].TEMP_IMAGES_PATH."/".$image, $_SERVER['DOCUMENT_ROOT'].IMAGES_PATH.$image);
            }
            //rmdir($_SERVER['DOCUMENT_ROOT'].TEMP_IMAGES_PATH.session_id()."/");
        }

        $risposta["return"] = $repo->addImages($params["id"], $imgs);       

    }
    catch(PDOException $e)
    {
        echo $e->getMessage();
        //$risposta["return"] = 1;
        $risposta = createErrorMessage(1, "Errore DB");
    }

    echo json_encode($risposta);
    $conn = null; //Close the connection to the DBMS

?>

Commits for Nextrek/Android/SmartCharging/endPoints/nightly/add_immagini.php

Diff revisions: vs.
Revision Author Commited Message
725 Diff Diff FSallustio picture FSallustio Wed 09 Sep, 2015 07:51:47 +0000

Gestione utenze admin in SC

723 Diff Diff FSallustio picture FSallustio Tue 08 Sep, 2015 15:05:25 +0000

Aggiunto check sull’associazione tra utente e token.

706 Diff Diff FSallustio picture FSallustio Mon 07 Sep, 2015 15:50:07 +0000
543 Diff Diff FSallustio picture FSallustio Tue 25 Aug, 2015 08:29:03 +0000
537 Diff Diff FSallustio picture FSallustio Mon 24 Aug, 2015 14:46:21 +0000
517 Diff Diff FSallustio picture FSallustio Thu 20 Aug, 2015 14:25:03 +0000
415 Diff Diff FSallustio picture FSallustio Wed 22 Jul, 2015 08:27:42 +0000

Piccolo refactor dei file php...

400 Diff Diff FSallustio picture FSallustio Mon 20 Jul, 2015 10:23:38 +0000
378 Diff Diff FSallustio picture FSallustio Fri 17 Jul, 2015 10:31:22 +0000

[DA TESTARE E CORREGGERE] Gestione path immagini tramite costanti.

374 FSallustio picture FSallustio Fri 17 Jul, 2015 08:20:18 +0000

Creazione “branch” nightly