Learner Credential Wallet is a cross-platform iOS and Android mobile application for storing and sharing digital learner credentials.
Install Learner Credential Wallet for your mobile!
The wallet is based on the learner credential wallet specification developed by the Digital Credentials Consortium. The learner credential wallet specification is based on the draft W3C Universal Wallet interoperability specification and the draft W3C Verifiable Credentials data model.
The app has been compiled for iOS and Android and allows users to add and share credentials, as well as manage the wallet.
This learner credential wallet includes the features and technical requirements ultimately enabling individuals to curate and present their learning and employment records to others—for example, as applicants to educational programs or to apply for jobs with employers—in an interoperable manner.
- Receive digital credentials from standards compliant issuers via link or QR code
- Store credentials on their mobile device
- Keep credential access safe with strong encryption best practices
- Create and share a presentation that collates any number of credentials in their wallet
- Backup and restore their wallet
The Digital Credentials Consortium is working with a number of colleges and universities to pilot test the wallet.
Prerequisite peer dependencies:
Optionally, if you use the asdf
version manager run asdf install
to install
the correct version of Node. Clone down this repository, run npm i
to install
the React Native dependencies and also npx pod-install
to install iOS
Cocoapods. You can start the project with npm run ios
or npm run android
.
This project was started with Expo, but had to be ejected because some libraries did not support it. Do not develop using Expo, even if it might still launch. That being said, we are still using unimodules, so feel free to install and use packages from the Expo community.
If you get cryptic errors like the following:
** BUILD FAILED **
The following build commands failed:
CompileC /Users/jc/Library/Developer/Xcode/DerivedData/eduwallet-cikpfctcsrnvkqflqlievgbjvnfr/Build/Intermediates.noindex/Pods.build/Debug-iphonesimulator/RealmJS.build/Objects-normal/x86_64/RealmReact.o /Users/jc/gitlab\ github/digitalcredentials/learner-credential-wallet/node_modules/realm/react-native/ios/RealmReact/RealmReact.mm normal x86_64 objective-c++ com.apple.compilers.llvm.clang.1_0.compiler (in target 'RealmJS' from project 'Pods')
(1 failure)
Then check your version of cocoa pods. If it is 1.9.3, try upgrading it to something newer, like 1.11.2_1
See Installing LCW on Linux on setting up the project on Linux.
This project uses TypeScript and React Native. It would be best to use an
editor that can hook into the TypeScript language server (VSCode does this with
Intellisense, Vim does it with CoC). We also use eslint to catch common mistakes
and formatting errors. Most editors should support dynamic linting support while
editing. If your editor does not, you can manually lint by running npm run lint
in the project root.
This project also uses environment variables, which are stored in config.ts
.
These values can be overridden, but development values should not be committed to the repository.
├── app
│ ├── assets ← Image assets
│ ├── components ← React components
│ ├── hooks ← This is where custom hooks are defined (usually wraps lib methods)
│ ├── lib ← Location for utility methods
│ ├── mock ← Location for mock data, usually used for testing
│ ├── model ← Database access objects and connections
│ ├── navigation ← React Navigation structure
│ ├── screens ← Individual screen views
│ ├── store ← Redux and Redux Toolkit definitions
│ │ └── slices ← Redux Toolkit slices (add new Redux state here)
│ ├── styles ← All app style definitions
│ └── types ← General place for defining types (usually DCC types for Credential, Presentation, etc...)
├── android ← Auto-generated android build folder, can still be manually edited if needed
└── ios ← Same as android, except it also uses Cocoapods for dependency management
A custom display can be created for different credentials, to do so:
- Create a new React component for your credential type in
app/components/CredentialCard/ -
eg.
app/components/CredentialCard/YourNewTypeCard.tsx
- Define addition styles in
app/components/CredentialCard/YourNewTypeCard.styles.tsx
- Add a function to the
credentialTypes
list defined in app/components/CredentialCard/CredentialCard.tsx. The function should return{component: YourNewCredentialCard, title: 'the title of the credential that should be used when listing it elsewhere'}
or null if the credential isn't the appropriate type for you custom display - note: the list will be scanned for the first function that returns a component and title, so it's important that the type check is specific and doesn't match any other types.
We have conducted a Voluntary Product Accessibility Test, please review the Learner Credential Wallet Accessibility Conformance Report, December 2021
For more information on accessibility please visit the MIT Accessibilty page.
This Privacy Policy explains how Learner Credential Wallet collects, uses, and processes personal information about our learners.
We do not collect any personal information.
We may change this Privacy Policy from time to time. If we make any significant changes in the way we treat your personal information we will make this clear on our website or by contacting you directly.
The controller for your personal information is the Learner Credential Wallet project at MIT. We can be contacted at lcw-support@mit.edu.
Learner Credential Wallet Terms and Conditions of Use
Initial development was supported by the U.S. Department of Education (Contract Number: 91990020C0105). The opinions expressed herein do not necessarily represent the positions or policies of the U.S. Department of Education, and no official endorsement by the U.S. Department of Education should be inferred.
Initial development was also supported by the Massachusetts Institute of Technology. Continued development is supported by members of the Digital Credentials Consortium.
MIT License Copyright (c) 2021 Massachusetts Institute of Technology
All files located in external directories are externally maintained libraries used by this software which have their own licenses; we recommend you read them, as their terms may differ from the terms above.