/
App Planning Document

App Planning Document

This document includes:

  • Detailed project plan outlining the specific stages of development and corresponding timelines for completion

  • A technical specification document outlining the app's architecture, technology stack, and infrastructure requirements

  • A detailed testing and quality assurance plan, including both manual and automated testing

  • A plan for post-launch maintenance and updates, including bug fixes and new feature releases

  • A clear communication plan for regular updates and progress reports

  • A plan for data and user privacy, compliance with regulations and standards

  • A plan for security, including measures to protect user data and the app itself from unauthorised access or attacks

  • The number of developers who will be working on the app so that we can provision the correct number of certificates and check costing

Development Stages

Stage

Goal

Details

Stage

Goal

Details

A

Boilerplate project

Create a simple single page app which builds and is preview-able on a phone.

B

Implement Browse Buildings Page

Replicate the function of the browse page on the Freerooms website, showing buildings and allowing for the selection of a building to then view rooms inside it.

C

Implement Individual Room Pages

Replicate the function of the individual room information page which contains the calendar of a page’s booking.

D

Implement Map

Replicate the function of the map on the Freerooms website.

E

Implement Search Page

Implement a page to search for buildings and rooms.

F

Implement Favouriting of Rooms

Implement a way to save favorited rooms.

G

Implement Home page

Design and implement a landing or home page which can direct users to the different functions and views of the app

H

Submit MVP for App Store Approval

 

Tech Stack and Infrastructure

The app will be written in React Native on the Expo framework. Expo will handle the build and packaging for App Store deployment on both iOS and Android platforms. Expo is also the only way to develop for iOS using a Windows device which certain members of the Freerooms team use.

  • Should Expo become unsuitable for any unforeseen costing reasons, it is still reasonably easy to convert the project to pure React Native - built with Xcode.

The app will rely on existing endpoints and routes on the v2 backend which as been used for the Freerooms website.

Testing

The following automated tests will be part of our CI pipeline:

  • Linting and static type analysis via Typescript

  • Unit tests for any calculation functions via Jest

  • Component testing for key components via Jest and React Native Testing Library

  • Integration testing via Detox

We will also perform manual usability testing on iOS and Android devices.

Updates and Maintenance

Development of the App will progress per the goals and features determined by each set of project directors. As updates and features are pushed to the master branch and deployed, app features will be pushed to the master branch and aggregated. Once sufficient, an update to apps will be pushed.

We will also establish a method for users to provide feedback, allowing us to respond to issues quickly.

Progress Reporting

We will provide updates on the development on the app in the monthly director meetings as we have already been for the website.

Regulatory and Privacy

Data Collection

Key:

⛔️ No plans to collect [22]

❇️ May collect in a later version of the app [10]

✅ Will collect in the first version of the app [0]

Contact Info

Contact Info

Name

Such as first or last name

❇️

Email Address

Including but not limited to a hashed email address

❇️

Phone Number

Including but not limited to a hashed phone number

❇️

Physical Address

Such as home address, physical address, or mailing address

⛔️

Other User Contact Info

Any other information that can be used to contact the user outside the app

⛔️

Health & Fitness

Health

Health and medical data, including but not limited to data from the Clinical Health Records API, HealthKit API, MovementDisorderAPIs, or health-related human subject research or any other user provided health or medical data

⛔️

Fitness

Fitness and exercise data, including but not limited to the Motion and Fitness API

⛔️

Financial Info

Payment Info

Such as form of payment, payment card number, or bank account number. If your app uses a payment service, the payment information is entered outside your app, and you as the developer never have access to the payment information, it is not collected and does not need to be disclosed.

⛔️

Credit Info

Such as credit score

⛔️

Other Financial Info

Such as salary, income, assets, debts, or any other financial information

⛔️

Location

Precise Location

Information that describes the location of a user or device with the same or greater resolution as a latitude and longitude with three or more decimal places

❇️

Coarse Location

Information that describes the location of a user or device with lower resolution than a latitude and longitude with three or more decimal places, such as Approximate Location Services

❇️

Sensitive Info

Sensitive Info

Such as racial or ethnic data, sexual orientation, pregnancy or childbirth information, disability, religious or philosophical beliefs, trade union membership, political opinion, genetic information, or biometric data

⛔️

Contacts

Contacts

Such as a list of contacts in the user’s phone, address book, or social graph

⛔️

User Content

Emails or Text Messages

Including subject line, sender, recipients, and contents of the email or message

⛔️

Photos or Videos

The user’s photos or videos

⛔️

Audio Data

The user’s voice or sound recordings

⛔️

Gameplay Content

Such as saved games, multiplayer matching or gameplay logic, or user-generated content in-game

⛔️

Customer Support

Data generated by the user during a customer support request

⛔️

Other User Content

Any other user-generated content

⛔️

Browsing History

Browsing History

Information about content the user has viewed that is not part of the app, such as websites

⛔️

Search History

Search History

Information about searches performed in the app

❇️

Identifiers

User ID

Such as screen name, handle, account ID, assigned user ID, customer number, or other user- or account-level ID that can be used to identify a particular user or account

⛔️

Device ID

Such as the device’s advertising identifier, or other device-level ID

⛔️

Purchases

Purchase History

An account’s or individual’s purchases or purchase tendencies

⛔️

Usage Data

Product Interaction

Such as app launches, taps, clicks, scrolling information, music listening data, video views, saved place in a game, video, or song, or other information about how the user interacts with the app

❇️

Advertising Data

Such as information about the advertisements the user has seen

⛔️

Other Usage Data

Any other data about user activity in the app

⛔️

Diagnostics

Crash Data

Such as crash logs

❇️

Performance Data

Such as launch time, hang rate, or energy use

❇️

Other Diagnostic Data

Any other data collected for the purposes of measuring technical diagnostics related to the app

❇️

Other Data

Other Data Types

Any other data types not mentioned

⛔️

Security

As stated above we aren’t handling any secure user data, the app is primarily an interface to our database. Regardless, we will:

  • Ensure that the app is regularly updated with the latest security patches and updates to address any known vulnerabilities.

  • Validate all user input to prevent malicious requests from being sent to the server

Developer Resource Provisioning

Both Freerooms Directors will have access and permissions to and oversight over the app source code.

Subcommittee groups will also be given tickets and tasks to work on. Per 2023 Freerooms practice, subcommittee members are paired together for tasks. Hence, 2 subcommittee will begin working on the app with 2 more to join as progress is made on the existing Frontend and Backend tasks.

Related content