This project contains a Microsoft Graph connector. Using Graph connectors you can import external data into Microsoft 365 and Microsoft Search. Ingested content is available to Microsoft Copilot for Microsoft 365, Microsoft Search and other Microsoft 365 services.
When developing the Graph connector, you can use Dev Proxy to simulate Microsoft Graph API responses. This allows you to develop and test the connector without having to connect to the Microsoft Graph API and wait for the connection to be provisioned/removed.
- Create a new Microsoft Entra app registration (uses CLI for Microsoft 365):
- Bash:
chmod +x ./setup.sh ./setup.sh 
- PowerShell:
./setup.ps1
 
- Bash:
- Restore dependencies: npm install
- Complete project
- In config.ts:- Complete schema definition
- Define URL to item resolvers (optional but recommended)
 
- In loadContent.ts:- Implement the loadContentfunction to load content to import
- Implement the getDocIdfunction to generate a unique ID for each document
- Update the transformfunction that convert documents from the external system into Microsoft Graph external items, with the schema you defined previously
 
- Implement the 
 
- In 
- Build project: npm run build
- Create connection: npm run start:createConnection
- Load content: npm run start:loadContent
If you want to simulate Microsoft Graph API responses using Dev Proxy:
- Install Dev Proxy
- Open terminal
- Change the working directory to the project root
- Start Dev Proxy: devproxy
 
- Open a new terminal
- Change the working directory to the project root
- Create connection: npm run start:createConnection:proxy
- Load content: npm run start:loadContent:proxy
 
- When finished, stop Dev Proxy:
- In the terminal where Dev Proxy is running, press Ctrl+Cto stop Dev Proxy
 
- In the terminal where Dev Proxy is running, press 
.
├── .devproxy
│   └── graph-connector-mocks.json
├── .gitignore
├── .vscode
│   ├── extensions.json
│   └── launch.json
├── README.md
├── devproxyrc.json
├── package.json
├── resultLayout.json
├── setup.ps1
├── setup.sh
├── src
│   ├── completeJobWithDelayMiddleware.ts
│   ├── config.ts
│   ├── createConnection.ts
│   ├── graphClient.ts
│   └── loadContent.ts
└── tsconfig.json (TypeScript configuration)
This file contains the Dev Proxy Microsoft Graph API mocks for the Graph connector.
This file contains the Dev Proxy configuration for use with the project.
This file contains the result layout (Adaptive Card) for Microsoft Search.
These scripts create a new Microsoft Entra app registration using CLI for Microsoft 365. Both scripts invoke CLI using npx, so that you don't need to manually install CLI for Microsoft 365 before you run these scripts.
This file contains the Microsoft Graph SDK Middleware to handle the long-running job of provisioning the connection's schema. The middleware waits for the job to complete before continuing. It waits the recommended 60 seconds before checking the job status.
This file contains the Graph connector configuration. You can define the schema for the external items, the URL to the item resolvers, and the connection name.
This file contains the code to create the external connection and provision the schema.
This file contains the Microsoft Graph SDK client instantiation code.
This file contains the code to load content to import. The code is organized following the Extract-Transform-Load (ETL) principle.
This file contains the TypeScript configuration for the project.
This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.
When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.
This project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft trademarks or logos is subject to and must follow Microsoft's Trademark & Brand Guidelines. Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship. Any use of third-party trademarks or logos are subject to those third-party's policies.