Editing SharePoint Online User Profiles with PowerShell
Borrowing heavily from these TechNet contributors, I cobbled the following PowerShell script to enable editing of User Profile properties in SharePoint Online. Don’t just run the script blindly, it updates the AboutMe property for anyone with an email address – you’ll need to adapt what properties you want to update of course and also, this script does not update MultiValue properties but it probably isn’t too much of a leap to get to that from this either.
- http://social.technet.microsoft.com/wiki/contents/articles/29415.export-sharepoint-online-user-profile-information-using-powershell-csom.aspx
- http://blogs.msdn.com/b/vesku/archive/2014/11/07/sharepoint-user-profile-properties-now-writable-with-csom.aspx
- http://www.vrdmn.com/2014/11/set-another-users-profile-properties.html
- http://blogs.technet.com/b/fromthefield/archive/2014/06/18/sharepoint-evolution-conference-roadshow-sharepoint-online-administration-with-powershell.aspx
NB: Most of the comments below relate to access denied issues, this is caused by not connecting to the correct site. Ensure you connect ONLY to the administration site.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 |
# Import the required DLL # Download and install this: http://www.microsoft.com/en-us/download/details.aspx?id=42038 Import-Module 'C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\16\ISAPI\Microsoft.SharePoint.Client.UserProfiles.dll' Import-Module 'C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\16\ISAPI\Microsoft.SharePoint.Client.dll' #Mysite URL $site = 'https://mysite-admin.sharepoint.com/' # This needs to be the "admin" site. #Admin User Principal Name $admin = 'lewis@mysite.onmicrosoft.com' #Get Password as secure String $password = Read-Host 'Enter Password' -AsSecureString #Get the Client Context and Bind the Site Collection $context = New-Object Microsoft.SharePoint.Client.ClientContext($site) #Authenticate $credentials = New-Object Microsoft.SharePoint.Client.SharePointOnlineCredentials($admin , $password) $context.Credentials = $credentials #Fetch the users in Site Collection $users = $context.Web.SiteUsers $context.Load($users) $context.ExecuteQuery() #Create an Object [People Manager] to retrieve profile information $people = New-Object Microsoft.SharePoint.Client.UserProfiles.PeopleManager($context) ForEach($user in $users) { $userprofile = $people.GetPropertiesFor($user.LoginName) $context.Load($userprofile) $context.ExecuteQuery() If($userprofile.Email -ne $null) { # do something a little more intelligent here. $people.SetSingleValueProfileProperty($userprofile.AccountName, "AboutMe", "Updated by CSOM") $context.ExecuteQuery() } } |
Every time getting following error
Cannot find an overload for “PeopleManager” and the argument count: “1”.
at following line
$people = New-Object Microsoft.SharePoint.Client.UserProfiles.PeopleManager($context)
Ensure you have this installed: SharePoint Online Client Components SDK (http://www.microsoft.com/en-us/download/details.aspx?id=42038)
Then review: http://sharepoint.stackexchange.com/questions/135140/error-creating-peoplemanager-object-using-csom-in-powershell
Ensure you’re importing modules from the 16 hive, not 15.
-Lewis
Can you add custom properties to SharePoint Online using PowerShell? I thought you could add custom properties using PowerShell in SharePoint 2013, but I haven’t found any code to do it in SPO. I have only found code to update current properties.
This scripts looks like just the thing we need to accomplish what we need in our sharepoint.
i have tried executing the script right now, and it executes succesfully, but nothing happens in the About Me Property on my users.
i have of course changed the script to connect to our own sharepoint online site, but it doesnt change the property of About Me.
do you have any suggestions?
It’s difficult to know what you have of course so I can’t really say where the script might have failed.
The best thing to do is run each line of the script using the PowerShell ISE (Integrated Scripting Environment) and do some basic debugging.
I personally would start with the $users variable. Of course if the $Context.Web.SiteUsers call isn’t returning any users, then nothing will get processed by the foreach loop.
Also add things like Write-Host in to the foreach loop to see if it’s doing anything and which user is being processed or acted on.
I don’t get all users profiles into the context when I use the admin site. I can export user profiles from sharepoint online when using the main site. But those users don’t exist in de admin site context.
If I use a different site in my tenant for populating my context I get an access denied on my execute query for all profiles but my own.
Any way to work around this?
Thank you very much!
I have the same dilemma with Karel, I wanted to update a user’s user profile property field. I am a global & sharepoint administrator
the script doesn’t return information from fields:
1) “Language Preferences:” | “My Display Languages:”
2) “Time Zone:”
Please, Help me. How i can Get and change this Filds from the PowerShell ?
Hi,
Everyting in this script runs fine, except actually updating the profile. I get this error when trying to change the email address for a user (not my own):
Exception calling “ExecuteQuery” with “0” argument(s): “Access denied. You do not have permission to perform this action or access
this resource.”
I am Sharepoint Admin, Global Administrator of the tenant…
Any ideas what permissions I still need to be able to change other users’ properties?
Thanks
Thanks for the script, very useful but I have the same issue as Peter, the scripts work perfectly for my account but gives an “Access Denied” error for any other.
If you log in to the administration site with that username and password and then go to the user profiles section, do you have permissions to make the changes you want to make manually?
I’ve just run the script again on my own subscription but I’m logging in with my God account (the onmicrosoft.com account) and have been able to update every profile without issue, so I’m not sure what’s missing for you but it’s clearly a permissions problem related to the account you’re using to do the updates.
Resolved this by connecting to the admin console as shown in the code above :). I had been connecting to the root sharepoint site.
Good Post!
I have been able to update my user profile properties on a site that i created and i am the admin.
I have giveen access to a hotmail external user on my site and to a test user that i created for my site.
I am getting access denied when trying to update their user profile properties.
Any idea?
Thank you Lewis and Dave.
Everybody.. just take care you use the right url like:
$site = ‘https://mysite-admin.sharepoint.com/’
basically the admin one. And you will not get access denied for other user’s profile.
Have a good day!
I need to update profile picture,
I am using the below code:
$people.SetSingleValueProfileProperty($userprofile.AccountName, “PictureURL”, “**”
what value should i give in picture url.
Do i need to upload the image in a image library and give its url?
I tried that but that did not work.
Please tell me how to reorder the position of user profile properties, like if i have one property in one section and i want to move same property in another section without clicking on move up or move down. Please help seems like this is impossible in the sharepoint online.
Sarang Kulkarni, We created a case with MS yesterday for this issue. This is a bug and there are not work around. It took us 3 days to move properties to the correct place holder.
Is it possible to change the logon account ID using this script?
I very much doubt it. The information is usually populated mainly from your Active Directory. The information you have control over is limited and almost certainly doesn’t cover things like account IDs – this would likely need to be done in AD.
Did anyone ever find an answer to Serg’s question about Display Languages? I’m trying to get that information from the user profile as well.
This is exactly what I am looking for! I’ve been searching forever.
Can you tell me how I can use this script to update individual information per user from a file? For instance, for each user, I want to put their Hire Date in the About me section.