Introduction
About a week ago, I was scrolling through Reddit and came across a post in r/sysadmin, Get list of aliases in Gsuite/Gmail.
I took a few minutes to install and configure PSGSuite, a module for interacting with G Suite (Google Apps) API that I heard about sometime last year. In short order, I was able to provide a response to the post.
PSGSuite project, other than being a very new, casual user of the module. Please visit the
GitHub repo or wiki for help with commands or to raise an issue.
        This module allows you to work with GSuite users, groups, sheets, and more. See the wiki for details.
This post will take you through creating organizational units, users, and groups, and assigning users to groups, and listing users with email aliases.
For fun, I’ve created a custom schema and attribute, EmployeeType, that will help categorize our users.
/test organizational unit and blocked automatic assignment of a license since I’m using my personal G Suite account.
I don’t want any surprises at the end of the month.
        Basic User Process
This list covers the basic workflow that we will be following.
- Create Organizational Units
- Create Groups
- Create Users
- Assign Users to Groups
- Get User Account Info
Setup
PSGSuite Module
I followed the project’s wiki Initial Setup page and the configuration went smoothly and quickly.
Custom Attribute in G Suite
Here are the basic steps I used to create the custom attribute in G Suite.
- Login to https://admin.google.com.
- Go to Users.
- Click on Manage Custom Attributes icon, next to Download Users.
- Click on ADD CUSTOM ATTRIBUTE.
- For Category, I used CustomUniversity. This will be the name of the custom schema that is applied to users.
- For Description, I used ‘All custom attributes for the university’.
- Then, in the entry for Custom Fields, I used the following:
| Name | Info Type | Visibility | No. of Values | 
|---|---|---|---|
| EmployeeType | text | visible to domain | single value | 
Once I saved the custom schema, I verified that I had entered everything correctly by managing user attributes again and selecting the category.

Data
I created the following data in a Google Sheets spreadsheet called UserManagement. These two sheets will be used to provide the required data for all steps of the process.
Sheet: Users
| FullName | GivenName | FamilyName | EmployeeType | ||
|---|---|---|---|---|---|
| Donald Edwards | Donald | Edwards | don@anovelidea.org | Staff | |
| Leslie Myers | Leslie | Myers | leslie@anovelidea.org | Staff | |
| Emily Jones | Emily | Jones | emily@anovelidea.org | Faculty | |
| Larry Brooks | Larry | Brooks | larry@anovelidea.org | Faculty | 
Sheet: Groups
| Name | Description | OrgUnitPath | |
|---|---|---|---|
| Business | business@anovelidea.org | Business Department | /test/business | 
| Academics | academics@anovelidea.org | Academics Department | /test/academics | 
User Process
To begin, we need to import the module and then use the command Get-GSDriveFileList to find the Google Sheet where our
data is stored.
Next, we use the command Import-GSSheet to import our user and group data.
|  |  | 
Create Organizational Units
We use Get-GSOrganizationalUnit to determine if the OU exists. And then we use New-GSOrganizationalUnit to create
it if it does not.
|  |  | 
Create Groups
Using the command Get-GSGroup, we check if the group exists. If the group does not already exist, use New-GSGroup to
create the group from the spreadsheet.
|  |  | 
Create Users
Create the users listed in the spreadsheet.
- First, determine the department based on the user type.
- Using the department, set the variable for the org unit path.
- Create the required hashtable for CustomSchemas to add the EmployeeType to the user.
- Generate a random secure password.
- Using the command New-GSUser, create the new user.
- If the user is successfully created, use the command New-GSUserAliasfor best effort to create an email alias based on the user’s full name.
|  |  | 
Get-RandomPassword function is a mock-up and currently only returns a string value.
        Assign Users to Groups
Next, we use Get-GSUserList to get a list of all users in the parent OU, and then add the user to the group with
Add-GSGroupMember.
|  |  | 
Listing All Email Addresses Including Aliases
When I commented on the Reddit post referenced above, it was with option 1. During the writing of this post, I created option 2 as a more real-world example of what data can be brought out of the GSUser object.
Option 1
This option uses the commands Get-GSUserList and Get-GSUserAlias to retrieve the data.
|  |  | 
Option 2
This option also uses the command Get-GSUserList, but it uses the more versatile command Get-GSUser to retrieve all
pertinent data.
|  |  | 
| Name | PrimaryEmail | CreationTime | Aliases | OrgUnitPath | EmployeeType | LastLoginTime | 
|---|---|---|---|---|---|---|
| Donald Edwards | don@anovelidea.org | 3/3/2019 7:13:47 PM | DonaldEdwards@anovelidea.org | /test/business | Staff | 12/31/1969 6:00:00 PM | 
| Emily Jones | emily@anovelidea.org | 3/3/2019 7:13:53 PM | EmilyJones@anovelidea.org | /test/academics | Faculty | 12/31/1969 6:00:00 PM | 
| Larry Brooks | larry@anovelidea.org | 3/3/2019 7:13:56 PM | LarryBrooks@anovelidea.org | /test/academics | Faculty | 12/31/1969 6:00:00 PM | 
| Leslie Myers | leslie@anovelidea.org | 3/3/2019 7:13:50 PM | LeslieMyers@anovelidea.org | /test/business | Staff | 12/31/1969 6:00:00 PM | 
Bonus
Of course, you could easily send the data back into a Google sheet or export it to CSV or Excel.
|  |  | 
And here is what the end result will look like.

Summary
As you can see based on these relatively simple examples, there is a great deal of automation for a G Suite organization
that you can perform using the PSGSuite module.
I hope these examples will help you understand how to start using the PSGSuite module, or at least have piqued your curiosity to learn more on your own.
If this blog post has helped you, please leave a comment below.
PowerShell to the People!
