martes, 22 de marzo de 2016

Powershell Web Access

Windows Powershell Web Access


I was thinking about how to connect into a Powershell console from a Mac or Linux computer, or just remotely from any public computer avoiding to do Remote Desktop.

One of the options is SSH (Secure SHell) for Powershell, to be honest I didn't test it yet but I am excited about to do it.

Another option is something call Windows Powershell Web Access.

So, I will be able to connect into a Powershell console from any computer that has a Web browser supporting Java Script.

Configuring Windows Powershell Web Access

  1. First of all we need to add the feature Powershell Web Access running the following command:
  2. PS:\>Install-WindowsFeature -Name WindowsPowershellWebAccess
    
    
  3. Ok, now we need to configure the Powersherll Web Access running the following command:

    PS:\>Install-PswaWebApplication -UseTestCertificate -WebApplicationName WebPS
    

    -UseTestCertificate: creates a certificate for testing enviroments.
    If you want to configure a production environment you should use a certificate signed by a CA.

    -WebApplicationName:The name of the ends of the website, in the example above is https://<ServerName>/WebPS 


















    More about Install-PswaWebApplication command here.
  4. After Windows PowerShell Web Access is installed and the gateway is configured, users can open the sign-in page in a browser, but they cannot sign in until the Windows PowerShell Web Access administrator grants users access explicitly.

    In the following command I'm providing access to all the users from any computer. 
  5. PS:\>Add-PswaAuthorizationRule –UserName * -ComputerName * -ConfigurationName *
    








  6. Then we need to browse our server following the link of our Powershell Web Access, by default is https://<ServerName>/pswa/
    Also, as we had showed above, you can specify your own Powershell Web Application name.

    Then, we need to login using any kind of user credentials with access to the server.
    And in Computer name: we need to write the server that we want to connect to.

  7. Enjoy powershell form the web!

miércoles, 2 de marzo de 2016

Remote Powershell to manage Office 365

Yhea, in the previous post I wrote about connecting to Office 365 using powershell in order to do taks related to Office 365.


But if we want to go a bit deep and do some Exchange tasks (For instance Get-Mailbox), we will need to connect into our  Exchange Online, if not we’ll get an error like:



So, in order to connect into our Exchange Online and be able to break everything … sorry, I mean to FIX everything, we should follow the next steps:


1- Update the default PowerShell Execution Policy

Set-ExecutionPolicy Unrestricted


2- Creating a Remote Session to Exchange Online. 
$UserCredential = Get-Credential
$Session = New-PSSession -ConfigurationName Microsoft.Exchange -ConnectionUri https://outlook.office365.com/powershell-liveid/ -Credential $UserCredential -Authentication Basic -AllowRedirection
Import-PSSession

NOTE: After that a window will pop up asking you for your credentials. You should enter your Office 365 admin user.

3- Done, you are connected to your Exchange Online. 
In order to check your connectivity, now you can run the command Get-Mailbox  

lunes, 29 de febrero de 2016

Get Office 365 users using Powershell

Sometimes, at work I need to check the licensed users in Office 365, I can check them from the Office 365 Admin website, but I’m not sure if I’m able to export them to an Excel (Or CSV file).

So, in order to do that I’ll do it using our little friend, the uncle PowerShell.

Before jumping into the commands, you will need to install some modules to connect to your Azure Office 365 platform.

  1. First install the  Microsoft Online Services Sign-In Assistant for IT Professionals RTW
  2. Then Azure Active Directory Module for Windows PowerShell (64-bit version) 
Now, open a powershell terminal and type:
 
PS C:\WINDOWS\system32> Connect-MsolService
A new window will pop up, enter your Office 365 credentials there. And then, if you don't have any error, you will be in. Now type the following command:
PS C:\WINDOWS\system32> Get-MsolUser | Where-Object {$_.isLicensed -eq "TRUE"} | Export-Csv C:\LicensedUsersOffice365.csv


And that is it, you will have an excel file of all your licensed users on Office 365.