Skip to content

Requirements

ocroquette edited this page Dec 17, 2012 · 41 revisions

The primary goal of the project is a mobile application for the Bladenight participants (vs. bladeguards, BRK, organizers...). This page lists the high prio requirements toward that goal.

You may also be interested in the Low priority requirements.

General requirements

  • Main audience: bladenight participants owning a smartphone
  • Keep support effort as low as possible on developers/organizer side

Target platform/clients

  • Android phones >=2.2 (90% of Android market share)
  • iPhone iOS >= 5 (90% of iOS market share)

Map view

Display a map with:

  • My position
  • My friends
  • Zoom on:
    • Me
    • Route
    • Procession
  • Auto zoom (e.g. follow automatically)

Map framework

Potential map frameworks (we could support several): Google Maps, Openstreetmap Mapsforge

Risks

No risk, feature is pretty straight-forward.

Code reuse

We can reuse code from the both legacy apps, but it's not critical because it's very straight-forward.

Progress bar view

  • My position
  • My friends
  • Width can represent:
    • Procession
    • Route

Risks

No risk, feature is pretty straight-forward.

Code reuse

We can reuse code from Olivier for Android, but it's not critical because it's very straight-forward.

Data view

  • Route length
  • Procession length
  • Current linear position on the route (2.4 of 10.6km)
  • Current/average speed

Risks

Feature is straight-forward on the client, but the server will have to do the work reliably.

Code reuse

We can reuse code from Olivier for Android, but it's not critical because it's very straight-forward.

Social features

  • Add a friend. Possible media: in the app only; by SMS
  • Find a friend ("Bob is 200m ahead of you")

Risks

This requires to set up a network first, and therefore a kind of authentication mechanism. On the other hand, we want to keep things as simple as possible, both for the users and for us (reliability, support effort).

Possible process:

  • User clicks on "Add friend"
  • Client connects to the server with the device id
  • Server sends back a random token (6 digits)
  • User gives this token to his friend (orally, SMS, email...)
  • Friend enters token on his client
  • Friend's client sends confirmation (and device id) to the server
  • Server stores the friend connection

Security

  • Identify client software

Risks

We have to find the right way to do it. Still to be clarified if we want also to crypt the entire connection.

Code reuse

Code or concept could be reused from the Bladenight App. It's pretty simple though.

Administration

  • Set active route to predefined route from mobile client

Risks

It requires to identify the administrators as such. How ?

  • User-independent master password, sent by the client either at the beginning of the data session, or for each admin command
  • User specific password, admin flag in the user database (it requires then to have usernames/ids)

Advertisement (see also Advertisement)

  • Support at least one ad network
  • Allow to add specific ads for the sponsors (AOK ?)

Risks

  • No experience in the team yet
  • Official sponsors and corresponding ad are still unknown

Privacy

  • Comply with the german Datenschutz

Risks

  • Requires a lawyer

Tunnels and bridges

  • Display tunnels/bridges for pedestrians and bikers to cross the bladenight safely

Risks

  • Data has to be available (potential data sources: Openstreetmap, survey)

Safety

  • Safety function to avoid people to watch their phones while skating

Development

  • Storage: support at least one inline solution (files, sqlite, h2...)
Clone this wiki locally