Skip to content

gabrielmoreira-nn/nl-wallet

 
 

Repository files navigation

EDI - NL Public Reference Wallet

Under the Working Agenda Value Driven Digitization, the Dutch government is preparing for the introduction of European digital identity wallets (in short ID-wallets) through the revision of the eIDAS-regulation. One of the ways in which they are doing this, is by developing a public reference wallet called the NL Wallet. These ID-wallets will be mobile apps that citizens can use to identify (or ‘log in’) to public and private online services, share data about themselves, and sign electronically.

The first version of the NL Wallet will focus on online identification and data sharing and will be piloted at small scale in 2024. In the future, it may be possible to use such an ID-wallet in a lot of different situations, for example to share your diploma’s when applying for a job, to show your driver’s license, or to prove that you are 18+ to buy a beer.

The NL Wallet is being developed in an open and transparent way. We offer the following channels to allow you to contribute:

  • The user interface of the app is available on Figma.
  • The source code is published in this GitHub repository.
  • More information, events and discussions can be found on Pleio.

Feel free to look around and share your feedback and ideas.

Please note that this code is still experimental and subject to change.

About progress

As this project is a work in progress, you will find that the different components are at different levels of maturity. Most notably, the user interface is always a few steps ahead of the software under the hood. To put it simply, we incrementally add functionality to the wallet in three steps:

  1. We design the user interface of a piece of functionality in Figma. This is purely graphical, ideal for quick iterations.
  2. We then build the user interface in the app displaying dummy data and using mocked logic. This makes it fast and easy to explore, demonstrate and discuss different scenarios and possibilities.
  3. We then replace the mocked logic with actual working software, still using dummy data. This allows us to prove the app works and is secure.

Once the first version of the app is complete, thoroughly tested and considered secure, we can fill it with real data and pilot it in real life scenarios.

Table of contents

Current release

See the releases page for the latest release. You can follow the latest work by subscribing to the releases of this GitHub repository at the top of this page.

Documentation

TL;DR

With the NL reference wallet we want to achieve the following things:

  • We want to validate the feasibility of the framework as proposed in the EU.
  • We want to explore how we can set the bar in terms of privacy protection, security, usability and inclusion.
  • We want to learn what this development means for citizens, businesses, other governments and public service providers.
  • We want to help citizens, especially those with special needs, in the best way possible.
  • We want to offer a testing ground for a variety of use cases.
  • We want to share the lessons we learn with the public and share them with the EU.

If you want to learn more about the NL Wallet development, please read the background information on the Pleio hub. The development of the user flows and screens can be followed through Figma.

Licensing

The source code of the NL Wallet is released under the EUPL license. The documentation is released under the CC0 license. Please see the .reuse/dep5 file for more details, which follows the Reuse specfication.

Contributing

We’re releasing the source code with the explicit intention of allowing contributions. The coordination of the project lies with the development team of the European Digital Identity Progam, but we’re open to all contributions. You can directly create a new Pull Request via Github, or contact the community manager via edi@minbzk.nl.

The development team works on the repository in a private fork (for reasons of compliance with existing processes) and shares its work as often as possible. If you watch the repository on GitHub, you will be notified of a new release. We will also send a notification through Pleio.

Although we are open to contributions, please consider the nature of this project as outlined in this Readme. At this stage the most useful way to contribute to the project is to participate on our community site edi.pleio.nl, and visit our EDI Meet-ups and/or Heartbeats.

If you plan to make non-trivial changes, we recommend that you open an issue beforehand where we can discuss your planned changes. This increases the chance that we might be able to use your contribution (or it avoids doing work if there are reasons why we wouldn't be able to use it).

Note that all commits should be signed using a GPG key.

Getting started

This section contains the general setup requirements of the project. For more details on configuration of the wallet app, the wallet core and the wallet_provider, please see the corresponding README files.

Setup development environment

The app's UI is build using Flutter, but to avoid tying the app to Flutter & Dart, all core business logic is build using Rust. This gives us the more flexibility to migrate to completely native iOS/Android app's if the need arises. This does mean building the app is slightly more complex than a simple flutter run. This section describes how to set up your environment.

Requirements:

  • Flutter
  • Rust (incl. additional targets)
  • Android SDK + NDK (for Android builds)
  • Xcode (for iOS builds)
  • Docker (to run supporting services)

Flutter

To install Flutter follow this installation guide. You can validate your initial setup by running flutter doctor.

Easily manage your local Flutter version using: Flutter Version Manager (FVM) FVM is a simple CLI to manage Flutter SDK versions per project. It enables fast switching between Flutter versions and pin them to your Flutter project. When using FVM; all Flutter related command need to be prefixed with fvm, e.g. fvm flutter run.

Optional step: To install FVM follow this installation guide. You can validate your initial setup by running fvm flutter doctor after the installations. Hit [Y]es when asked to install the pinned Flutter version defined in fvm_config.json.

Note that FVM only pins the Flutter version for local development, not the CI pipelines.

Rust

To install Rust & Cargo (the package manager) follow the installation guide. After installing rust make sure to add the following targets:

  • For iOS: rustup target add aarch64-apple-ios x86_64-apple-ios
  • For iOS simulator: rustup target add aarch64-apple-ios-sim
  • For Android: rustup target add aarch64-linux-android armv7-linux-androideabi x86_64-linux-android

Android

To build for android you need to have the Android SDK and NDK installed on your system. Likely the easiest way to do so is:

  1. Install Android Studio (includes SDK)
  2. Open Android Studio
    1. Tools -> SDK Manager
    2. Select 'SDK Tools' Tab
    3. Check latest 'NDK (Side by side)' in the list (>= v25.2.9519653)
    4. Hit 'apply' to install
  3. Add export ANDROID_HOME="$HOME/Library/Android/sdk" to your ~/.bash_profile or ~/.zshrc, this will make sure the Android SDK is available in your path and automatically picks up the NDK version you installed in the previous step
  4. Tell gradle where it can find the NDK by updating one of your gradle.properties, e.g. echo "NDK_HOME=\"$HOME/Library/Android/sdk/ndk/{ndk_version}\"" >> ~/.gradle/gradle.properties
  5. Run cargo install cargo-ndk (>= v3.0.0) to be able to build the Rust code for Android
  6. Optional: let Android Studio use Flutter SDK installed via FVM by following these steps
  7. Run ${HOME}/Library/Android/sdk/emulator/emulator -list-avds to list the installed devices
  8. Start the emulator using `${HOME}/Library/Android/sdk/emulator/emulator [[AVDs] FROM PREVIOUS OUTPUT]``

iOS

  1. Install Xcode
  2. Follow the steps to install iOS simulators
  3. Start the simulator using open -a Simulator

Prerequisites

The Wallet needs several supporting services to run, and also requires the user to log in using DigiD in order to create the Wallet. The services are the following:

  • Wallet Provider: See wallet_core/wallet_provider/README.md

    The Wallet Provider requires a Postgres database.

  • PID Issuer: See wallet_core/pid_issuer/README.md

  • Digid Connector: See RDO MAX.

All these applications will need to be configured correctly. A local development environment can be set up using the scripts/setup-devenv.sh and scripts/start-devenv.sh scripts.

Configuring the development environment

The setup-devenv.sh script will configure the digid-connector to listen on https://localhost:8006/ . Note the https in the URL, which is provided using self-signed certificates, therefore we have to disable TLS validation in the wallet and the pid_issuer. Also when using the browser for the first time, a security exception must be added to allow connecting to localhost. Disabling TLS validation is gated behind the feature disable_tls_validation on the wallet and the pid_issuer crates.

Besides that, the development setup runs without using TLS. Therefore, the feature allow_http_return_url enables the possibility to use a return URL with the scheme http (while normally https is only allowed).

Additionally, the wallet crate offers the config_env feature to aid during local development, which does the following:

  • Any constant defined in the file data.rs can be overridden by an environment variable of the same name at compile time.
  • Additional environment variables are read from a file named .env in the wallet crate directory, if present.
Android Emulator

In order to connect to our locally running services from the Android Emulator on the domain localhost, some port mappings have to be made. Note that this must be done every time the Android Emulator is restarted.

This is automated in the script: scrips/map_android_ports.sh.

The setup-devenv.sh script will automatically run this script when it detects the adb command.

However, when the Android Emulator has been restarted, one can just run map_android_ports.sh.

Starting development environment

The individual services of the development environment can be started using start-devenv.sh. Tip: use the --help commandline option to show the help output

Validate

After doing the above flutter doctor should report that at least the following are installed successfully:

  • Flutter
  • Android toolchain
  • Xcode

You should now be able to launch an Android Emulator or iOS Simulator and run the app by following these steps:

  • cd wallet_app
  • flutter pub get
  • flutter run! 🎉

File structure

Code

All Dart code goes in the wallet_app/lib/ directory and their appropriate sub-directories.

All Rust code goes in the wallet_core/ directory and their appropriate sub-directories.

Flutter <-> Rust Bridge

Communication between the Flutter and Rust layers relies on the flutter_rust_bridge package, the bridge code is generated. The definition of this bridge can is located at /wallet_core/src/api.rs and generation is done with the following command:

cargo run --manifest-path wallet_core/flutter_rust_bridge_codegen/Cargo.toml

The generated code is currently checked in, so that generation only has to be performed when the API changes.

Conventions

Git

Commit message

  • Capitalize the subject line
  • Use the imperative mood in the subject line
  • Do not end the subject line with a period
  • Wrap lines at 72 characters

Branch names

  • Prefix the branch name with the Jira code for the story or subtask the branch relates to. If there is no story or subtask, strongly consider making one or forego the prefix.
  • The rest of the branch name should be a short description of the purpose of the branch, in lowercase and separated by hyphens. The description should be clear enough that any reader should understand it without having to look up the Jira ticket. Consider starting the description with the component that is being worked on, e.g. ci- or core-.

Example of a branch name: PVW-123-wp-teapot-status-code

PR title

See commit message.

PR merge

  • Default to squash merge (combined with PR title conventions)

Distribution

Follow these steps to (force) distribute internal alpha & beta builds that target the Android platform":

Alpha

Use Alpha distribution at any time during development cycle.

  • Push commit of your choosing to: alpha/v{X.Y.Z}
  • After the GitHub Action has completed successfully; install the release via F-Droid repo

Beta

Use Beta distribution at the end of a sprint cycle; to represent the sprint demo version.

  • $ git fetch && git pull
  • Push main branch to: beta/v{X.Y.Z}
  • After the GitHub Action has completed successfully; install the release via F-Droid repo

Troubleshooting

Initial checkout / branch switch

Generate/update localisation files (to compile/run the project successfully):

$ flutter gen-l10n

About

NL Public Reference Wallet

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Dart 49.7%
  • Rust 42.9%
  • Kotlin 4.3%
  • Shell 1.1%
  • Swift 0.8%
  • Ruby 0.5%
  • Other 0.7%