still editing!
This is a project that aims to provide developers with an easy-to-use third-party accounts system and provide users with a secure, reliable, and private experiance with full control over their data.
- Developers must use the provided library, without any custom modifications to it in any way.
- Developers must provide minimal statestics about the user
- Developers must adhere to using the tracking functions within the provided library
- Should the user decide to delete their account, all data related to that user must be deleted (per the user's request).
- Should the user request a copy of their data through this accounts service, the Developer must provide a copy of the user's data within 30 days!
Note that the user can fully control which data within the website will be collected and which data should not be shared. Note to myself: the data should not be transfered out of a server without checking the user's preferences first.
- Add a welcome screen
- Add a sign in page
- Add a sign up page
- Add a control panel (Home page)
- Add an "about" section
- Add an activity tracking system (Must be completely controlable by the user)
- Make a library/API for developers
- Tracking functions
- Login/Logout functions
- Data-related requests channels (for account deletion/data copy requests)
- Add two-steps verification
- Add an "authenticator" to the PWA (with an in-app generated code)
- Add the option for an authentication promt to the PWA (a y/n screen)
- Support external authenticators (Like Google/Microsoft Authenticator)
- Support security keys
- Add mandatory back-up codes
Do NOT allow SMS or email two-steps verification
- Force the user to set up security questions (3 minimum)
- Always require the user to do device authentication on new devices or when the user attempts to change important settings. (https://try-webauthn.appspot.com/)
The sign up process:
- User must fill in the personal first and last names
- User must choose a username
- User must choose a password
- User must enter their date of birth and gender
- User must choose their security quesitons
- User must choose their prefered quick settings
- User will be prompted to read the privacy policy and terms of service, and agree to them
- User will be promted to review their account creation settings (this data can be exported)
- User will be prompted to set up two-factor authentication, or go to the home page!
The sign in process (trusted device - with device auth):
- User must enter username (/user/login)
- User must do the local device auth challenge
The sign in process (new/untrusted device):
- User must enter username (/user/login)
- User must enter password (/user/login/password)
- User must complete the two factor authentication process (if it's set up) (/user/challenge)
- User will be prompted to authenticate the device as a trusted device (If the user doesn't choose to mark the device as trusted, they will be unable to change their settings on that device without password confirmation)
New service access/signup prompt (trusted devices):
- User will be asked to authenticate their device
- User will be prompted with the list of permissions that the service requested (button must say "Allow access as {PP}{username}")
New service access/signup prompt (untrusted devices):
- User will be asked to type in their password
- User will be prompted with the list of permissions that the service requested (button must say "Allow access as {PP}{username}")
Service login prompt (trusted/untrusted device):
- User will be prompted to continue to the website (button must say "Continue as {PP}{username}"), or sign out and sign in with another account
Settings change confirmation prompt (trusted device):
- User will be asked to authenticate their device
Settings change confirmation prompt (untrusted device):
- User will be asked to enter their password
The password reset process:
- The user must use their email to verify ownership (in case the user chose to not attach an email address to their account, they can use a trusted device to verify ownership)
- The user must answer the security questions correctly
Account recovry process: (In case the user can't access their email)
- Must file the request through a trusted device
- Must enter their date of birth and gender
- Must answer all the security questions correctly
Note 1: Add option to save auth codes for other services, passwords and emails, and important data (like bank info, hashes, etc)
Note 2: Disable screenshots
Note 2: Add page transitions
Collected data (not provided by the user manually):
- IP address, user location, and user agent. (For user login history, and active devices list)
- Services usage (time of login/connection approval)
- Services action history (full history of your actions in connected services)
In the project directory, you can run:
Runs the app in the development mode.
Open http://localhost:4000 to view it in the browser.
The page will reload if you make edits.
Builds the app for production to the dist
folder.
It correctly bundles Solid in production mode and optimizes the build for the best performance.
The build is minified and the filenames include the hashes.
Your app is ready to be deployed!
Builds the app in developer mode with a php server.
You can deploy the dist
folder to any static host provider (netlify, surge, now, etc.)
This work is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License.