Skip to content

Commit

Permalink
Merge pull request #110 from Glynnryan/sample/Sharepoint---List---Upd…
Browse files Browse the repository at this point in the history
…ate-Created-By

sample/sharepoint-list-update-created-by
  • Loading branch information
Katerina-Chernevskaya authored Oct 15, 2024
2 parents c865657 + 08d02d8 commit b651688
Show file tree
Hide file tree
Showing 19 changed files with 601 additions and 0 deletions.
184 changes: 184 additions & 0 deletions samples/sharepoint-list-update-created-by/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,184 @@
# Update "Created by" in a Microsoft List

## Summary

This Power Automate flow updates the “Created By” field of a Microsoft List item, replacing the account with a specified user based on their email address, using an HTTP request to SharePoint.

![Overview](assets/Overview.jpg)

## Applies to

![Power Automate](https://img.shields.io/badge/Power%20Automate-Yes-green "Yes")

## Compatibility

![Premium License](https://img.shields.io/badge/Premium%20License-Not%20Required-red.svg "Premium license not required") ![Experimental Features](https://img.shields.io/badge/Experimental%20Features-No-red.svg "Does not rely on experimental features")

## Contributors

* [Glynn Pearson](https://github.com/Glynnryan)

## Version history

| Version | Date | Comments |
| ------- | ------------------ | --------------- |
| 1.0.0.0 | September 18, 2024 | Initial release |

## Prerequisites

- **Microsoft Lists**
- A configured Microsoft List

## Minimal path to awesome

### Using the solution zip

* [Download](./solution/sharepoint-list-update-created-by.zip) the `.zip` from the `solution` folder
* Within **Power Apps Studio**, import the solution `.zip` file using **Solutions** > **Import Solution** and select the `.zip` file you just packed.
* Open the app in edit mode and make sure the data source **Data source name** is connected correctly.

### Using the source code

You can also use the [Power Apps CLI](https://docs.microsoft.com/powerapps/developer/data-platform/powerapps-cli) to pack the source code by following these steps:

* Clone the repository to a local drive
* Pack the source files back into a solution `.zip` file:

```bash
pac solution pack --zipfile pathtodestinationfile --folder pathtosourcefolder --processCanvasApps
```

Making sure to replace `pathtosourcefolder` to point to the path to this sample's `sourcecode` folder, and `pathtodestinationfile` to point to the path of this solution's `.zip` file (located under the `solution` folder)
* Within **Power Apps Studio**, import the solution `.zip` file using **Solutions** > **Import Solution** and select the `.zip` file you just packed.

### Create from scratch

> [!NOTE]
> My solution uses a flow created within a Solution in Power Automate. You can still achieve the end goal by following the steps below in a dedicated flow. However, if you're not using solutions, I would recommend starting to do so, as there are several benefits, such as running a child flow.
> [!TIP]
> For more information on Solutions, you can click [here](https://learn.microsoft.com/en-us/power-automate/overview-solution-flows).
### Steps
1. Sign in to [Power Automate](https://make.powerautomate.com/).
2. In the left-hand menu, select **Solutions**.
3. Choose the solution where you want to create the automation, or [create a new solution](https://learn.microsoft.com/en-us/power-automate/overview-solution-flows).
4. Create a new automation:
- In the top menu, select **New** > **Automation** > **Cloud Flow** > **Instant**.

![Step 4a](assets/Step%204a.jpg)

- Enter a **Flow name**. (I called mine "Update Created By". Original, right? 🤓)
- Select **Manually trigger a flow** as the trigger.
- Select **Create**.

![Step 4b](assets/Step%204a.jpg)

5. Select **Manually trigger a flow** and add the following inputs:

| Type | Name | Description |
| ------ | ---------------- | -------------------------------------------- |
| Text | List Name | Name of the list to update |
| Number | List ID | List item ID to update |
| Text | Created By Email | Email address of the person to set as Author |
| Text | Site Address | Site address of the list |

![Step 5](assets/Step%205.jpg)

6. Add a **Send an HTTP request to SharePoint** action.

![Step 6](assets/Step%206.jpg)

> [!TIP]
> You can search for "HTTP" in the search box to find this action quickly.
7. Configure the **Send an HTTP request to SharePoint** action as follows:

- **Site Address**
- Select the **Site Address** dynamic content created in step 5, or enter the relevant SharePoint site address.

> [!TIP]
> If you want this automation to work dynamically across multiple SharePoint sites, add the **Site Address** at step 5. Alternatively, you can set this as a fixed value if your use case means the SharePoint site will not change.
- **Method**
- Post

- **Uri**

``` HTML
_api/web/lists/getbytitle('List Name')/items('ID')/validateUpdateListItem
```

> [!NOTE]
> - If you've followed the exact sequence in step 5, you can use [Uri-Sample.html](./assets/Uri-Sample.html) without modification.
> - If you configured your own inputs in Step 5, adjust [Uri.html](./assets/Uri.html) as needed.
- **Body**

``` JSON
{
"formValues":[
{
"FieldName": "Author",
"FieldValue": "[{'Key':'i:0#.f|membership|[email protected]'}]"
}
]
}
```

> [!NOTE]
> - If you've followed the exact sequence in step 5, you can use [Body-Sample.json](./assets/Body-Sample.json) without modification.
> - If you configured your own inputs in Step 5, adjust [Body.json](./assets/Body.json) as needed.
![Step 7](assets/Step%207.jpg)

8. Add a **Respond to a Power App or flow** action.

![Step 8](assets/Step%208.jpg)

> [!TIP]
> Add an **Output**, with the **Type** of **Text** and **Value** of "Complete" to parse this status back to your previous flow.
9. Save and **publish** your automation.
10. Select **Back** at the top left corner of your screen to return to the automation's overview screen.
11. **Edit** the **Run only users**

> [!IMPORTANT]
> This is to ensure that the automation can be run when using the "Run a child flow" action.
- Select the dropdown arrow below the **SharePoint** connection.
- Select a connection to use.
- Select **Save**
And that’s it! Now, whenever you need to update the “Created By” field in a Microsoft List item, use the **Run a Child Flow** action, select this automation, and input your dynamic content into the fields you set up in step 5.

## Features

I have several Power Automate flows that create items in various Microsoft Lists within the same SharePoint site using a service account. As a result, these list items have a "Created By" value that reflects the service account's name.

While this is acceptable in some instances, there are cases where I need a specific individual to appear as the author of the item. For example, when a Microsoft Form triggers my flow, I may want the list item to reflect the form responder as the list item author.

This Power Automate flow updates the “Created By” field in Microsoft Lists, replacing the default account with a specified user based on their email address, using an HTTP request to SharePoint.

## Help

We do not support samples, but this community is always willing to help, and we want to improve these samples. We use GitHub to track issues, which makes it easy for community members to volunteer their time and help resolve issues.

If you encounter any issues while using this sample, you can [create a new issue](https://github.com/pnp/powerapps-samples/issues/new?assignees=&labels=Needs%3A+Triage+%3Amag%3A%2Ctype%3Abug-suspected&template=bug-report.yml&sample=sharepoint-list-update-created-by&authors=@Glynnryan&title=sharepoint-list-update-created-by%20-%20).

For questions regarding this sample, [create a new question](https://github.com/pnp/powerapps-samples/issues/new?assignees=&labels=Needs%3A+Triage+%3Amag%3A%2Ctype%3Abug-suspected&template=question.yml&sample=sharepoint-list-update-created-by&authors=@Glynnryan&title=sharepoint-list-update-created-by%20-%20).

Finally, if you have an idea for improvement, [make a suggestion](https://github.com/pnp/powerapps-samples/issues/new?assignees=&labels=Needs%3A+Triage+%3Amag%3A%2Ctype%3Abug-suspected&template=suggestion.yml&sample=sharepoint-list-update-created-by&authors=@Glynnryan&title=sharepoint-list-update-created-by%20-%20).

## Disclaimer

**THIS CODE IS PROVIDED *AS IS* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING ANY IMPLIED WARRANTIES OF FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR NON-INFRINGEMENT.**

## Post Script

I stumbled onto a Microsoft Community post titled "[Update 'Created By' and 'Modified By' fields.](https://techcommunity.microsoft.com/t5/power-apps-and-power-automate-in/update-created-by-and-modified-by-fields/m-p/3672675/highlight/true#M6072)", with an answer by [Rob Elliott](https://techcommunity.microsoft.com/t5/user/viewprofilepage/user-id/174092#profile) which gave me the idea and framework for my solution.

### Acknowledgements

- [Rob Elliott](https://techcommunity.microsoft.com/t5/user/viewprofilepage/user-id/174092#profile)

<img src="https://m365-visitor-stats.azurewebsites.net/powerplatform-samples/samples/sharepoint-list-update-created-by" aria-hidden="true" />
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"formValues":[
{
"FieldName": "Author",
"FieldValue": "[{'Key':'i:0#.f|membership|@{triggerBody()?['text_1']}'}]"
}
]
}
8 changes: 8 additions & 0 deletions samples/sharepoint-list-update-created-by/assets/Body.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"formValues":[
{
"FieldName": "Author",
"FieldValue": "[{'Key':'i:0#.f|membership|[email protected]'}]"
}
]
}
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
_api/web/lists/getbytitle('@{triggerBody()?'text'}')/items('@{triggerBody()?'number'}')/validateUpdateListItem
1 change: 1 addition & 0 deletions samples/sharepoint-list-update-created-by/assets/Uri.html
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
_api/web/lists/getbytitle('List Name')/items('ID')/validateUpdateListItem
66 changes: 66 additions & 0 deletions samples/sharepoint-list-update-created-by/assets/sample.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
[
{
"name": "pnp-powerplatform-samples-sharepoint-list-update-created-by",
"source": "pnp",
"title": "Update Created by in a Microsoft List",
"shortDescription": "This Power Automate flow updates the “Created By” field of a Microsoft List item, replacing the account with a specified user based on their email address, using an HTTP request to SharePoint.",
"url": "https://github.com/pnp/powerplatform-samples/tree/main/samples/sharepoint-list-update-created-by",
"downloadUrl": "https://pnp.github.io/download-partial/?url=https://github.com/pnp/powerplatform-samples/tree/main/samples/sharepoint-list-update-created-by",
"longDescription": [
"This Power Automate flow updates the “Created By” field of a Microsoft List item, replacing the account with a specified user based on their email address, using an HTTP request to SharePoint."
],
"creationDateTime": "2024-09-18",
"updateDateTime": "2024-09-18",
"products": [
"Power Automate",
"Power Platform"
],
"tags": [
"SharePoint",
"List update"
],
"categories": [
"CLOUD-FLOW"
],
"metadata": [
{
"key": "POWERAPPS-EXPERIMENTAL",
"value": "No"
},
{
"key": "POWERAPPS-PREMIUM",
"value": "No"
},
{
"key": "POWERAPPS-ONPREM",
"value": "No"
},
{
"key": "POWERAPPS-CUSTOMCONNECTOR",
"value": "No"
}
],
"thumbnails": [
{
"type": "image",
"order": 100,
"url": "https://github.com/pnp/powerplatform-samples/raw/main/samples/sharepoint-list-update-created-by/assets/Overview.jpg",
"alt": "App preview"
}
],
"authors": [
{
"gitHubAccount": "Glynnryan",
"pictureUrl": "https://github.com/Glynnryan.png",
"name": "Glynn Pearson"
}
],
"references": [
{
"name": "Microsoft Power Platform documentation",
"description": "Discover how to make the most of Microsoft Power Platform products with online training courses, docs, and videos covering product capabilities and how-to guides.",
"url": "https://learn.microsoft.com/power-platform/"
}
]
}
]
Binary file not shown.
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="15.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<PowerAppsTargetsPath>$(MSBuildExtensionsPath)\Microsoft\VisualStudio\v$(VisualStudioVersion)\PowerApps</PowerAppsTargetsPath>
</PropertyGroup>

<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" />
<Import Project="$(PowerAppsTargetsPath)\Microsoft.PowerApps.VisualStudio.Solution.props" Condition="Exists('$(PowerAppsTargetsPath)\Microsoft.PowerApps.VisualStudio.Solution.props')" />

<PropertyGroup>
<ProjectGuid>8f595c70-54fd-477e-bd05-7937e1d15be0</ProjectGuid>
<TargetFrameworkVersion>v4.6.2</TargetFrameworkVersion>
<!--Remove TargetFramework when this is available in 16.1-->
<TargetFramework>net462</TargetFramework>
<RestoreProjectStyle>PackageReference</RestoreProjectStyle>
<SolutionRootPath>src</SolutionRootPath>
</PropertyGroup>

<!--
Solution Packager overrides, un-comment to use: SolutionPackagerType (Managed, Unmanaged, Both)
Solution Localization Control, if you want to enabled localization of your solution, un-comment SolutionPackageEnableLocalization and set the value to true. - Requires use of -loc flag on Solution Clone or Sync
-->
<!--
<PropertyGroup>
<SolutionPackageType>Managed</SolutionPackageType>
<SolutionPackageEnableLocalization>false</SolutionPackageEnableLocalization>
</PropertyGroup>
-->

<ItemGroup>
<PackageReference Include="Microsoft.PowerApps.MSBuild.Solution" Version="1.*" />
<PackageReference Include="Microsoft.NETFramework.ReferenceAssemblies" Version="1.0.0" PrivateAssets="All" />
</ItemGroup>

<ItemGroup>
<ExcludeDirectories Include="$(MSBuildThisFileDirectory)\.gitignore" />
<ExcludeDirectories Include="$(MSBuildThisFileDirectory)\bin\**" />
<ExcludeDirectories Include="$(MSBuildThisFileDirectory)\obj\**" />
<ExcludeDirectories Include="$(MSBuildThisFileDirectory)\*.cdsproj" />
<ExcludeDirectories Include="$(MSBuildThisFileDirectory)\*.cdsproj.user" />
<ExcludeDirectories Include="$(MSBuildThisFileDirectory)\*.sln" />
</ItemGroup>

<ItemGroup>
<None Include="$(MSBuildThisFileDirectory)\**" Exclude="@(ExcludeDirectories)" />
<Content Include="$(SolutionPackageZipFilePath)">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</Content>
</ItemGroup>

<Import Project="$(MSBuildToolsPath)\Microsoft.Common.targets" />
<Import Project="$(PowerAppsTargetsPath)\Microsoft.PowerApps.VisualStudio.Solution.targets" Condition="Exists('$(PowerAppsTargetsPath)\Microsoft.PowerApps.VisualStudio.Solution.targets')" />

</Project>
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
<?xml version="1.0" encoding="utf-8"?>
<ImportExportXml xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" OrganizationVersion="9.2.24092.184" OrganizationSchemaType="Standard" CRMServerServiceabilityVersion="9.2.24093.00198">
<Entities />
<Roles />
<Workflows />
<FieldSecurityProfiles />
<Templates />
<EntityMaps />
<EntityRelationships />
<OrganizationSettings />
<optionsets />
<CustomControls />
<EntityDataProviders />
<connectionreferences>
<connectionreference connectionreferencelogicalname="glynn_SharePoint">
<connectionreferencedisplayname>SharePoint</connectionreferencedisplayname>
<connectorid>/providers/Microsoft.PowerApps/apis/shared_sharepointonline</connectorid>
<description>Microsoft SharePoint</description>
<iscustomizable>1</iscustomizable>
<promptingbehavior>0</promptingbehavior>
<statecode>0</statecode>
<statuscode>1</statuscode>
</connectionreference>
</connectionreferences>
<Languages>
<Language>1033</Language>
</Languages>
</ImportExportXml>
Loading

0 comments on commit b651688

Please sign in to comment.