Over the years I’ve considered the number of emails received to be a gauge of how busy I am. For two years I’ve been using Microsoft Flow to track the number of emails received and basic details about the email. I realized recently that I have many flows triggered by an email being received:
- Track the number of emails received in Excel
- Save an attachment received weekly into a specific OneDrive folder
- Push notification when my boss emails me
- Push notification when the CIO of my customers email me
- Push notification when my old boss emails me
data:image/s3,"s3://crabby-images/892d3/892d39e2d6502f6f4a071a2131d001712182886b" alt=""
Tracking Emails in Azure Logic Apps instead of Flow
This quickly got out of hand, so I decided to use a Logic App. Microsoft Flow is built on Logic Apps, with Logic Apps having more enterprise connectors but also lacking the ability to send a push notification. 2,000 executions per month are free on Microsoft Flow with an Office 365 subscription (as long as the administrator hasn’t taken that right away). However I want to ‘upgrade’ my email tracking/processing solution, so I created a single, larger Logic App that would handle email receipts all at once. I skipped the ones which provide me push notifications.
data:image/s3,"s3://crabby-images/f4ed8/f4ed85bbf14386c8612833d7d09d0022a186881f" alt=""
I first started by recreating the functionality which would add a row in Excel. The trigger is whenever I receive a work email, then add a row with details to Excel. I was even able to keep the original Excel file with all the historical records from the Flow I had been using.
data:image/s3,"s3://crabby-images/fdaaa/fdaaae92b5e3ff283fa82cc369797850a271dde8" alt=""
Saving a Report Attachment Automatically
Weekly I receive an email with an attached Excel file containing information about the hours the consultants in my practice have worked. Every week, the email comes from the same person with a particular subject. So I used a Condition to filter out emails that do not meet those criteria.
data:image/s3,"s3://crabby-images/bce5c/bce5cf6c1944be9d46c9a29287af266861022b88" alt=""
I want to save the Excel attachment, so I started a ForEach loop, but I realized that the MCA Connect logo is treated as an attachment in the email, so let’s filter those out too-
data:image/s3,"s3://crabby-images/108d4/108d4959008a84d3e42621442f9f8dbcd7f2c724" alt=""
Now that we have filtered down to the exact attachment to save, let’s go crazy by saving it in two spots and posting a message about it!
data:image/s3,"s3://crabby-images/b02c0/b02c0cbef5082ec0b5a6fedbfa73e3e990c35ff1" alt=""
First we save the file to my OneDrive. The name I’m using prepends the name with the date I received the file using the following formula: concat(string(utcNow(‘yyyy-MM-dd’)),’ ‘,items(‘For_each_report_attachment’)?[‘Name’])
data:image/s3,"s3://crabby-images/a0833/a083394e408d3180781ead0d03b06cd40aef3d1d" alt=""
Then we save that same file into SharePoint Online. This particular site was created by Microsoft Teams and it is shown as a tab within the tool.
data:image/s3,"s3://crabby-images/a143f/a143f3ef70ea13e077d7e4f36914125a69c325d7" alt=""
data:image/s3,"s3://crabby-images/9b268/9b268dcbc663569d20cee83fd181bcde291e33f0" alt=""
Let’s post a message to the channel letting people know the report is available.
data:image/s3,"s3://crabby-images/7e1ff/7e1ffba28fc85b56333dacc0308c53859d2128e7" alt=""
data:image/s3,"s3://crabby-images/2ea3c/2ea3c84abeb1da8fdda9322a5d394d05f0b3d07f" alt=""
I know what you are thinking…why wouldn’t the sender of the report set this up so that when she saves the report into a folder called “Publish” that it would save the report to the SharePoint folder and post a message…well that’s a great idea!!
Conclusion
I wanted to document this to show that Logic Apps can be used easily. I was able to use it here as an individual but it is geared towards the enterprise with extra connections and more depth in logging. I consider it a solid and scalable integration tool- and you should too!
data:image/s3,"s3://crabby-images/f5ecb/f5ecb349e70b69097466713f986ea165c2b61ca1" alt=""
Leave A Comment