Aller au contenu

Office 365 / Outlook / Hotmail

Aperçu

  • Prise en charge des images: Non
  • Prise en charge des pièces jointes: Oui
  • Limites de caractères des messages:
    • Corps: 32768
  • Créer votre URL Apprise

Choisissez Personnel si vous envoyez depuis une boîte Microsoft grand public comme @outlook.com, @hotmail.com, @live.com ou @msn.com. Cette méthode utilise une connexion unique pour obtenir un refresh_token, ensuite renouvelé automatiquement par Apprise au fil des envois.

Choisissez Organisationnel si vous envoyez depuis un tenant Microsoft 365 professionnel ou scolaire adossé à Exchange Online. Cette méthode repose sur un enregistrement d’application Azure et le flux client_credentials avec votre tenant_id, client_id et client_secret.

Les comptes consommateurs personnels — @outlook.com, @hotmail.com, @live.com, @msn.com et les variantes régionales Hotmail/Live — utilisent un flux par jeton de rafraîchissement à la place du flux client credentials organisationnel.

Ce processus comporte deux phases :

  • Configuration unique : enregistrez une application cliente publique dans Azure, puis exécutez un court script pour vous connecter et capturer votre refresh_token.
  • Utilisation courante : Apprise utilise le refresh_token stocké pour obtenir automatiquement des jetons d’accès de courte durée. Chaque envoi réussi renouvelle silencieusement le jeton de rafraîchissement, de sorte qu’il reste actif tant qu’Apprise est utilisé au moins une fois tous les 90 jours.
  1. Allez dans App Registrations dans le portail Azure et cliquez sur Register an application.

    • Donnez-lui un nom (ex. Apprise Personnel).

    • Sous Supported account types, sélectionnez Personal Microsoft accounts only.

    • Sous Redirect URI, choisissez Public client / native (mobile & desktop) et définissez l’URI sur :

      https://login.microsoftonline.com/common/oauth2/nativeclient
    • Cliquez sur Register.

  2. Depuis le panneau Overview, copiez l’Application (client) ID - c’est votre client_id.

  3. Sous Manage -> Authentication, faites défiler jusqu’à Advanced settings et définissez Allow public client flows sur Yes, puis cliquez sur Save. Cela active le flux de code d’appareil utilisé pour obtenir le jeton initial.

  4. Sous Manage -> API permissions :

    • Cliquez sur Add a permission -> Microsoft Graph -> Delegated Permissions
    • Recherchez et cochez Mail.Send, puis cliquez sur Add permissions

Il s’agit d’une étape unique. Les scripts ci-dessous utilisent le flux de code d’appareil de Microsoft : votre script affiche un code court et un lien ; vous ouvrez ce lien dans n’importe quel navigateur et vous connectez ; le script capture automatiquement votre refresh_token.

L’ensemble du processus prend généralement moins de deux minutes.

Seul requests est requis - déjà installé si vous avez Apprise.

Modifiez la ligne CLIENT_ID, puis copiez et collez l’intégralité du bloc dans votre terminal.

import time, requests
# - Modifiez cette ligne
CLIENT_ID = "your-client-id-here" # Application (client) ID depuis Azure
# -
DEVICE_URL = "https://login.microsoftonline.com/consumers/oauth2/v2.0/devicecode"
TOKEN_URL = "https://login.microsoftonline.com/consumers/oauth2/v2.0/token"
SCOPE = "Mail.Send offline_access"
# Étape 1 - demander un code d'appareil
r = requests.post(DEVICE_URL, data={"client_id": CLIENT_ID, "scope": SCOPE})
r.raise_for_status()
d = r.json()
# Étape 2 - le script affiche un lien et un code court ; ouvrez le lien dans
# un navigateur et entrez le code pour vous connecter à votre compte
print("\n" + d["message"] + "\n")
# Étape 3 - interroger silencieusement jusqu'à la fin de la connexion (< 60 s)
interval = d.get("interval", 5)
while True:
time.sleep(interval)
r = requests.post(TOKEN_URL, data={
"client_id": CLIENT_ID,
"grant_type": "urn:ietf:params:oauth:grant-type:device_code",
"device_code": d["device_code"],
})
t = r.json()
if "refresh_token" in t:
print("Votre refresh_token (à utiliser dans votre URL Apprise) :\n")
print(t["refresh_token"])
break
if t.get("error") == "slow_down":
interval += 5
elif t.get("error") != "authorization_pending":
print("Erreur :", t.get("error_description", t))
break

La syntaxe valide est la suivante, les alias o365:// et azure:// étant tous deux acceptés :

  • o365://{source}/{client_id}/{refresh_token}/
  • o365://{source}/{client_id}/{refresh_token}/{targets}

Apprise détecte automatiquement le mode personnel lorsque source est un domaine consommateur connu (outlook.com, hotmail.com, live.com, msn.com et variantes régionales). Utilisez ?mode=personal pour forcer le mode personnel sur tout autre domaine.

VariableRequisDescription
source*OuiVotre adresse e-mail consommateur (ex. user@outlook.com). Utilisée comme expéditeur et, si aucun targets n’est précisé, également comme destinataire.
client_id*OuiL’Application (client) ID issu de votre enregistrement d’application Azure.
refresh_token*OuiLe jeton de rafraîchissement obtenu lors de la configuration unique ci-dessus. Apprise le renouvelle automatiquement à chaque envoi réussi.
targetsNonUne ou plusieurs adresses e-mail destinataires. Si omis, l’e-mail est envoyé à source.
toNonAlias de targets. Pratique dans une configuration YAML.
ccNonUne ou plusieurs adresses en copie carbone. Accepte des valeurs séparées par des virgules et des adresses nommées (ex. Nom <email@example.com>).
bccNonUne ou plusieurs adresses en copie carbone invisible. Accepte des valeurs séparées par des virgules et des adresses nommées (ex. Nom <email@example.com>).
reply_toNonUne ou plusieurs adresses Répondre à. Lorsqu’un destinataire répond, sa réponse est dirigée ici plutôt que vers source. Accepte des valeurs séparées par des virgules et des adresses nommées.
modeNonForce le mode personnel sur un domaine non standard : ?mode=personal.
VariableDescription
overflowCe paramètre peut être défini sur split, truncate ou upstream. Il détermine la manière dont Apprise remet le message que vous lui transmettez. Par défaut, il vaut upstream.
👉 upstream : ne fait aucune modification et transmet le message exactement tel qu’il a été reçu au service.
👉 truncate : veille à ce que le message tienne dans la limite amont documentée par le service. Si plus d’informations sont fournies que la limite définie, l’excédent est tronqué.
👉 split : similaire à truncate, sauf que si le message dépasse la limite amont documentée par le service, il est découpé en plusieurs morceaux plus petits puis envoyés séquentiellement.
formatCe paramètre peut être défini sur text, html ou markdown. Certains services prennent en charge plusieurs formats de publication du contenu. La valeur par défaut varie selon le service choisi et peut correspondre à l’un de ces trois formats. Vous pouvez facultativement forcer cette option pour vous écarter du comportement par défaut. Si le service ne prend pas en charge plusieurs formats de transmission, ce champ est ignoré.
verifyLes requêtes externes vers des emplacements sécurisés, par exemple via https, utilisent des certificats. Par défaut, Apprise vérifie la validité de ces certificats ; si ce n’est pas le cas, aucune notification n’est envoyée à la source. Dans certains cas, un utilisateur ne dispose pas d’une autorité de certification pour valider la clé ou fait simplement confiance à la source ; dans ce cas, vous pouvez définir ce drapeau sur no. Par défaut, il vaut yes.
ctoSignifie Socket Connect Timeout. Il s’agit du nombre de secondes pendant lesquelles Requests attend que votre client établisse une connexion avec une machine distante, ce qui correspond à l’appel connect() sur la socket. La valeur par défaut est de 4.0 secondes.
rtoSignifie Socket Read Timeout. Il s’agit du nombre de secondes pendant lesquelles le client attend que le serveur envoie une réponse. La valeur par défaut est de 4.0 secondes.
emojisActive la prise en charge des emojis, par exemple :+1: qui sera traduit en 👍. Par défaut, cette option vaut no.
Remarque : selon la configuration côté serveur, l’administrateur peut désactiver globalement la prise en charge des emojis ; mais par défaut, ce n’est pas le cas.
tzIdentifie le fuseau horaire de la base IANA que vous souhaitez utiliser. Par défaut, celui-ci est détecté à partir de la configuration du serveur qui exécute Apprise. Vous pouvez le définir sur des valeurs comme America/Toronto, ou sur tout autre fuseau correctement formaté correspondant à votre région.

Envoyer depuis un compte Outlook personnel (le mode est détecté automatiquement depuis le domaine) :

Fenêtre de terminal
# source: vous@outlook.com
# client_id: aa-bb-cc-dd-ee
# refresh_token: (issu du script ci-dessus)
apprise -vv -t "Titre du test" -b "Corps du test" \
"o365://vous@outlook.com/aa-bb-cc-dd-ee/votre-refresh-token-ici/"

Envoyer à un destinataire différent depuis un compte Hotmail :

Fenêtre de terminal
apprise -vv -t "Bonjour" -b "Corps du message" \
"o365://moi@hotmail.com/aa-bb-cc-dd-ee/votre-refresh-token-ici/ami@example.com"

Forcer le mode personnel sur un domaine non standard :

Fenêtre de terminal
apprise -vv -t "Bonjour" -b "Corps du message" \
"o365://moi@custom.com/aa-bb-cc-dd-ee/votre-refresh-token-ici/?mode=personal"
Questions ou commentaires ?

Documentation

Vous avez repéré une faute de frappe ou une erreur ? Signalez-la ou proposez une correction .

Problèmes Techniques

Vous rencontrez un problème avec le code ? Ouvrez un ticket sur GitHub :

Conçu avec amour depuis le Canada