So yesterday I needed to automatically start a 2013 workflow on a list with a lot of items on it. Here is the Powershell script I wrote to do that. Hope this helps someone else.
# Run Flawless Execution site workflows automatically
$web = get-spweb -identity "YOURWEBSITEURL"
$list = $web.Lists["YOURLISTNAME"]
$workflow = "YOURWORKFLOWNAME"
$wfm = New-object Microsoft.SharePoint.WorkflowServices.WorkflowServicesManager($web)
$sub = $wfm.GetWorkflowSubscriptionService()
$wf = $sub.EnumerateSubscriptionsByList($list.ID) | Where-Object {$_.Name -eq "$workflow"}
$wis = $wfm.GetWorkflowInstanceService()
$items = $list.Items
foreach($item in $items)
{
$object = New-object 'system.collections.generic.dictionary[string, object]'
$object.Add("WorkflowStart", "StartWorkflow")
$wis.StartWorkFlowOnListItem($wf, $item.ID, $object)
}
$wfm.Dispose()
$web.Dispose()
Thursday, January 28, 2016
Thursday, January 21, 2016
Enabling SharePoint 2013 PeoplePicker to retrieve users from multiple domains.
There is already information out on the net about this, but I thought I would try to package this up concisely to help someone (possibly myself) do this in the future.
Has your organization recently acquired another company?
Do you now have multiple domains added to your previously single domain SharePoint Farm?
That has been my motivation for writing this blog post.
We had one domain called "Domain1" and needed to integrate a second domain we will call "Domain2"
Below is the Powershell script for making this happen.
$wa = Get-SPWebApplication -identity "https://sharepoint.company.com"
$key = convertto-securestring "Add_Your_Password_For_The_Search_Account_Here" -AsPlainText -Force
[Microsoft.SharePoint.SPSecurity]::SetApplicationCredentialKey($key)
$adsearchobj = New-Object Microsoft.SharePoint.Administration.SPPeoplePickerSearchActiveDirectoryDomain
$userpassword = Convertto-SecureString "Password_For_UserProfileSynchAccount(Domain1)" -asplaintext -force
$adsearchobj.DomainName = "Domain1"
$adsearchobj.ShortDomainName = "This_Is_Optional"
$adsearchobj.IsForest = $false
$adsearchobj.LoginName = "UserProfileSynchAccountForDomain1"
$adsearchobj.SetPassword($userpassword)
$wa.PeoplePickerSettings.SearchActiveDirectoryDomains.Add($adsearchobj)
$wa.Update()
$wa.PeoplePickerSettings #This displays current settings for clarity (optional)
$adsearchobj = New-Object Microsoft.SharePoint.Administration.SPPeoplePickerSearchActiveDirectoryDomain
$userpassword = Convertto-SecureString "Password_For_UserProfileSynchAccount(Domain2)" -asplaintext -force
$adsearchobj.DomainName = "Domain2"
$adsearchobj.ShortDomainName = "This_Is_Optional"
$adsearchobj.IsForest = $false
$adsearchobj.LoginName = "UserProfileSynchAccountForDomain2"
$adsearchobj.SetPassword($userpassword)
$wa.PeoplePickerSettings.SearchActiveDirectoryDomains.Add($adsearchobj)
$wa.Update()
$wa.PeoplePickerSettings #This displays current settings for clarity (optional)
If for some reason you need to back out of this, the below code will remove them one at a time:
$wa = Get-SPWebApplication -identity "https://sharepoint.company.com"
$adsearchobj = $wa.PeoplePickerSettings.SearchActiveDirectoryDomains.Item(1) #zero-based index
$wa.PeoplePickerSettings.SearchActiveDirectoryDomains.Remove($adsearchobj)
$wa.Update()
Labels:
Multiple Domains,
PeoplePicker,
Powershell,
SharePoint 2013
Location:
Winston-Salem, NC, USA
Subscribe to:
Posts (Atom)