|
1 | 1 | using PnP.Framework;
|
| 2 | +using PnP.PowerShell.Commands.Base; |
| 3 | +using PnP.PowerShell.Commands.Enums; |
2 | 4 | using PnP.PowerShell.Commands.Model;
|
3 | 5 | using PnP.PowerShell.Commands.Utilities;
|
4 | 6 | using PnP.PowerShell.Commands.Utilities.REST;
|
5 | 7 | using System;
|
6 | 8 | using System.Collections.Generic;
|
| 9 | +using System.Dynamic; |
7 | 10 | using System.IO;
|
8 | 11 | using System.Linq;
|
9 | 12 | using System.Management.Automation;
|
10 | 13 | using System.Net.Http;
|
11 | 14 | using System.Threading;
|
12 | 15 | using System.Threading.Tasks;
|
13 |
| -using OperatingSystem = PnP.PowerShell.Commands.Utilities.OperatingSystem; |
14 |
| -using PnP.PowerShell.Commands.Base; |
15 |
| -using System.Dynamic; |
16 |
| -using PnP.PowerShell.Commands.Enums; |
17 | 16 | using TextCopy;
|
| 17 | +using OperatingSystem = PnP.PowerShell.Commands.Utilities.OperatingSystem; |
18 | 18 |
|
19 | 19 | namespace PnP.PowerShell.Commands.AzureAD
|
20 | 20 | {
|
@@ -49,6 +49,11 @@ public class RegisterEntraIDAppForInteractiveLogin : BasePSCmdlet, IDynamicParam
|
49 | 49 |
|
50 | 50 | protected override void ProcessRecord()
|
51 | 51 | {
|
| 52 | + if (!PSUtility.IsUserLocalAdmin()) |
| 53 | + { |
| 54 | + throw new PSArgumentException("Running this cmdlet requires elevated permissions (Run as Admin) to generate a certificate."); |
| 55 | + } |
| 56 | + |
52 | 57 | var redirectUri = "http://localhost";
|
53 | 58 | // if (ParameterSpecified(nameof(DeviceLogin)) || OperatingSystem.IsMacOS())
|
54 | 59 | if (ParameterSpecified(nameof(DeviceLogin)) || OperatingSystem.IsMacOS())
|
@@ -460,7 +465,7 @@ private AzureADApp CreateApp(string loginEndPoint, HttpClient httpClient, string
|
460 | 465 | private void StartConsentFlow(string loginEndPoint, AzureADApp azureApp, string redirectUri, string token, HttpClient httpClient, PSObject record, CmdletMessageWriter messageWriter, List<PermissionScope> scopes)
|
461 | 466 | {
|
462 | 467 | var htmlMessageConsentSuccess = $"<html lang=en><meta charset=utf-8><title>PnP PowerShell - Consent</title><meta content=\"width=device-width,initial-scale=1\"name=viewport><style>html{{height:100%}}.message-container{{flex-grow:1;display:flex;align-items:center;justify-content:center;margin:0 30px}}body{{box-sizing:border-box;min-height:100%;display:flex;flex-direction:column;color:#fff;font-family:\"Segoe UI\",\"Helvetica Neue\",Helvetica,Arial,sans-serif;background-color:#2c2c32;margin:0;padding:15px 30px}}.message{{font-weight:300;font-size:1.4rem}}.branding{{background-image:url();background-repeat:no-repeat;padding-left:26px;font-size:20px;letter-spacing:-.04rem;font-weight:400;height:26px;color:#fff;background-position:left center;text-decoration:none}}</style><a class=branding href=https://pnp.github.io/powershell>PnP PowerShell</a><div class=message-container><div class=message>You successfully provided consent now and can close this page.</div></div>";
|
463 |
| - var htmlMessageConsentFailed= $"<html lang=en><meta charset=utf-8><title>PnP PowerShell - Consent</title><meta content=\"width=device-width,initial-scale=1\"name=viewport><style>html{{height:100%}}.error-text{{color:red;font-size:1rem}}.message-container{{flex-grow:1;display:flex;align-items:center;justify-content:center;margin:0 30px}}body{{box-sizing:border-box;min-height:100%;display:flex;flex-direction:column;color:#fff;font-family:\"Segoe UI\",\"Helvetica Neue\",Helvetica,Arial,sans-serif;background-color:#2c2c32;margin:0;padding:15px 30px}}.message{{font-weight:300;font-size:1.4rem}}.branding{{background-image:url();background-repeat:no-repeat;height:26px;padding-left:26px;font-size:20px;letter-spacing:-.04rem;font-weight:400;color:#fff;background-position:left center;text-decoration:none}}</style><a class=branding href=https://pnp.github.io/powershell>PnP PowerShell</a><div class=message-container><div class=message>You failed to provide consent. Please try again. You can close this page.</div></div>"; |
| 468 | + var htmlMessageConsentFailed = $"<html lang=en><meta charset=utf-8><title>PnP PowerShell - Consent</title><meta content=\"width=device-width,initial-scale=1\"name=viewport><style>html{{height:100%}}.error-text{{color:red;font-size:1rem}}.message-container{{flex-grow:1;display:flex;align-items:center;justify-content:center;margin:0 30px}}body{{box-sizing:border-box;min-height:100%;display:flex;flex-direction:column;color:#fff;font-family:\"Segoe UI\",\"Helvetica Neue\",Helvetica,Arial,sans-serif;background-color:#2c2c32;margin:0;padding:15px 30px}}.message{{font-weight:300;font-size:1.4rem}}.branding{{background-image:url();background-repeat:no-repeat;height:26px;padding-left:26px;font-size:20px;letter-spacing:-.04rem;font-weight:400;color:#fff;background-position:left center;text-decoration:none}}</style><a class=branding href=https://pnp.github.io/powershell>PnP PowerShell</a><div class=message-container><div class=message>You failed to provide consent. Please try again. You can close this page.</div></div>"; |
464 | 469 |
|
465 | 470 | var graphEndpoint = $"https://{AuthenticationManager.GetGraphEndPoint(AzureEnvironment)}";
|
466 | 471 | if (AzureEnvironment == AzureEnvironment.Custom)
|
@@ -598,7 +603,7 @@ private void SetLogo(AzureADApp azureApp, string token)
|
598 | 603 | {
|
599 | 604 | var byteArrayContent = new ByteArrayContent(bytes);
|
600 | 605 | byteArrayContent.Headers.ContentType = new System.Net.Http.Headers.MediaTypeHeaderValue(mediaType);
|
601 |
| - var requestHelper = new ApiRequestHelper(GetType(),PnPConnection.Current); |
| 606 | + var requestHelper = new ApiRequestHelper(GetType(), PnPConnection.Current); |
602 | 607 | requestHelper.Put2(endpoint, byteArrayContent, token);
|
603 | 608 |
|
604 | 609 | WriteVerbose("Successfully set the logo for the Entra ID app");
|
|
0 commit comments