Simple question: Using a Flow condition, how do you check the value of a SharePoint Yes No field?
My first attempt was to set a variable equal to the SharePoint list value, then check the condition like this:
And, for good reason, this did not work.
My next attempt was to try replacing the condition value with true or false.
And, again, this did not work!
Sooo, what if I convert the true or false to a string?
It worked!
How do you set or update a SharePoint Yes No field using a Flow variable?
Create a string variable, then set the value to true or false.
SharePoint display values:
Yes = true
No = false
Author Archives: Ian Hayse
Get Files From a SharePoint Folder Using PowerShell PNP
How do you get all the files from a folder in SharePoint using PowerShell PNP?
$devConn = Connect-PnPOnline -Url "https://sharepointed.sharepoint.com/sites/siteA/siteB" -Credentials -Credentials (Get-Credential) -ReturnConnection
$folderName = "/Shared Documents/myfolder/anotherfolder"
$folderItems = Get-PnPFolderItem -FolderSiteRelativeUrl $folderName -Connection $devConn
foreach($item in $folderItems)
{
Write-Host $item.Name
}
Write-Host "done"
Depending on your needs, you could also use a search query with a path filter to get the files.
Example of using the Get-PnPListItem cmdlet with the FolderServerRelativeUrl parameter.
$devConn = Connect-PnPOnline -Url "https://sharepointed.sharepoint.com/sites/siteA/siteB" -Credentials -Credentials (Get-Credential) -ReturnConnection
$folderName = "/sites/spdev2/bw2/Shared Documents/myfolder/anotherfolder"
$folderItems = Get-PnPListItem -List "Shared Documents" -FolderServerRelativeUrl $folderName -Connection $devConn
foreach($item in $folderItems)
{
Write-Host $item
}
Flow Trigger On SharePoint Item Version
How do you run a Flow on a specific version SharePoint item version?
Create a Flow, then navigate into the Settings of the first step. Scroll down to Trigger Conditions and enter the following:
@equals(float(triggerBody()?['{VersionNumber}']),1.0)
Save the Flow and run a test.
The Flow should only process items / documents where the version is equal to 1.0.
Flow Variables Not Displaying In The Dynamic Content Menu
I was trying to dynamically set a SharePoint list item ID to a variable but the variable was not displaying in the Dynamic Content menu.
The solution was to use an expression to set the value, save the flow, exit the edit screen, then re-enter the edit screen.
variables('varRefID')
PowerAutomate SharePoint Server relative urls must start with SPWeb.ServerRelativeUrl
{
"inputs": {
"variables": [
{
"name": "varURI-String",
"type": "string",
"value": "/_api/web/GetFolderByServerRelativeUrl('@{triggerBody()?['FolderPath']}')/ListItemAllFields/breakroleinheritance(copyRoleAssignments=false, clearSubscopes=true)"
}
]
}
}
Using a Power Automate Flow to break inheritance on a folder and this error was being returned. The issue turned out to be the path I was trying to use for the folder.
This did not work: LibraryName/Folder
This DID work: /sites/ParentSite/SubSite/LibraryName/Folder’
Copy Files From Azure File Storage to SharePoint
As of today, there is not a Logic App trigger for Azure File Storage, so I went with a schedule-based approach. Yes, this example leaves out a lot of fine-tuning, but it will get you headed in the right direction.
Create a blank Logic app
Trigger: Schedule
Action: Azure File Storage – List files
Action: SharePoint – Create file
After you add the SharePoint action, the Logic App should automatically add a For Each action and place the SharePoint Create File action inside of it.
In the last screenshot, I tested the Logic App by uploading a couple of documents in Azure Storage Explorer, then I manually ran the Logic App (click the Run button).
Again, this is a simple example. The example does not account for processing the same files over and over…
SharePoint Search Query Tool Login
If you have ever worked with SharePoint search you likely already know about the SharePoint Search Query Tool. If you are new to SharePoint and need a little insight into the SharePoint search experience this tool is a lifesaver!
SharePoint Query Tool GitHub: https://github.com/pnp/PnP-Tools/
In future posts, I will outline how to form queries and use the tool but for now, I want to simply connect to my SharePoint Online site.
Enter the URL for your SharePoint site, select the Authentication options shown above, then click Sign-In. If a web login form appears be sure to complete it. If your normal Windows login doesn’t work, try using your work email address and password, and if that doesn’t work try your work email address and App Password.
App Passwords are created and managed at this URL: https://account.activedirectory.windowsazure.com/AppPasswords.aspx
Power Automate Bad Gateway Error
I was trying to use a SQL Insert Row action to insert a new row in a SQL Server table and received a Bad Gateway error. First, I thought it was a permissions issue, then I thought my Flow stopped working…
Turned out to be an issue with the amount of data being inserted into a field. One SQL column was set to varchar(X) and the Flow was trying to insert more characters than X.
Flow Power Automate and SharePoint Required Fields
On the surface, this request sounded super simple and straightforward. “we need to copy files from a SharePoint library to Blob storage.” Simple enough? Well, yes, but the SharePoint library has a couple of required fields and a Flow is triggered by an action.
Consider what I’m outlining below to be version ONE of the process. In the near future, I will update this post with a slightly more resilient solution.
My SharePoint library has a required field titled DesinationFolder
Context of what I’m doing in the Flow:
Trigger: When files is created in a folder
When a file is added to a library the flow is triggered
Get file metadata
File Identifier: Use File identifier from the step above
Get file properties
Id: Use the ItemId from the previous step
Initialize variable
Name: vCheckedOut
Type: Boolean
Value: Checked out (field from Get properties)
Initialize variable
Name: vFolderPath
Type: String
Value:
Condition
vCheckedOut is equal to true
Yes:
Do until
vCheckout is equal to False
GetFileProperties
Set variable
Name: vCheckedOut
Value: Checked out (value from the Get file properties above)
No:
Set variable
Name: vFolderPath
Value: FolderPath (SharePoint field)
Compose
/blobfolder/vFolderPath (variable)
Create blob
Get-PnPSearchCrawlLog Filter to a List or Library
Using the Get-PnpSearchCrawlLog cmdlet wanted to filter the returned result set to a specific list. Before you begin, you’ll want to make sure you have access to the Crawl Log: https://yourSite-admin.sharepoint.com/_layouts/15/searchadmin/crawllogreadpermission.aspx
Connect-PnPOnline -Url "https://sharepointed.sharepoint.com/sites/food" -Credentials (Get-Credential)
$logs = Get-PnPSearchCrawlLog -filter "https://sharepointed.sharepoint.com/sites/food/Lists/tacos/"
foreach($l in $logs)
{
Write-Host " "
Write-Host $l.Url
Write-Host $l.ItemId
Write-Host $l.LogLevel
Write-Host $l.CrawlTime
}
This will filter the returned results to a specific list. Note: when using Connect-PnPOnline I use my email address and App Password. App Password can be created/found here: https://account.activedirectory.windowsazure.com/AppPasswords.aspx
Get-PnPSearchCrawlLog details: https://docs.microsoft.com/en-us/powershell/module/sharepoint-pnp/get-pnpsearchcrawllog?view=sharepoint-ps