Aller au contenu

GET /v1/eol/products

Le catalogue EOL liste tous les produits référencés dans TechWatchAlert avec leurs cycles de version et dates de fin de vie. Ces données sont indépendantes de vos projets — c’est la base de référence globale.


GET /api/v1/eol/products
Authorization: Bearer twa_votre_cle_ici
ParamètreTypeDéfautDescription
qstringRecherche textuelle sur l’identifiant et le nom du produit
pageinteger ≥ 11Numéro de page
page_sizeinteger 1–10020Nombre de produits par page
{
"items": [
{
"id": "nodejs",
"name": "Node.js",
"description": "Node.js is a JavaScript runtime built on Chrome's V8 engine"
},
{
"id": "postgresql",
"name": "PostgreSQL",
"description": "PostgreSQL is an advanced, enterprise-class open-source relational database"
}
],
"total": 312,
"page": 1,
"page_size": 20
}
ChampTypeDescription
itemsarrayProduits de la page courante
totalintegerNombre total de produits dans le catalogue
pageintegerPage courante
page_sizeintegerTaille de page utilisée
items[].idstringIdentifiant technique du produit (ex : nodejs, ubuntu, spring-boot) — à utiliser dans les autres endpoints
items[].namestringNom lisible
items[].descriptionstring | nullDescription courte

GET /api/v1/eol/products/{product_id}/cycles
Authorization: Bearer twa_votre_cle_ici
ParamètreTypeDescription
product_idstringIdentifiant du produit (ex : nodejs, ubuntu)
{
"id": "nodejs",
"name": "Node.js",
"description": "Node.js is a JavaScript runtime built on Chrome's V8 engine",
"cycles": [
{
"cycle": "22",
"release_date": "2024-04-24",
"eol": "2027-04-30",
"lts": "2024-10-29",
"support": null,
"latest": "22.9.0",
"link": "https://nodejs.org/en/blog/release/v22.0.0"
},
{
"cycle": "20",
"release_date": "2023-04-18",
"eol": "2026-04-30",
"lts": "2023-10-24",
"support": null,
"latest": "20.18.0",
"link": "https://nodejs.org/en/blog/release/v20.0.0"
},
{
"cycle": "18",
"release_date": "2022-04-19",
"eol": "2025-04-30",
"lts": "2022-10-25",
"support": null,
"latest": "18.20.4",
"link": "https://nodejs.org/en/blog/release/v18.0.0"
}
]
}
ChampTypeDescription
cyclestringIdentifiant de la version (ex : "18", "22.04 LTS")
release_datestring (YYYY-MM-DD) | nullDate de sortie initiale
eolstring (YYYY-MM-DD) | boolean | nullFin de vie : date ISO, false (pas encore en EOL), true (déjà en EOL sans date précise), ou null (inconnu)
ltsstring (YYYY-MM-DD) | boolean | nullDébut du support LTS (même logique que eol)
supportstring (YYYY-MM-DD) | boolean | nullFin du support actif (même logique)
lateststring | nullDernière version dans ce cycle
linkstring | nullURL de la release notes officielle

Les champs eol, lts et support peuvent avoir trois formes :

ValeurSignification
"2025-04-30"Date précise connue
trueStatut atteint mais sans date précise
falseStatut non encore atteint
nullInformation non disponible
CodeDétailCause
404Produit introuvableproduct_id inexistant dans le catalogue

Rechercher tous les produits “python”

Fenêtre de terminal
curl -s \
-H "Authorization: Bearer twa_votre_cle_ici" \
"https://app.techwatchalert.com/api/v1/eol/products?q=python" \
| jq '.items[] | {id, name}'

Obtenir les cycles actifs de Python (non encore en EOL)

Fenêtre de terminal
curl -s \
-H "Authorization: Bearer twa_votre_cle_ici" \
"https://app.techwatchalert.com/api/v1/eol/products/python/cycles" \
| jq '.cycles[] | select(.eol != true and (.eol == false or (.eol | type) == "string")) | {version: .cycle, eol: .eol, latest: .latest}'

Tableau de bord EOL complet de votre stack

import httpx
from datetime import date
BASE = "https://app.techwatchalert.com/api/v1"
headers = {"Authorization": "Bearer twa_votre_cle_ici"}
project_id = "018e1234-abcd-7000-8000-000000000010"
# Abonnements du projet
subs = httpx.get(f"{BASE}/projects/{project_id}/eol", headers=headers).json()
today = date.today()
rows = []
for sub in subs:
if sub["cycle"] is None:
continue
detail = httpx.get(f"{BASE}/eol/products/{sub['product_id']}/cycles", headers=headers).json()
cycle_data = next((c for c in detail["cycles"] if c["cycle"] == sub["cycle"]), None)
if not cycle_data:
continue
eol = cycle_data.get("eol")
eol_date = date.fromisoformat(eol) if isinstance(eol, str) else None
days_left = (eol_date - today).days if eol_date else None
rows.append({
"produit": detail["name"],
"version": sub["cycle"],
"EOL": str(eol_date) if eol_date else ("déjà" if eol is True else "N/A"),
"jours_restants": days_left,
"latest": cycle_data.get("latest"),
})
rows.sort(key=lambda r: r["jours_restants"] if r["jours_restants"] is not None else 9999)
for r in rows:
status = f"⚠ {r['jours_restants']}j" if r["jours_restants"] and r["jours_restants"] < 90 else r["EOL"]
print(f"{r['produit']:20} {r['version']:10} EOL: {status:15} latest: {r['latest']}")