Bonjour,

Je suis actuellement en train de développer une api qui fonctionnerait ensuite avec une application angular. J'ai effectué divers test via Postman et cela ne fonctionne pas. J'aimerai comprend d'où vient mon erreur.

Voici l'arborescence de mes fichiers :

api / agency / editAgency.php et listAgency.php

config / Database.php

models / Agency.php


Le code de database.php pour la connection à la bdd
Code : Sélectionner tout - Visualiser dans une fenêtre à part
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
 
<?php
class Database {
    // Paramètres DB
    // Les attributs sont en mode "private" et ne sont donc accessibles qu'à l'intérieur de la classe
    private $host = "localhost";
    private $dbname = "mouttec";
    private $username = "root";
    private $password = "root";
    private $conn;
    // méthode de connection à la DB
    public function connect() {
        $this->conn = null;
        try {
            // Définition des otions de l'objet PDO
            // référence PDO : https://www.php.net/manual/en/book.pdo.php
            $options = [
                PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
                PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC
            ];
            // Connection à la DB
            $this->conn = new PDO("mysql:host=$this->host;dbname=$this->dbname;charset=utf8", $this->username, $this->password, $options);
             //echo "Succesfully connected to db";
        } catch (PDOException $error) {
            echo "Connection error : $error->getMessage()";
        }
        return $this->conn;
    }
}
Le code de mon models Agency.php
Code : Sélectionner tout - Visualiser dans une fenêtre à part
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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
 
<?php
class Post {
    // Propriétés privées de connexion à la DB
    private $conn;
    private $table = "agencies";
    // Propriétés publiques de l'objet Post
    public $idAgency;
    public $nameAgency;
    public $numberAddressAgency;
    public $typeAddressAgency;
    public $nameAddressAgency;
    public $complementAddressAgency;
    public $zipAddressAgency;
    public $cityAddressAgency;
    public $phoneAgency;
    public $mailAgency;
    public $statusAgency;
    public $dateAgency;
 
    public function __construct($db) {
        $this->conn = $db;
    }
 
    public function createAgency() {
        $query = "
            INSERT INTO "
            . $this->table .
            " SET
            nameAgency = :nameAgency,
            numberAddressAgency = :numberAddressAgency,
            typeAddressAgency = :typeAddressAgency,
            nameAddressAgency = :nameAddressAgency,
            complementAddressAgency : :complementAddressAgency,
            zipAddressAgency = :zipAddressAgency,
            cityAddressAgency = :cityAddressAgency,
            phoneAgency = :phoneAgency,
            mailAgency = :mailAgency,
            statusAgency = :statusAgency,
            dateAgency = :dateAgency
        ";
 
        $stmt = $this->conn->prepare($query);
        $params = [
            "nameAgency" = $this->nameAgency,
            "numberAddressAgency" = $this->numberAddressAgency,
            "typeAddressAgency" = $this->typeAddressAgency,
            "nameAddressAgency" = $this->nameAddressAgency,
            "complementAddressAgency" : $this->complementAddressAgency,
            "zipAddressAgency" = $this->zipAddressAgency,
            "cityAddressAgency" = $this->cityAddressAgency,
            "phoneAgency" = $this->phoneAgency,
            "mailAgency" = $this->mailAgency,
            "statusAgency" = $this->statusAgency,
            "dateAgency" = date(dmY) //La date est retournée au format DDMMYYYY
        ];
 
        if ($stmt->execute($params)) {
            return true;
        }
        return false;
    }
 
    public function listAgencies() {
        $query = "
            SELECT *
            FROM "
            . $this->table . " 
            ORDER BY
            created_at DESC";
 
        $stmt = $this->conn->prepare($query);
        $stmt->execute();
 
        return $stmt;
    }
 
    public function searchAgency() {
        $query = "
        SELECT *
        FROM "
        . $this->table . " 
        WHERE nameAgency = :nameAgency
        LIMIT 0,1";
 
        $stmt = $this->conn->prepare($query);
        $params = ["nameAgency" => $this->nameAgency];
 
        if ($stmt->execute($params)) {
            $row = $stmt->fetch();    
            return $row;
        }
        return false;
    }
 
    public function updateAgency($id) {
        // On crée la requête
        $query = "
            UPDATE "
            . $this->table .
            " SET
            nameAgency = :nameAgency,
            numberAddressAgency = :numberAddressAgency,
            typeAddressAgency = :typeAddressAgency,
            nameAddressAgency = :nameAddressAgency,
            complementAddressAgency : :complementAddressAgency,
            zipAddressAgency = :zipAddressAgency,
            cityAddressAgency = :cityAddressAgency,
            phoneAgency = :phoneAgency,
            mailAgency = :mailAgency,
            statusAgency = :statusAgency,
            dateAgency = :dateAgency
            WHERE
            id = :id        
        ";
 
        $stmt = $this->conn->prepare($query);
        $params = [
            "nameAgency" = $this->nameAgency,
            "numberAddressAgency" = $this->numberAddressAgency,
            "typeAddressAgency" = $this->typeAddressAgency,
            "nameAddressAgency" = $this->nameAddressAgency,
            "complementAddressAgency" : $this->complementAddressAgency,
            "zipAddressAgency" = $this->zipAddressAgency,
            "cityAddressAgency" = $this->cityAddressAgency,
            "phoneAgency" = $this->phoneAgency,
            "mailAgency" = $this->mailAgency,
            "statusAgency" = $this->statusAgency,
        ];
 
        if ($stmt->execute($params)) {
                return true;
            }
        return false;
    }
 
    public function deleteAgency($id) {
        $query = "
            DELETE
            FROM " . $this->table .
            " WHERE id = :id
        ";
 
        $stmt = $this->conn->prepare($query);
        $params = ["id" => $this->id];
 
        if($stmt->execute($params)) {
            return true;
        }
        return false;
    }
}

Le code de pour la création de la liste

Code : Sélectionner tout - Visualiser dans une fenêtre à part
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
 
<?php
 
//ini_set('display_errors', 1);
//ini_set('display_startup_errors', 1);
//error_reporting(E_ALL);
 
// On envoie les headers
header("Access-Control-Allow-Origin: *");
header("Access-Control-Allow-Methods: POST");
header("Content-Type: application/json");
header("Access-Control-Allow-Headers: Access-Control-Allow-Headers, Access-Control-Allow-Methods, Content-Type, Authorization, X-Requested-With");
 
// On inclus les objets (ou classes) nécessaires
include_once "../../config/Database.php";
include_once "../../models/Agency.php";
 
// Si données en json
$decodedData = json_decode(file_get_contents("php://input"));
 
$agency = array();
foreach ($decodedData as $key => $value) {
    array_push($agency, array($key => $value));
}
 
$db = new Database();
$conn = $db->connect();
$agencyRequest = new Agency($conn);
$agencyExists = $agencyRequest->searchAgency($agency['nameAgency']);
 
//On regarde quelle action de Read est demandée
switch ($agency['action']) {
    case 'editAgency':
        if (!empty($agencyExists)) {
            $result = $agencyRequest->updateAgency($agency);
        } else { 
            $result = $agencyRequest->createAgency($agency);
        }
        break;
    // case 'changePassword':
    //     if (!empty($agencyExists) 
    //         && (password_verify($oldPassword, $agency['mixedPassword']) 
    //             || $_SESSION('superAdmin' == 1))) {
    //         $agencyRequest->passwordUpdate($agency); 
    //     }
    //     break;
    case 'deleteAgency':
        $result = $agencyRequest->deleteAgency($agency['idAgency']);
        break;
    default:
    	$result = false;
        break;
}
 
if ($result) {
    echo json_encode([ "message" => "L'agence a été éditée !" ]);
} else {
    echo json_encode([ "message" => "L'agence n'a pas pu être éditée..." ]);
}
Au niveau des erreurs sur Postmann, il sort cela

Unexpected '<'


Je ne sais plus quoi faire. Cela fait des jours que je bloque.