Skip to main content

A package dedicated to creating new users in o365

Project description

M365 User Manager

A robust Python package for automating Microsoft 365 user management operations through Microsoft Graph API, with support for both local execution and Asio RPA integration.

Features

  • User Creation & Management

    • Create new M365 users with comprehensive profile details
    • Copy properties, groups, and roles from template users
    • Manage group memberships and license assignments
    • Handle phone number formatting and validation
  • License Management

    • Automatic license availability checking
    • Smart license name matching and resolution
    • Batch license assignment with detailed reporting
    • Support for all major Microsoft 365 license types
  • Security & Authentication

    • Secure password generation and sharing
    • Integration with Password Pusher and fallback services
    • Token management for Microsoft Graph API
    • Comprehensive error handling and logging
  • Environment Flexibility

    • Supports both local execution and Asio RPA environment
    • Environment-aware configuration loading
    • Unified logging across environments

Installation

# Clone the repository
gh repo clone VinnyVanGogh/m365_user_manager
cd m365-user-manager

# Install dependencies
pip install -r requirements.txt

Configuration

  1. Create a configuration file at environments/asio_365_config.json:
{
    "client_id": "your_client_id",
    "client_secret": "your_client_secret",
    "tenant_id": "your_tenant_id"
}

(Optional) Set up Discord webhook for logging:

  • Configure webhook URL through the input form or environment configuration

Usage

Basic Usage

from m365_user_manager import UserManagementOrchestrator

# Initialize and run the orchestrator
orchestrator = UserManagementOrchestrator()
orchestrator.run()

Creating a New User

from m365_user_manager import M365UserManager

# Initialize the manager
user_manager = M365UserManager(access_token, logger)

# Create a new user
result = user_manager.create_user(
    display_name="John Doe",
    email_address="john.doe@example.com",
    job_title="Software Engineer",
    department="Engineering",
    license_skus=["Microsoft 365 E3", "Power BI Pro"],
    groups=["Engineering Team", "All Company"]
)

Copying User Properties

# Create user by copying from template
result = user_manager.create_user(
    display_name="Jane Smith",
    email_address="jane.smith@example.com",
    user_to_copy="template@example.com",
    copy_licenses=True
)

Input Parameters

Parameter Description Required
display_name User's full name Yes
email_address User's email address Yes
password Initial password (generated if not provided) No
job_title User's job title No
department User's department No
office_location Office location No
city City No
state State/Province No
business_phone Business phone number No
mobile_phone Mobile phone number No
groups List or comma-separated string of groups No
license_skus List or comma-separated string of licenses No
user_to_copy Template user's email to copy from No
copy_licenses Whether to copy licenses from template user No

Error Handling

The package includes comprehensive error handling with custom exceptions:

  • GraphAPIError: Microsoft Graph API operation failures
  • TokenManagerError: Authentication and token-related issues
  • PasswordManagerError: Password management operation failures
  • InsufficientPermissionsError: Permission-related failures

Logging

The package uses a unified logging system supporting:

  • Local file logging
  • Discord webhook integration
  • ASIO logging integration

Configure logging through the logging_config function in config/default_config.py.

Dependencies

  • Microsoft Graph API
  • Password Pusher API (for secure password sharing)
  • Discord Webhook (optional, for logging)
  • Asio RPA Framework (optional)

License

MIT License

Contributing

Please read the CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

m365_user_manager-0.1.1rc5.tar.gz (88.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

m365_user_manager-0.1.1rc5-py3-none-any.whl (106.3 kB view details)

Uploaded Python 3

File details

Details for the file m365_user_manager-0.1.1rc5.tar.gz.

File metadata

  • Download URL: m365_user_manager-0.1.1rc5.tar.gz
  • Upload date:
  • Size: 88.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for m365_user_manager-0.1.1rc5.tar.gz
Algorithm Hash digest
SHA256 f4336e9b6b07b78a2430903a2588c3918ac8ec9914a6c93495f57ccb01507961
MD5 fac0334a94d2c0f4ea2cafac795d8553
BLAKE2b-256 3e4eeae2041e660a78392da5d9d5ca4e3f24426a21a621d22d2db853dfb4e5a6

See more details on using hashes here.

File details

Details for the file m365_user_manager-0.1.1rc5-py3-none-any.whl.

File metadata

File hashes

Hashes for m365_user_manager-0.1.1rc5-py3-none-any.whl
Algorithm Hash digest
SHA256 2eabc7e3aee998955a07461e9f9551ffdd053761f80679aab42158eec30256c0
MD5 7a656e93f3ead06def4b3937099f3584
BLAKE2b-256 b3a1e984e16d2d71c53f35bb8de0d3b864a0bc6deb94dd9107d335873d287a88

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page