Contacts.ReadWrite
Allows the app to create, read, update, and delete user contacts.
Administrators can configure application access policy to limit app access to specific mailboxes and not to all the mailboxes in the organization, even if the app has been granted the Contacts.ReadWrite application permission.
Merill's Note
For an app to access data in Microsoft Graph, the user or administrator must grant it the permissions it needs. This article lists all the Microsoft Graph APIs and your tenant data that can be accessed by the application (vendor/developer) if you consent to the
Contacts.ReadWritepermission.If you need to create an audit report of the permissions granted to all the apps in your tenant, you can run the
Export-MsIdAppConsentGrantReportcommand. See How To: Run a quick OAuth app audit of your tenant
| Category | Application | Delegated | 
|---|---|---|
| Identifier | 6918b873-d17a-4dc1-b314-35f528134491 | d56682ec-c09e-4743-aaf4-1a3aac4caa21 | 
| DisplayText | Read and write contacts in all mailboxes | Have full access to user contacts | 
| Description | Allows the app to create, read, update, and delete all contacts in all mailboxes without a signed-in user. | Allows the app to create, read, update, and delete user contacts. | 
| AdminConsentRequired | Yes | No | 
Graph Methods
 → API supports delegated access (access on behalf of a user)
 → API supports app-only access (access without a user)
| Methods | |
|---|---|
 → API supports delegated access (access on behalf of a user)
 → API supports app-only access (access without a user)
| Methods | |
|---|---|
 → Command supports delegated access (access on behalf of a user)
 → Command supports app-only access (access without a user)
| Commands | |
|---|---|
 → Command supports delegated access (access on behalf of a user)
 → Command supports app-only access (access without a user)
| Commands | |
|---|---|
Resources
Granting this permission allows the calling application to access (and/or update) the following information in your tenant.
- basetask
- basetasklist
- calendar
- contact
- contactFolder
- device
- driveItem
- emailAddress
- event
- extended-properties-overview
- group
- mailFolder
- message
- multiValueLegacyExtendedProperty
- opentypeextension
- organization
- outlooktask
- outlooktaskfolder
- phone
- physicalAddress
- post
- profilePhoto
- singleValueLegacyExtendedProperty
- todoTask
- todoTaskList
- typedEmailAddress
- user
- website
Graph reference: basetask
| Property | Type | Description | 
|---|---|---|
| textBody | String | The task body in text format that typically contains information about the task. | 
| bodyLastModifiedDateTime | DateTimeOffset | The date and time when the task was last modified. By default, it is in UTC. You can provide a custom time zone in the request header. The property value uses ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2020 would look like this: '2020-01-01T00:00:00Z'. | 
| completedDateTime | DateTimeOffset | The date when the task was finished. | 
| createdDateTime | DateTimeOffset | The date and time when the task was created. By default, it is in UTC. You can provide a custom time zone in the request header. The property value uses ISO 8601 format. For example, midnight UTC on Jan 1, 2020 would look like this: '2020-01-01T00:00:00Z'. | 
| displayName | String | The name of the task. | 
| dueDateTime | dateTimeTimeZone | The date in the specified time zone that the task is to be finished. | 
| id | String | Unique identifier for the task. By default, this value will not change if a task is moved from one list to another. | 
| importance | importance | The importance of the task. Possible values are: low,normal,high.  The possible values are:low,normal,high. | 
| lastModifiedDateTime | DateTimeOffset | The date and time when the task was last modified. By default, it is in UTC. You can provide a custom time zone in the request header. The property value uses ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2020 would look like this: '2020-01-01T00:00:00Z'. | 
| viewpoint | taskViewpoint | Properties that are personal to a user such as reminderDateTime and categories. | 
| recurrence | patternedRecurrence | The recurrence pattern for the task. | 
| startDateTime | dateTimeTimeZone | The date in the specified time zone when the task is to begin. | 
| status | taskStatus_v2 | Indicates the state or progress of the task. Possible values are: notStarted,inProgress,completed,unknownFutureValue. | 
Graph reference: basetasklist
| Property | Type | Description | 
|---|---|---|
| displayName | String | The name of the task list. | 
| id | String | The identifier of the task list, unique in the user's mailbox. Read-only. | 
Graph reference: calendar
| Property | Type | Description | 
|---|---|---|
| allowedOnlineMeetingProviders | onlineMeetingProviderType collection | Represent the online meeting service providers that can be used to create online meetings in this calendar. Possible values are: unknown,skypeForBusiness,skypeForConsumer,teamsForBusiness. | 
| canEdit | Boolean | trueif the user can write to the calendar,falseotherwise. This property istruefor the user who created the calendar. This property is alsotruefor a user who shared a calendar and granted write access. | 
| canShare | Boolean | trueif the user has permission to share the calendar,falseotherwise. Only the user who created the calendar can share it. | 
| canViewPrivateItems | Boolean | If true, the user can read calendar items that have been marked private,falseotherwise. | 
| changeKey | String | Identifies the version of the calendar object. Every time the calendar is changed, changeKey changes as well. This allows Exchange to apply changes to the correct version of the object. Read-only. | 
| color | calendarColor | Specifies the color theme to distinguish the calendar from other calendars in a UI. The property values are: auto,lightBlue,lightGreen,lightOrange,lightGray,lightYellow,lightTeal,lightPink,lightBrown,lightRed,maxColor. | 
| defaultOnlineMeetingProvider | onlineMeetingProviderType | The default online meeting provider for meetings sent from this calendar. Possible values are: unknown,skypeForBusiness,skypeForConsumer,teamsForBusiness. | 
| hexColor | String | The calendar color, expressed in a hex color code of three hexadecimal values, each ranging from 00 to FF and representing the red, green, or blue components of the color in the RGB color space. If the user has never explicitly set a color for the calendar, this property is empty. Read-only. | 
| id | String | The calendar's unique identifier. Read-only. | 
| isDefaultCalendar | Boolean | trueif this is the default calendar where new events are created by default,falseotherwise. | 
| isRemovable | Boolean | Indicates whether this user calendar can be deleted from the user mailbox. | 
| isTallyingResponses | Boolean | Indicates whether this user calendar supports tracking of meeting responses. Only meeting invites sent from users' primary calendars support tracking of meeting responses. | 
| name | String | The calendar name. | 
| owner | emailAddress | If set, this represents the user who created or added the calendar. For a calendar that the user created or added, the **o | 
Graph reference: contact
| Property | Type | Description | 
|---|---|---|
| assistantName | String | The name of the contact's assistant. | 
| birthday | DateTimeOffset | The contact's birthday. The Timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z | 
| businessAddress | PhysicalAddress | The contact's business address. | 
| businessHomePage | String | The business home page of the contact. | 
| businessPhones | String collection | The contact's business phone numbers. | 
| categories | String collection | The categories associated with the contact. | 
| changeKey | String | Identifies the version of the contact. Every time the contact is changed, ChangeKey changes as well. This allows Exchange to apply changes to the correct version of the object. | 
| children | String collection | The names of the contact's children. | 
| companyName | String | The name of the contact's company. | 
| createdDateTime | DateTimeOffset | The time the contact was created. The Timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z | 
| department | String | The contact's department. | 
| displayName | String | The contact's display name. You can specify the display name in a create or update operation. Note that later updates to other properties may cause an automatically generated value to overwrite the displayName value you have specified. To preserve a pre-existing value, always include it as displayName in an update operation. | 
| emailAddresses | EmailAddress collection | The contact's email addresses. | 
| fileAs | String | The name the contact is filed under. | 
| generation | String | The contact's suffix. | 
| givenName | String | The contact's given name. | 
| homeAddress | PhysicalAddress | The contact's home address. | 
| homePhones | String collection | The contact's home phone numbers. | 
| id | String | The contact's unique identifier. !INCLUDE [outlook-beta-id] Read-only. | 
| imAddresses | String collection | The contact's instant messaging (IM) addresses. | 
| initials | String | The contact's initials. | 
| jobTitle | String | The contact’s job title. | 
| lastModifiedDateTime | DateTimeOffset | The time the contact was modified. The Timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z | 
| manager | String | The name of the contact's manager. | 
| middleName | String | The contact's middle name. | 
| mobilePhone | String | The contact's mobile phone number. | 
| nickName | String | The contact's nickname. | 
| officeLocation | String | The location of the contact's office. | 
| otherAddress | PhysicalAddress | Other addresses for the contact. | 
| parentFolderId | String | The ID of the contact's parent folder. | 
| personalNotes | String | The user's notes about the contact. | 
| profession | String | The contact's profession. | 
| spouseName | String | The name of the contact's spouse/partner. | 
| surname | String | The contact's surname. | 
| title | String | The contact's title. | 
| yomiCompanyName | String | The phonetic Japanese company name of the contact. | 
| yomiGivenName | String | The phonetic Japanese given name (first name) of the contact. | 
| yomiSurname | String | The phonetic Japanese surname (last name) of the contact. | 
Graph reference: contactFolder
| Property | Type | Description | 
|---|---|---|
| displayName | String | The folder's display name. | 
| id | String | Unique identifier of the contact folder. Read-only. | 
| parentFolderId | String | The ID of the folder's parent folder. | 
Graph reference: device
| Property | Type | Description | 
|---|---|---|
| accountEnabled | Boolean | trueif the account is enabled; otherwise,false. Required. Default istrue.Supports $filter(eq,ne,not,in). Only callers with at least the Cloud Device Administrator role can set this property. | 
| alternativeSecurityIds | alternativeSecurityId collection | For internal use only. Not nullable. Supports $filter(eq,not,ge,le). | 
| approximateLastSignInDateTime | DateTimeOffset | The timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z. Read-only. Supports$filter(eq,ne,not,ge,le, andeqonnullvalues) and$orderby. | 
| complianceExpirationDateTime | DateTimeOffset | The timestamp when the device is no longer deemed compliant. The timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z. Read-only. | 
| deviceCategory | String | User-defined property set by Intune to automatically add devices to groups and simplify managing devices. | 
| deviceId | String | Unique identifier set by Azure Device Registration Service at the time of registration. This alternate key can be used to reference the device object. Supports $filter(eq,ne,not,startsWith). | 
| deviceMetadata | String | For internal use only. Set to null. | 
| deviceOwnership | String | Ownership of the device. Intune sets this property. Possible values are: unknown,company,personal. | 
| deviceVersion | Int32 | For internal use only. | 
| displayName | String | The display name for the device. Maximum length is 256 characters. Required. Supports $filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues),$search, and$orderby. | 
| enrollmentProfileName | String | Enrollment profile applied to the device. For example, Apple Device Enrollment Profile,Device enrollment - Corporate device identifiers, orWindows Autopilot profile name. This property is set by Intune. | 
| enrollmentType | String | Enrollment type of the device. Intune sets this property. Possible values are: unknown,userEnrollment,deviceEnrollmentManager,appleBulkWithUser,appleBulkWithoutUser,windowsAzureADJoin,windowsBulkUserless,windowsAutoEnrollment,windowsBulkAzureDomainJoin,windowsCoManagement,windowsAzureADJoinUsingDeviceAuth,appleUserEnrollment,appleUserEnrollmentWithServiceAccount.NOTE: This property might return other values apart from those listed. | 
| extensionAttributes | onPremisesExtensionAttributes | Contains extension attributes 1-15 for the device. The individual extension attributes aren't selectable. These properties are mastered in the cloud and can be set during creation or update of a device object in Microsoft Entra ID. Supports $filter(eq,not,startsWith, andeqonnullvalues). | 
| id | String | The unique identifier for the device. Inherited from directoryObject. Key, Not nullable. Read-only. Supports $filter(eq,ne,not,in). | 
| isCompliant | Boolean | trueif the device complies with Mobile Device Management (MDM) policies; otherwise,false. Read-only. This can only be updated by Intune for any device OS type or by an approved MDM app for Windows OS devices. Supports$filter(eq,ne,not). | 
| isManaged | Boolean | trueif the device is managed by a Mobile Device Management (MDM) app; otherwise,false. This can only be updated by Intune for any device OS type or by an approved MDM app for Windows OS devices. Supports$filter(eq,ne,not). | 
| isManagementRestricted | Boolean | Indicates whether the device is a member of a restricted management administrative unit. If not set, the default value is nulland the default behavior is false. Read-only.To manage a device that's a member of a restricted management administrative unit, the administrator or calling app must be assigned a Microsoft Entra role at the scope of the restricted management administrative unit. Returned only on $select. | 
| isRooted | Boolean | trueif the device is rooted or jail-broken. This property can only be updated by Intune. | 
| managementType | String | The management channel of the device. This property is set by Intune. Possible values are: eas,mdm,easMdm,intuneClient,easIntuneClient,configurationManagerClient,configurationManagerClientMdm,configurationManagerClientMdmEas,unknown,jamf,googleCloudDevicePolicyController. | 
| manufacturer | String | Manufacturer of the device. Read-only. | 
| mdmAppId | String | Application identifier used to register device into MDM. Read-only. Supports $filter(eq,ne,not,startsWith). | 
| model | String | Model of the device. Read-only. | 
| onPremisesLastSyncDateTime | DateTimeOffset | The last time at which the object was synced with the on-premises directory. The Timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00ZRead-only. Supports$filter(eq,ne,not,ge,le,in). | 
| onPremisesSecurityIdentifier | String | The on-premises security identifier (SID) for the user who was synchronized from on-premises to the cloud. Read-only. Returned only on $select. Supports$filter(eq). | 
| onPremisesSyncEnabled | Boolean | trueif this object is synced from an on-premises directory;falseif this object was originally synced from an on-premises directory but is no longer synced;nullif this object has never been synced from an on-premises directory (default). Read-only. Supports$filter(eq,ne,not,in, andeqonnullvalues). | 
| operatingSystem | String | The type of operating system on the device. Required. Supports $filter(eq,ne,not,ge,le,startsWith, andeqonnullvalues). | 
| operatingSystemVersion | String | The version of the operating system on the device. Required. Supports $filter(eq,ne,not,ge,le,startsWith, andeqonnullvalues). | 
| physicalIds | String collection | For internal use only. Not nullable. Supports $filter(eq,not,ge,le,startsWith,/$count eq 0,/$count ne 0). | 
| profileType | deviceProfileType | The profile type of the device. Possible values: RegisteredDevice(default),SecureVM,Printer,Shared,IoT. | 
| registrationDateTime | DateTimeOffset | Date and time of when the device was registered. The timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z. Read-only. | 
| systemLabels | String collection | List of labels applied to the device by the system. Supports $filter(/$count eq 0,/$count ne 0). | 
| trustType | String | Type of trust for the joined device. Read-only. Possible values: Workplace(indicates *b | 
Graph reference: driveItem
| Property | Type | Description | 
|---|---|---|
| audio | [audio][] | Audio metadata, if the item is an audio file. Read-only. Read-only. Only on OneDrive Personal. | 
| bundle | [bundle][] | Bundle metadata, if the item is a bundle. Read-only. | 
| content | Stream | The content stream, if the item represents a file. | 
| createdBy | [identitySet][] | Identity of the user, device, and application that created the item. Read-only. | 
| createdDateTime | DateTimeOffset | Date and time of item creation. Read-only. | 
| cTag | String | An eTag for the content of the item. This eTag isn't changed if only the metadata is changed. Note This property isn't returned if the item is a folder. Read-only. | 
| deleted | [deleted][] | Information about the deleted state of the item. Read-only. | 
| description | String | Provides a user-visible description of the item. Read-write. Only on OneDrive Personal. | 
| eTag | String | eTag for the entire item (metadata + content). Read-only. | 
| file | [file][] | File metadata, if the item is a file. Read-only. | 
| fileSystemInfo | [fileSystemInfo][] | File system information on client. Read-write. | 
| folder | [folder][] | Folder metadata, if the item is a folder. Read-only. | 
| id | String | The unique identifier of the item within the Drive. Read-only. | 
| image | [image][] | Image metadata, if the item is an image. Read-only. | 
| lastModifiedBy | [identitySet][] | Identity of the user, device, and application that last modified the item. Read-only. | 
| lastModifiedDateTime | DateTimeOffset | Date and time the item was last modified. Read-only. | 
| location | [geoCoordinates][] | Location metadata, if the item has location data. Read-only. | 
| malware | [malware][] | Malware metadata, if the item was detected to contain malware. Read-only. | 
| name | String | The name of the item (filename and extension). Read-write. | 
| package | [package][] | If present, indicates that this item is a package instead of a folder or file. Packages are treated like files in some contexts and folders in others. Read-only. | 
| parentReference | [itemReference][] | Parent information, if the item has a parent. Read-write. | 
| pendingOperations | [pendingOperations][] | If present, indicates that one or more operations that might affect the state of the driveItem are pending completion. Read-only. | 
| photo | [photo][] | Photo metadata, if the item is a photo. Read-only. | 
| publication | [publicationFacet][] | Provides information about the published or checked-out state of an item, in locations that support such actions. This property isn't returned by default. Read-only. | 
| remoteItem | [remoteItem][] | Remote item data, if the item is shared from a drive other than the one being accessed. Read-only. | 
| root | [root][] | If this property is non-null, it indicates that the driveItem is the top-most driveItem in the drive. | 
| searchResult | [searchResult][] | Search metadata, if the item is from a search result. Read-only. | 
| shared | [shared][] | Indicates that the item was shared with others and provides information about the shared state of the item. Read-only. | 
| sharepointIds | [sharepointIds][] | Returns identifiers useful for SharePoint REST compatibility. Read-only. | 
| size | Int64 | Size of the item in bytes. Read-only. | 
| specialFolder | [specialFolder][] | If the current item is also available as a special folder, this facet is returned. Read-only. | 
| video | [video][] | Video metadata, if the item is a video. Read-only. | 
| webDavUrl | String | WebDAV compatible URL for the item. | 
| webUrl | String | URL that displays the resource in the browser. Read-only. | 
Graph reference: emailAddress
| Property | Type | Description | 
|---|---|---|
| address | String | The email address of the person or entity. | 
| name | String | The display name of the person or entity. | 
Graph reference: event
| Property | Type | Description | 
|---|---|---|
| allowNewTimeProposals | Boolean | trueif the meeting organizer allows invitees to propose a new time when responding; otherwise,false. Optional. The default istrue. | 
| attendees | Attendee collection | The collection of attendees for the event. | 
| body | ItemBody | The body of the message associated with the event. It can be in HTML or text format. | 
| bodyPreview | String | The preview of the message associated with the event. It's in text format. | 
| cancelledOccurrences | String collection | Contains occurrenceId property values of canceled instances in a recurring series, if the event is the series master. Instances in a recurring series that are canceled are called canceled occurences. Returned only on $selectin a Get operation which specifies the ID (seriesMasterId property value) of a series master event. | 
| categories | String collection | The categories associated with the event. Each category corresponds to the displayName property of an outlookCategory defined for the user. | 
| changeKey | String | Identifies the version of the event object. Every time the event is changed, ChangeKey changes as well. It allows Exchange to apply changes to the correct version of the object. | 
| createdDateTime | DateTimeOffset | The Timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z | 
| end | DateTimeTimeZone | The date, time, and time zone that the event ends. By default, the end time is in UTC. | 
| hasAttachments | Boolean | Set to true if the event has attachments. | 
| hideAttendees | Boolean | When set to true, each attendee only sees themselves in the meeting request and meeting Tracking list. The default is false. | 
| iCalUId | String | A unique identifier for an event across calendars. This ID is different for each occurrence in a recurring series. Read-only. | 
| id | String | Unique identifier for the event. !INCLUDE [outlook-beta-id] Case-sensitive and read-only. | 
| importance | String | The importance of the event. The possible values are: low,normal,high. | 
| isAllDay | Boolean | Set to true if the event lasts all day. If true, regardless of whether it's a single-day or multi-day event, start, and endtime must be set to midnight and be in the same time zone. | 
| isCancelled | Boolean | Set to true if the event has been canceled. | 
| isDraft | Boolean | Set to true if the user has updated the meeting in Outlook but hasn't sent the updates to attendees. Set to false if all changes are sent, or if the event is an appointment without any attendees. | 
| isOnlineMeeting | Boolean | Trueif this event has online meeting information (that is, onlineMeeting points to an onlineMeetingInfo resource),falseotherwise. Default isfalse(onlineMeeting isnull). Optional.After you set isOnlineMeeting to true, Microsoft Graph initializes onlineMeeting. Subsequently, Outlook ignores any further changes to isOnlineMeeting, and the meeting remains available online. | 
| isOrganizer | Boolean | Set to true if the calendar owner (specified by the owner property of the calendar) is the organizer of the event (specified by the organizer property of the event). It also applies if a delegate organized the event on behalf of the owner. | 
| isReminderOn | Boolean | Set to true if an alert is set to remind the user of the event. | 
| lastModifiedDateTime | DateTimeOffset | The Timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z | 
| location | Location | The location of the event. | 
| locations | Location collection | The locations where the event is held or attended from. The location and locations properties always correspond with each other. If you update the location property, any prior locations in the locations collection are removed and replaced by the new location value. | 
| onlineMeeting | OnlineMeetingInfo | Details for an attendee to join the meeting online. The default is null. Read-only. After you set the isOnlineMeeting and onlineMeetingProvider properties to enable a meeting online, Microsoft Graph initializes onlineMeeting. When set, the meeting remains available online, and you can't change the isOnlineMeeting, onlineMeetingProvider, and onlneMeeting properties again. | 
| onlineMeetingProvider | onlineMeetingProviderType | Represents the online meeting service provider. By default, onlineMeetingProvider is unknown. The possible values areunknown,teamsForBusiness,skypeForBusiness, andskypeForConsumer. Optional.After you set onlineMeetingProvider, Microsoft Graph initializes onlineMeeting. Subsequently, you can't change onlineMeetingProvider again, and the meeting remains available online. | 
| onlineMeetingUrl | String | A URL for an online meeting. The property is set only when an organizer specifies in Outlook that an event is an online meeting such as Skype. Read-only. To access the URL to join an online meeting, use joinUrl which is exposed via the onlineMeeting property of the event. The onlineMeetingUrl property will be deprecated in the future. | 
| organizer | Recipient | The organizer of the event. | 
| originalEndTimeZone | String | The end time zone that was set when the event was created. A value of tzone://Microsoft/Customindicates that a legacy custom time zone was set in desktop Outlook. | 
| originalStart | DateTimeOffset | Represents the start time of an event when it's initially created as an occurrence or exception in a recurring series. This property is not returned for events that are single instances. Its date and time information is expressed in ISO 8601 format and is always in UTC. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z | 
| originalStartTimeZone | String | The start time zone that was set when the event was created. A value of tzone://Microsoft/Customindicates that a legacy custom time zone was set in desktop Outlook. | 
| recurrence | PatternedRecurrence | The recurrence pattern for the event. | 
| reminderMinutesBeforeStart | Int32 | The number of minutes before the event start time that the reminder alert occurs. | 
| responseRequested | Boolean | Default is true, which represents the organizer would like an invitee to send a response to the event. | 
| responseStatus | ResponseStatus | Indicates the type of response sent in response to an event message. | 
| sensitivity | String | Possible values are: normal,personal,private, andconfidential. | 
| seriesMasterId | String | The ID for the recurring series master item, if this event is part of a recurring series. | 
| showAs | String | The status to show. Possible values are: free,tentative,busy,oof,workingElsewhere,unknown. | 
| start | DateTimeTimeZone | The start date, time, and time zone of the event. By default, the start time is in UTC. | 
| subject | String | The text of the event's subject line. | 
| transactionId | String | A custom identifier specified by a client app for the server to avoid redundant POST operations in case of client retries to create the same event. It's useful when low network connectivity causes the client to time out before receiving a response from the server for the client's prior create-event request. After you set transactionId when creating an event, you can't change transactionId in a subsequent update. This property is only returned in a response payload if an app has set it. Optional. | 
| type | String | The event type. Possible values are: singleInstance,occurrence,exception,seriesMaster. Read-only | 
| webLink | String | The URL to open the event in Outlook on the web. Outlook on the web opens the event in the browser if you are signed in to your mailbox. Otherwise, Outlook on the web prompts you to sign in. This URL can't be accessed from within an iFrame. | 
Graph reference: extended-properties-overview
Graph reference: group
| Property | Type | Description | 
|---|---|---|
| allowExternalSenders | Boolean | Indicates if people external to the organization can send messages to the group. The default value is false.Returned only on $select. Supported only on the Get group API (GET /groups/{ID}). | 
| assignedLabels | assignedLabel collection | The list of sensitivity label pairs (label ID, label name) associated with a Microsoft 365 group. Returned only on $select. This property can be updated only in delegated scenarios where the caller requires both the Microsoft Graph permission and a supported administrator role. | 
| assignedLicenses | assignedLicense collection | The licenses that are assigned to the group. Returned only on $select. Supports$filter(eq). Read-only. | 
| autoSubscribeNewMembers | Boolean | Indicates if new members added to the group are autosubscribed to receive email notifications. You can set this property in a PATCH request for the group; don't set it in the initial POST request that creates the group. Default value is false.Returned only on $select. Supported only on the Get group API (GET /groups/{ID}). | 
| classification | String | Describes a classification for the group (such as low, medium, or high business impact). Valid values for this property are defined by creating a ClassificationList setting value, based on the template definition. Returned by default. Supports $filter(eq,ne,not,ge,le,startsWith). | 
| createdDateTime | DateTimeOffset | Timestamp of when the group was created. The value can't be modified and is automatically populated when the group is created. The Timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on January 1, 2014 is 2014-01-01T00:00:00Z.Returned by default. Read-only. | 
| deletedDateTime | DateTimeOffset | For some Microsoft Entra objects (user, group, application), if the object is deleted, it's first logically deleted, and this property is updated with the date and time when the object was deleted. Otherwise this property is null. If the object is restored, this property is updated tonull. Inherited from directoryObject. | 
| description | String | An optional description for the group. Returned by default. Supports $filter(eq,ne,not,ge,le,startsWith) and$search. | 
| displayName | String | The display name for the group. This property is required when a group is created and can't be cleared during updates. Maximum length is 256 characters. Returned by default. Supports $filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues),$search, and$orderby. | 
| expirationDateTime | DateTimeOffset | Timestamp of when the group is set to expire. It's nullfor security groups, but for Microsoft 365 groups, it represents when the group is set to expire as defined in the groupLifecyclePolicy. The Timestamp type represents date and time information using ISO 8601 format and is always in UTC. For example, midnight UTC on January 1, 2014 is2014-01-01T00:00:00Z.Returned by default. Supports $filter(eq,ne,not,ge,le,in). Read-only. | 
| groupTypes | String collection | Specifies the group type and its membership. If the collection contains Unified, the group is a Microsoft 365 group; otherwise, it's either a security group or a distribution group. For details, see groups overview.If the collection includes DynamicMembership, the group has dynamic membership; otherwise, membership is static.Returned by default. Supports $filter(eq,not). | 
| hasMembersWithLicenseErrors | Boolean | Indicates whether there are members in this group that have license errors from its group-based license assignment. This property is never returned on a GET operation. You can use it as a $filter argument to get groups that have members with license errors (that is, filter for this property being true). See an example. Supports $filter(eq). | 
| hideFromAddressLists | Boolean | True if the group isn't displayed in certain parts of the Outlook UI: the Address Book, address lists for selecting message recipients, and the Browse Groups dialog for searching groups; otherwise, false. The default value is false.Returned only on $select. Supported only on the Get group API (GET /groups/{ID}). | 
| hideFromOutlookClients | Boolean | True if the group isn't displayed in Outlook clients, such as Outlook for Windows and Outlook on the web; otherwise, false. The default value is false.Returned only on $select. Supported only on the Get group API (GET /groups/{ID}). | 
| id | String | The unique identifier for the group. Returned by default. Inherited from directoryObject. Key. Not nullable. Read-only. Supports $filter(eq,ne,not,in). | 
| isArchived | Boolean | When a group is associated with a team, this property determines whether the team is in read-only mode. To read this property, use the /group/{groupId}/teamendpoint or the Get team API. To update this property, use the archiveTeam and unarchiveTeam APIs. | 
| isAssignableToRole | Boolean | Indicates whether this group can be assigned to a Microsoft Entra role. Optional. This property can only be set while creating the group and is immutable. If set to true, the securityEnabled property must also be set totrue, visibility must beHidden, and the group can't be a dynamic group (that is, groupTypes can't containDynamicMembership).Only callers with at least the Privileged Role Administrator role can set this property. The caller must also be assigned the RoleManagement.ReadWrite.Directory permission to set this property or update the membership of such groups. For more, see Using a group to manage Microsoft Entra role assignments Using this feature requires a Microsoft Entra ID P1 license. Returned by default. Supports $filter(eq,ne,not). | 
| isManagementRestricted | Boolean | Indicates whether the group is a member of a restricted management administrative unit. If not set, the default value is nulland the default behavior is false. Read-only.To manage a group member of a restricted management administrative unit, the administrator or calling app must be assigned a Microsoft Entra role at the scope of the restricted management administrative unit. Returned only on $select. | 
| isSubscribedByMail | Boolean | Indicates whether the signed-in user is subscribed to receive email conversations. The default value is true.Returned only on $select. Supported only on the Get group API (GET /groups/{ID}). | 
| licenseProcessingState | String | Indicates the status of the group license assignment to all group members. The default value is false. Read-only. Possible values:QueuedForProcessing,ProcessingInProgress, andProcessingComplete.Returned only on $select. Read-only. | 
| String | The SMTP address for the group, for example, "[email protected]". Returned by default. Read-only. Supports $filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | |
| mailEnabled | Boolean | Specifies whether the group is mail-enabled. Required. Returned by default. Supports $filter(eq,ne,not). | 
| mailNickname | String | The mail alias for the group, unique for Microsoft 365 groups in the organization. Maximum length is 64 characters. This property can contain only characters in the ASCII character set 0 - 127 except the following characters:  @ () \ [] " ; : <> , SPACE.Required. Returned by default. Supports $filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| membershipRule | String | The rule that determines members for this group if the group is a dynamic group (groupTypes contains DynamicMembership). For more information about the syntax of the membership rule, see Membership Rules syntax.Returned by default. Supports $filter(eq,ne,not,ge,le,startsWith). | 
| membershipRuleProcessingState | String | Indicates whether the dynamic membership processing is on or paused. Possible values are OnorPaused.Returned by default. Supports $filter(eq,ne,not,in). | 
| onPremisesDomainName | String | Contains the on-premises domain FQDN, also called dnsDomainName synchronized from the on-premises directory. The property is only populated for customers synchronizing their on-premises directory to Microsoft Entra ID via Microsoft Entra Connect. Returned by default. Read-only. | 
| onPremisesLastSyncDateTime | DateTimeOffset | Indicates the last time at which the group was synced with the on-premises directory. The Timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on January 1, 2014 is 2014-01-01T00:00:00Z.Returned by default. Read-only. Supports $filter(eq,ne,not,ge,le,in). | 
| onPremisesNetBiosName | String | Contains the on-premises netBios name synchronized from the on-premises directory. The property is only populated for customers synchronizing their on-premises directory to Microsoft Entra ID via Microsoft Entra Connect. Returned by default. Read-only. | 
| onPremisesProvisioningErrors | onPremisesProvisioningError collection | Errors when using Microsoft synchronization product during provisioning. Returned by default. Supports $filter(eq,not). | 
| onPremisesSamAccountName | String | Contains the on-premises SAM account name synchronized from the on-premises directory. The property is only populated for customers synchronizing their on-premises directory to Microsoft Entra ID via Microsoft Entra Connect. Returned by default. Supports $filter(eq,ne,not,ge,le,in,startsWith). Read-only. | 
| onPremisesSecurityIdentifier | String | Contains the on-premises security identifier (SID) for the group synchronized from on-premises to the cloud. Read-only. Returned by default. Supports $filter(eqincluding onnullvalues). | 
| onPremisesSyncEnabled | Boolean | trueif this group is synced from an on-premises directory;falseif this group was originally synced from an on-premises directory but is no longer synced; null if this object has never synced from an on-premises directory (default).Returned by default. Read-only. Supports $filter(eq,ne,not,in, andeqonnullvalues). | 
| preferredDataLocation | String | The preferred data location for the Microsoft 365 group. By default, the group inherits the group creator's preferred data location. To set this property, the calling app must be granted the Directory.ReadWrite.All permission and the user be assigned at least one of the following Microsoft Entra roles: 
 For more information about this property, see OneDrive Online Multi-Geo. Nullable. Returned by default. | 
| preferredLanguage | String | The preferred language for a Microsoft 365 group. Should follow ISO 639-1 Code; for example, en-US.Returned by default. Supports $filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| proxyAddresses | String collection | Email addresses for the group that direct to the same group mailbox. For example: ["SMTP: [email protected]", "smtp: [email protected]"]. The any operator is required to filter expressions on multi-valued properties.Returned by default. Read-only. Not nullable. Supports $filter(eq,not,ge,le,startsWith,endsWith,/$count eq 0,/$count ne 0). | 
| renewedDateTime | DateTimeOffset | Timestamp of when the group was last renewed. This value can't be modified directly and is only updated via the renew service action. The Timestamp type represents date and time information using ISO 8601 format and is always in UTC. For example, midnight UTC on January 1, 2014 is 2014-01-01T00:00:00Z.Returned by default. Supports $filter(eq,ne,not,ge,le,in). Read-only. | 
| securityEnabled | Boolean | Specifies whether the group is a security group. Required. Returned by default. Supports $filter(eq,ne,not,in). | 
| securityIdentifier | String | Security identifier of the group, used in Windows scenarios. Read-only. Returned by default. | 
| serviceProvisioningErrors | serviceProvisioningError collection | Errors published by a federated service describing a nontransient, service-specific error regarding the properties or link from a group object. Supports $filter(eq,not, for isResolved and serviceInstance). | 
| theme | string | Specifies a Microsoft 365 group's color theme. Possible values are Teal,Purple,Green,Blue,Pink,Orange, orRed.Returned by default. | 
| uniqueName | String | The unique identifier that can be assigned to a group and used as an alternate key. Immutable. Read-only. | 
| unseenCount | Int32 | Count of conversations that received new posts since the signed-in user last visited the group. Returned only on $select. Supported only on the Get group API (GET /groups/{ID}). | 
| visibility | String | Specifies the group join policy and group content visibility for groups. Possible values are: Private,Public, orHiddenMembership.HiddenMembershipcan be set only for Microsoft 365 groups when the groups are created. It can't be updated later. Other values of visibility can be updated after group creation.If visibility value isn't specified during group creation on Microsoft Graph, a security group is created as Privateby default, and the Microsoft 365 group isPublic. Groups assignable to roles are alwaysPrivate. To learn more, see group visibility options.Returned by default. Nullable. | 
Graph reference: mailFolder
| Property | Type | Description | 
|---|---|---|
| childFolderCount | Int32 | The number of immediate child mailFolders in the current mailFolder. | 
| displayName | String | The mailFolder's display name. | 
| id | String | The mailFolder's unique identifier. | 
| isHidden | Boolean | Indicates whether the mailFolder is hidden. This property can be set only when creating the folder. Find more information in Hidden mail folders. | 
| parentFolderId | String | The unique identifier for the mailFolder's parent mailFolder. | 
| totalItemCount | Int32 | The number of items in the mailFolder. | 
| unreadItemCount | Int32 | The number of items in the mailFolder marked as unread. | 
Graph reference: message
| Property | Type | Description | 
|---|---|---|
| bccRecipients | recipient collection | The Bcc: recipients for the message. | 
| body | itemBody | The body of the message. It can be in HTML or text format. Find out about safe HTML in a message body. | 
| bodyPreview | String | The first 255 characters of the message body. It is in text format. | 
| ccRecipients | recipient collection | The Cc: recipients for the message. | 
| changeKey | String | The version of the message. | 
| conversationId | String | The ID of the conversation the email belongs to. | 
| conversationIndex | Edm.Binary | Indicates the position of the message within the conversation. | 
| createdDateTime | DateTimeOffset | The date and time the message was created. The date and time information uses ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z. | 
| flag | followupFlag | Indicates the status, start date, due date, or completion date for the message. | 
| from | recipient | The owner of the mailbox from which the message is sent. In most cases, this value is the same as the sender property, except for sharing or delegation scenarios. The value must correspond to the actual mailbox used. Find out more about setting the from and sender properties of a message. | 
| hasAttachments | Boolean | Indicates whether the message has attachments. This property doesn't include inline attachments, so if a message contains only inline attachments, this property is false. To verify the existence of inline attachments, parse the body property to look for a srcattribute, such as<IMG src="cid:[email protected]">. | 
| id | String | Unique identifier for the message. !INCLUDE [outlook-beta-id] Read-only. | 
| importance | importance | The importance of the message. The possible values are: low,normal, andhigh. | 
| inferenceClassification | inferenceClassificationType | The classification of the message for the user, based on inferred relevance or importance, or on an explicit override. The possible values are: focusedorother. | 
| internetMessageHeaders | internetMessageHeader collection | A collection of message headers defined by RFC5322. The set includes message headers indicating the network path taken by a message from the sender to the recipient. It can also contain custom message headers that hold app data for the message. Returned only on applying a $selectquery option. Read-only. | 
| internetMessageId | String | The message ID in the format specified by RFC2822. | 
| isDeliveryReceiptRequested | Boolean | Indicates whether a read receipt is requested for the message. | 
| isDraft | Boolean | Indicates whether the message is a draft. A message is a draft if it hasn't been sent yet. | 
| isRead | Boolean | Indicates whether the message has been read. | 
| isReadReceiptRequested | Boolean | Indicates whether a read receipt is requested for the message. | 
| lastModifiedDateTime | DateTimeOffset | The date and time the message was last changed. The date and time information uses ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z. | 
| parentFolderId | String | The unique identifier for the message's parent mailFolder. | 
| receivedDateTime | DateTimeOffset | The date and time the message was received. The date and time information uses ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z. | 
| replyTo | recipient collection | The email addresses to use when replying. | 
| sender | recipient | The account that is used to generate the message. In most cases, this value is the same as the from property. You can set this property to a different value when sending a message from a shared mailbox, for a shared calendar, or as a delegate. In any case, the value must correspond to the actual mailbox used. Find out more about setting the from and sender properties of a message. | 
| sentDateTime | DateTimeOffset | The date and time the message was sent. The date and time information uses ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z. | 
| subject | String | The subject of the message. | 
| toRecipients | recipient collection | The To: recipients for the message. | 
| uniqueBody | itemBody | The part of the body of the message that is unique to the current message. uniqueBody is not returned by default but can be retrieved for a given message by use of the ?$select=uniqueBodyquery. It can be in HTML or text format. | 
| webLink | String | The URL to open the message in Outlook on the web. You can append an ispopout argument to the end of the URL to change how the message is displayed. If ispopout is not present or if it is set to 1, then the message is shown in a popout window. If ispopout is set to 0, the browser shows the message in the Outlook on the web review pane. The message opens in the browser if you are signed in to your mailbox via Outlook on the web. You are prompted to sign in if you are not already signed in with the browser. This URL cannot be accessed from within an iFrame. | 
Graph reference: multiValueLegacyExtendedProperty
| Property | Type | Description | 
|---|---|---|
| id | string | The property identifier. Read-only. | 
| value | string collection | A collection of property values. | 
Graph reference: opentypeextension
| Property | Type | Description | 
|---|---|---|
| extensionName | String | A unique text identifier for an open type data extension. Optional. | 
| id | String | A fully qualified identifier that concatenates the extension type with the **e | 
Graph reference: organization
| Property | Type | Description | 
|---|---|---|
| assignedPlans | assignedPlan collection | The collection of service plans associated with the tenant. Not nullable. | 
| businessPhones | String collection | Telephone number for the organization. Although this property is a string collection, only one number can be set. | 
| city | String | City name of the address for the organization. | 
| country | String | Country or region name of the address for the organization. | 
| countryLetterCode | String | Country or region abbreviation for the organization in ISO 3166-2 format. | 
| createdDateTime | DateTimeOffset | Timestamp of when the organization was created. The value can't be modified and is automatically populated when the organization is created. The Timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z. Read-only. | 
| defaultUsageLocation | String | Two-letter ISO 3166 country code indicating the default service usage location of an organization. | 
| deletedDateTime | DateTimeOffset | Represents date and time of when the Microsoft Entra tenant was deleted using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z. Read-only. | 
| displayName | String | The display name for the tenant. | 
| id | String | The tenant ID, a unique identifier representing the organization (or tenant). Inherited from directoryObject. Key. Not nullable. Read-only. | 
| isMultipleDataLocationsForServicesEnabled | Boolean | trueif organization is Multi-Geo enabled; false if the organization isn't Multi-Geo enabled; null (default). Read-only. For more information, see OneDrive Online Multi-Geo. | 
| marketingNotificationEmails | String collection | Not nullable. | 
| onPremisesLastSyncDateTime | DateTimeOffset | The time and date at which the tenant was last synced with the on-premises directory. The Timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z. Read-only. | 
| onPremisesSyncEnabled | Boolean | trueif this object is synced from an on-premises directory;falseif this object was originally synced from an on-premises directory but is no longer synced. Nullable.nullif this object isn't synced from on-premises active directory (default). | 
| partnerTenantType | partnerTenantType | The type of partnership this tenant has with Microsoft. The possible values are: microsoftSupport,syndicatePartner,breadthPartner,breadthPartnerDelegatedAdmin,resellerPartnerDelegatedAdmin,valueAddedResellerPartnerDelegatedAdmin,unknownFutureValue. Nullable. For more information about the possible types, see partnerTenantType values. | 
| postalCode | String | Postal code of the address for the organization. | 
| preferredLanguage | String | The preferred language for the organization. Should follow ISO 639-1 Code; for example, en. | 
| privacyProfile | privacyProfile | The privacy profile of an organization. | 
| provisionedPlans | ProvisionedPlan collection | Not nullable. | 
| securityComplianceNotificationMails | String collection | Not nullable. | 
| securityComplianceNotificationPhones | String collection | Not nullable. | 
| state | String | State name of the address for the organization. | 
| street | String | Street name of the address for organization. | 
| technicalNotificationMails | String collection | Not nullable. | 
| tenantType | String | Not nullable. Can be one of the following types: AAD- An enterprise identity access management (IAM) service that serves business-to-employee and business-to-business (B2B) scenarios.AAD B2CAn identity access management (IAM) service that serves business-to-consumer (B2C) scenarios.CIAM- A customer identity & access management (CIAM) solution that provides an integrated platform to serve consumers, partners, and citizen scenarios. | 
| verifiedDomains | VerifiedDomain collection | The collection of domains associated with this tenant. Not nullable. | 
Graph reference: outlooktask
| Property | Type | Description | 
|---|---|---|
| assignedTo | String | The name of the person who has been assigned the task in Outlook. Read-only. | 
| body | itemBody | The task body that typically contains information about the task. Only the HTML type is supported. | 
| categories | String collection | The categories associated with the task. Each category corresponds to the displayName property of an outlookCategory that the user has defined. | 
| changeKey | String | The version of the task. | 
| completedDateTime | dateTimeTimeZone | The date in the specified time zone that the task was finished. | 
| createdDateTime | DateTimeOffset | The date and time when the task was created. By default, it is in UTC. You can provide a custom time zone in the request header. The property value uses ISO 8601 format. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z. | 
| dueDateTime | dateTimeTimeZone | The date in the specified time zone that the task is to be finished. | 
| hasAttachments | Boolean | Set to true if the task has attachments. | 
| id | String | Unique identifier for the task. !INCLUDE [outlook-beta-id] Read-only. | 
| importance | importance | The importance of the event. Possible values are: low,normal,high. | 
| isReminderOn | Boolean | Set to true if an alert is set to remind the user of the task. | 
| lastModifiedDateTime | DateTimeOffset | The date and time when the task was last modified. By default, it is in UTC. You can provide a custom time zone in the request header. The property value uses ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z. | 
| owner | String | The name of the person who created the task. | 
| parentFolderId | String | The unique identifier for the task's parent folder. | 
| recurrence | patternedRecurrence | The recurrence pattern for the task. | 
| reminderDateTime | dateTimeTimeZone | The date and time for a reminder alert of the task to occur. | 
| sensitivity | sensitivity | Indicates the level of privacy for the task. Possible values are: normal,personal,private,confidential. | 
| startDateTime | dateTimeTimeZone | The date in the specified time zone when the task is to begin. | 
| status | taskStatus | Indicates the state or progress of the task. Possible values are: notStarted,inProgress,completed,waitingOnOthers,deferred. | 
| subject | String | A brief description or title of the task. | 
Graph reference: outlooktaskfolder
| Property | Type | Description | 
|---|---|---|
| changeKey | String | The version of the task folder. | 
| id | String | The identifier of the task folder, unique in the user's mailbox. Read-only. | 
| isDefaultFolder | Boolean | True if the folder is the default task folder. | 
| name | String | The name of the task folder. | 
| parentGroupKey | Guid | The unique GUID identifier for the task folder's parent group. | 
Graph reference: phone
| Property | Type | Description | 
|---|---|---|
| number | string | The phone number. | 
| type | phoneType | The type of phone number. The possible values are: home,business,mobile,other,assistant,homeFax,businessFax,otherFax,pager,radio. | 
Graph reference: physicalAddress
| Property | Type | Description | 
|---|---|---|
| city | String | The city. | 
| countryOrRegion | String | The country or region. It's a free-format string value, for example, "United States". | 
| postalCode | String | The postal code. | 
| state | String | The state. | 
| street | String | The street. | 
Graph reference: post
| Property | Type | Description | 
|---|---|---|
| body | itemBody | The contents of the post. This is a default property. This property can be null. | 
| categories | String collection | The categories associated with the post. | 
| changeKey | String | Identifies the version of the post. Every time the post is changed, ChangeKey changes as well. This allows Exchange to apply changes to the correct version of the object. | 
| conversationId | String | Unique ID of the conversation. Read-only. | 
| conversationThreadId | String | Unique ID of the conversation thread. Read-only. | 
| createdDateTime | DateTimeOffset | Specifies when the post was created. The DateTimeOffset type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z | 
| from | recipient | Used in delegate access scenarios. Indicates who posted the message on behalf of another user. This is a default property. | 
| hasAttachments | Boolean | Indicates whether the post has at least one attachment. This is a default property. | 
| id | String | Read-only. | 
| lastModifiedDateTime | DateTimeOffset | Specifies when the post was last modified. The DateTimeOffset type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z | 
| newParticipants | recipient collection | Conversation participants that were added to the thread as part of this post. | 
| receivedDateTime | DateTimeOffset | Specifies when the post was received. The DateTimeOffset type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z | 
| sender | recipient | Contains the address of the sender. The value of Sender is assumed to be the address of the authenticated user in the case when Sender is not specified. This is a default property. | 
Graph reference: profilePhoto
| Property | Type | Description | 
|---|---|---|
| id | string | Read-only. | 
| height | int32 | The height of the photo. Read-only. | 
| width | int32 | The width of the photo. Read-only. | 
Graph reference: singleValueLegacyExtendedProperty
| Property | Type | Description | 
|---|---|---|
| id | string | The property ID used to identify the property. Read-only. | 
| value | string | A property value. | 
Graph reference: todoTask
| Property | Type | Description | 
|---|---|---|
| body | itemBody | The task body that typically contains information about the task. | 
| bodyLastModifiedDateTime | DateTimeOffset | The date and time when the task body was last modified. By default, it is in UTC. You can provide a custom time zone in the request header. The property value uses ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2020 would look like this: '2020-01-01T00:00:00Z'. | 
| categories | String collection | The categories associated with the task. Each category corresponds to the displayName property of an outlookCategory that the user has defined. | 
| completedDateTime | dateTimeTimeZone | The date and time in the specified time zone that the task was finished. | 
| createdDateTime | DateTimeOffset | The date and time when the task was created. By default, it is in UTC. You can provide a custom time zone in the request header. The property value uses ISO 8601 format. For example, midnight UTC on Jan 1, 2020 would look like this: '2020-01-01T00:00:00Z'. | 
| dueDateTime | dateTimeTimeZone | The date and time in the specified time zone that the task is to be finished. | 
| hasAttachments | Boolean | Indicates whether the task has attachments. | 
| id | String | Unique identifier for the task. By default, this value changes when the item is moved from one list to another. | 
| importance | importance | The importance of the task. Possible values are: low,normal,high. | 
| isReminderOn | Boolean | Set to true if an alert is set to remind the user of the task. | 
| lastModifiedDateTime | DateTimeOffset | The date and time when the task was last modified. By default, it is in UTC. You can provide a custom time zone in the request header. The property value uses ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2020 would look like this: '2020-01-01T00:00:00Z'. | 
| recurrence | patternedRecurrence | The recurrence pattern for the task. | 
| reminderDateTime | dateTimeTimeZone | The date and time in the specified time zone for a reminder alert of the task to occur. | 
| startDateTime | dateTimeTimeZone | The date and time in the specified time zone at which the task is scheduled to start. | 
| status | taskStatus | Indicates the state or progress of the task. Possible values are: notStarted,inProgress,completed,waitingOnOthers,deferred. | 
| title | String | A brief description of the task. | 
Graph reference: todoTaskList
| Property | Type | Description | 
|---|---|---|
| displayName | String | The name of the task list. | 
| id | String | The identifier of the task list, unique in the user's mailbox. Read-only. Inherited from entity | 
| isOwner | Boolean | True if the user is owner of the given task list. | 
| isShared | Boolean | True if the task list is shared with other users | 
| wellknownListName | wellknownListName | Property indicating the list name if the given list is a well-known list. Possible values are: none,defaultList,flaggedEmails,unknownFutureValue. | 
Graph reference: typedEmailAddress
| Property | Type | Description | 
|---|---|---|
| address | String | The email address of a contact. | 
| name | String | The display name of a contact. | 
| type | String | The type of email address. Possible values are: unknown,work,personal,main,other. The default value isunknown, which means address has not been set as a specific type. | 
| otherLabel | String | To specify a custom type of email address, set **t | 
Graph reference: user
| Property | Type | Description | 
|---|---|---|
| aboutMe | String | A freeform text entry field for the user to describe themselves. Returned only on $select. | 
| accountEnabled | Boolean | trueif the account is enabled; otherwise,false. This property is required when a user is created.Returned only on $select. Supports$filter(eq,ne,not, andin). | 
| ageGroup | ageGroup | Sets the age group of the user. Allowed values: null,Minor,NotAdult, andAdult. For more information, see legal age group property definitions.Returned only on $select. Supports$filter(eq,ne,not, andin). | 
| assignedLicenses | assignedLicense collection | The licenses that are assigned to the user, including inherited (group-based) licenses. This property doesn't differentiate between directly assigned and inherited licenses. Use the licenseAssignmentStates property to identify the directly assigned and inherited licenses. Not nullable. Returned only on $select. Supports$filter(eq,not,/$count eq 0,/$count ne 0). | 
| assignedPlans | assignedPlan collection | The plans that are assigned to the user. Read-only. Not nullable. Returned only on $select. Supports$filter(eqandnot). | 
| birthday | DateTimeOffset | The birthday of the user. The Timestamp type represents date and time information using ISO 8601 format and is always in UTC. For example, midnight UTC on Jan 1, 2014, is 2014-01-01T00:00:00Z.Returned only on $select. | 
| businessPhones | String collection | The telephone numbers for the user. NOTE: Although it's a string collection, only one number can be set for this property. Read-only for users synced from the on-premises directory. Returned by default. Supports $filter(eq,not,ge,le,startsWith). | 
| city | String | The city where the user is located. Maximum length is 128 characters. Returned only on $select. Supports$filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| companyName | String | The name of the company that the user is associated with. This property can be useful for describing the company that a guest comes from. The maximum length is 64 characters. Returned only on $select. Supports$filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| consentProvidedForMinor | consentProvidedForMinor | Sets whether consent was obtained for minors. Allowed values: null,Granted,Denied, andNotRequired. For more information, see legal age group property definitions.Returned only on $select. Supports$filter(eq,ne,not, andin). | 
| country | String | The country or region where the user is located; for example, USorUK. Maximum length is 128 characters.Returned only on $select. Supports$filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| createdDateTime | DateTimeOffset | The date and time the user was created, in ISO 8601 format and UTC. The value can't be modified and is automatically populated when the entity is created. Nullable. For on-premises users, the value represents when they were first created in Microsoft Entra ID. Property is nullfor some users created before June 2018 and on-premises users that were synced to Microsoft Entra ID before June 2018. Read-only.Returned only on $select. Supports$filter(eq,ne,not,ge,le,in). | 
| creationType | String | Indicates whether the user account was created through one of the following methods: 
 Read-only. Returned only on $select. Supports$filter(eq,ne,not,in). | 
| customSecurityAttributes | customSecurityAttributeValue | An open complex type that holds the value of a custom security attribute that is assigned to a directory object. Nullable. Returned only on $select. Supports$filter(eq,ne,not,startsWith). The filter value is case-sensitive. | 
| deletedDateTime | DateTimeOffset | The date and time the user was deleted. Returned only on $select. Supports$filter(eq,ne,not,ge,le,in). | 
| department | String | The name of the department in which the user works. Maximum length is 64 characters. Returned only on $select. Supports$filter(eq,ne,not,ge,le,in, andeqonnullvalues). | 
| displayName | String | The name displayed in the address book for the user. This value is usually the combination of the user's first name, middle initial, and family name. This property is required when a user is created and it can't be cleared during updates. Maximum length is 256 characters. Returned by default. Supports $filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues),$orderby, and$search. | 
| employeeHireDate | DateTimeOffset | The date and time when the user was hired or will start work in a future hire. Returned only on $select. Supports$filter(eq,ne,not,ge,le,in). | 
| employeeLeaveDateTime | DateTimeOffset | The date and time when the user left or will leave the organization. Supports $filter(eq,ne,not,ge,le,in).For more information, see Configure the employeeLeaveDateTime property for a user. | 
| employeeId | String | The employee identifier assigned to the user by the organization. The maximum length is 16 characters. Returned only on $select. Supports$filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| employeeOrgData | employeeOrgData | Represents organization data (for example, division and costCenter) associated with a user. Returned only on $select. Supports$filter(eq,ne,not,ge,le,in). | 
| employeeType | String | Captures enterprise worker type. For example, Employee,Contractor,Consultant, orVendor. Returned only on$select. Supports$filter(eq,ne,not,ge,le,in,startsWith). | 
| externalUserState | String | For a guest invited to the tenant using the invitation API, this property represents the invited user's invitation status. For invited users, the state can be PendingAcceptanceorAccepted, ornullfor all other users.Returned only on $select. Supports$filter(eq,ne,not,in). | 
| externalUserStateChangeDateTime | DateTimeOffset | Shows the timestamp for the latest change to the externalUserState property. Returned only on $select. Supports$filter(eq,ne,not,in). | 
| faxNumber | String | The fax number of the user. Returned only on $select. Supports$filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| givenName | String | The given name (first name) of the user. Maximum length is 64 characters. Returned by default. Supports $filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| hireDate | DateTimeOffset | The hire date of the user. The Timestamp type represents date and time information using ISO 8601 format and is always in UTC. For example, midnight UTC on Jan 1, 2014, is 2014-01-01T00:00:00Z.Returned only on $select.Note: This property is specific to SharePoint in Microsoft 365. We recommend using the native employeeHireDate property to set and update hire date values using Microsoft Graph APIs. | 
| id | String | The unique identifier for the user. Should be treated as an opaque identifier. Inherited from directoryObject. Key. Not nullable. Read-only. Returned by default. Supports $filter(eq,ne,not,in). | 
| identities | objectIdentity collection | Represents the identities that can be used to sign in to this user account. Microsoft (also known as a local account), organizations, or social identity providers such as Facebook, Google, and Microsoft can provide identity and tie it to a user account. It might contain multiple items with the same signInType value. Returned only on $select.Supports $filter(eq) with limitations. | 
| imAddresses | String collection | The instant message voice-over IP (VOIP) session initiation protocol (SIP) addresses for the user. Read-only. Returned only on $select. Supports$filter(eq,not,ge,le,startsWith). | 
| interests | String collection | A list for the user to describe their interests. Returned only on $select. | 
| isManagementRestricted | Boolean | trueif the user is a member of a restricted management administrative unit. If not set, the default value isnulland the default behavior is false. Read-only.To manage a user who is a member of a restricted management administrative unit, the administrator or calling app must be assigned a Microsoft Entra role at the scope of the restricted management administrative unit. Returned only on $select. | 
| isResourceAccount | Boolean | Don't use – reserved for future use. | 
| jobTitle | String | The user's job title. Maximum length is 128 characters. Returned by default. Supports $filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| lastPasswordChangeDateTime | DateTimeOffset | The time when this Microsoft Entra user last changed their password or when their password was created, whichever date the latest action was performed. The date and time information uses ISO 8601 format and is always in UTC. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z.Returned only on $select. | 
| legalAgeGroupClassification | legalAgeGroupClassification | Used by enterprise applications to determine the legal age group of the user. This property is read-only and calculated based on ageGroup and consentProvidedForMinor properties. Allowed values: null,Undefined,MinorWithOutParentalConsent,MinorWithParentalConsent,MinorNoParentalConsentRequired,NotAdult, andAdult. For more information, see legal age group property definitions.Returned only on $select. | 
| licenseAssignmentStates | licenseAssignmentState collection | State of license assignments for this user. Also indicates licenses that are directly assigned or the user inherited through group memberships. Read-only. Returned only on $select. | 
| String | The SMTP address for the user, for example, [email protected]. Changes to this property update the user's proxyAddresses collection to include the value as an SMTP address. This property can't contain accent characters.NOTE: We don't recommend updating this property for Azure AD B2C user profiles. Use the otherMails property instead. Returned by default. Supports $filter(eq,ne,not,ge,le,in,startsWith,endsWith, andeqonnullvalues). | |
| mailboxSettings | mailboxSettings | Settings for the primary mailbox of the signed-in user. You can get or update settings for sending automatic replies to incoming messages, locale, and time zone. Returned only on $select. | 
| mailNickname | String | The mail alias for the user. This property must be specified when a user is created. Maximum length is 64 characters. Returned only on $select. Supports$filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| mobilePhone | String | The primary cellular telephone number for the user. Read-only for users synced from the on-premises directory. Maximum length is 64 characters. Returned by default. Supports $filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues) and$search. | 
| mySite | String | The URL for the user's site. Returned only on $select. | 
| officeLocation | String | The office location in the user's place of business. Returned by default. Supports $filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| onPremisesDistinguishedName | String | Contains the on-premises Active Directory distinguished nameorDN. The property is only populated for customers who are synchronizing their on-premises directory to Microsoft Entra ID via Microsoft Entra Connect. Read-only.Returned only on $select. | 
| onPremisesDomainName | String | Contains the on-premises domainFQDN, also called dnsDomainName synchronized from the on-premises directory. The property is only populated for customers who are synchronizing their on-premises directory to Microsoft Entra ID via Microsoft Entra Connect. Read-only.Returned only on $select. | 
| onPremisesExtensionAttributes | onPremisesExtensionAttributes | Contains extensionAttributes1-15 for the user. These extension attributes are also known as Exchange custom attributes 1-15. Each attribute can store up to 1024 characters. false), these properties can be set during the creation or update of a user object.Returned only on $select. Supports$filter(eq,ne,not,in). | 
| onPremisesImmutableId | String | This property is used to associate an on-premises Active Directory user account to their Microsoft Entra user object. This property must be specified when creating a new user account in the Graph if you're using a federated domain for the user's userPrincipalName (UPN) property. NOTE: The $ and _ characters can't be used when specifying this property. Returned only on $select. Supports$filter(eq,ne,not,ge,le,in). | 
| onPremisesLastSyncDateTime | DateTimeOffset | Indicates the last time at which the object was synced with the on-premises directory; for example: 2013-02-16T03:04:54Z. The Timestamp type represents date and time information using ISO 8601 format and is always in UTC. For example, midnight UTC on Jan 1, 2014 is2014-01-01T00:00:00Z. Read-only.Returned only on $select. Supports$filter(eq,ne,not,ge,le,in). | 
| onPremisesProvisioningErrors | onPremisesProvisioningError collection | Errors when using Microsoft synchronization product during provisioning. Returned only on $select. Supports$filter(eq,not,ge,le). | 
| onPremisesSamAccountName | String | Contains the on-premises samAccountNamesynchronized from the on-premises directory. The property is only populated for customers who are synchronizing their on-premises directory to Microsoft Entra ID via Microsoft Entra Connect. Read-only.Returned only on $select. Supports$filter(eq,ne,not,ge,le,in,startsWith). | 
| onPremisesSecurityIdentifier | String | Contains the on-premises security identifier (SID) for the user that was synchronized from on-premises to the cloud. Read-only. Returned only on $select. Supports$filter(eqincluding onnullvalues). | 
| onPremisesSyncEnabled | Boolean | trueif this user object is currently being synced from an on-premises Active Directory (AD); otherwise the user isn't being synced and can be managed in Microsoft Entra ID. Read-only.Returned only on $select. Supports$filter(eq,ne,not,in, andeqonnullvalues). | 
| onPremisesUserPrincipalName | String | Contains the on-premises userPrincipalNamesynchronized from the on-premises directory. The property is only populated for customers who are synchronizing their on-premises directory to Microsoft Entra ID via Microsoft Entra Connect. Read-only.Returned only on $select. Supports$filter(eq,ne,not,ge,le,in,startsWith). | 
| otherMails | String collection | A list of other email addresses for the user; for example: ["[email protected]", "[email protected]"]. Can store up to 250 values, each with a limit of 250 characters.NOTE: This property can't contain accent characters. Returned only on $select. Supports$filter(eq,not,ge,le,in,startsWith,endsWith,/$count eq 0,/$count ne 0). | 
| passwordPolicies | String | Specifies password policies for the user. This value is an enumeration with one possible value being DisableStrongPassword, which allows weaker passwords than the default policy to be specified.DisablePasswordExpirationcan also be specified. The two might be specified together; for example:DisablePasswordExpiration, DisableStrongPassword.Returned only on $select. For more information on the default password policies, see Microsoft Entra password policies. Supports$filter(ne,not, andeqonnullvalues). | 
| passwordProfile | passwordProfile | Specifies the password profile for the user. The profile contains the user's password. This property is required when a user is created. The password in the profile must satisfy minimum requirements as specified by the passwordPolicies property. By default, a strong password is required. Returned only on $select. Supports$filter(eq,ne,not,in, andeqonnullvalues).To update this property: | 
| pastProjects | String collection | A list for the user to enumerate their past projects. Returned only on $select. | 
| postalCode | String | The postal code for the user's postal address. The postal code is specific to the user's country or region. In the United States of America, this attribute contains the ZIP code. Maximum length is 40 characters. Returned only on $select. Supports$filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| preferredDataLocation | String | The preferred data location for the user. For more information, see OneDrive Online Multi-Geo. | 
| preferredLanguage | String | The preferred language for the user. The preferred language format is based on RFC 4646. The name is a combination of an ISO 639 two-letter lowercase culture code associated with the language, and an ISO 3166 two-letter uppercase subculture code associated with the country or region. Example: "en-US", or "es-ES". Returned by default. Supports $filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues) | 
| preferredName | String | The preferred name for the user. Not Supported. This attribute returns an empty string. Returned only on $select. | 
| provisionedPlans | provisionedPlan collection | The plans that are provisioned for the user. Read-only. Not nullable. Returned only on $select. Supports$filter(eq,not,ge,le). | 
| proxyAddresses | String collection | For example: "SMTP: [email protected]", "smtp: [email protected]"]. Changes to the mail property update this collection to include the value as an SMTP address. For more information, see [mail and proxyAddresses properties. The proxy address prefixed withSMTP(capitalized) is the primary proxy address, while those addresses prefixed withsmtpare the secondary proxy addresses. For Azure AD B2C accounts, this property has a limit of 10 unique addresses. Read-only in Microsoft Graph; you can update this property only through the Microsoft 365 admin center. Not nullable.Returned only on $select. Supports$filter(eq,not,ge,le,startsWith,endsWith,/$count eq 0,/$count ne 0). | 
| refreshTokensValidFromDateTime | DateTimeOffset | Any refresh tokens or session tokens (session cookies) issued before this time are invalid. Applications get an error when using an invalid refresh or session token to acquire a delegated access token (to access APIs such as Microsoft Graph). If this happens, the application needs to acquire a new refresh token by requesting the authorized endpoint. Returned only on $select. Read-only. | 
| responsibilities | String collection | A list for the user to enumerate their responsibilities. Returned only on $select. | 
| serviceProvisioningErrors | serviceProvisioningError collection | Errors published by a federated service describing a nontransient, service-specific error regarding the properties or link from a user object. Supports $filter(eq,not, for isResolved and serviceInstance). | 
| schools | String collection | A list for the user to enumerate the schools they attended. Returned only on $select. | 
| securityIdentifier | String | Security identifier (SID) of the user, used in Windows scenarios. Read-only. Returned by default. Supports $selectand$filter(eq,not,ge,le,startsWith). | 
| showInAddressList | Boolean | Do not use in Microsoft Graph. Manage this property through the Microsoft 365 admin center instead. Represents whether the user should be included in the Outlook global address list. See Known issue. | 
| signInActivity | signInActivity | Get the last signed-in date and request ID of the sign-in for a given user. Read-only. Returned only on $select. Supports$filter(eq,ne,not,ge,le) but not with any other filterable properties.Note: | 
| signInSessionsValidFromDateTime | DateTimeOffset | Any refresh tokens or session tokens (session cookies) issued before this time are invalid. Applications get an error when using an invalid refresh or session token to acquire a delegated access token (to access APIs such as Microsoft Graph). If this happens, the application needs to acquire a new refresh token by requesting the authorized endpoint. Read-only. Use revokeSignInSessions to reset. Returned only on $select. | 
| skills | String collection | A list for the user to enumerate their skills. Returned only on $select. | 
| state | String | The state or province in the user's address. Maximum length is 128 characters. Returned only on $select. Supports$filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| streetAddress | String | The street address of the user's place of business. Maximum length is 1,024 characters. Returned only on $select. Supports$filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| surname | String | The user's surname (family name or last name). Maximum length is 64 characters. Returned by default. Supports $filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| usageLocation | String | A two-letter country code (ISO standard 3166). Required for users that are assigned licenses due to legal requirements to check for availability of services in countries/regions. Examples include: US,JP, andGB. Not nullable.Returned only on $select. Supports$filter(eq,ne,not,ge,le,in,startsWith, andeqonnullvalues). | 
| userPrincipalName | String | The user principal name (UPN) of the user. The UPN is an Internet-style sign-in name for the user based on the Internet standard RFC 822. By convention, this value should map to the user's email name. The general format is alias@domain, where the domain must be present in the tenant's collection of verified domains. This property is required when a user is created. The verified domains for the tenant can be accessed from the verifiedDomains property of organization. NOTE: This property can't contain accent characters. Only the following characters are allowed A - Z,a - z,0 - 9, ' . - _ ! # ^ ~. For the complete list of allowed characters, see username policies.Returned by default. Supports $filter(eq,ne,not,ge,le,in,startsWith,endsWith) and$orderby. | 
| userType | String | A string value that can be used to classify user types in your directory. The possible values are MemberandGuest.Returned only on $select. Supports$filter(eq,ne,not,in, andeqonnullvalues). **N | 
Graph reference: website
| Property | Type | Description | 
|---|---|---|
| address | string | The URL of the website. | 
| displayName | string | The display name of the web site. | 
| type | websiteType | The possible values are: other,home,work,blog,profile. |