API Revendeur pour Node JS

Gérez votre compte revendeur avec notre API pour Node JS facilement et en toute sécurité. Essayez gratuitement notre API pour Node JS. Notre équipe vous aidera à gérer les clients de votre compte revendeur en Node JS.

Fonctionnalité API pour les revendeurs

Ajouter un sous-compte avec Node JS

var aclass = "subaccount";
var method = "addsubaccount";
var user = "user";
var password = "password";
var accountemail = "email@email.com";
var accountpassword = "password";
var namelastname = "name+lastname";
var iscompany = "1";
var companyname = "mycompany";
var documentid = "123456789A";
var language = "en";
var countrycode = "us";
var cityid = "1";
var cityname = "town";
var zipcode = "123456";
var address = "address";

const https = require('https')
const options = {
  hostname: 'afilnet.com',
  port: 443,
  path: '/api/http/?class='+aclass+'&method='+method+'&user='+user+'&password='+password+'&accountemail='+accountemail+'&accountpassword='+accountpassword+'&namelastname='+namelastname+'&iscompany='+iscompany+'&companyname='+companyname+'&documentid='+documentid+'&language='+language+'&countrycode='+countrycode+'&cityid='+cityid+'&cityname='+cityname+'&zipcode='+zipcode+'&address='+address,
  method: 'GET'
}

const req = https.request(options, res => {
  res.on('data', d => {
	// Do something
  })
})

req.on('error', error => {
  console.error(error)
})

req.end()
var aclass = "subaccount";
var method = "addsubaccount";
var user = "user";
var password = "password";
var accountemail = "email@email.com";
var accountpassword = "password";
var namelastname = "name+lastname";
var iscompany = "1";
var companyname = "mycompany";
var documentid = "123456789A";
var language = "en";
var countrycode = "us";
var cityid = "1";
var cityname = "town";
var zipcode = "123456";
var address = "address";

const https = require('https')
const options = {
  hostname: 'afilnet.com',
  port: 443,
  path: '/api/http/?class='+aclass+'&method='+method+'&user='+user+'&password='+password+'&accountemail='+accountemail+'&accountpassword='+accountpassword+'&namelastname='+namelastname+'&iscompany='+iscompany+'&companyname='+companyname+'&documentid='+documentid+'&language='+language+'&countrycode='+countrycode+'&cityid='+cityid+'&cityname='+cityname+'&zipcode='+zipcode+'&address='+address,
  method: 'POST'
}

const req = https.request(options, res => {
  res.on('data', d => {
	// Do something
  })
})

req.on('error', error => {
  console.error(error)
})

req.end()
Paramètre Description Obligatoire / Optionnel
class=subaccount Classe à laquelle la requête est réalisée Obligatoire
method=addsubaccount Méthode de la classe à laquelle la requête est réalisée Obligatoire
user L'utilisateur / e-mail de votre compte chez Afilnet Obligatoire
password Le mot de passe de votre compte chez Afilnet Obligatoire
accountemail Compte email Obligatoire
accountpassword Mot de passe du compte Obligatoire
namelastname Nom et prénom de la personne de contact Obligatoire
iscompany (0) S'il s'agit d'une personne physique ou (1) s'il s'agit d'une société Obligatoire
companyname Nom de l'entreprise (s'il s'agit d'une entreprise) Optionnel
documentid Code du document d'identification de l'entreprise Obligatoire
language Langue du sous-compte. Voir le tableau ci-joint Obligatoire
countrycode Code pays ISO au format ISO-3166-1 ALPHA-2 Obligatoire
cityid Identifiant de la ville Obligatoire
cityname Nom de la ville ou du village auquel il appartient Obligatoire
zipcode code postal Obligatoire
address Adresse physique Obligatoire
Répondre:
  • statut
  • result (si status=success), vous recevrez les valeurs suivantes :
    • Acucun valeur supplémentaire vous sera envoyé
  • error (si status=error), vous recevrez le code d'erreur

Codes d'erreur :
Code Description
MISSING_USER Utilisateur / e-mail non renseigné
MISSING_PASSWORD Mot de passe non renseigné
MISSING_CLASS Classe non renseignée
MISSING_METHOD Méthode non renseignée
MISSING_COMPULSORY_PARAM Paramètre obligatoire non renseigné
INCORRECT_USER_PASSWORD Utilisateur ou mot de passe incorrect
INCORRECT_CLASS Classe incorrecte
INCORRECT_METHOD Méthode incorrecte
EMPTY_COUNTRYCODE Le code du pays est vide
EMPTY_FIELDS Un champ obligatoire est vide
COUNTRY_NOT_FOUND Il n'y a pas de pays avec le code indiqué
EMPTY_CITY Vous n'avez pas indiqué la ville
CITY_NOT_FOUND La ville indiquée n'existe pas
INCORRECT_EMAIL L'email inclus n'est pas valide
INCORRECT_PASSWORD Le mot de passe inclus n'est pas valide
RESELLER_ACCOUNT_REQUIRED Le compte de l'utilisateur n'a pas de plan revendeur actif

Modifier un sous-compte avec Node JS

var aclass = "subaccount";
var method = "addsubaccount";
var user = "user";
var password = "password";
var accountemail = "email@email.com";
var accountpassword = "password";
var namelastname = "name+lastname";
var iscompany = "1";
var companyname = "mycompany";
var documentid = "123456789A";
var language = "en";
var countrycode = "us";
var cityid = "1";
var cityname = "town";
var zipcode = "123456";
var address = "address";

const https = require('https')
const options = {
  hostname: 'afilnet.com',
  port: 443,
  path: '/api/http/?class='+aclass+'&method='+method+'&user='+user+'&password='+password+'&accountemail='+accountemail+'&accountpassword='+accountpassword+'&namelastname='+namelastname+'&iscompany='+iscompany+'&companyname='+companyname+'&documentid='+documentid+'&language='+language+'&countrycode='+countrycode+'&cityid='+cityid+'&cityname='+cityname+'&zipcode='+zipcode+'&address='+address,
  method: 'POST'
}

const req = https.request(options, res => {
  res.on('data', d => {
	// Do something
  })
})

req.on('error', error => {
  console.error(error)
})

req.end()var aclass = "subaccount";
var method = "modifysubaccount";
var user = "user";
var password = "password";
var accountemail = "email@email.com";
var modifypassword = "1";
var accountpassword = "password";
var namelastname = "name+lastname";
var iscompany = "1";
var companyname = "mycompany";
var documentid = "123456789A";
var language = "en";
var countrycode = "us";
var cityid = "1";
var cityname = "town";
var zipcode = "123456";
var address = "address";

const https = require('https')
const options = {
  hostname: 'afilnet.com',
  port: 443,
  path: '/api/http/?+'&class='+aclass+'&method='+method+'&user='+user+'&password='+password+'&accountemail='+accountemail+'&modifypassword='+modifypassword+'&accountpassword='+accountpassword+'&namelastname='+namelastname+'&iscompany='+iscompany+'&companyname='+companyname+'&documentid='+documentid+'&language='+language+'&countrycode='+countrycode+'&cityid='+cityid+'&cityname='+cityname+'&zipcode='+zipcode+'&address='+address,
  method: 'GET'
}

const req = https.request(options, res => {
  res.on('data', d => {
	// Do something
  })
})

req.on('error', error => {
  console.error(error)
})

req.end()
var aclass = "subaccount";
var method = "modifysubaccount";
var user = "user";
var password = "password";
var accountemail = "email@email.com";
var modifypassword = "1";
var accountpassword = "password";
var namelastname = "name+lastname";
var iscompany = "1";
var companyname = "mycompany";
var documentid = "123456789A";
var language = "en";
var countrycode = "us";
var cityid = "1";
var cityname = "town";
var zipcode = "123456";
var address = "address";

const https = require('https')
const options = {
  hostname: 'afilnet.com',
  port: 443,
  path: '/api/http/?class='+aclass+'&method='+method+'&user='+user+'&password='+password+'&accountemail='+accountemail+'&modifypassword='+modifypassword+'&accountpassword='+accountpassword+'&namelastname='+namelastname+'&iscompany='+iscompany+'&companyname='+companyname+'&documentid='+documentid+'&language='+language+'&countrycode='+countrycode+'&cityid='+cityid+'&cityname='+cityname+'&zipcode='+zipcode+'&address='+address,
  method: 'POST'
}

const req = https.request(options, res => {
  res.on('data', d => {
	// Do something
  })
})

req.on('error', error => {
  console.error(error)
})

req.end()
Paramètre Description Obligatoire / Optionnel
class=subaccount Classe à laquelle la requête est réalisée Obligatoire
method=modifysubaccount Méthode de la classe à laquelle la requête est réalisée Obligatoire
user L'utilisateur / e-mail de votre compte chez Afilnet Obligatoire
password Le mot de passe de votre compte chez Afilnet Obligatoire
accountemail Compte email Obligatoire
modifypassword Obligatoire
accountpassword Mot de passe du compte Optionnel
namelastname Nom et prénom de la personne de contact Obligatoire
iscompany (0) S'il s'agit d'une personne physique ou (1) s'il s'agit d'une société Obligatoire
companyname Nom de l'entreprise (s'il s'agit d'une entreprise) Optionnel
documentid Code du document d'identification de l'entreprise Obligatoire
language Langue du sous-compte. Voir le tableau ci-joint Obligatoire
countrycode Code pays ISO au format ISO-3166-1 ALPHA-2 Obligatoire
cityid Identifiant de la ville Obligatoire
cityname Nom de la ville ou du village auquel il appartient Obligatoire
zipcode code postal Obligatoire
address Adresse physique Obligatoire
Répondre:
  • statut
  • result (si status=success), vous recevrez les valeurs suivantes :
    • Acucun valeur supplémentaire vous sera envoyé
  • error (si status=error), vous recevrez le code d'erreur

Codes d'erreur :
Code Description
MISSING_USER Utilisateur / e-mail non renseigné
MISSING_PASSWORD Mot de passe non renseigné
MISSING_CLASS Classe non renseignée
MISSING_METHOD Méthode non renseignée
MISSING_COMPULSORY_PARAM Paramètre obligatoire non renseigné
INCORRECT_USER_PASSWORD Utilisateur ou mot de passe incorrect
INCORRECT_CLASS Classe incorrecte
INCORRECT_METHOD Méthode incorrecte
EMPTY_COUNTRYCODE Le code du pays est vide
EMPTY_FIELDS Un champ obligatoire est vide
COUNTRY_NOT_FOUND Il n'y a pas de pays avec le code indiqué
EMPTY_CITY Vous n'avez pas indiqué la ville
CITY_NOT_FOUND La ville indiquée n'existe pas
INCORRECT_EMAIL L'email inclus n'est pas valide
INCORRECT_PASSWORD Le mot de passe inclus n'est pas valide
ACCOUNT_NOT_FOUND Le compte utilisateur n'a pas été trouvé

Obtenir la liste des sous-comptes avec Node JS

var aclass = "subaccount";
var method = "modifysubaccount";
var user = "user";
var password = "password";
var accountemail = "email@email.com";
var modifypassword = "1";
var accountpassword = "password";
var namelastname = "name+lastname";
var iscompany = "1";
var companyname = "mycompany";
var documentid = "123456789A";
var language = "en";
var countrycode = "us";
var cityid = "1";
var cityname = "town";
var zipcode = "123456";
var address = "address";

const https = require('https')
const options = {
  hostname: 'afilnet.com',
  port: 443,
  path: '/api/http/?class='+aclass+'&method='+method+'&user='+user+'&password='+password+'&accountemail='+accountemail+'&modifypassword='+modifypassword+'&accountpassword='+accountpassword+'&namelastname='+namelastname+'&iscompany='+iscompany+'&companyname='+companyname+'&documentid='+documentid+'&language='+language+'&countrycode='+countrycode+'&cityid='+cityid+'&cityname='+cityname+'&zipcode='+zipcode+'&address='+address,
  method: 'POST'
}

const req = https.request(options, res => {
  res.on('data', d => {
	// Do something
  })
})

req.on('error', error => {
  console.error(error)
})

req.end()var aclass = "subaccount";
var method = "getsubaccounts";
var user = "user";
var password = "password";

const https = require('https')
const options = {
  hostname: 'afilnet.com',
  port: 443,
  path: '/api/http/?+'&class='+aclass+'&method='+method+'&user='+user+'&password='+password,
  method: 'GET'
}

const req = https.request(options, res => {
  res.on('data', d => {
	// Do something
  })
})

req.on('error', error => {
  console.error(error)
})

req.end()
var aclass = "subaccount";
var method = "getsubaccounts";
var user = "user";
var password = "password";

const https = require('https')
const options = {
  hostname: 'afilnet.com',
  port: 443,
  path: '/api/http/?class='+aclass+'&method='+method+'&user='+user+'&password='+password,
  method: 'POST'
}

const req = https.request(options, res => {
  res.on('data', d => {
	// Do something
  })
})

req.on('error', error => {
  console.error(error)
})

req.end()
Paramètre Description Obligatoire / Optionnel
class=subaccount Classe à laquelle la requête est réalisée Obligatoire
method=getsubaccounts Méthode de la classe à laquelle la requête est réalisée Obligatoire
user L'utilisateur / e-mail de votre compte chez Afilnet Obligatoire
password Le mot de passe de votre compte chez Afilnet Obligatoire
Répondre:
  • statut
  • result (si status=success), vous recevrez les valeurs suivantes :
    • Acucun valeur supplémentaire vous sera envoyé
  • error (si status=error), vous recevrez le code d'erreur

Codes d'erreur :
Code Description
MISSING_USER Utilisateur / e-mail non renseigné
MISSING_PASSWORD Mot de passe non renseigné
MISSING_CLASS Classe non renseignée
MISSING_METHOD Méthode non renseignée
MISSING_COMPULSORY_PARAM Paramètre obligatoire non renseigné
INCORRECT_USER_PASSWORD Utilisateur ou mot de passe incorrect
INCORRECT_CLASS Classe incorrecte
INCORRECT_METHOD Méthode incorrecte

Supprimer un sous-compte avec Node JS

var aclass = "subaccount";
var method = "getsubaccounts";
var user = "user";
var password = "password";

const https = require('https')
const options = {
  hostname: 'afilnet.com',
  port: 443,
  path: '/api/http/?class='+aclass+'&method='+method+'&user='+user+'&password='+password,
  method: 'POST'
}

const req = https.request(options, res => {
  res.on('data', d => {
	// Do something
  })
})

req.on('error', error => {
  console.error(error)
})

req.end()var aclass = "subaccount";
var method = "deletesubaccount";
var user = "user";
var password = "password";
var accountemail = "email@email.com";

const https = require('https')
const options = {
  hostname: 'afilnet.com',
  port: 443,
  path: '/api/http/?+'&class='+aclass+'&method='+method+'&user='+user+'&password='+password+'&accountemail='+accountemail,
  method: 'GET'
}

const req = https.request(options, res => {
  res.on('data', d => {
	// Do something
  })
})

req.on('error', error => {
  console.error(error)
})

req.end()
var aclass = "subaccount";
var method = "deletesubaccount";
var user = "user";
var password = "password";
var accountemail = "email@email.com";

const https = require('https')
const options = {
  hostname: 'afilnet.com',
  port: 443,
  path: '/api/http/?class='+aclass+'&method='+method+'&user='+user+'&password='+password+'&accountemail='+accountemail,
  method: 'POST'
}

const req = https.request(options, res => {
  res.on('data', d => {
	// Do something
  })
})

req.on('error', error => {
  console.error(error)
})

req.end()
Paramètre Description Obligatoire / Optionnel
class=subaccount Classe à laquelle la requête est réalisée Obligatoire
method=deletesubaccount Méthode de la classe à laquelle la requête est réalisée Obligatoire
user L'utilisateur / e-mail de votre compte chez Afilnet Obligatoire
password Le mot de passe de votre compte chez Afilnet Obligatoire
accountemail Compte email Obligatoire
Répondre:
  • statut
  • result (si status=success), vous recevrez les valeurs suivantes :
    • Acucun valeur supplémentaire vous sera envoyé
  • error (si status=error), vous recevrez le code d'erreur

Codes d'erreur :
Code Description
MISSING_USER Utilisateur / e-mail non renseigné
MISSING_PASSWORD Mot de passe non renseigné
MISSING_CLASS Classe non renseignée
MISSING_METHOD Méthode non renseignée
MISSING_COMPULSORY_PARAM Paramètre obligatoire non renseigné
INCORRECT_USER_PASSWORD Utilisateur ou mot de passe incorrect
INCORRECT_CLASS Classe incorrecte
INCORRECT_METHOD Méthode incorrecte
ACCOUNT_NOT_FOUND Le compte utilisateur n'a pas été trouvé

Transférer le solde vers un sous-compte avec Node JS

var aclass = "subaccount";
var method = "deletesubaccount";
var user = "user";
var password = "password";
var accountemail = "email@email.com";

const https = require('https')
const options = {
  hostname: 'afilnet.com',
  port: 443,
  path: '/api/http/?class='+aclass+'&method='+method+'&user='+user+'&password='+password+'&accountemail='+accountemail,
  method: 'POST'
}

const req = https.request(options, res => {
  res.on('data', d => {
	// Do something
  })
})

req.on('error', error => {
  console.error(error)
})

req.end()var aclass = "subaccount";
var method = "transferbalance";
var user = "user";
var password = "password";
var accountemail = "email@email.com";
var balancetotransfer = "10";

const https = require('https')
const options = {
  hostname: 'afilnet.com',
  port: 443,
  path: '/api/http/?+'&class='+aclass+'&method='+method+'&user='+user+'&password='+password+'&accountemail='+accountemail+'&balancetotransfer='+balancetotransfer,
  method: 'GET'
}

const req = https.request(options, res => {
  res.on('data', d => {
	// Do something
  })
})

req.on('error', error => {
  console.error(error)
})

req.end()
var aclass = "subaccount";
var method = "transferbalance";
var user = "user";
var password = "password";
var accountemail = "email@email.com";
var balancetotransfer = "10";

const https = require('https')
const options = {
  hostname: 'afilnet.com',
  port: 443,
  path: '/api/http/?class='+aclass+'&method='+method+'&user='+user+'&password='+password+'&accountemail='+accountemail+'&balancetotransfer='+balancetotransfer,
  method: 'POST'
}

const req = https.request(options, res => {
  res.on('data', d => {
	// Do something
  })
})

req.on('error', error => {
  console.error(error)
})

req.end()
Paramètre Description Obligatoire / Optionnel
class=subaccount Classe à laquelle la requête est réalisée Obligatoire
method=transferbalance Méthode de la classe à laquelle la requête est réalisée Obligatoire
user L'utilisateur / e-mail de votre compte chez Afilnet Obligatoire
password Le mot de passe de votre compte chez Afilnet Obligatoire
accountemail Compte email Obligatoire
balancetotransfer Indique le solde à transférer vers le sous-compte, une valeur négative peut être utilisée pour soustraire le solde du sous-compte. Obligatoire
Répondre:
  • statut
  • result (si status=success), vous recevrez les valeurs suivantes :
    • Acucun valeur supplémentaire vous sera envoyé
  • error (si status=error), vous recevrez le code d'erreur

Codes d'erreur :
Code Description
MISSING_USER Utilisateur / e-mail non renseigné
MISSING_PASSWORD Mot de passe non renseigné
MISSING_CLASS Classe non renseignée
MISSING_METHOD Méthode non renseignée
MISSING_COMPULSORY_PARAM Paramètre obligatoire non renseigné
INCORRECT_USER_PASSWORD Utilisateur ou mot de passe incorrect
INCORRECT_CLASS Classe incorrecte
INCORRECT_METHOD Méthode incorrecte
ACCOUNT_NOT_FOUND Le compte utilisateur n'a pas été trouvé
NOT_ENOUGH_BALANCE ERROR_NOT_ENOUGH_BALANCE
INCORRECT_MIN_BALANCE ERROR_INCORRECT_MIN_BALANCE

Renvoie l'état de livraison des SMS certifiés avec PHP Renvoie l'état de livraison des SMS certifiés avec Java Renvoie l'état de livraison des SMS certifiés avec C Sharp Renvoie l'état de livraison des SMS certifiés avec Unix Renvoie l'état de livraison des SMS certifiés avec Ruby on rails Renvoie l'état de livraison des SMS certifiés avec Python Renvoie l'état de livraison des SMS certifiés avec Android Renvoie l'état de livraison des SMS certifiés avec Objective C / iPhone Renvoie l'état de livraison des SMS certifiés avec SQL Server Renvoie l'état de livraison des SMS certifiés avec Oracle Renvoie l'état de livraison des SMS certifiés avec Node JS Renvoie l'état de livraison des SMS certifiés avec Go lang Renvoie l'état de livraison des SMS certifiés avec Scala lang Renvoie l'état de livraison des SMS certifiés avec Swift Renvoie l'état de livraison des SMS certifiés avec Delphi

Afilnet vous propose des méthodes pour améliorer la sécurité lors de l'utilisation de notre API avec Node JS, grâce à la possibilité de créer des accès et la possibilité d'activer le filtrage par IP.

Quelle API pour Node JS dois-je utiliser ?

Découvrez les avantages et les inconvénients de chacune de nos API. Découvrez quelle API convient le mieux à votre logiciel en Node JS.

Cette API vous permet de vous connecter à nous depuis Node JS pour envoyer des requêtes via des requêtes HTTP GET. Cette requête envoie les paramètres dans la même URL que la requête.

  • HTTP GET est extrêmement simple à mettre en œuvre
  • Les informations sont envoyées non cryptées (les mots de passe peuvent être extraits des journaux ou du cache)
  • Requête maximale d'environ 4 000 caractères

L'API de requête POST vous permet de vous connecter à notre API à partir de Node JS en envoyant des paramètres de requête via des paramètres HTTP POST. Les informations sont envoyées indépendamment de l'URL.

  • HTTP POST est simple à mettre en œuvre
  • Les informations sont envoyées cryptées
  • Il n'y a pas de limite à la taille de la demande
  • Sécurité moyenne

L'API d'authentification de base permet l'utilisation de requêtes GET et POST en Node JS avec une couche de sécurité supplémentaire, puisque dans ce cas le nom d'utilisateur et le mot de passe sont envoyés dans l'en-tête de la requête.

  • L'authentification de base est facile à mettre en œuvre
  • Les données d'accès sont envoyées cryptées
  • La limite de taille dépend de l'utilisation de GET ou POST
  • Sécurité moyenne

SOAP vous permet d'envoyer des requêtes au format XML avec Node JS, SOAP ajoute une couche de sécurité supplémentaire aux requêtes API.

  • L'intégration SOAP est plus complexe
  • Les informations sont envoyées cryptées
  • Il n'y a pas de limite à la taille de la demande
  • Moyenne / Haute sécurité

Notre API JSON permet d'envoyer des requêtes au format JSON avec Node JS, en plus cette API ajoute le protocole oAuth 2.0 dans l'authentification qui permet d'ajouter une couche de sécurité supplémentaire.

  • L'intégration JSON oAuth 2.0 est plus complexe
  • Les informations sont envoyées cryptées
  • Il n'y a pas de limite à la taille de la demande
  • Haute sécurité

Connectez Node JS à notre Sous-comptes API

01

Inscrivez-vous en tant que client

Pour avoir accès à l'API, vous devez être un client Afilnet. L'inscription prendra quelques minutes.

02

Demander votre essai gratuit

Notre société vous proposera une balance d'essai qui vous permettra de tester avec l'API dont vous avez besoin.

03

Intégrer l'API

Effectuez l'intégration de l'API en utilisant le langage de programmation de votre choix. Si vous avez des questions ou des suggestions sur l'API, contactez-nous

04

Bienvenue sur Afilnet!

Tout est prêt!, A réussi à améliorer ses communications avec Afilnet. Nous sommes ici pour prendre en charge notre API lorsque vous en avez besoin


Contactez notre équipe pour toute question via les méthodes de contact que nous proposons. Notre équipe essaiera de vous proposer une solution immédiate et vous aidera dans l'intégration de notre API dans votre logiciel.

Essayez Afilnet gratuitement!

Inscrivez-vous gratuitement et essayez Afilnet ! Nous vous proposons un essai gratuit de nos services. *



(*) Promotion uniquement valable pour les entreprises qui n'ont jamais utilisé le service Afilnet auparavant. Lors de la demande du solde gratuit, Afilnet peut demander de vérifier les informations de votre entreprise


SMS groupés · E-mail Marketing · Réseaux Sociaux · Messagerie instantannée · Certification · et beaucoup plus
Continuer INFORMATION IMPORTANTE SUR LES COOKIES : Ce site web utilise des cookies propres pour garantir la meilleure expérience sur notre site. En poursuivant votre navigation, vous acceptez l'utilisation de cookies. Pour en savoir plus cliquez sur Politique de cookies.
Méthodes de payement
Virement Bancaire
Carte de crédit
Paypal
Western Union
Skrill
Crypto
Afilnet dans votre langue

Copyright © 2024 Afilnet · Tous droits réservés