cancel
Showing results for 
Search instead for 
Did you mean: 
Reply
invintern
Helper II
Helper II

Duplicate Shared Office Calendar into D365 Calendar

Hello,

 

I am looking to update the D365 Dataverse Calendar with any and all events on our Shared Office Resources Calendar.

 

I can get D365 to re-create any events that have been 'added, updated, or deleted' but for some reason my Flow was created tons of duplicates.

 

Here is the Flow:

invintern_1-1639615135005.png

 

 

invintern_0-1639615125420.png

 

 Here are the results: 

invintern_2-1639615238643.png

 

(D365 will load forever - I assume there are 100+ duplicate entries on this day alone. Trust me that there are ALSO duplicates on the prior days, though D365 does not seem to want to load them while it is pre-loading my infinite list)

 

SO, I am hoping to re-create this Flow without the duplication.

 

Any thoughts?

 

Thanks,

 

1 ACCEPTED SOLUTION

Accepted Solutions

I've created the demo flow earlier and it appears to still work. I've updated the "updated actions", if no existing appointment record was found to update (because the appointment existed before the flow was created) then create a new appointment.

 

Here is the overall flow:

 

ekarim2020_0-1641930098926.png

 

 

Snag_218a7c.png

 

For updating the Appointments table

This is the Updated case:

ekarim2020_1-1641930170263.png

The Condition expanded for the Update case:

Snag_17e6a7.png

If there is no existing appointment record was found to update (because the appointment existed before the flow was created) then create a new appointment.

 

Close-up of the Condition action

Snag_19a212.png

Hope this helps.

 

Ellis

View solution in original post

31 REPLIES 31
ekarim2020
Super User
Super User

One approach to this problem would be to store the Calendar event Id in the Appointments table. This then will enable you to find which Dataverse record (row) needs to be updated or deleted or created. For example:

2021-12-20_17-57-15.png

 

Your flow will likely contain the following actions or similar:

 

Dataverse Diagram.drawio.png

 

Hope this helps.

 


Ellis
____________________________________
If I have answered your question, please mark the post as Solved.
If you like my response, please give it a Thumbs Up.

invintern
Helper II
Helper II

Hi Ellis,

 

Yes, this makes sense...in theory!

 

My first question: what does the remainder of your Flow look like? I am not sure where within the Flow to put your 'add a new row 2' box.

 

What is the 'EventID' and where do I find it?

 

Do you input 'id' onto....duration? As you can see, my 'add a new row' step does NOT have an input ask for EventID. It looks to me like you put it over Duration?

invintern_0-1640032170654.png

 

How do I setup the 3-branch logic, differentiating between a record deleted, updated, or added? I am looking at the 'Condition' option, and am wondering how to end up with the results, given the inputs of 'if event [is equal to/does contain/ends with/etc].' 

 

Thank you for your efforts in helping me. Please let me know what you come up with.

 

I have a flow that does almost the opposite, it takes events from a Dataverse table and updates a SharePoint List:

2021-12-20_21-08-40.png

The concepts should be the same or similar to what you are trying to do:

2021-12-20_20-56-15.png

The SharePoint list has a column called itemInternalId that stores the Dataverse row Id (itemInternalId):

2021-12-20_21-03-35.png

The example screen shot I created of the Dataverse action was for just for demonstration purposes only. You would need to create a new column to store the Event ID:

2021-12-20_17-57-15.png

The Calendar Event Id can be found in Dynamic content as shown below:

2021-12-20_20-54-00.png

 


Ellis
____________________________________
If I have answered your question, please mark the post as Solved.
If you like my response, please give it a Thumbs Up.

The Switch action could be used for the different actions, for example:

2021-12-20_21-34-09.png

 

2021-12-20_21-36-50.png

 

Ellis

invintern
Helper II
Helper II

Very helpful, thank you for introducing to me the concepts of Scope & Switch. 

 

I find that I am often unaware of the tools at my disposal. It is very easy to begin the PA journey somewhere in the middle (in my experience).

 

Ok, so depending on the Action Type of the events (created, deleted, updated) I can send the Flow down one of three paths.

 

Add a row makes sense. Add a row to Appointment with the details given in Exchange.

 

How about Update or Delete? Where do I find the Row ID to update? My Dynamic Content selector lets me choose the ID of the Exchange event, though I believe I need the specific Dataverse event....In my head, I could find a way to search the Dataverse for the ID that the newly-created appointment was given...though it seems like listing Rows -> Appointments does not seem to give me that level of specificity.

 

I will keep poking around. Thank you for your continued assistance. 

 

Edit: Further, would you mind please showing me the contents of your Scopes?

This is the updated logic of the flow:

 

Outlook Calendar Updating Dataverse Appointments table-Basic Event Flow.png

This is the flow based more or less on the above flow chart:

2021-12-21_10-17-32.png

 

The Outlook Calendar Id can in fact be stored in the Outlook Appointment field during the Add a new row action. The Dataverse internal name for this column is globalobjectid:

2021-12-21_10-53-10.png

 

To find appointments that were Updated or Deleted:

2021-12-21_10-21-21.png

 

Hope this helps.

 

Ellis

invintern
Helper II
Helper II

This does help. Of course, I still have a few questions. I am going to build as I type to you.

 

Regarding the snip marked "This is the flow based more or less on the above flow chart:" - What is your 'Compose Documentation' about?

 

Regarding your Conditions, I can't see what you're doing in there and here is my educated guess on the 'update event' Switch path. I have a feeling I may be incorrect here. My 'delete' path has the same condition.

invintern_2-1640110914899.png

 

Further, in my 'delete' path could you please let me know if this is what you have in mind?

invintern_3-1640111004472.png

 

 

 

Finally, in one more clue that I have something wrong, I notice that my Flow gave me the 'Apply to each' boxes, whereas yours does not have them. 

 

I believe my next issue lies in those conditions.

 

Thank you for your continued support.

-Ryan

 

 

invintern
Helper II
Helper II

One final question (maybe):

 

invintern_4-1640111219693.png

 

Where does this snip come from? I don't see any boxes asking for 'Outlook ID'. 

 

[updated] Click Show Advanced Options:

2021-12-21_18-49-15.png

Then scroll down the long page of field names:

2021-12-21_18-48-09.png

2021-12-21_18-53-51.png

The Id is taken from Dynamic content as shown below:

 

2021-12-21_18-56-27.png

Ellis

2021-12-21_12-37-24-0123.png

2021-12-21_21-02-37.png

2021-12-21_12-37-24.png

2021-12-21_12-44-59.png

 

2021-12-21_12-46-33.png

2021-12-21_12-48-10.png

2021-12-21_12-49-25.png

2021-12-21_12-37-24-2.png

2021-12-21_12-53-14.png

 

2021-12-21_12-55-22.png

2021-12-21_12-37-24-3.png

 

2021-12-21_12-57-44.png

2021-12-21_20-52-14.png

2021-12-21_20-56-27.png

2021-12-21_20-58-38.png

Hope this helps.


Ellis
____________________________________
If I have answered your question, please mark the post as Solved.
If you like my response, please give it a Thumbs Up.

 

 

 

invintern
Helper II
Helper II

Is this a full-time job, helping me with this Flow? Thank you so much for the help.

 

I don't see explicit instructions on the Composeitem action just after the Flow begins, underneath "When an event is added, updated or deleted (V3)." But judging by your later snips it LOOKS LIKE that compose function should have its "inputs" listed as 'activityid' - though I don't think that is right because your hover shows text "outputs('ComposeItem')?['activityid']" whereas mine says "outputs('ComposeItem)."

 

I will keep working, as the rest of it makes sense...so far!

 

Thanks again for the help.

 

 

As long as you enter this as an expression the flow should work:

2021-12-21_22-54-12.png

Power Automate sometimes changes the display name of the inputs. In the above example, the display name got changed to activityid when I later re-opened the flow again:

2021-12-21_22-51-07.png

 

In both case the expression is still:

outputs('ComposeItem2')?['activityid']

Ellis

 

invintern
Helper II
Helper II

(edit) Interesting. I have input the Expressions where you mentioned. Before I had selected the Dynamic Content output of the Compose action. I changed mine to make sure it's like yours. If you don't mind, I'd like to show you what I've got to see if you think it is good to activate.

 

I also have one final (maybe) question about your first Compose action. I didn't seem to use mine. Please let me know if I misunderstood.

 

invintern_6-1640128334777.png

 

 

invintern_4-1640128123018.pnginvintern_5-1640128131149.png

 

 

invintern_1-1640128034975.png

 

invintern_2-1640128071354.pnginvintern_3-1640128085742.png

 

I believe I have EXACTLY what you have, other than the icons by the expressions we were just talking about. Notice how in my 'update a row' section my expression is left with its Expression icon, whereas yours has the Compose icon.

 

Can I ask for one my favor from you, to check what I've got here and give me a thumbs up?

(1) Use the End time with time zone from the Outlook event - as the End time may be one of the fields that were changed. Same with Start time - which I take from the Outlook event - as the Start time may have changed too. Same again with Subject, Body, Location or any other column to you want to track the changes of.

 

2021-12-21_23-19-11.png

 

(2)  I'm not using an Apply to each loop - but the flow could still work with a loop. In my flow I am using the Compose action (ComposeItem) to select the record that was returned from the List rows action - so I can avoid using a loop.

 

(3) Optional - I usually include a compose action to keep some notes about the flow

2021-12-21_23-31-00.png

 

Or you can keep notes using the new Comments feature in Power Automate:

2021-12-21_23-34-27.png

2021-12-21_23-32-55.png

 Ellis

invintern
Helper II
Helper II

Wonderful,

 

I have made the changes you suggested to End Time (as well as start time, which I hadn't shown you!)

 

I didn't see anything from you saying it doesn't work.........so I think I am going to activate it tonight and see if it works as intended tomorrow morning.

 

I will report back with questions/updates and will be sure to give you that 'Accept as a solution,' just as soon as I know it works!

 

Thank you so much for the help.

-Ryan

invintern
Helper II
Helper II

Hello Ellis,

 

Naturally, Xmas holiday season is one where not many people are scheduling events on the calendar for testing purposes.

 

I had one Flow go off since I turned this one on and it 'ran successfully' but 'ActionBranchingConditionNotSatisfied. The execution of template action 'Compose_2' skipped: the branching condition for this action is not satisfied."

 

Snip:

invintern_0-1640194900330.png

Here is the condition: 'length(outputs('List_rows')?['body/value']) is greater than 0.

invintern_1-1640194992683.png

 

Thanks again.

 

This is the sample Output from my flow:

2021-12-22_17-47-37.png

(1) Check the List Rows action

2021-12-22_17-54-02.png

It is likely that you are updating a calendar event in Outlook - but that event does not exist in the Dataverse Appointments table? The flow was created later but the event was already in Outlook before the flow was created. Please confirm. If that is the case you will need to add some extra actions to deal with this situation.

 

(2) Please check the expression for the condition, you can copy-and-paste the expression below:

 

 

length(outputs('List_rows')?['body/value'])

 

 

 

 Ellis

invintern
Helper II
Helper II

Good point that maybe the Dataverse item does not exist, yet the Outlook may have been updated.

 

List rows looks like it's fine.

invintern_0-1640196416877.png

 

My condition uses 'length,' not 'first.' It is what you have written, though the final snip with 'first(outputs(...", though I can't seem to paste into my Expression box. That 'first(outputs(...' is what is written in my Compose 2, in the Update a row path.

 

Ok, if I have my inputs correct and the latest issue was that an event was updated that hadn't been added to the dataverse....it looks like we've got it right.

 

Thanks for the help, Ellis. I will write back if anything funny comes up.

This is more or less the the current flow:

Outlook Calendar Updating Datavers Appointments table-Basic Event Flow.png

 

You could update the flow for the "updated" condition to add a new appointment if none was found:

 

Outlook Calendar Updating Datavers Appointments table-Event flow with Update Actions.drawio.png

 

2021-12-22_17-47-37.png

 Ellis

 

Helpful resources

Announcements

Power Platform Connections Ep 15 | L. Baybutt | Thursday, 1 June 2023

Episode Fifteen of Power Platform Connections sees David Warner and Hugo Bernier talk to Microsoft MVP Lewis Baybutt aka Low Code Lewis, alongside the latest news and community blogs.   Use the hashtag #PowerPlatformConnects on social media for a chance to have your work featured on the show.        Action requested: Feel free to provide feedback on how we can make our community more inclusive and diverse.  This episode premiers live on our YouTube at 12pm PST on Thursday 1st June 2023.  Video series available at Power Platform Community YouTube channel.    Upcoming events:  European Power Platform conference – Jun. 20-22nd - Dublin Microsoft Power Platform Conference – Oct. 3-5th - Las Vegas  Join our Communities:  Power Apps Community Power Automate Community Power Virtual Agents Community Power Pages Community  If you’d like to hear from a specific community member in an upcoming recording and/or have specific questions for the Power Platform Connections team, please let us know. We will do our best to address all your requests or questions.  Action requested: Feel free to provide feedback on how we can make our community more inclusive and diverse.  This episode premiers live on our YouTube at 12pm PST on Thursday 1st June 2023.  Video series available at Power Platform Community YouTube channel.    Upcoming events:  European Power Platform conference – Jun. 20-22nd - Dublin Microsoft Power Platform Conference – Oct. 3-5th - Las Vegas  Join our Communities:  Power Apps Community Power Automate Community Power Virtual Agents Community Power Pages Community  If you’d like to hear from a specific community member in an upcoming recording and/or have specific questions for the Power Platform Connections team, please let us know. We will do our best to address all your requests or questions. 

May 2023 Community Newsletter and Upcoming Events

Welcome to our May 2023 Community Newsletter, where we'll be highlighting the latest news, releases, upcoming events, and the great work of our members inside the Biz Apps communities. If you're new to this LinkedIn group, be sure to subscribe here in the News & Announcements to stay up to date with the latest news from our ever-growing membership network who "changed the way they thought about code".         LATEST NEWS "Mondays at Microsoft" LIVE on LinkedIn - 8am PST - Monday 15th May  - Grab your Monday morning coffee and come join Principal Program Managers Heather Cook and Karuana Gatimu for the premiere episode of "Mondays at Microsoft"! This show will kick off the launch of the new Microsoft Community LinkedIn channel and cover a whole host of hot topics from across the #PowerPlatform, #ModernWork, #Dynamics365, #AI, and everything in-between. Just click the image below to register and come join the team LIVE on Monday 15th May 2023 at 8am PST. Hope to see you there!     Executive Keynote | Microsoft Customer Success Day CVP for Business Applications & Platform, Charles Lamanna, shares the latest #BusinessApplications product enhancements and updates to help customers achieve their business outcomes.         S01E13 Power Platform Connections - 12pm PST - Thursday 11th May Episode Thirteen of Power Platform Connections sees Hugo Bernier take a deep dive into the mind of co-host David Warner II, alongside the reviewing the great work of Dennis Goedegebuure, Keith Atherton, Michael Megel, Cat Schneider, and more. Click below to subscribe and get notified, with David and Hugo LIVE in the YouTube chat from 12pm PST. And use the hashtag #PowerPlatformConnects on social media for a chance to have your work featured on the show.         UPCOMING EVENTS   European Power Platform Conference - early bird ticket sale ends! The European Power Platform Conference early bird ticket sale ends on Friday 12th May 2023! #EPPC23 brings together the Microsoft Power Platform Communities for three days of unrivaled days in-person learning, connections and inspiration, featuring three inspirational keynotes, six expert full-day tutorials, and over eighty-five specialist sessions, with guest speakers including April Dunnam, Dona Sarkar, Ilya Fainberg, Janet Robb, Daniel Laskewitz, Rui Santos, Jens Christian Schrøder, Marco Rocca, and many more. Deep dive into the latest product advancements as you hear from some of the brightest minds in the #PowerApps space. Click here to book your ticket today and save!      DynamicMinds Conference - Slovenia - 22-24th May 2023 It's not long now until the DynamicsMinds Conference, which takes place in Slovenia on 22nd - 24th May, 2023 - where brilliant minds meet, mingle & share! This great Power Platform and Dynamics 365 Conference features a whole host of amazing speakers, including the likes of Georg Glantschnig, Dona Sarkar, Tommy Skaue, Monique Hayward, Aleksandar Totovic, Rachel Profitt, Aurélien CLERE, Ana Inés Urrutia de Souza, Luca Pellegrini, Bostjan Golob, Shannon Mullins, Elena Baeva, Ivan Ficko, Guro Faller, Vivian Voss, Andrew Bibby, Tricia Sinclair, Roger Gilchrist, Sara Lagerquist, Steve Mordue, and many more. Click here: DynamicsMinds Conference for more info on what is sure an amazing community conference covering all aspects of Power Platform and beyond.    Days of Knowledge Conference in Denmark - 1-2nd June 2023 Check out 'Days of Knowledge', a Directions 4 Partners conference on 1st-2nd June in Odense, Denmark, which focuses on educating employees, sharing knowledge and upgrading Business Central professionals. This fantastic two-day conference offers a combination of training sessions and workshops - all with Business Central and related products as the main topic. There's a great list of industry experts sharing their knowledge, including Iona V., Bert Verbeek, Liza Juhlin, Douglas Romão, Carolina Edvinsson, Kim Dalsgaard Christensen, Inga Sartauskaite, Peik Bech-Andersen, Shannon Mullins, James Crowter, Mona Borksted Nielsen, Renato Fajdiga, Vivian Voss, Sven Noomen, Paulien Buskens, Andri Már Helgason, Kayleen Hannigan, Freddy Kristiansen, Signe Agerbo, Luc van Vugt, and many more. If you want to meet industry experts, gain an advantage in the SMB-market, and acquire new knowledge about Microsoft Dynamics Business Central, click here Days of Knowledge Conference in Denmark to buy your ticket today!   COMMUNITY HIGHLIGHTS Check out our top Super and Community Users reaching new levels! These hardworking members are posting, answering questions, kudos, and providing top solutions in their communities.   Power Apps:  Super Users: @WarrenBelz, @LaurensM  @BCBuizer  Community Users:  @Amik@ @mmollet, @Cr1t    Power Automate:  Super Users: @Expiscornovus , @grantjenkins, @abm  Community Users: @Nived_Nambiar, @ManishSolanki    Power Virtual Agents:  Super Users: @Pstork1, @Expiscornovus  Community Users: @JoseA, @fernandosilva, @angerfire1213    Power Pages: Super Users: @ragavanrajan  Community Users: @Fubar, @Madhankumar_L,@gospa  LATEST COMMUNITY BLOG ARTICLES  Power Apps Community Blog  Power Automate Community Blog  Power Virtual Agents Community Blog  Power Pages Community Blog  Check out 'Using the Community' for more helpful tips and information:  Power Apps , Power Automate, Power Virtual Agents, Power Pages 

Announcing | Super Users - 2023 Season 1

Super Users – 2023 Season 1    We are excited to kick off the Power Users Super User Program for 2023 - Season 1.  The Power Platform Super Users have done an amazing job in keeping the Power Platform communities helpful, accurate and responsive. We would like to send these amazing folks a big THANK YOU for their efforts.      Super User Season 1 | Contributions July 1, 2022 – December 31, 2022  Super User Season 2 | Contributions January 1, 2023 – June 30, 2023    Curious what a Super User is? Super Users are especially active community members who are eager to help others with their community questions. There are 2 Super User seasons in a year, and we monitor the community for new potential Super Users at the end of each season. Super Users are recognized in the community with both a rank name and icon next to their username, and a seasonal badge on their profile.  Power Apps  Power Automate  Power Virtual Agents  Power Pages  Pstork1*  Pstork1*  Pstork1*  OliverRodrigues  BCBuizer  Expiscornovus*  Expiscornovus*  ragavanrajan  AhmedSalih  grantjenkins  renatoromao    Mira_Ghaly*  Mira_Ghaly*      Sundeep_Malik*  Sundeep_Malik*      SudeepGhatakNZ*  SudeepGhatakNZ*      StretchFredrik*  StretchFredrik*      365-Assist*  365-Assist*      cha_cha  ekarim2020      timl  Hardesh15      iAm_ManCat  annajhaveri      SebS  Rhiassuring      LaurensM  abm      TheRobRush  Ankesh_49      WiZey  lbendlin      Nogueira1306  Kaif_Siddique      victorcp  RobElliott      dpoggemann  srduval      SBax  CFernandes      Roverandom  schwibach      Akser  CraigStewart      PowerRanger  MichaelAnnis      subsguts  David_MA      EricRegnier  edgonzales      zmansuri  GeorgiosG      ChrisPiasecki  ryule      AmDev  fchopo      phipps0218  tom_riha      theapurva  takolota     Akash17  momlo     BCLS776  Shuvam-rpa     rampprakash  ScottShearer     Rusk  ChristianAbata     cchannon  Koen5     a33ik  Heartholme     AaronKnox  okeks      Matren  David_MA     Alex_10        Jeff_Thorpe        poweractivate        Ramole        DianaBirkelbach        DavidZoon        AJ_Z        PriyankaGeethik        BrianS        StalinPonnusamy        HamidBee        CNT        Anonymous_Hippo        Anchov        KeithAtherton        alaabitar        Tolu_Victor        KRider        sperry1625        IPC_ahaas      zuurg    rubin_boer   cwebb365   Dorrinda   G1124   Gabibalaban   Manan-Malhotra   jcfDaniel   WarrenBelz   Waegemma   drrickryp   GuidoPreite   metsshan    If an * is at the end of a user's name this means they are a Multi Super User, in more than one community. Please note this is not the final list, as we are pending a few acceptances.  Once they are received the list will be updated. 

Check out the new Power Platform Communities Front Door Experience!

We are excited to share the ‘Power Platform Communities Front Door’ experience with you!   Front Door brings together content from all the Power Platform communities into a single place for our community members, customers and low-code, no-code enthusiasts to learn, share and engage with peers, advocates, community program managers and our product team members. There are a host of features and new capabilities now available on Power Platform Communities Front Door to make content more discoverable for all power product community users which includes ForumsUser GroupsEventsCommunity highlightsCommunity by numbersLinks to all communities Users can see top discussions from across all the Power Platform communities and easily navigate to the latest or trending posts for further interaction. Additionally, they can filter to individual products as well.   Users can filter and browse the user group events from all power platform products with feature parity to existing community user group experience and added filtering capabilities.     Users can now explore user groups on the Power Platform Front Door landing page with capability to view all products in Power Platform.      Explore Power Platform Communities Front Door today. Visit Power Platform Community Front door to easily navigate to the different product communities, view a roll up of user groups, events and forums.

Microsoft Power Platform Conference | Registration Open | Oct. 3-5 2023

We are so excited to see you for the Microsoft Power Platform Conference in Las Vegas October 3-5 2023! But first, let's take a look back at some fun moments and the best community in tech from MPPC 2022 in Orlando, Florida.   Featuring guest speakers such as Charles Lamanna, Heather Cook, Julie Strauss, Nirav Shah, Ryan Cunningham, Sangya Singh, Stephen Siciliano, Hugo Bernier and many more.   Register today: https://www.powerplatformconf.com/   

Users online (3,223)