API dla programistów
Darmowe REST API ze strukturalnymi odpowiedziami JSON. Wymagany klucz API (bezpłatny). CORS włączony. Idealny do budowania aplikacji, systemów rekomendacji lub zasilania LLM danymi o perfumach.
Bazowy URL
https://fraganty.aiWszystkie endpointy API wymagają bezpłatnego klucza API. Dołącz go do każdego żądania za pomocą nagłówka X-API-Key lub parametru api_key.
Nagłówek
X-API-Key: YOUR_API_KEYParametr zapytania
?api_key=YOUR_API_KEYZamów bezpłatny klucz API pod adresem [email protected]
/api/perfumesLista i wyszukiwanie perfum
Parametry
| Nazwa | Typ | Opis |
|---|---|---|
| q | string | Szukaj po nazwie |
| brand | string | Filtruj po slug marki |
| page | number | Numer strony (domyślnie: 1) |
| limit | number | Wyników na stronę (domyślnie: 20, maks: 100) |
Przykładowe zapytanie
Odpowiedź
{
"data": [
{
"id": "rose-goldea-kathleen-kye-edition",
"name": "Rose Goldea Kathleen Kye Edition",
"brand": "Bvlgari",
"year": 2021,
"rating": 4.62,
"concentration": null,
"image": "https://img.fraganty.ai/perfume/64818.jpg",
"buyUrl": "https://fraganty.ai/goto/rose-goldea-kathleen-kye-edition",
"accords": [
{ "name": "Rose", "strength": 100, "color": "#C4647C" },
{ "name": "Floral", "strength": 79, "color": "#9E3B52" }
]
}
],
"total": 2460,
"page": 1,
"pages": 492
}/api/perfumes/:slugPobierz pełne szczegóły perfumu, w tym nuty, akordy, oceny, sezony i podobne perfumy
Przykładowe zapytanie
Odpowiedź
{
"id": "bleu-de-chanel-eau-de-parfum",
"name": "Bleu de Chanel Eau de Parfum",
"brand": "Chanel",
"year": 2014,
"rating": 4.21,
"concentration": "Eau de Parfum",
"gender": "masculine",
"description": "...",
"buyUrl": "https://fraganty.ai/goto/bleu-de-chanel-eau-de-parfum",
"notes": {
"top": [{ "name": "Lemon", "intensity": 80 }],
"middle": [{ "name": "Cedar", "intensity": 90 }],
"base": [{ "name": "Sandalwood", "intensity": 85 }]
},
"accords": [...],
"seasons": { "winter": 45, "spring": 60, "summer": 30, "fall": 65 },
"dayNight": { "day": 55, "night": 70 },
"similarPerfumes": [...],
"perfumers": [{ "name": "Olivier Polge" }]
}/api/brandsLista wszystkich marek z liczbą perfum
Parametry
| Nazwa | Typ | Opis |
|---|---|---|
| q | string | Szukaj marek po nazwie |
Przykładowe zapytanie
Odpowiedź
{
"data": [
{ "name": "Guerlain", "slug": "Guerlain", "count": 412 },
{ "name": "Dior", "slug": "Dior", "count": 312 },
{ "name": "Chanel", "slug": "Chanel", "count": 248 }
],
"total": 6619
}/api/notesLista wszystkich nut zapachowych z częstotliwością występowania
Parametry
| Nazwa | Typ | Opis |
|---|---|---|
| limit | number | Ogranicz wyniki (domyślnie: wszystkie) |
Przykładowe zapytanie
Odpowiedź
{
"data": [
{ "name": "Musk", "count": 3097 },
{ "name": "Bergamot", "count": 2498 },
{ "name": "Rose", "count": 2460 }
],
"total": 981
}/api/perfumersLista wszystkich perfumiarzy z liczbą perfum
Przykładowe zapytanie
Odpowiedź
{
"data": [
{ "name": "Alberto Morillas", "slug": "alberto-morillas", "count": 45 },
{ "name": "Olivier Polge", "slug": "olivier-polge", "count": 38 }
],
"total": 358
}/api/perfumers/:slugSzczegóły perfumiarza z jego perfumami (stronicowane)
Parametry
| Nazwa | Typ | Opis |
|---|---|---|
| page | number | Numer strony (domyślnie: 1) |
| limit | number | Wyników na stronę (domyślnie: 20) |
Przykładowe zapytanie
Odpowiedź
{
"name": "Alberto Morillas",
"slug": "alberto-morillas",
"perfumes": {
"data": [...],
"total": 45,
"page": 1,
"pages": 3
}
}