Giter VIP home page Giter VIP logo

stayaway-app's Introduction

STAYAWAY COVID

Covid-19 Exposure Notification App for Portugal ๐Ÿ‡ต๐Ÿ‡น


Introduction

STAYAWAY COVID is a voluntary system aiming at supporting Portuguese Health Authorities in the screening of COVID-19. This repository contains the STAYAWAY COVID source code for both Android and iOS. Before anyone can run the app, a Pilot was launched in order to improve the detection and correction of any issues. The Pilot phase is restricted to a defined number of invited users, though we provide an UI only mode as detailed in the building section. So, if not everyone can run it, why are we open-sourcing the code? It's pretty simple actually, for a reason of transparency, public scrutiny and security. We believe that such an important application should be available to the community. We welcome any bug reports, security or privacy concerns that you might have with the app and will do our best to address them.

STAYAWAY COVID is a React Native project built on top of the Decentralised Privacy-Preserving Proximity Tracing (DP^3T) project. DP^3T is an open protocol for COVID-19 proximity tracing using Bluetooth Low Energy functionality on mobile devices that ensures personal data and computation stays entirely on an individual's phone. STAYAWAY COVID relies on the open source DP^3T SDKs, which are the implementation of the DP^3T protocol using the Exposure Notification Framework of Google and Apple. DP^3T is a completely separate project, for any issues, concerns or checking the source code, please visit the official repository.

In the course of a pandemic, timely diagnosis of the population and informed reporting are crucial to break and control the chains of transmission. In the case of COVID-19, this does not come easy given the extended incubation period of the disease and the fact that, in many cases, infected patients are asymptomatic.

Thanks to STAYAWAY COVID, we are able to find out if we are at risk of being infected, based on the contacts we have been close to in the previous couple of weeks. A community-wide uptake of this app will turn it into a valuable and decisive ally in the fight against COVID-19.

The project was led by INESC TEC with the collaboration of Keyruptive and Ubirider.

Installation and Building

Requirements

To build the project you'll need to setup your React Native development environment, which can achieved by following the steps at https://reactnative.dev/docs/environment-setup. The requirements will depend on your development platform.

Android

Only approved government public health authorities can access the Exposure Notification APIs. STAYAWAY COVID for Android will not work properly unless either your account is whitelisted as test account or your app is approved by Google and signed with the production certificate.

Required tools for building:

  • Watchman
  • Node 8.3
  • Yarn
  • Java SE Development Kit 8
  • Android Studio
  • Android SDK

iOS

Only approved government public health authorities can access the Exposure Notification APIs. STAYAWAY COVID for iOS will only work correctly if you were granted the com.apple.developer.exposure-notification entitlement by Apple. The ExposureNotification.framework is available starting with iOS 13.5.

Required tools for building:

  • Watchman
  • Node 8.3
  • Yarn
  • CocoaPods
  • XCode

Installation

  • Clone or download this repository.
git clone https://github.com/stayawayinesctec/stayaway-app.git
  • Copy .env.example to .env.{production,ui}.debug and fill in the variables with your own information, eg:
cp .env.example .env.production.debug
  • Install dependencies by running:
yarn
  • If you're using android, you'll also need to manually download the binary distribution of play-services-nearby and attach it to your project on android/app/libs. You can do so by running on your project root:
wget https://github.com/google/exposure-notifications-android/raw/7dc2979051703443895123f83c370f64a81baa38/app/libs/play-services-nearby-18.0.3-eap.aar -P android/app/libs

Building

  • And finally, build the project:
yarn android # or yarn android-ui
yarn ios # or yarn ios-ui

NOTE: Running android-ui or ios-ui will allow you to run and test the applications' user interface without requiring to activate the Exposure Notification API.

Copyright and license

Copyright (c) 2020 INESC TEC. Developed with Keyruptive. This project is licensed under the terms of the EUPL-1.2 license. Please see the LICENSE file for full reference.

Some files contain code from the DP3T applications, Copyright (c) 2020 Ubique Innovation AG. These files are are marked as such and licensed also under MPL-2.0.

Third-party components licenses

Tools

Name License
Gradle Apache 2.0
Cocoapods MIT

Libraries

Name License
DP3T-SDK-Android MPL 2.0
DP3T-SDK-iOS MPL 2.0
OkHttp Apache 2.0
Retrofit Apache 2.0
Version Compare Apache 2.0
TrustKit MIT

Fonts

Name License
Roboto Apache 2.0

React Native Packages

Name License
@react-native-community/async-storage MIT
@react-native-community/checkbox MIT
@react-native-community/masked-view MIT
@react-native-community/netinfo MIT
@react-navigation/bottom-tabs MIT
@react-navigation/native MIT
@react-navigation/stack MIT
i18n-js MIT
lodash.pickby MIT
lodash.memoize MIT
mirror-creator MIT
moment MIT
react MIT
react-native MIT
react-native-android-location-enabler MIT
react-native-config MIT
react-native-elements MIT
react-native-gesture-handler MIT
react-native-indicators BSD-3-Clause
react-native-keyboard-aware-scroll-view MIT
react-native-localize MIT
react-native-modal MIT
react-native-permissions MIT
react-native-reanimated MIT
react-native-safe-area-context MIT
react-native-screens MIT
react-native-splash-screen MIT
react-native-svg MIT
react-native-svg-icon MIT
react-native-swiper MIT
react-native-vector-icons MIT
react-native-version-number MIT
react-navigation-redux-debouncer MIT
react-redux MIT
redux-actions MIT
redux-saga MIT
reselect MIT

stayaway-app's People

Contributors

djcouto avatar fmaia avatar fmcruz avatar maghuro avatar marado avatar mluisbrown avatar sctfcm avatar stuntspt avatar zamith avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.