
Personal Data & Privacy Management Software
A ready-to-use solution for personal data and consent management.
Pryv.io is a solid foundation on which you build your own digital health solution, so you can collect, store, share and rightfully use personal data.
Maintained and developed by Pryv.

 Open-Pryv.io is recognized as a digital public good by DPGAlliance a UN-endorsed initiative that facilitates the discovery and deployment of open-source technologies.
 
Open-Pryv.io is recognized as a digital public good by DPGAlliance a UN-endorsed initiative that facilitates the discovery and deployment of open-source technologies.
Pryv.io is designed to be exposed by a third party SSL termination such as NGINX.
Choose your Set-up
The dockerized versions and their instructions are available at this link: Download link.
If you wish to build the images yourself, refer to the following README: docker/README-build.md.
Once it is running, you can continue with the tutorials.
Prerequisites:
The installation script has been tested on Linux Ubuntu 18.04 LTS and MacOSX.
npm run setup-dev-env to setup local file structurenpm install to install node modulesEach service independently - logs will be displayed on the console
npm run database start mongodb or start ferretDBnpm run api start the API server on port 3000 (default)npm run mail start the mail servicebackloop.dev certificates facilitate local developpment by enabling https on localhost.
npm run database to start mongodb  or start ferretDBnpm run mail start the mail servicenpm run apibackloop to start api server using configs/api-backloop.ymlYou can now access you API from you own computer with SSL on
https://my-computer.backloop.dev:4443You can check by opening https://my-computer.backloop.dev:4443/reg/service/info
And create new users or access token from the Pryv Access Token Generation Page
http:ssl part in ./configs/api.yml file to point to your certificates an key files.dnsLess:publicUrl in ./configs/api.yml to matchnpm run pryv to start the APIFor the native installation, edit ./configs/api.yml
dnsLess:
  publicUrl: http://localhost:3000
http:
  port: 3000
  ip: 127.0.0.1
auth:
  adminAccessKey: REPLACE_ME 
  trustedApps: "*@https://pryv.github.io*, *@https://*.rec.la*, *@https://*.backloop.dev*"
eventFiles:
  attachmentsDirPath: var-pryv/attachment-files
service:
  name: Open-Pryv.io
  support: https://pryv.com/open-pryv-non-configured-page/
  terms: https://pryv.com/open-pryv-non-configured-page/
  home: https://pryv.com/open-pryv-non-configured-page/
  eventTypes: https://pryv.github.io/event-types/flat.json
services:
  email:
    enabled:
      welcome: true
      resetPassword: true
http to another network./reg/admin/users. A random key should be generated on setup.At this moment you should have your application running on the public URL you defined.
If you are using another public URL, replace https://my-computer.backloop.dev:4443 by it in the link above.
Data in Pryv is stored in streams and events. We provide you with all necessary information to design your own data model in our Data Modelling Guide through a broad range of use cases and scenarios you might encounter.
After this process, you should have an account on your Open Pryv.io platform with a valid authorization token in the form of an API endpoint, you can try various API requests using Postman following this guide https://pryv.github.io/open-api/.
You can also try our example apps with guides and tutorials.
Read README-DBs for more information.
Open Pryv.io comes packaged with app-web-auth3, the default web pages for app authentication, user registration and password reset.
During the set-up process it has been built and published in public_html/access/. To customize it, refer to its README in app-web-auth3/.
To use a new build, simply copy the contents of the generated files from app-web-auth3/dist/ to public_html/access/
Open Pryv.io comes with default event types.
The default ones are fetched at boot from the URL defined in service:eventTypes in the .yml config file, set to https://pryv.github.io/event-types/flat.json.
To customize your own, clone the Data Types repository and follow the guide there.
By default the MongoDB data are stored in var-pryv/mongodb-data. If you want to modify the folder where the MongoDB data files are stored, read ferretDB README.
By default the FerretDB data are stored in var-pryv/ferretdb-data. If you want to modify the folder where the FerretDB data files are stored, you can modify in scripts/setup-mongodb the variable MONGO_DATA_FOLDER.
Your platforms visuals can be customized in public_html/assets/, please refer to the README inside. These assets are a clone of the assets-open-pryv.io.
Pryv.io can send e-mails at registration and password reset request.
The emails can be sent either by local sendmail (default) or SMTP.
This service, its documentation and mail templates can be found in service-mail/.
Prerequisites:
To make a backup of your data:
Run ./scripts/backup-database-native ${BACKUP_FOLDER} to generate a dump of the current database contents
Run ./scripts/backup-usersfiles-native ${BACKUP_FOLDER} to copy the current usersfiles files.
To restore the database, run ./scripts/restore-database-native ${BACKUP_FOLDER} to restore data from the provided backup folder.
To restore attachments, run ./scripts/restore-usersfiles-native ${BACKUP_FOLDER} to restore data from the provided backup folder.
Depending on your setup, you may need additional access rights.
Follow the guide in the docker package.
Contributions are welcome. Get in touch with the Pryv team or submit a PR with your changes or adaptation.