Skip to content

Latest commit

 

History

History
94 lines (61 loc) · 3.36 KB

README.md

File metadata and controls

94 lines (61 loc) · 3.36 KB

Microsoft Teams Chat Backup

Enhancement:

I've added more options and feature for easy backup a chat:

  • Search user id through user displayname
  • Auto search for chat id
  • Add the options for
    • Skip download messages: skipmess
    • Skip download images: skipimg
    • Use Chat ID instead of user display name: usechatid
  • Add Darkmode for the final output. Adjust body to center.

Purpose and output

This project retrieves a full chat history (messages and uploaded files) and renders it as an HTML.

Requirements

Node.js 10 (or higher). Tested on macOS and Windows, but will most likely run on Linux too.

Setup

Like any other JS project, clone this repo and run the following command to install dependencies:

npm install

Run

To backup a chat with friend's display name, run:

npm run start 

To backup a chat with chat id (How to get chat id), run

npm run start usechatid

To skip download messages, run

npm run start skipmess

To skip download messages and images run

npm run start skipmess skipimg

This will ask several questions:

Chat ID

Chat Id: - If you use usechatid option, the program need chat id inorder to get the messages. Please login into MS Teams in Web browser: https://teams.microsoft.com/. Chose a chat or group or even team (channel) There will be something like that in the URL: teams.microsoft.com/_#/conversations/19:<somee_id>@thread.v2?ctx=chat ->

19:<some_id>@thread.v2 will be your chat id

Your display name: - Your display name. Example: John. If there are similar name in the company, the sugesst list will appear, you just need to re-run the program again with the correct one.

Friend's display name: - Friend's display name. Name of the guys that you want to backup chat messages.

Auth token (JWT) - this is needed for calling Microsoft Graph APIs.

  1. Go to https://developer.microsoft.com/en-us/graph/graph-explorer. At the top right side, under User icon, click it to sign-in.
  2. After having logged in, on the right side (where you clicked for login), click on the User's Icon and then click Consent to permissions. Enable Chat.Read and User.ReadBasic.All
  3. In the Main Window, you will see multilples tab name like Request body, Request headers, etc. Click on the tab Access token . Copy this value.

Note:

  • Your name, when first inputed, will be cached, for later use. If you want to clear it. Please remove the folder: teams-chat-backup\dat\
  • You Access Token (JWT): when first inputed, will be cached for later use

The out put will be

The exported folder (will be created in the teams-chat-backup\out\ directory in this project). And the name of sub folder is the name of your friend's displayname.

Output

An exported chat contains:

  • messages-#####.json: these are the pages of messages. Page 0000 is the most recent one (pages and messages within are in reverse order).
  • image-#####: these are images uploaded in the chat
  • index.html: is the full history rendered into a simple HTML template, referring to the downloaded images. This is the file you want for viewing.

To Do

  • Make an easier way of obtaining a token.
  • Add support for bot messages (for example a form).