Create Google Workspace Aliases in Bulk with this Script
Here is a video guide where I take you through from start to finish on how to quickly create hundreds or even thousands of email aliases in just minutes using this script.
1. Create new Google sheet
data:image/s3,"s3://crabby-images/b5569/b5569a953365ac7bf43e07b253c011ca6a3dc9fb" alt="rename sheet to create aliase"
So first step is for you to create a new Google spreadsheet. Then rename your sheet to ‘Create Alias‘.
This is because the script will be looking for a spreadsheet with the same exact name, so it is important you copy and paste the name correctly.
2. Go to script editor
data:image/s3,"s3://crabby-images/db926/db926458a68cf883e6225da25c33bbce75713aea" alt="rename sheet to create alias"
Next, from the new sheet you just created, go to ‘Tools‘ then click on ‘Script editor‘ to create a new script.
3. Copy and paste script
data:image/s3,"s3://crabby-images/149d7/149d7cdae7695cbd5e45daee85e2d5143b2b4b99" alt="paste script then save file"
Now copy and paste the following script into your script file. After pasting the script, don’t forget to save where you get also get prompted to provide project name.
----------------------------------------------------------------------------
function createrAlias() {
var ss = SpreadsheetApp.getActive()
var sheet = ss.getSheetByName("Create Alias")
var values = sheet.getDataRange().getValues()
var fileArray = [["Alias Creation Status"]]
for(i=1; i <values.length; i++) {
var userKey = values[i][0]
var aliasId = values[i][1]
try{
var status = "Alias Not Created"
var status = AdminDirectory.Users.Aliases.insert({"primaryEmail": userKey,"alias": aliasId}, userKey)
if (status != "Alias Not Created") {
status = "Alias Created Successfully"}
} catch (e) { Logger.log(e.message)
var status = e.message }
fileArray.push([status]) } var range = sheet.getRange(1, 3, fileArray.length, 1).setValues(fileArray)
}
----------------------------------------------------------------------------
Script overview
So, here is an overview of how the script essentially works:
- The script will look for two values from the first two columns of the spreadsheet.
- The first column should be ‘User key”, which is the user’s primary email address.
- The second column is a user’s alias id which is also the nickname.
- In the third column, the script will report whether or not an alias was successfully created.
4. Prepare spreadsheet
data:image/s3,"s3://crabby-images/656f0/656f0a7cc47e0046cce2e4b09c41fc3431e28997" alt="prepare sheet with primary email and alias ids"
As explained above, you will need to provide two columns with the first column being a user’s primary email address and in the second, an alias ID you want to create for that specific user.
In my case, I am creating aliases for just one email address however, you can create for several different users be it 500 or 1000 different email IDs whichever you like.
5. Enable ‘Admin Directory API’
Now before you can run the script, you need to do one more thing. That is to enable Admin Directory API.
data:image/s3,"s3://crabby-images/3e77d/3e77da99df74f5fc7ed5a0a1fbc6f3a7e6188416" alt="go to resource then advanced"
So to enable Admin Directory API, go back to the script page, click on ‘Resources‘ then from the drop down menu click on ‘Advanced Google services‘ option.
data:image/s3,"s3://crabby-images/ef2cc/ef2cc3a7c9a6326e33e965b61e30489d7363af6c" alt="enable admin directory API then GoogleAPIconsole e1519243902331"
Toggle the on-off button to enable Admin directory API. Then, click on ‘Google API Console’ link.
data:image/s3,"s3://crabby-images/50aeb/50aebfe28740a5257676df2299cd6f91b66502f2" alt="click enable API and services"
On the next screen, click on ‘Enable APIS and Services’ button
data:image/s3,"s3://crabby-images/548a3/548a3696ab8c091854ba32ddfea9c9efa5c59259" alt="search for admin SDK"
Now, search for ‘admin sdk’ and then click on ‘Admin SDK‘ from the results
data:image/s3,"s3://crabby-images/4311c/4311c78c1a1f9dd21bfd8c43767ebdbcb4ac2efd" alt="enable admin SDK"
Click on ‘Enable‘ button to turn on admin SDK.
data:image/s3,"s3://crabby-images/21ce0/21ce0920c46291061abfbf220f9032caea953d88" alt="click OK to finish API enable settings"
After enabling admin SDK, you then come back to ‘Advanced Google services‘ page then click on ‘OK’ button then Google will update the changes.
6. Run script
data:image/s3,"s3://crabby-images/088de/088de37d153fb3548daa850c8e43257e28565861" alt="save script and click run"
Now you’re all set and ready to run your script. Click on the ‘play’ button to execute the script.
Because you’re running the script for the first time, Google will ask you to give permissions using your account.
data:image/s3,"s3://crabby-images/7f8d8/7f8d8365eb70d5a95db095da8eeb0c02fdc115a3" alt="allow permission"
All you have to do is choose an account (if you have multiple account signed in) then click on ‘Allow’ button to give your project permissions to services such as spreadsheet, and user management.
Now the script will run for a few seconds or more depending on the number of email aliases on the spreadsheet.
data:image/s3,"s3://crabby-images/f87c6/f87c670955ae2b95cf7faa1fd8a30df9051e03a4" alt="alias successfully created"
So, you should see a script response on the third column of the spreadsheet after aliases have successfully been created.
data:image/s3,"s3://crabby-images/492c4/492c46f0aa7aca1f0b290ebc6b2cec71a3b98dac" alt="entity already exists - script"
The script will also be able to notify you if an alias you’re trying to create already exists with ‘Entity already exists‘ message response.
That’s all!
That’s all to it. You can quickly create hundreds of email aliases by simply running a Google apps script.
I hope you found it helpful, for questions and comments, please leave them in the comment section below and I will be more than glad to help.
Related Posts
....