Deep Linking Cross-Platform Mobile Apps Hosted in AWS
Deep linking is a great way to improve user experience and flow by routing users directly to the in-app content they want to see. When users tap a deep link, they are sent directly into your app, without routing through the device’s web browser first. If the app isn’t installed, the user can be directed to a website, or the device’s app store. Deep links are a great feature for cross-platform apps, and provide a seamless mobile experience with increased ease for users to successfully access the intended content.
Although the benefits of deep links are significant, set up can be a bit daunting. Between AWS set up, iOS and Android configuration, and app set up and routing, there are a lot of pieces to account for. Don’t worry though, this step by step guide will help you to successfully set up deep linking in your mobile app.
iOS Configuration
Log into the Apple Developer Site. Navigate to the ‘Certificates, Identifiers, & Profiles' section. Select your app’s identifier. Toggle to enable “Associated Domains”, and save. Be sure to take note of your App ID Prefix and Bundle ID on this page as well.
Create the site association file, titled apple-app-site-association. It is important the file has this specific title with no ending or extension. Populate your appId with your App ID and Bundle ID.
3. Create an index.html file.
4. Open Xcode and navigate to 'Signing & Capabilities’. Click ‘+ Capability’, and choose Associated Domains. In the Domains entry, add your domain with the format applinks:yourdomain.com.
In AWS
Create the domain. Sign into AWS and get a domain via Route 53. We’ll say this is example.com.
Create your S3 bucket. S3 is simple storage in AWS. Think of it like a folder on your Desktop that can be easily accessed in AWS for your project. We’ll use this for our two newly created files. Navigate to the S3 page, select ‘Create Bucket’, and follow the steps. The name of your bucket should match your Route 53, example.com. Be sure to uncheck ‘Block all public access’ to make this publicly available.
Upload both the apple-app-site-association and index.html files to your newly created S3 bucket.
Within your bucket, select the ‘Properties’ tab, then click ‘Static Website Hosting’, and ’Edit’. Choose ‘Enable’, and ‘Host a static website’. For the index.html option, input ‘index.html’ and save. Once saved, this will give you a domain that can be used in the Route 53.
Create a Custom SSL Certificate via Certificate Manager. Select ‘Request certificate’ and follow the steps to create. For the domain name, use your same example.com. Once created, click ‘Create records in Route 53’. This can take up to 15 minutes to certify.
Set up Cloudfront to redirect to your S3 bucket. Using Cloudfront allows us to redirect all traffic from our domain to https and our S3 bucket. Once in the Cloudfront section, select ‘Create Distribution’. For the 'Origin Domain Name’ input the endpoint found in the static web hosting section of the S3 bucket, which will look something like http://example.com.s3-website-us-east-1.amazonaws.com. Under ‘Viewer Protocol Policy’ select Redirect HTTP to HTTPS. Under the Settings section, find ‘Alternate domain name (CNAME)’. Here, use the domain name used in the naming of the S3 bucket, example.com. Select the Custom SSL Certificate created in the previous step, and Save.
Configure Route 53 to redirect domain to Cloudfront. Select your hosted domain in Route 53, and select ‘Create Record’. For the ‘Record Name’ use the same domain used for your S3 bucket, example.com. Select option Record Type ‘A’. Enable Alias, and select the option of ‘Alias to CloudFront distribution’, US-East-1, and finally enter your Cloudfront distribution domain name you just created.
Android Configuration
Open your project in Android Studio. Under ‘Tools’, select ‘App Links Assistant’.
Click ‘Open URL Mapping Editor’, then the ‘+’ to add your Url Mapping. Provide the url and path. Select ‘OK’.
Click ‘Select Activity’. Select your Activity and click ‘Insert Code’.
Create Digital Asset Links JSON file. First, get the fingerprint from your keystore file. Then generate the content for your assetlinks file by using this site: https://developers.google.com/digital-asset-links/tools/generator. Create a file titled assetlinks.json. Copy the content you just generated into your newly created assetlinks.json.
In AWS S3 bucket, add a folder titled .well-known. Upload your assetlinks.json file into this folder.
App Routing
Lastly, update the routing in your Angular app. In app.component.ts, add a listener that will redirect when a deep link is found.
And there you have it! A step by step guide to create a deep link for your cross-platform mobile app hosted in AWS.
Women Pioneers in Software Engineering
In the ever-evolving field of software engineering, it’s easy to loose sight of the origins. Many of the fundamental principles guiding our modern technological landscape were crafted by the hands and minds of women. These women defied societal norms and expectations, and helped shape the trajectory of software engineering. Their influence continues to be felt in the steadfast fundamentals that are still used today. Sadly, their stories are not widely known. So let’s dive in on just a few of their remarkable legacies.
The first recognized computer programmer was Ada Lovelace, daughter of the famous poet Lord Byron, born in 1815. She became a mathematician and worked closely with Charles Babbage. She created a program for Babbage’s prototype of a digital computer. She was later asked to translate an article on Babbage’s analytical engine written by Italian engineer Luigi Federico Menabrea. Not only did she translate the article from French into English, but also contributed her own thoughts and ideas. In her notes, she theorized a method to repeat a series of instructions, which today, is know as looping, and continues to be a foundation used regularly by developers.
Hedy Lamar was an Austrian-American actress and inventor. While revered for her beauty in Hollywood in the 1930s, she was also a brilliant inventor. She created an upgraded stoplight and a dissolvable tablet to make soda. Her most significant invention, though, was engineering in the years leading up to World War II. She met George Antheil in 1940 and together, they created a communication system with the intention of guiding torpedoes to their targets in war. The system used “frequency hopping” amongst radio waves with both transmitter and receiver hopping to new frequencies together. Their work pioneered the technology that would come to form the basis for Wi-Fi, GPS, and Bluetooth communication systems. She has been recognized with numerous awards for her contributions and continues to be known as “the mother of Wi-Fi”.
During World War II, hundreds of women became employed as “computers”. Their jobs included computing and solving long lists of equations, which were often used on the battlefields, allowing soldiers in the field to aim artillery and other weapons taking into account variable conditions. During this time, the ENIAC was completed, an electronic device to compute and calculate automatically, and is widely regarded as the first electronic digital computer. Six women were chosen from the human computers to be trained as programmers to program this new machine — Kay McNulty, Frances Bilas, Jean Jennings, Elizabeth Snyder, Ruth Lichterman, and Maryln Wescoff. These six women created the very first computer program. Jean Bartik, one of the lead programmers, also made contributions to early BINAC and UNIVAC 1 computers. She received a Pioneer Award from the IEEE in 2009.
Margaret Hamilton coined the term Software Engineering in the early 1960s while leading the team developing the guidance and navigation systems for the Apollo missions, while also serving as Director of the Software Engineering Division at MIT’s Instrumentation Laboratory. She created error detection and recovery programs, including loop concepts that allowed the on-board flight software to communicate asynchronously with the astronaut within. This software showed priority displays to the astronauts to warn them in cases of emergency. She has received numerous honors, including NASA’s Exceptional Space Act Award in 2003 and the Presidential Medal of Freedom in 2016.
These are just a few of the exceptional women and their contributions to software engineering. Their groundbreaking achievements remind us of the importance of acknowledging and honoring the diverse perspectives and talents that continue to shape our technological world.
Sources:
https://www.britannica.com/biography/Ada-Lovelace
https://www.biography.com/scholars-educators/ada-lovelace
https://www.womenshistory.org/education-resources/biographies/hedy-lamarr
https://ethw.org/Women_Computers_in_World_War_II
https://computerhistory.org/profile/jean-jennings-bartik/
https://science.nasa.gov/people/margaret-hamilton/
https://www.britannica.com/biography/Margaret-Hamilton-American-computer-scientist
https://computerhistory.org/profile/margaret-hamilton/
html2canvas & the Secret Setting You Need To Know
I recently created a feedback form for a client. The feedback form was on a side drawer that could be accessed on any page. The client wanted the user to have the capability to take and send a screenshot to help with feedback and for debugging purposes. ( So smart! ) I used html2canvas for this purpose, which was my first encounter with this product. I found it quite easy to use and set up was quick. The tricky part was figuring out how to hide the drawer from the screen shot and only snap the screen behind drawer. I found the documentation for this concern on the html2canvas site a little lacking. It took a bit of digging and inspecting their site and demos to figure out the special setting to hide what you want. Let’s walk through it.
To set up, install the npm package “html2canvas”.
npm install html2canvas
Add a button to your page that calls:
html2canvas(element, options);
to render the screenshot element.
Using this set up with ‘document.body’ as the element, will render a screenshot of whatever is on the entire screen at that time.
To ignore a part of the screen during the screen shot, like the feedback drawer, add a
<div></div>
around the section you want to ignore. Then add “data-html2canvas-ignore=“true” within your opening div.
<div data-html2canvas-ignore=”true”></div>
This special addition will remove whatever is within that <div> from your screenshot. Overall, I enjoyed using html2canvas and would use it again in future projects.
New Year’s Intentions
New Year’s Intentions
I have never liked the term New Year’s Resolution. Resolution sounds harsh and unforgiving. So absolute. Either you succeed or you fail. And statistically, most resolutions fail quite quickly, with up to 80-90% of resolutions being abandoned within the first few months. So, why set yourself up for failure?
I much prefer the term New Year’s Intention. It sounds much gentler. More of a mindset or guidance, fit for the fluidity of life. Something to keep you on the rails when life inevitably tries to sway you off. Psychology also supports this thought process as well. Having the flexibility to adjust and play with your process allows you to actually enjoy your path instead of checking a box on a resolution list. And when you enjoy something, you’re more likely to continue it. So, New Year’s Intentions it is.
Be Present
I struggle with constant multitasking. As a mom of two small children, someone always needs something and something always needs done. My mental to-do list is a mile long, and I have a difficult time putting that to-do list down and staying present in the moment. I can easily miss life’s little pleasures to the constant chatter in my mind. Research suggests that meditation and mindfulness can help quiet the mind and keep you in the moment. I have dabbled in meditation off and on for the past several years. Admittedly, this past year has been much more off than on. But, when I do practice mediation regularly, I notice a significant difference in my mental state. I am more calm, more focused, and am able to be more mindful in my day to day activities. Even just ten minutes of meditation a day can make a significant impact on my mental state.
Be Grateful
It is incredibly easy to fall into the trap of always wanting more. Of thinking more money, more stuff, more things will make us happier. Research though, suggests that is not the case. One thing research does support, is gratitude. The simple act of taking time to stop and be grateful for the things in life that you do have can make you happier. Studies show gratitude can reduce depression and anxiety, support heart health, improve sleep, and relieve stress. Simple ways to practice gratitude include sharing something you are grateful for at the dinner table each evening, redirecting negative thoughts to change your focus to a positive aspect, or writing down a daily gratitude list.
Be Productive
A productivity killer for me, is context switching. Whether it is switching between projects, catching up with a coworker, checking an email or Teams message, or scrolling through social media, context switching takes a toll. Research shows a single context switch can take 23 minutes to recover from. Having just three context switches a day can cost you an hour of your time. Trying to combat this means being more intentional with work time. Adjust meeting times, if you can, to avoid a Swiss cheese schedule, and block out several hours to designate as deep work time. Set your devices and messaging systems to ‘Do Not Disturb’ and get in the zone. It’s also helpful to know your high productivity hours and when you need recovery in your day. Alter your schedule to allow for productivity during your high productivity hours, and shift those check in times to your recovery. By being mindful of these pitfalls, you can set yourself up for success to limit context switching and increase productivity.
Be Active
Physical health is just as important as your mental health. Setting an intention of being active promotes movement in all shapes and forms to fit that mantra. Parking up an extra level and taking the stairs down and up. Going on a walk with your family. Taking the kiddos to the park. Enjoying a yoga class with a friend. Making small consistent decisions to prioritize movement and health. Research shows consistent activity benefits brain health, heart health, muscle and joint health, and helps to manage weight.
My four New Year’s Intentions for 2024 — Be Present. Be Grateful. Be Productive. Be Active. As I type this out, four seems a little lack-luster, but also seems manageable. And seems more likely I’ll stick with it this year. At the end of the day, it doesn’t matter if you have one intention or twenty. What matters is you work on improving yourself on a regular and consistent basis. Happy 2024!
From Healthcare to Software
Healthcare to Software
I am a software developer in the first year of my career.
My background, though, is not in software or technology. My background is in healthcare. My profession, for nearly the past decade, was as a Physician Assistant with experience in Vascular Surgery, General Surgery, and Gastroenterology. I was initially drawn to health care with interest in science and physiology and how all the pieces of the body work together. As well as a drive to serve and help my community.
While I greatly enjoyed many aspects of health care and a career as a health care provider, after a few years, I struggled to find a sustainable work/life balance. I was working long hours, evenings, nights, weekends, holidays, and was living a lot of my life on call. My life had become work-centric.
After the birth of my first daughter in 2019, my priorities and outlook began to shift. I desired a career that was challenging and fulfilling, and that utilized my problem-solving skill set and my love of math and science. And I wanted the flexibility to be there for my family and be involved in my children’s lives.
In short, I wanted my cake and to eat it too.
I began to think about a potential career change my acquired skills would translate to. For the first time in my life, I began considering what my life would look like outside of healthcare.
I was nervous, overwhelmed, and — to be honest — a little scared. I was also excited, open, and liberated in a way I had never felt before. The idea of pursuing a career change at this stage of life meant I could choose something I was truly passionate about. A career that would be fulfilling and fit my needs.
I began researching various career paths and the needs of our local community. In my search, I came across a common phrase: the Silicon Prairie – this exploding tech presence in our community and a great need for skilled developers.
As I dug into this a little deeper, I found myself captivated by software development and the process of creating and maintaining workable, functional, and enjoyable user experiences in the technology of our everyday lives. I started a web development course online and was instantly hooked.
I came across the Pathways Program at Don’t Panic Labs and knew this would be a perfect start to my career transition. I applied, was accepted, and was a member of the spring 2023 cohort. I graduated in July and have been working as a software developer for Don’t Panic Labs since.
The Pathways Program was challenging, quick-moving, and focused on the fundamentals of software development and engineering. I was able to build a solid base of knowledge to navigate front and backend development in any stack. I developed the tools to think like an engineer to successfully solve problems that developers commonly work through.
Since completing the program, I have collaborated on several projects in numerous languages. I have worked on frontend development, backend development, web application development, and mobile application development. I have been thoroughly challenged, stretched to think in different ways, and have solved countless problems.
I am confident I have made the right decision regarding my career change. I am following my passions and pursuing a career that will empower me, challenge me, and continue to push me to learn and grow, as technology is ever changing. I am allowing myself to find a better balance for myself and my family.
For anyone considering a career change or entering the field of software development, I abundantly encourage you to do so! I encourage you to know your strengths and do your research about the field you are entering. Identify your knowledge gaps and put in the work to close those gaps, knowing there will always be work to be done.
Most importantly, have the confidence in yourself that you can accomplish your goals and have the career you deserve. Fortune really does favor the bold.