Microsoft Search
Quick Start
Configure Azure App
Register App
Go to Microsoft Azure Portal and navigate to App registrations
.
Register a new app with the option New registration
.
data:image/s3,"s3://crabby-images/7030f/7030fd44af6a02dbb46c2b915600127a6c71ba38" alt="App Registration"
data:image/s3,"s3://crabby-images/f797e/f797ef5f14a94861ac682651bbd576eb355d749e" alt="New Registration"
Type the name and select the option Accounts in this organizational directory only
and submit the registration with register
.
Omit the Redirect URI
for your app.
data:image/s3,"s3://crabby-images/60309/60309e71e781e7e26c1c107c54d471430d7f3c8a" alt="Your App Registration"
Create Client Secret
Add Client Secret under Certificates & secrets → Client secrets
.
data:image/s3,"s3://crabby-images/00da1/00da1d9abac21421df22032344007938f75457a0" alt="Client Secrets"
Submit your new client secret with the option New client secret
.
data:image/s3,"s3://crabby-images/7ea51/7ea51bd3289ab2f619495410233e8cc198954c89" alt="Add Client Secret"
Create Certificate
If you prefer to authenticate with a certificate instead of a secret, first receive a certificate.
For example, create a self-signed certificate keystore using the Java keytool with the following command adapted to your needs:
Linux:
$JAVA_HOME/bin/keytool -genkey -keyalg RSA -keysize 2048 -dname
"CN=servername,CN=company,CN=com,O=Company,L=City,C=XY" -validity 7305 -alias
selfsignedFQDNcert -ext san=dns:servername -keypass changeit -keystore
mykeystore.jks -storepass changeit
Windows:
"%JAVA_HOME%\bin\keytool" -genkey -keyalg RSA -keysize 2048 -dname
"CN=servername,CN=company,CN=com,O=Company,L=City,C=XY" -validity 7305 -alias
selfsignedFQDNcert -ext san=dns:servername -keypass changeit -keystore
mykeystore.jks -storepass changeit
Export the public certificate to upload in the Azure portal:
Linux:
$JAVA_HOME/bin/keytool -export -alias selfsignedFQDNcert -keystore
mykeystore.jks -rfc -file publickey.cert
Windows:
"%JAVA_HOME%\bin\keytool" -export -alias selfsignedFQDNcert -keystore
mykeystore.jks -rfc -file publickey.cert
You may extract the private certificate to use it instead of the keystore:
Linux:
$JAVA_HOME/bin/keytool -importkeystore -srckeystore mykeystore.jks
-destkeystore keystore_export.p12 -deststoretype PKCS12 -srcalias
selfsignedFQDNcert -deststorepass changeit -destkeypass changeit
Windows:
"%JAVA_HOME%\bin\keytool" -importkeystore -srckeystore mykeystore.jks
-destkeystore keystore_export.p12 -deststoretype PKCS12 -srcalias
selfsignedFQDNcert -deststorepass changeit -destkeypass changeit
Define API Permissions
The connector requires access to the Microsoft Search External Connection/Item API for synchronizing external content items and to Users/Groups API for synchronizing principal information.
To assign the required permission to your app, navigate to API permissions
inside your app menu.
data:image/s3,"s3://crabby-images/8118f/8118ff766d1ae5123251dbfd13807531ed8e88a3" alt="New Registration"
With the option Add a permission
, you can assign new permissions to your app.
data:image/s3,"s3://crabby-images/67513/67513e0f59b09e7b2338e4c5bb9f372a09409d0d" alt="Add Permission"
Register all permissions as Microsoft Graph API Application permission.
data:image/s3,"s3://crabby-images/6ae30/6ae30018c2dfcfa8b62a18f1d078dad7f364ea91" alt="Graph API Application Permission"
Ensure you grant the connector Application Permissions, not Delegated Permissions. It will not work with delegated permissions. |
Add External Connection/Item Permissions
To access the Microsoft Search API, following permissions are required by the app:
-
ExternalConnection.ReadWrite.OwnedBy
-
ExternalItem.ReadWrite.All
-
ExternalItem.ReadWrite.OwnedBy
data:image/s3,"s3://crabby-images/f6f08/f6f08f01b16f57187226f243dadabcfdb9d6c484" alt="External Connection/Item Permissions"
Add Users and Groups Permissions
To access user and group information for your tenant, the app requires following permissions:
-
Group.Read.All
-
User.Read.All
data:image/s3,"s3://crabby-images/06afa/06afabcc77659979cd650da8e40baac833b42576" alt="User Permission"
data:image/s3,"s3://crabby-images/195b3/195b348bcd3a1166cd51b8b277c5172c94eb79da" alt="Group Permission"
Make sure to grant admin consent for all permissions. |
Configure External Connection
The item metadata that the connector sends to Microsoft Search is defined by a schema, this schema is generated within Microsoft Search and defines the fields used by Microsoft Search. Therefore, the schema must be generated before a connector can run a traversal to ingest documents. This section describes the steps required to create a default schema within Microsoft Search, the request to generate the schema can be modified as required prior to creating the schema. There are 3 steps to setup Microsoft Search prior to using the connector to ingest documents:
-
Authenticate against Microsoft Search
-
Create a Connection ID within Microsoft Search
-
Generate a schema within the Connection ID
These steps are performed via the Microsoft Search API, the following guide provides a Postman Workspace for calling the Microsoft Search API endpoints:
The Connection ID can only contain ASCII alphanumeric characters, and must be between 3 and 32 characters long. e.g. 2ecbffec1da74fab8057b4530d3c442a.
Create new Connection
Headers
Content-Type:application/json
Authentication:Access Token
Body Request
{
"name": "Raytion Microsoft Search Connector for Filesystem 1.0",
"description": "Raytion Microsoft Search Connector for Filesystem 1.0",
"id": "2ecbffec1da74fab8057b4530d3c442a"
}
Create default Schema
Authentication:Access Token
Headers
-
Content-Type:application/json
-
prefer:respond-async
Body Request:
{
"baseType": "microsoft.graph.externalItem",
"properties": [
{
"name": "author",
"type": "string",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true",
"labels": [
"lastModifiedBy"
]
},
{
"name": "breadcrumbs",
"type": "stringCollection",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "breadcrumbUrls",
"type": "stringCollection",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "clickUrl",
"type": "string",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true",
"labels": [
"url"
]
},
{
"name": "contributors",
"type": "stringCollection",
"isSearchable": "true",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "contributorsRefiner",
"type": "stringCollection",
"isQueryable": "true",
"isRetrievable": "true",
"isRefinable": "true",
"labels": [
"authors"
]
},
{
"name": "createdDate",
"type": "dateTime",
"isQueryable": "true",
"isRetrievable": "true",
"labels": [
"createdDateTime"
],
"isRefinable": "true"
},
{
"name": "fileExtension",
"type": "string",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true",
"labels": [
"fileExtension"
]
},
{
"name": "fileName",
"type": "string",
"isSearchable": "true",
"isQueryable": "true",
"isRetrievable": "true",
"labels": [
"fileName"
]
},
{
"name": "fileType",
"type": "stringCollection",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true",
"isRefinable": "true"
},
{
"name": "iconUrl",
"type": "string",
"isSearchable": "false",
"isQueryable": "false",
"isRetrievable": "true"
},
{
"name": "itemType",
"type": "string",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "itemTypeRefiner",
"type": "stringCollection",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true",
"isRefinable": "true"
},
{
"name": "keywords",
"type": "string",
"isSearchable": "true",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "keywordsRefiner",
"type": "stringCollection",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true",
"isRefinable": "true"
},
{
"name": "labels",
"type": "stringCollection",
"isSearchable": "true",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "labelsRefiner",
"type": "stringCollection",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true",
"isRefinable": "true"
},
{
"name": "languages",
"type": "stringCollection",
"isQueryable": "true",
"isRetrievable": "true",
"isRefinable": "true"
},
{
"name": "lastModifiedDate",
"type": "dateTime",
"isQueryable": "true",
"isRetrievable": "true",
"labels": [
"lastModifiedDateTime"
],
"isRefinable": "true"
},
{
"name": "mimeType",
"type": "string",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "parentItemUrl",
"type": "string",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "parentItemTitle",
"type": "string",
"isSearchable": "true",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "previewUrl",
"type": "string",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "rootItemTitle",
"type": "string",
"isSearchable": "true",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "rootItemTitleRefiner",
"type": "stringCollection",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true",
"isRefinable": "true"
},
{
"name": "rootItemUrl",
"type": "string",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "sourceItemType",
"type": "string",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "sourceName",
"type": "string",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "sourceUrl",
"type": "string",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "sourceNameRefiner",
"type": "stringCollection",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true",
"isRefinable": "true"
},
{
"name": "spaceCategories",
"type": "stringCollection",
"isSearchable": "false",
"isQueryable": "true",
"isRetrievable": "true"
},
{
"name": "title",
"type": "string",
"isSearchable": "true",
"isQueryable": "true",
"isRetrievable": "true",
"labels": [
"title"
]
}
]
}