Skip to main content
Glama

Server Configuration

Describes the environment variables required to run the server.

NameRequiredDescriptionDefault

No arguments

Capabilities

Features and capabilities supported by this server

CapabilityDetails
tools
{
  "listChanged": true
}

Tools

Functions exposed to the LLM to take actions

NameDescription
loginA

Authenticate with Microsoft using device code flow

logoutB

Log out from Microsoft account

verify-loginB

Check current Microsoft authentication status

list-accountsB

List all available Microsoft accounts

select-accountC

Select a specific Microsoft account to use

remove-accountC

Remove a Microsoft account from the cache

delete-onedrive-fileC

Delete navigation property items for drives

list-folder-filesB

Return a collection of DriveItems in the children relationship of a DriveItem. DriveItems with a non-null folder or package facet can have one or more child DriveItems.

download-onedrive-file-contentC

The content stream, if the item represents a file.

upload-file-contentD

The content stream, if the item represents a file.

list-excel-worksheetsB

Represents a collection of worksheets associated with the workbook. Read-only.

create-excel-chartC

Creates a new chart.

format-excel-rangeC

Update the navigation property format in drives

sort-excel-rangeC

Update the navigation property sort in drives

get-excel-rangeC

Invoke function range

get-drive-root-itemB

The root folder of the drive. Read-only.

get-current-userA

Retrieve the properties and relationships of user object. This operation returns by default only a subset of the more commonly used properties for each user. These default properties are noted in the Properties section. To get properties that are not returned by default, do a GET operation for the user and specify the properties in a $select OData query option. Because the user resource supports extensions, you can also use the GET operation to get custom properties and extension data in a user instance. Customers through Microsoft Entra ID for customers can also use this API operation to retrieve their details.

list-calendarsB

Get all the user's calendars (/calendars navigation property), get the calendars from the default calendar group or from a specific calendar group.

list-specific-calendar-eventsC

The events in the calendar. Navigation property. Read-only.

create-specific-calendar-eventA

Use this API to create a new event in a calendar. The calendar can be one for a user, or the default calendar of a Microsoft 365 group.

💡 TIP: CRITICAL: Do not try to guess the email address of the recipients. Use the list-users tool to find the email address of the recipients.

get-specific-calendar-eventC

The events in the calendar. Navigation property. Read-only.

update-specific-calendar-eventC

Update the navigation property events in me

💡 TIP: CRITICAL: Do not try to guess the email address of the recipients. Use the list-users tool to find the email address of the recipients.

delete-specific-calendar-eventC

Delete navigation property events for me

get-calendar-viewB

Get the occurrences, exceptions, and single instances of events in a calendar view defined by a time range, from the user's default calendar, or from some other calendar of the user.

list-outlook-contactsC

Get a contact collection from the default contacts folder of the signed-in user. There are two scenarios where an app can get contacts in another user's contact folder:

create-outlook-contactB

Add a contact to the root Contacts folder or to the contacts endpoint of another contact folder.

get-outlook-contactB

Retrieve the properties and relationships of a contact object. There are two scenarios where an app can get a contact in another user's contact folder:

update-outlook-contactB

Update the properties of a contact object.

delete-outlook-contactB

Delete a contact.

list-drivesB

Retrieve the list of Drive resources available for a target User, Group, or Site.

list-calendar-eventsB

Get a list of event objects in the user's mailbox. The list contains single instance meetings and series masters. To get expanded event instances, you can get the calendar view, or get the instances of an event. Currently, this operation returns event bodies in only HTML format. There are two scenarios where an app can get events in another user's calendar:

create-calendar-eventD

Create one or more multi-value extended properties in a new or existing instance of a resource. The following user resources are supported: The following group resources are supported: See Extended properties overview for more information about when to use open extensions or extended properties, and how to specify extended properties.

💡 TIP: CRITICAL: Do not try to guess the email address of the recipients. Use the list-users tool to find the email address of the recipients.

get-calendar-eventB

Get the properties and relationships of the specified event object. Currently, this operation returns event bodies in only HTML format. There are two scenarios where an app can get an event in another user's calendar: Since the event resource supports extensions, you can also use the GET operation to get custom properties and extension data in an event instance.

update-calendar-eventB

Update the properties of the event object.

💡 TIP: CRITICAL: Do not try to guess the email address of the recipients. Use the list-users tool to find the email address of the recipients.

delete-calendar-eventA

Removes the specified event from the containing calendar. If the event is a meeting, deleting the event on the organizer's calendar sends a cancellation message to the meeting attendees.

list-mail-foldersA

Get the mail folder collection directly under the root folder of the signed-in user. The returned collection includes any mail search folders directly under the root. By default, this operation does not return hidden folders. Use a query parameter includeHiddenFolders to include them in the response. This operation does not return all mail folders in a mailbox, only the child folders of the root folder. To return all mail folders in a mailbox, each child folder must be traversed separately.

list-mail-folder-messagesA

Get all the messages in the specified user's mailbox, or those messages in a specified folder in the mailbox.

💡 TIP: CRITICAL: When searching emails, the $search parameter value MUST be wrapped in double quotes. Format: $search="your search query here". Use KQL (Keyword Query Language) syntax to search specific properties: 'from:', 'subject:', 'body:', 'to:', 'cc:', 'bcc:', 'attachment:', 'hasAttachments:', 'importance:', 'received:', 'sent:'. Examples: $search="from:john@example.com" | $search="subject:meeting AND hasAttachments:true" | $search="body:urgent AND received>=2024-01-01" | $search="from:alice AND importance:high". Remember: ALWAYS wrap the entire search expression in double quotes! Reference: https://learn.microsoft.com/en-us/graph/search-query-parameter

list-mail-messagesD

Get an open extension (openTypeExtension object) identified by name or fully qualified name. The table in the Permissions section lists the resources that support open extensions. The following table lists the three scenarios where you can get an open extension from a supported resource instance.

💡 TIP: CRITICAL: When searching emails, the $search parameter value MUST be wrapped in double quotes. Format: $search="your search query here". Use KQL (Keyword Query Language) syntax to search specific properties: 'from:', 'subject:', 'body:', 'to:', 'cc:', 'bcc:', 'attachment:', 'hasAttachments:', 'importance:', 'received:', 'sent:'. Examples: $search="from:john@example.com" | $search="subject:meeting AND hasAttachments:true" | $search="body:urgent AND received>=2024-01-01" | $search="from:john AND importance:high". Remember: ALWAYS wrap the entire search expression in double quotes! Reference: https://learn.microsoft.com/en-us/graph/search-query-parameter

create-draft-emailD

Create an open extension (openTypeExtension object) and add custom properties in a new or existing instance of a resource. You can create an open extension in a resource instance and store custom data to it all in the same operation, except for specific resources. The table in the Permissions section lists the resources that support open extensions.

get-mail-messageA

Get the properties and relationships of the eventMessage object. Apply the $expand parameter on the event navigation property to get the associated event in an attendee's calendar. Currently, this operation returns event message bodies in only HTML format.

delete-mail-messageB

Delete eventMessage.

list-mail-attachmentsB

Retrieve a list of attachment objects.

add-mail-attachmentC

Use this API to create a new Attachment. An attachment can be one of the following types: All these types of attachment resources are derived from the attachment resource.

get-mail-attachmentB

Read the properties, relationships, or raw contents of an attachment that is attached to a user event, message, or group post. An attachment can be one of the following types: All these types of attachments are derived from the attachment resource.

delete-mail-attachmentB

Delete navigation property attachments for me

move-mail-messageA

Move a message to another folder within the specified user's mailbox. This creates a new copy of the message in the destination folder and removes the original message.

list-onenote-notebooksB

Retrieve a list of notebook objects.

list-onenote-notebook-sectionsB

Retrieve a list of onenoteSection objects from the specified notebook.

create-onenote-pageA

Create a new OneNote page in the default section of the default notebook. To create a page in a different section in the default notebook, you can use the sectionName query parameter. Example: ../onenote/pages?sectionName=My%20section The POST /onenote/pages operation is used only to create pages in the current user's default notebook. If you're targeting other notebooks, you can create pages in a specified section.

get-onenote-page-contentC

The page's HTML content.

list-onenote-section-pagesB

Retrieve a list of page objects from the specified section.

list-planner-tasksB

Retrieve a list of plannertask objects assigned to a User.

send-mailA

Send the message specified in the request body using either JSON or MIME format. When using JSON format, you can include a file attachment in the same sendMail action call. When using MIME format: This method saves the message in the Sent Items folder. Alternatively, create a draft message to send later. To learn more about the steps involved in the backend before a mail is delivered to recipients, see here.

💡 TIP: CRITICAL: Do not try to guess the email address of the recipients. Use the list-users tool to find the email address of the recipients.

list-todo-task-listsB

Get a list of the todoTaskList objects and their properties.

list-todo-tasksB

Get the todoTask resources from the tasks navigation property of a specified todoTaskList.

create-todo-taskB

Create a new task object in a specified todoTaskList.

get-todo-taskB

Read the properties and relationships of a todoTask object.

update-todo-taskC

Update the properties of a todoTask object.

delete-todo-taskA

Delete a todoTask object.

get-planner-planB

Retrieve the properties and relationships of a plannerplan object.

list-plan-tasksB

Retrieve a list of plannerTask objects associated with a plannerPlan object.

create-planner-taskC

Create a new plannerTask.

get-planner-taskB

Retrieve the properties and relationships of plannerTask object.

update-planner-taskC

Update the properties of plannerTask object.

update-planner-task-detailsB

Update the properties of plannerTaskDetails object.

search-queryB

Runs the query specified in the request body. Search results are provided in the response.

Prompts

Interactive templates invoked by user choice

NameDescription

No prompts

Resources

Contextual data attached and managed by the client

NameDescription

No resources

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/Softeria/ms-365-mcp-server'

If you have feedback or need assistance with the MCP directory API, please join our Discord server