Course Handout

Download as pdf or txt
Download as pdf or txt
You are on page 1of 11

BIRLA INSTITUTE OF TECHNOLOGY & SCIENCE, PILANI

WORK INTEGRATED LEARNING PROGRAMMES


Digital
Part A: Content Design

Course Title CROSS PLATFORM APPLICATION


DEVELOPMENT
Course No(s) SE* ZG585 /SS ZG585
Credit Units 4
Credit Model
Content Authors PRAVIN PAWAR
Version 1.0

Course Description

Cross-platform applications development involves creation of software applications that are


compatible with multiple platforms or software environments. This course aims to equip
students with the expertise to design and develop web and mobile based applications that can
operate in varied environments and platforms. Additionally, it also aims to develop the
understanding of the role and importance of API management in such applications. The
course involves hands-on exposure to full stack development of cross-platform applications
using some of the existing development frameworks.

Course Objectives

The course aims at:

CO1 Introducing the modern application landscape ranging from web, mobile apps to cloud
native, Serverless apps

CO2 Developing understanding about the typical structure, design and implementation
considerations of an end-to-end application

CO3 Exploring the frameworks, tools choices available for various types of cross platform
applications such as native, hybrid , web and multiplatform apps

CO4 Developing multiplatform application with leading edge application framework

CO5 Identifying the need, architectural styles, design considerations and management
essentials for the Application Programming interfaces (APIs)

Text Book(s)

T1 Designing Web APIs – Building APIs that developers love, Jin, Sahni, Shevat ,
O’REILY
T2 Continuous API Management – Making the right decisions in evolving landscape,

Page | 1
Medjaoui, Wilde, Mitra, Amundsen, O’REILY

Reference Book(s) & other resources

R1 Building Microservices – designing fine grained systems , O’REILY


R2 API Architecture, Matthias Biehl
R3 Various product, tools, frameworks documentation

Learning Outcomes:

Students will :

LO1 Get an overview of modern application paradigms, respective architectures and


development framework options

LO2 Appreciate the necessity and usage of modern edge cloud based application platforms
required for microservices and Serverless apps

LO3 Obtain hands-on experience in multiplatform application design and development using
the cutting edge framework involving user interface, interaction with server side etc.

LO4 Recognize the role, usage of APIs in applications and experience the design and
development of APIs using the commonly used ecosystem tools

LO5 Realize the need for API management, challenges involved therein and considerations for
the same

Part B: Learning Plan

Academic Term FIRST SEMESTER 2021-2022


Course Title CROSS PLATFORM APPLICATION DEVELOPMENT
Course No SE ZG585 /SS ZG585
Lead Instructor PRAVIN PAWAR

Glossary of Terms

Module M Module is a standalone quantum of designed content. A


typical course is delivered using a string of modules. M2
means module 2.

Contact Hour CH Contact Hour (CH) stands for a hour long live session with
students conducted either in a physical classroom or enabled
through technology. In this model of instruction, instructor led
sessions will be for 32 CH.

Page | 2
Recorded RL RL stands for Recorded Lecture or Recorded Lesson. It is
Lecture presented to the student through an online portal. A given RL
unfolds as a sequences of video segments interleaved with
exercises.

Lab Exercises LE Lab exercises associated with various modules

Self-Study SS Specific content assigned for self study

Homework HW Specific problems/design/lab exercises assigned as homework

Modular Structure
Module Summary
No. Content of the Module
M1 Modern Application Landscape
• Web apps
• Mobile applications
• Cross Platform applications
• Cloud native applications
• Serverless Apps
• API Products
M2 App Structure
• Typical structure of end-to-end application
o Frontend and Backend components, Databases
o Interaction between the components
• Modern Architectural Styles
o Modern app requirements
o Architectural styles overview
M3 Modern App Architectures
• Microservices
o Motivation, Architecture, Constraints
o Migrating legacy applications
• Cloud Native Architecture [Optional]#
o Distributed Systems and Fallacies, 12 factor app
o Cloud based architecture
o Motivation, Principles, Architecture, Components, Constraints
• Serverless Architecture
o Deployment approaches
o Cloud services for development, testing and deployments of applications
(P/B/FaSS)
• Low Code Architecture [Optional] #
o Motivation, use cases, choices
M4 Serverless Apps
• BaaS/mBaaS
o Motivation, Choices (Firebase / Parse / Back4App )
• FaaS [Optional] #
o Motivation, Options (AWS Lambda / Google Cloud Functions / Azure Functions
)

Page | 3
M5 Cross Platform Mobile Applications Development
• Native Applications
o Platforms – Android, iOS etc.
o Framework choices, benefits, limitations
• Cross Platform – Native Applications
o Motivation, working
o Framework Choices (ReactNative, Xamarin, Flutter etc.)
• Cross Platform - Web Apps
o Purpose, working
o Framework Choices (Ionic, Cordova/PhoneGap, Capacitor)
M6 API Design
• Application Programming Interfaces
o Motivations, requirements, constraints
o API Paradigms
o API Platform Architecture
• API Design Practices [Optional] #
o Design of API
o Best practices
o Developer resources
• API Specification / Description
o Usage
o Languages
M7 API Management
• API as a Product
o Challenge of API Management
o API as a Product lifecycle
o Continuous API improvement
• API Landscape
o API teams
o API Management at scale
o Managing API lifecycle in an Evolving Landscape

# Refer the courseware page for the optional topics / videos

Detailed Lecture Plan

M1: Modern Application Landscape

Type Description/Plan/Reference
RL_1.1.* • Web apps
RL_1.2.* • Mobile applications

RL_1.3.* • Cross Platform applications

RL_1.4.* • Cloud native applications

RL_1.5.* • Serverless Apps

RL_1.6.* • API Products

Page | 4
CS 1.1 • Single Page Aplications, MVC • Classroom
• Mobile Apps - Landscape discussion
• Cross Platform Apps - Comparison with
Native Apps
CS 1.2 • Cross Platform Apps - Selection of app type • Classroom
• Cloud native Landscape discussion
• Serverless Computing
• API Products
SS 1.1 • Identify the factors that needs to be taken into consideration while
developing mobile apps
• Note down the common APIs those are used in applications that we
daily use
• Explore more on the
Microservices
Serverless applications types
Types of APIs
LE 1 • Typical Web Application development with • [Optional]
nodejs

M2: App Structure

Type Description/Plan/Reference
RL_2.1.* • Frontend components
RL_2.2.* • Backend components
RL_2.3.* • Databases [Optional]

RL_2.4.* • Modern Architectural Styles

CS 2.1 • Typical structure of end-to-end application • Classroom


o Frontend and Backend components, discussion
Databases [Optional]
o Interaction between the components
CS 2.2 • Modern Architectural Styles • Classroom
o Modern app requirements discussion
o Architectural styles overview
SS 2.1 • Explore more on the differences between the Relational and Non-
relational databases
• Identify the options available for the caching systems
• Survey the modern age applications and note down the
commonalities among them

Page | 5
M3: Modern App Architectures

Type Description/Plan/Reference
3.1 Modern App Architectures - I
RL_3.1.* • Microservices Architecture
RL_3.2.* • Cloud Native Architecture [Optional]

CS 3.1 • Microservices • Classroom


o Motivation, Architecture, Constraints discussion
o Migrating legacy applications

CS 3.2 • Cloud Native Architecture [Optional] • Classroom


o Distributed Systems and Fallacies, 12 discussion
factor app
o Cloud based architecture
o Motivation, Principles, Architecture,
Components, Constraints
SS 3.1 • Explore and note down the challenges associated with microservices
based architecture
• Study that how cloud application model is more suitable for
distributed application development
LE 2 • Microservices with Nodejs • [Optional]

3.2 Modern App Architectures - II

RL_3.3.* • Serverless Architecture

RL_3.4.* • Low Code Architecture [Optional]

CS 4.1 • Serverless Architecture • Classroom


o Deployment approaches discussion
o Cloud services for development, testing
and deployments of applications
(P/B/FaSS)
CS 4.2 • Low Code Architecture [Optional] • Classroom
o Motivation, use cases, choices discussion

SS 4.1 • Discuss the advantages and disadvantages related to the cloud


computing in general
• Explore how Serverless apps are different than SaaS apps
• Identify what are the common use cases in our daily life that can be
easily targeted through the low code architecture

Page | 6
M4: Serverless Apps

Type Description/Plan/Reference
RL_4.1.* • Backend as a Service (BaaS)
RL_4.2.* • Function as a Service (FaaS) [Optional]

CS 5.1 • BaaS/mBaaS • Classroom


o Motivation, Choices (Firebase / Parse discussion
/ Back4App )
o Demonstration
CS 5.2 • FaaS [Optional] • Classroom
o Motivation, Options (AWS Lambda / discussion
Google Cloud Functions / Azure
Functions )
o Demonstration
SS 5.1 • Explore more about Firebase and how it helps in speeding up the
mobile apps development
• Try out the getting started guides provided by different cloud service
providers for the FaaS services
LE 3 • Serverless App Development • Lab 3 manual

M5: Cross Platform Mobile Applications Development

Type Description/Plan/Reference
5.1 Native Applications
RL_5.1.* • Mobile Apps Development
RL_5.2.* • Native Applications

CS 6.1 • Native Applications • Classroom


o Platforms – Android, iOS etc. discussion
o Framework choices, benefits,
limitations
CS 6.2 o Demonstration of Android app • Google Docs
development using Dart
SS 6.1 • List down the application that are most suitable candidate for native
app development
• Explore more about AWS device farm which allows testing of mobile
apps on cloud platform
• Think about what sort of CI/CD pipeline will be required for the
mobile app development
5.2 Cross Platform - Native Apps

Page | 7
RL_5.3.* • Cross Platform-Native Apps

CS 7.1 • Cross Platform – Native Applications • Classroom


o Motivation, working discussion
o Framework Choices (ReactNative,
Xamarin, Flutter etc.)
CS 7.2 • Demonstration of React native application • ReactNative
illustrating the frontend and backend docs
interaction
SS 7.1 • Study about how organizations are getting benefitted through cross
platform application platforms development frameworks
• Prepare a simple calendar application using one of the framework
discussed in the class, leverage the database for data storage
LE 4 • Google Maps with Flutter app • Lab 4 manual
LE 5 • Google Maps with Flutter app • Lab 5 manual
LE 6 • Flutter app with persistence • Lab 6 manual
5.3 Cross Platform – Web Apps

RL_5.4.* • Cross Platform-Web Apps

CS 8.1 • Cross Platform - Web Apps • Classroom


o Purpose, working discussion
o Framework Choices (Ionic,
Cordova/PhoneGap, Capacitor)
CS 8.2 • Demonstration of Ionic application • Ionic docs
illustrating the frontend development using
one of commonly used frontend framework
SS 8.1 • Explore more about the various ecosystem components provided by
the Ionic
• List down the scenarios where cross platform web apps outshine the
other types of mobile apps

M6: API Design

Type Description/Plan/Reference
RL_6.1.* • API
RL_6.2.* • API Paradigm

RL_6.3.* • API Platform Architecture

RL_6.4.* • API Design Best Practices [Optional]

RL_6.5.* • API Description Languages

CS 9.1 • Application Programming Interfaces • T1 Ch 1, 2


o Motivations, requirements,
constraints

Page | 8
o API Paradigms

CS 9.2 • API Specification / Description • R2 – Ch6


o Usage
• Languages
SS 9.1 • Note down the best practices applied during web API development
• Explore more about the API description languages
• Import a simple OpenAPI spec into AWS API gateway and try to
create a proxy API which can be invoked from the client side
LE 7 • API design and documentation with • Lab 7 manual
OpenAPI
LE 8 • GraphQL Getting Started • Lab 8 manual

M7: API Management

Type Description/Plan/Reference
RL_7.1.* • API Product management
RL_7.2.* • API Change Management

RL_7.3.* • API teams

RL_7.4.* • API management platforms

RL_7.5.* • API Analytics

CS 10.1 API Product Management • T2 – Ch1,3,


o Challenge of API Management 5,6
o API as a Product lifecycle
o Pillars of API product
o Continuous API improvement
CS 10.2 API Landscape • T2 – Ch
o API teams 7,8,10
o API Management at scale
o API platforms
o API Analytics
SS 10.1 • Compare the APIM capabilities offered by the different providers

API Management with Microsoft Azure


LE 9 o Azure API Management Service • Lab 9 manual
LE 10 o Managing API Products • Lab10 manual
LE 11 o Monitoring an API • Lab11 manual
LE 12 o Managing Versions of API [Optional]
• Lab12 manual
[Optional]

Contact Session 11

Page | 9
Session Type Description/Plan Reference
11 CS • Review / Buffer

Proposed Structure for Lectures

CS CH Pre-CH During CH Post-CH


1 RL_1.1.*, 1.2.*, 1.3.*, CS 1.1
1
2 RL_1.4.*, 1.5.*, 1.6.*, CS1.2 SS 1.1, LE 1
3 RL_2.1.*, 2.2.*, 2.3.*, CS 2.1
2
4 RL_2.4.* CS 2.2 SS 2.1
5 RL_3.1.* CS 3.1
3
6 RL_3.2.* CS 3.2 SS 3.1, LE 2
7 RL_3.3.* CS 4.1
4
8 RL_3.4.* CS 4.2 SS 4.1,
9 RL_4.1.* CS 5.1
5
10 RL_4.2.* CS 5.2 SS 5.1, LE 3
11 RL_5.1.* CS 6.1
6
12 RL_5.2.* CS 6.2 SS 6.1
Mid Semester Exam
13 RL_5.3.* CS 7.1
7
14 CS 7.2 SS 7.1, LE 4, 5, 6
8 15 RL_5.4.* CS 8.1
16 CS 8.2 SS 8.1
17 RL_6.1.*, 6.2.*, 6.3.* CS 9.1
9
18 RL_6.4.*, 6.5.* CS 9.2 SS 9.1, LE 7, 8
19 RL_7.1.*, 7.2.*, CS 10.1
10
20 RL_7.3.*, 7.4.*, 7.5.*, CS 10.2 SS 10.1, LE 9,10,11,12
11 21-22 - Review -
End Semester Exam

Page | 10
Evaluation Scheme:

Legend: EC = Evaluation Component; AN = After Noon Session; FN = Fore Noon Session

No Name Type Duration Weight Day, Date, Session, Time


EC-1 Assignment-1 - 10% August 16-30, 2021
Assignment-2 - 20% September 16-30, 2021
EC-2 Mid-Semester Test Open 2 hours 30% Saturday 25/09/2021 (AN)
Book 2 PM – 4 PM
EC-3 Comprehensive Open 2 hours 40% Saturday 13/11/2021 (AN)
Exam Book 2 PM – 4 PM

Notes:
Syllabus for Mid-Semester Test (Open Book): Topics in M1 to M4 (contact sessions 1 to 5)
Syllabus for Comprehensive Exam (Open Book): All topics

Important links and information:


Elearn portal: https://elearn.bits-pilani.ac.in
Students are expected to visit the Elearn portal on a regular basis and stay up to date
with the latest announcements and deadlines.
Contact sessions: Students should attend the online lectures as per the schedule
provided on the Elearn portal.
Evaluation Guidelines:
1. EC-1 consists of either two Assignments or three Quizzes. Students will
attempt them through the course pages on the Elearn portal. Announcements
will be made on the portal, in a timely manner.
2. For Closed Book tests: No books or reference material of any kind will be
permitted.
3. For Open Book exams: Use of books and any printed / written reference
material (filed or bound) is permitted. However, loose sheets of paper will not
be allowed. Use of calculators is permitted in all exams. Laptops/Mobiles of
any kind are not allowed. Exchange of any material is not allowed.
4. If a student is unable to appear for the Regular Test/Exam due to genuine
exigencies, the student should follow the procedure to apply for the Make-Up
Test/Exam which will be made available on the Elearn portal. The Make-Up
Test/Exam will be conducted only at selected exam centres on the dates to be
announced later.

It shall be the responsibility of the individual student to be regular in maintaining the


self-study schedule as given in the course handout, attend the online lectures, and take
all the prescribed evaluation components such as Assignment/Quiz, Mid-Semester
Test and Comprehensive Exam according to the evaluation scheme provided in the
handout.

Page | 11

You might also like