m365receiver

package module
v1.39.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 15, 2023 License: Apache-2.0 Imports: 25 Imported by: 0

README

Microsoft 365 Receiver

Receives metrics from Microsoft 365 via the Microsoft Graph API, and logs via the Microsoft Management API.

Important Notes

Due to the nature of the APIs being used to collect data from Microsoft 365, there are some important notes that should be acknowledged before continuing.

  • Metrics collected by this receiver can be 48 hours old. This is because the Reports endpoint of the Microsoft Graph API can take up to 48 hours to be updated with new data. The timestamps for metrics will represent when the data was scraped from the API rather than when the data points occurred (48 hours earlier). Because of this, the metrics receiver has a scrape interval of 1 hour. This is done so that the receiver can scrape data from the API once it becomes available, within a reasonable amount of time. This also means that most data points are duplicates. Please keep this in mind when viewing metric data. For more info please see Microsoft's documentation.
  • When an instance of Microsoft 365 is going to have logs collected for the very first time, it can take several hours for logs to be made available by the API. After completing the required step (described in further detail here), wait 60 minutes before attempting to collect logs. It takes 60 minutes for activation to be completed, during which Microsoft will make it seem like logs are still disabled. Once logs are completely activated, it can still take up to 12 hours before any logs are available for consumption. During this time, logs can be "collected" but the API won't have any logs available. After this initial waiting period logs will begin to appear "regularly". Microsoft gives no guarantee on when logs will be made available in the API after they've occurred, but it's been observed to take around 3 hours in the worst case. This may change though depending on the tenant being monitored. For more info please see Microsoft's documentation.
  • As part of configuring Microsoft 365 a client secret will need to be generated in Azure Active Directory. When this is done, a date for when the secret expires will need to be selected. The user is responsible for tracking expiration of secrets and generating new secrets as needed.

Minimum Agent Versions

Supported Pipelines

  • Metrics
  • Logs

How It Works

  1. The user configures their instance of Microsoft 365 to enable monitoring of metrics, logs, or both.
  2. The user configures this receiver in a pipeline.
  3. The user configures a supported component to route telemetry from this receiver.

Prerequisites

  • Created instance of Microsoft 365 with the following subscriptions: Microsoft 365 Business Basic, Microsoft 365 E5 Compliance, Microsoft 365 E3 (Works with the respective "upgraded" versions as well.)
  • Access to an Admin account for the instance of Microsoft 365 to be monitored.

Configuration

Field Type Default Description
tenant_id string (no default) required Identifies the instance of 365 to be monitored by this receiver. Needed for metrics and logs.
client_id string (no default) required The identifier this receiver will use to monitor the given tenant/instance. Needed for metrics and logs.
client_secret string (no default) required The private key this receiver will use, must belong to the given client_id. Needed for metrics and logs.
logs object (n/a) Configuration object for other fields listed below.
logs.poll_interval duration 5m The receiver collects logs on an interval. Value must be in minutes (i.e. 10m, 120m). Can be omitted for default interval of 5 minutes.
logs.general bool true Indicates whether or not logs should be collected from the General audit/content blob. Can be omitted to indicate true.
logs.exchange bool true Indicates whether or not logs should be collected from the Exchange audit/content blob. Can be omitted to indicate true.
logs.sharepoint bool true Indicates whether or not logs should be collected from the SharePoint audit/content blob. Can be omitted to indicate true.
logs.azureAD bool true Indicates whether or not logs should be collected from the Azure Active Directory audit/content blob. Can be omitted to indicate true.
logs.dlp bool true Indicates whether or not logs should be collected from the Data Loss Prevention audit/content blob. Can be omitted to indicate true.
storage component (no default) The component ID of a storage extension which can be used when polling for logs . The storage extension prevents duplication of data after a agent restart by remembering which data were previously collected. No storage is used when omitted.

Example Configurations

Collect metrics:
receivers:
  m365:
    tenant_id: tenant_id
    client_id: client_id
    client_secret: client_secret
exporters:
  file/no_rotation:
    path: /some/file/path/foo.json
service:
  pipelines:
    metrics:
      receivers: [m365]
      exporters: [file/no_rotation]
Collect logs (default values):
receivers:
  m365:
    tenant_id: tenant_id
    client_id: client_id
    client_secret: client_secret
exporters:
  file/no_rotation:
    path: /some/file/path/foo.json
service:
  pipelines:
    logs:
      receivers: [m365]
      exporters: [file/no_rotation]
Collect logs (custom poll interval, storage component, only sharepoint & azureAD logs):
receivers:
  m365:
    tenant_id: tenant_id
    client_id: client_id
    client_secret: client_secret
    logs:
      poll_interval: 10m
      general: false
      exchange: false
      dlp: false
    storage: file_storage
exporters:
  file/no_rotation:
    path: /some/file/path/foo.json
service:
  pipelines:
    logs:
      receivers: [m365]
      exporters: [file/no_rotation]

How To

Configuring Microsoft 365

The steps below outline how to configure Microsoft 365 to allow the receiver to collect metrics from it. To use this receiver, the instance of Microsoft 365 needs the following subscriptions: Microsoft 365 Business Basic, Microsoft 365 E5 Compliance, and Microsoft 365 E3. (Works with the respective "upgraded" versions as well.)

  1. Login to Azure: Log in to Microsoft Azure under an Admin account for the instance of 365 to be monitored.
  2. Register the receiver in Azure AD: Navigate to Azure Active Directory. Then go to "App Registrations" and select "New Registration". Give the app a descriptive name like "365 Receiver". For "Supported account types", select the Single Tenant option and leave the Redirect URL empty.
  3. Add API Permissions: Select "View API Permissions" beneath the general application info and click "Add Permissions". The permissions needed for metrics and logs differ, so for whichever monitoring is needed the respective permissions are outlined below.
    • Metrics: Select "Microsoft Graph", then "Application Permissions". Find the "Reports" tab and select "Reports.Read.All". Click "Add Permissions" at the bottom of the panel.
    • Logs: Select "Office 365 Management APIs", then "Application Permissions". Now select the "ActivityFeed.Read", "ActivityFeed.ReadDlp", and "ServiceHealth.Read" permissions. Click "Add Permissions" at the bottom of the panel.
  4. Grant Admin Consent: Select the "Grant admin consent for {organization}" button and confirm the pop-up. This will allow the application to access the data returned by the Microsoft Graph and Office 365 Management APIs.
  5. Generate Client Secret: Select the "Certificates & secrets" tab in the left panel. Under the "Client Secrets" tab, select "New Client Secret." Give it a meaningful description and select the recommended period of 180 days. Save the text in the "Value" column since this is the only time that value will be accessible.
    • Note: The receiver will need to be reconfigured with a newly generated Client Secret once the initial one expires.
  6. Save Client ID and Tenant ID values: You will also need the "client_id" value found on the information page for the application that was created. The value will be listed as "Application (client) id." You will also need the tenant value which will be listed as "Directory (tenant) id." Save these values for later.

Note: The first time an instance of Microsoft 365 is set up for monitoring, an extra step for collecting logs is required.

  1. Log into Microsoft Purview Compliance Portal with an admin account.
  2. Navigate to "Solutions" then "Audit".
  3. If auditing is not turned on for your organization, a banner is displayed prompting you start recording user and admin activity.
  4. Select "Start recording user and admin activity". It will take up to 60 minutes for the change to take effect, so until that point do not run the receiver with logs turned on or else it will fail.

After following the above steps, the instance of Microsoft 365 is ready for monitoring and the receiver can now be configured.

Documentation

Overview

Package m365receiver import "github.com/observiq/bindplane-agent/receiver/m365receiver"

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func NewFactory

func NewFactory() receiver.Factory

NewFactory creates a factory for Microsoft Office 365 receiver.

Types

type AttachmentData

type AttachmentData struct {
	FileName string `json:"FileName"`
}

AttachmentData json struct

type AzureActor

type AzureActor struct {
	ID   string `json:"ID"`
	Type int    `json:"Type"`
}

AzureActor json struct

type Config

type Config struct {
	scraperhelper.ScraperControllerSettings `mapstructure:",squash"`
	confighttp.HTTPClientSettings           `mapstructure:",squash"`
	MetricsBuilderConfig                    metadata.MetricsBuilderConfig `mapstructure:",squash"`
	TenantID                                string                        `mapstructure:"tenant_id"`
	ClientID                                string                        `mapstructure:"client_id"`
	ClientSecret                            string                        `mapstructure:"client_secret"`
	Logs                                    *LogsConfig                   `mapstructure:"logs"`
	StorageID                               *component.ID                 `mapstructure:"storage"`
}

Config defines configuration for Microsoft Office 365 receiver.

func (*Config) Validate

func (c *Config) Validate() error

Validate validates the configuration by checking for missing or invalid fields

type ExchangeDetails

type ExchangeDetails struct {
	NetworkMessageID string `json:"NetworkMessageId,omitempty"`
}

ExchangeDetails json struct

type ExchangeMetaData

type ExchangeMetaData struct {
	MessageID string `json:"MessageID"`
}

ExchangeMetaData json struct

type FileData

type FileData struct {
	DocumentID  string `json:"DocumentId"`
	FileVerdict int    `json:"FileVerdict"`
}

FileData json struct

type Invitation

type Invitation struct {
	ShareID string `json:"ShareId"`
}

Invitation json struct

type LogsConfig

type LogsConfig struct {
	PollInterval   time.Duration `mapstructure:"poll_interval"`
	GeneralLogs    bool          `mapstructure:"general"`
	ExchangeLogs   bool          `mapstructure:"exchange"`
	SharepointLogs bool          `mapstructure:"sharepoint"`
	AzureADLogs    bool          `mapstructure:"azureAD"`
	DLPLogs        bool          `mapstructure:"dlp"`
}

LogsConfig defines configuration for the M365 logs receiver

type Option

type Option func(r *http.Request)

Option func for GetJSON request handler case

func WithBody

func WithBody() Option

WithBody is an option func for the request handler

func WithTime

func WithTime(end, start string) Option

WithTime is an option func for the request handler

func WithToken

func WithToken(token string) Option

WithToken is an option func for the request handler

type PolicyDetails

type PolicyDetails struct {
	PolicyID   string `json:"PolicyId"`
	PolicyName string `json:"PolicyName"`
}

PolicyDetails json struct

type SharePointMetaData

type SharePointMetaData struct {
	From string `json:"From"`
}

SharePointMetaData json struct

Directories

Path Synopsis
internal

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL