Aller au contenu principal

Endpoints Departments

Consulter les départements disponibles et vérifier les disponibilités.

GET /departments

Liste tous les départements de votre organisation.

Request

curl https://mc-prd.duckdns.org/api/v1/departments \
-H "X-API-Key: YOUR_API_KEY"
Java
import com.moncreneau.ApiClient;
import com.moncreneau.model.Department;
import java.util.List;

ApiClient client = new ApiClient("your_api_key");
List<Department> departments = client.departments().list();

for (Department dept : departments) {
System.out.println(dept.getName() + " - " + dept.getAddress());
}
Node.js
const { MoncreneauClient } = require('moncreneau');

const client = new MoncreneauClient('your_api_key');

const departments = await client.departments.list();
departments.forEach(dept => {
console.log(`${dept.name} - ${dept.address}`);
});
PHP
<?php
use Moncreneau\Client;

$client = new Client('your_api_key');
$departments = $client->departments->list();

foreach ($departments as $dept) {
echo $dept->name . ' - ' . $dept->address . PHP_EOL;
}
Python
from moncreneau import MoncreneauClient

client = MoncreneauClient('your_api_key')
departments = client.departments.list()

for dept in departments:
print(f"{dept.name} - {dept.address}")

Response 200

[
{
"id": 5,
"name": "Consultation générale",
"address": "123 Rue de la Santé, Conakry",
"phoneNumber": "+224 123 456 789",
"slotInterval": 30,
"workingHours": "Lundi-Vendredi: 08:00-17:00"
},
{
"id": 8,
"name": "Urgences",
"address": "456 Avenue de la République",
"phoneNumber": "+224 987 654 321",
"slotInterval": 15,
"workingHours": "Lundi-Dimanche: 00:00-23:59"
}
]

GET /departments/{id}

Récupère les détails d'un département spécifique.

Request

curl https://mc-prd.duckdns.org/api/v1/departments/5 \
-H "X-API-Key: YOUR_API_KEY"
Java
import com.moncreneau.ApiClient;
import com.moncreneau.model.Department;

ApiClient client = new ApiClient("your_api_key");
Department dept = client.departments().get(5L);

System.out.println("Nom: " + dept.getName());
System.out.println("Adresse: " + dept.getAddress());
System.out.println("Intervalle: " + dept.getSlotInterval() + " minutes");
Node.js
const { MoncreneauClient } = require('moncreneau');

const client = new MoncreneauClient('your_api_key');
const dept = await client.departments.get(5);

console.log(`Nom: ${dept.name}`);
console.log(`Adresse: ${dept.address}`);
console.log(`Intervalle: ${dept.slotInterval} minutes`);
PHP
<?php
use Moncreneau\Client;

$client = new Client('your_api_key');
$dept = $client->departments->get(5);

echo "Nom: {$dept->name}" . PHP_EOL;
echo "Adresse: {$dept->address}" . PHP_EOL;
echo "Intervalle: {$dept->slotInterval} minutes" . PHP_EOL;
Python
from moncreneau import MoncreneauClient

client = MoncreneauClient('your_api_key')
dept = client.departments.get(5)

print(f"Nom: {dept.name}")
print(f"Adresse: {dept.address}")
print(f"Intervalle: {dept.slot_interval} minutes")

Response 200

{
"id": 5,
"name": "Consultation générale",
"address": "123 Rue de la Santé, Conakry",
"phoneNumber": "+224 123 456 789",
"slotInterval": 30,
"workingHours": "Lundi-Vendredi: 08:00-17:00"
}

Response 404

{
"code": "DEPARTMENT_NOT_FOUND",
"message": "Department not found with id: 5",
"timestamp": "2026-01-21T10:00:00"
}

GET /departments/{id}/availability

Vérifie la disponibilité d'un créneau horaire pour un département.

Request

curl "https://mc-prd.duckdns.org/api/v1/departments/5/availability?dateTime=2026-02-15T10:00:00" \
-H "X-API-Key: YOUR_API_KEY"
Java
import com.moncreneau.ApiClient;
import com.moncreneau.model.SlotAvailability;
import java.time.LocalDateTime;

ApiClient client = new ApiClient("your_api_key");
LocalDateTime dateTime = LocalDateTime.parse("2026-02-15T10:00:00");

SlotAvailability availability = client.departments()
.checkAvailability(5L, dateTime);

if (availability.isAvailable()) {
System.out.println("Créneau disponible! Places restantes: " +
availability.getRemainingSlots());
} else {
System.out.println("Créneau indisponible: " +
availability.getUnavailabilityReason());
}
Node.js
const { MoncreneauClient } = require('moncreneau');

const client = new MoncreneauClient('your_api_key');
const dateTime = '2026-02-15T10:00:00';

const availability = await client.departments.checkAvailability(5, dateTime);

if (availability.available) {
console.log(`Créneau disponible! Places restantes: ${availability.remainingSlots}`);
} else {
console.log(`Créneau indisponible: ${availability.unavailabilityReason}`);
}
PHP
<?php
use Moncreneau\Client;

$client = new Client('your_api_key');
$dateTime = '2026-02-15T10:00:00';

$availability = $client->departments->checkAvailability(5, $dateTime);

if ($availability->available) {
echo "Créneau disponible! Places restantes: {$availability->remainingSlots}" . PHP_EOL;
} else {
echo "Créneau indisponible: {$availability->unavailabilityReason}" . PHP_EOL;
}
Python
from moncreneau import MoncreneauClient

client = MoncreneauClient('your_api_key')
date_time = '2026-02-15T10:00:00'

availability = client.departments.check_availability(5, date_time)

if availability.available:
print(f"Créneau disponible! Places restantes: {availability.remaining_slots}")
else:
print(f"Créneau indisponible: {availability.unavailability_reason}")

Response 200 - Disponible

{
"slotTime": "2026-02-15T10:00:00",
"available": true,
"remainingSlots": 3,
"unavailabilityReason": null
}

Response 200 - Indisponible

{
"slotTime": "2026-02-15T10:00:00",
"available": false,
"remainingSlots": 0,
"unavailabilityReason": "Slot full (5/5 appointments)"
}