A Ionic mobile app to display information from a DynamoDB table containing blog posts from the AWS What's New blog.
Relies on the RSS and mobile push lambda functions.
Contains Security vulnerabilities For reference only.
This Ionic starter comes with a pre-configured AWS Mobile Hub project set up to use Amazon DynamoDB, S3, Pinpoint, and Cognito.
This starter project requires Ionic CLI 3.0, to install, run
npm install -g ionic@latest
Make sure to add sudo
on Mac and Linux. If you encounter issues installing the Ionic 3 CLI, uninstall the old one using npm uninstall -g ionic
first.
npm install -g awsmobile-cli
To create a new Ionic project using this AWS Mobile Hub starter, run
ionic start myApp aws
Which will create a new app in ./myApp
.
Once the app is created, cd
into it:
cd myApp
Init AWSMobile project
awsmobile init
Please tell us about your project:
? Where is your project's source directory: src
? Where is your project's distribution directory that stores build artifacts: www
? What is your project's build command: npm run-script build
? What is your project's start command for local test run: ionic serve
? What awsmobile project name would you like to use: ...
Successfully created AWS Mobile Hub project: ...
The starter project gives instructions on how to do this from the command line, but some have reported bugs with awsmobile, so here's how to do it in the browser.
Enable.
Create a custom table named tasks
. Make it Private.
Accept userId
as Partition key.
Add an attribute taskId
with type string and make it a Sort key
Add an attribute category
with type string.
Add an attribute description
with type string.
Add an attribute created
with type number.
Create an index DateSorted
with userId as Partition key and taskId
as Sort key.
Turn this on.
Set your password requirements.
Turn this on.
Turn this on.
From the AWS Console, go to S3.
Select the bucket named <project name>-userfiles-mobilehub-<AWS resource number>
Go to the Permissions tab. Click on CORS Configuration. Paste the following into the editor and save.
<?xml version="1.0" encoding="UTF-8"?>
<CORSConfiguration xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
<CORSRule>
<AllowedOrigin>*</AllowedOrigin>
<AllowedMethod>HEAD</AllowedMethod>
<AllowedMethod>PUT</AllowedMethod>
<AllowedMethod>GET</AllowedMethod>
<MaxAgeSeconds>3000</MaxAgeSeconds>
<ExposeHeader>x-amz-server-side-encryption</ExposeHeader>
<ExposeHeader>x-amz-request-id</ExposeHeader>
<ExposeHeader>x-amz-id-2</ExposeHeader>
<AllowedHeader>*</AllowedHeader>
</CORSRule>
</CORSConfiguration>
Go back to the command line for your project.
awsmobile pull
Answer yes, when asked "? sync corresponding contents in backend/ with #current-backend-info/"
npm install
The following commands are needed due to breaking changes in aws-amplify 0.4.6. They may not be needed in the future.
npm install @types/zen-observable
npm install @types/paho-mqtt
Now the app is configured and wired up to the AWS Mobile Hub and AWS services. To run the app in the browser, run
ionic serve
To run the app on device, first add a platform, and then run it:
ionic cordova platform add ios
ionic cordova run ios
Or open the platform-specific project in the relevant IDE:
open platforms/ios/MyApp.xcodeproj
Since your Ionic app is just a web app, it can be hosted as a static website in an Amazon S3 bucket.
npm run build
awsmobile publish