unable to encrypt

Rising Flight 4,796 Reputation points
Oct 11, 2024, 5:39 AM

I have using an Azure App Registration and i have encrypted client secret using the below syntax from powershell.

$myfile = 'c:\temp\myappreg.key'

Read-Host -assecurestring | convertfrom-securestring | out-file

I am using the below lines in the script. i am getting error at client secret. can anyone help in correcting the syntax

$ClientId = "9999999999999999999"
$Clientkey = "c:\temp\myappreg.key"
$TenantId = "88888888888888888888888""
$SecureString = convertto-securestring -string (get-content $ClientKey)
$bstr = [System.Runtime.InteropServices.Marshal]::SecureStringToBSTR($SecureString)
$ClientSecret = [System.Runtime.InteropServices.Marshal]::PtrToStringAuto($bstr)
# Get an access token
$body = @{
    grant_type    = "client_credentials"
    client_id     = $ClientId
    client_secret = $ClientSecret
    scope         = "https://outlook.office365.com/.default"
}
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
$response = Invoke-RestMethod -Uri "https://login.microsoftonline.com/$TenantId/oauth2/v2.0/token" -Method Post -ContentType "application/x-www-form-urlencoded" -Body $body
$accessToken = $response.access_token
# Load EWS Managed API (Exchange 2016)
$EWSServicePath = 'C:\Scripts\EWS-Managed-API\bin\Debug\Microsoft.Exchange.WebServices.dll'
Import-Module $EWSServicePath
 
# Connect to Exchange Online using EWS with OAuth
$ExchVer = [Microsoft.Exchange.WebServices.Data.ExchangeVersion]::Exchange2016
$Service = New-Object Microsoft.Exchange.WebServices.Data.ExchangeService($ExchVer)
$Service.Url = "https://outlook.office365.com/EWS/Exchange.asmx"
$Service.Credentials = New-Object Microsoft.Exchange.WebServices.Data.OAuthCredentials($accessToken)
Microsoft Exchange Online
Microsoft Graph
Microsoft Graph
A Microsoft programmability model that exposes REST APIs and client libraries to access data on Microsoft 365 services.
12,715 questions
Microsoft Exchange Online Management
Microsoft Exchange Online Management
Microsoft Exchange Online: A Microsoft email and calendaring hosted service.Management: The act or process of organizing, handling, directing or controlling something.
4,671 questions
PowerShell
PowerShell
A family of Microsoft task automation and configuration management frameworks consisting of a command-line shell and associated scripting language.
2,719 questions
0 comments No comments
{count} votes

Accepted answer
  1. Jake Zhang-MSFT 8,005 Reputation points Microsoft Vendor
    Oct 11, 2024, 6:13 AM

    Hi @Rising Flight ,

    Welcome to the Microsoft Q&A platform!

    From your description, you are trying to authenticate in a PowerShell script using a client key stored in a file. The problem may be due to the way the secure string is converted back to a plain text string. Here is a revised version of the script that should work fine:

    $ClientId = "9999999999999999999"
    $ClientKeyPath = "c:\temp\myappreg.key"
    $TenantId = "88888888888888888888888"
    
    # Read the encrypted client secret from the file and convert it back to a secure string
    $SecureString = Get-Content $ClientKeyPath | ConvertTo-SecureString
    
    # Convert the secure string to plain text
    $ClientSecret = [System.Runtime.InteropServices.Marshal]::PtrToStringAuto(
        [System.Runtime.InteropServices.Marshal]::SecureStringToBSTR($SecureString)
    )
    
    # Get an access token
    $body = @{
        grant_type    = "client_credentials"
        client_id     = $ClientId
        client_secret = $ClientSecret
        scope         = "https://outlook.office365.com/.default"
    }
    [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
    $response = Invoke-RestMethod -Uri "https://login.microsoftonline.com/$TenantId/oauth2/v2.0/token" -Method Post -ContentType "application/x-www-form-urlencoded" -Body $body
    $accessToken = $response.access_token
    
    # Load EWS Managed API (Exchange 2016)
    $EWSServicePath = 'C:\Scripts\EWS-Managed-API\bin\Debug\Microsoft.Exchange.WebServices.dll'
    Import-Module $EWSServicePath
    
    # Connect to Exchange Online using EWS with OAuth
    $ExchVer = [Microsoft.Exchange.WebServices.Data.ExchangeVersion]::Exchange2016
    $Service = New-Object Microsoft.Exchange.WebServices.Data.ExchangeService($ExchVer)
    $Service.Url = "https://outlook.office365.com/EWS/Exchange.asmx"
    $Service.Credentials = New-Object Microsoft.Exchange.WebServices.Data.OAuthCredentials($accessToken)
    

    Make sure the file c:\temp\myappreg.key contains the encrypted client key. The script reads this file, converts the encrypted client key back to a secure string and then to plain text. This plain text client key is used to obtain an access token from Azure AD.


    Please feel free to contact me for any updates. And if this helps, don't forget to mark it as an answer.

    Best,

    Jake Zhang

    0 comments No comments

0 additional answers

Sort by: Most helpful

Your answer

Answers can be marked as Accepted Answers by the question author, which helps users to know the answer solved the author's problem.