You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
317 lines
11 KiB
317 lines
11 KiB
8 months ago
|
---
|
||
|
geometry: margin=1in
|
||
|
header-includes:
|
||
|
- \usepackage{graphicx}
|
||
|
- \usepackage{titling}
|
||
|
- \usepackage{fancyhdr}
|
||
|
- \usepackage{lastpage}
|
||
|
- \pagestyle{fancy}
|
||
|
- \fancyhead[L]{Time Safari Usage Guide}
|
||
|
- \fancyhead[C]{Page \thepage\ of \pageref{LastPage}}
|
||
|
- \fancyhead[R]{}
|
||
|
- \fancyfoot[L]{}
|
||
|
- \fancyfoot[C]{}
|
||
8 months ago
|
- \fancyfoot[R]{\includegraphics[width=1cm]{images/timesafari-logo-binoculars.png}}
|
||
8 months ago
|
- \usepackage{tocloft}
|
||
|
- \usepackage{libertine}
|
||
|
- \renewcommand{\familydefault}{\sfdefault}
|
||
|
- \fancypagestyle{tocstyle}{
|
||
|
\fancyhead[L]{Time Safari Usage Guide}
|
||
|
\fancyhead[C]{Page \thepage\ of \pageref{LastPage}}
|
||
|
\fancyhead[R]{}
|
||
|
\fancyfoot[L]{}
|
||
|
\fancyfoot[C]{}
|
||
|
\fancyfoot[R]{\includegraphics[width=1cm]{images/timesafari-logo-binoculars.png}}}
|
||
|
---
|
||
|
|
||
|
\begin{titlepage}
|
||
|
\centering
|
||
|
\vspace*{\fill}
|
||
|
{\huge\textbf{TimeSafari Usage guide}}
|
||
|
|
||
|
\vspace{1cm}
|
||
|
{\Large Signing up users, adding contacts, and adding gifts.}
|
||
|
|
||
|
\vspace{1cm}
|
||
|
\includegraphics[width=0.5\textwidth]{images/timesafari-logo.png}
|
||
|
\vspace*{\fill}
|
||
|
|
||
|
\vspace{1cm}
|
||
|
{\Large Trent Larson, Kent Bull}
|
||
|
|
||
|
\vspace{0.5cm}
|
||
|
{\large 2024-06-25}
|
||
|
|
||
|
\end{titlepage}
|
||
|
|
||
|
\clearpage
|
||
|
|
||
|
\begin{center}
|
||
|
\includegraphics[width=2cm]{images/timesafari-logo-binoculars.png}
|
||
|
\end{center}
|
||
|
\tableofcontents
|
||
|
|
||
|
\clearpage
|
||
|
|
||
|
|
||
|
# Purpose of Document
|
||
|
|
||
|
Both end-users and development team members need to know how to use TimeSafari.
|
||
|
This document serves to show how to use every feature of the TimeSafari platform.
|
||
|
|
||
|
Sections of this document are geared specifically for software developers and quality assurance
|
||
|
team members.
|
||
|
|
||
|
Companion videos will also describe end-to-end workflows for the end-user.
|
||
|
|
||
|
# TimeSafari
|
||
|
|
||
|
## Overview
|
||
|
|
||
8 months ago
|
\pagebreak
|
||
|
|
||
|
# 1 - End Users
|
||
|
|
||
|
This section covers application usage for people who will use TimeSafari as intended. It is a
|
||
|
simplified guide illustrating how to gain value from using TimeSafari.
|
||
|
|
||
|
\pagebreak
|
||
|
|
||
|
# 2 - Software Developers
|
||
|
|
||
|
This section is tailored for software developers seeking to use the application during development,
|
||
|
quality assurance, and testing.
|
||
|
|
||
8 months ago
|
# Bootstrapping a local development environment
|
||
8 months ago
|
|
||
|
The first concern a software developer has when working on TimeSafari is to set up a local
|
||
|
development environment. This section will guide you through the process.
|
||
|
|
||
8 months ago
|
## Prerequisites
|
||
8 months ago
|
|
||
|
1. Have the following installed on your local machine:
|
||
|
- Node.js and NPM
|
||
|
- A web browser. For this guide, we will use Google Chrome.
|
||
|
- Git
|
||
|
- A code editor
|
||
|
|
||
|
2. Create an API key on Infura. This is necessary for the Endorser API to connect to the Ethereum
|
||
|
blockchain.
|
||
|
- You can create an account on Infura [here](https://infura.io/).\
|
||
|
Click "CREATE NEW API KEY" and label the key. Then click "API Keys" in the top menu bar to
|
||
|
be taken back to the list of keys.
|
||
|
|
||
|
Click "VIEW STATS" on the key you want to use.
|
||
|
|
||
8 months ago
|
data:image/s3,"s3://crabby-images/8fa08/8fa080311fb6450774ce19e0f193ccc013507a80" alt=""{ width=550px }
|
||
8 months ago
|
|
||
|
- Go to the key detail page. Then click "MANAGE API KEY".
|
||
|
|
||
8 months ago
|
data:image/s3,"s3://crabby-images/15160/151607d518b22738f67ff4ad42c8cb5e5ce16054" alt=""{ width=550px }
|
||
8 months ago
|
|
||
|
- Click the copy and paste button next to the string of alphanumeric characters.\
|
||
|
This is your API, also known as your project ID.
|
||
|
|
||
8 months ago
|
data:image/s3,"s3://crabby-images/50fb5/50fb5dce33c6641d629335bee3d1994d49adeaab" alt=""{width=550px }
|
||
8 months ago
|
|
||
|
- Save this for later during the Endorser API setup. This will go in your `INFURA_PROJECT_ID`
|
||
|
environment variable.
|
||
|
|
||
|
|
||
8 months ago
|
## Setup steps
|
||
8 months ago
|
|
||
8 months ago
|
### 1. Clone the following repositories from their respective Git hosts:
|
||
8 months ago
|
- [TimeSafari Frontend](https://gitea.anomalistdesign.com/trent_larson/crowd-funder-for-time-pwa)\
|
||
|
This is a Progressive Web App (PWA) built with VueJS and TypeScript.
|
||
|
Note that the clone command here is different from the one you would use for GitHub.
|
||
8 months ago
|
|
||
|
```bash
|
||
|
git clone git clone \
|
||
|
ssh://git@gitea.anomalistdesign.com:222/trent_larson/crowd-funder-for-time-pwa.git
|
||
|
```
|
||
|
|
||
8 months ago
|
- [TimeSafari Backend - Endorser API](https://github.com/trentlarson/endorser-ch)\
|
||
|
This is a NodeJS service providing the backend for TimeSafari.
|
||
8 months ago
|
|
||
8 months ago
|
```bash
|
||
|
git clone git@github.com:trentlarson/endorser-ch.git
|
||
|
```
|
||
|
|
||
|
\pagebreak
|
||
|
|
||
8 months ago
|
### 2. Database creation
|
||
8 months ago
|
|
||
8 months ago
|
#### Alternative 1 - use test data
|
||
8 months ago
|
|
||
|
To generate a development database and perform user setup you can run a local test with instructions
|
||
|
below to generate sample data. Then copy the test database, rename it to `-dev` as below:\
|
||
|
`cp ../endorser-ch-test-local.sqlite3 ../endorser-ch-dev.sqlite3` \
|
||
|
and rerun `npm run dev` to give yourself user #0 and others from the ETHR_CRED_DATA in [the endorser.ch test util file](https://github.com/trentlarson/endorser-ch/blob/master/test/util.js#L90)
|
||
|
|
||
8 months ago
|
#### Alternative 2 - boostrap single seed user
|
||
|
|
||
|
In this method you will end up with two accounts in the database, one for the first boostrap user,
|
||
|
and the second as the primary user you will use during testing. The first user will invite the
|
||
|
second user to the app.
|
||
|
|
||
|
1. Install dependencies and environment variables.\
|
||
|
In endorser-ch install dependencies and set up environment variables to allow starting it up in
|
||
|
development mode.
|
||
|
```bash
|
||
|
cd endorser-ch
|
||
|
npm clean install # or npm ci
|
||
|
cp .env.local .env
|
||
|
```
|
||
|
Edit the .env file's INFURA_PROJECT_ID with the value you saved earlier in the
|
||
|
prerequisites.\
|
||
|
Then create the SQLite database by running `npm run flyway migrate` with environment variables
|
||
|
set correctly to select the default SQLite development user as follows.
|
||
|
```bash
|
||
|
export NODE_ENV=dev
|
||
|
export DBUSER=sa
|
||
|
export DBPASS=sasa
|
||
|
npm run flyway migrate
|
||
|
```
|
||
|
The first run of flyway migrate may take some time to complete because the entire Flyway
|
||
|
distribution must be downloaded prior to executing migrations.
|
||
8 months ago
|
|
||
8 months ago
|
Successful output looks similar to the following:
|
||
|
|
||
|
```
|
||
|
Database: jdbc:sqlite:../endorser-ch-dev.sqlite3 (SQLite 3.41)
|
||
|
Schema history table "main"."flyway_schema_history" does not exist yet
|
||
|
Successfully validated 10 migrations (execution time 00:00.034s)
|
||
|
Creating Schema History table "main"."flyway_schema_history" ...
|
||
|
Current version of schema "main": << Empty Schema >>
|
||
|
Migrating schema "main" to version "1 - initial-anew"
|
||
|
Migrating schema "main" to version "2 - registration"
|
||
|
Migrating schema "main" to version "3 - plan project"
|
||
|
Migrating schema "main" to version "4 - offer gave"
|
||
|
Migrating schema "main" to version "5 - more confirmations"
|
||
|
Migrating schema "main" to version "6 - providers urls"
|
||
|
Migrating schema "main" to version "7 - hash nonce"
|
||
|
Migrating schema "main" to version "8 - project location"
|
||
|
Migrating schema "main" to version "9 - plan links"
|
||
|
Migrating schema "main" to version "10 - gift or trade"
|
||
|
Successfully applied 10 migrations to schema "main", now at version v10 (execution time 00:00.043s)
|
||
|
A Flyway report has been generated here: /Users/kbull/code/timesafari/endorser-ch/report.html
|
||
|
```
|
||
8 months ago
|
|
||
|
\pagebreak
|
||
|
|
||
8 months ago
|
2. Generate the first user in TimeSafari PWA and bootstrap that user in Endorser's database.\
|
||
|
As TimeSafari is an invite-only platform the first user must be manually bootstrapped since
|
||
|
no other users exist to be able to invite the first user. This first user must be added manually
|
||
|
to the SQLite database used by Endorser. In this setup you generate the first user from the PWA.
|
||
|
|
||
|
This user is automatically generated on first usage of the TimeSafari PWA. Bootstrapping that
|
||
|
user is required so that this first user can register other users.
|
||
8 months ago
|
- Change directories into `crowd-funder-for-time-pwa`
|
||
8 months ago
|
|
||
8 months ago
|
```bash
|
||
|
cd ..
|
||
|
cd crowd-funder-for-time-pwa
|
||
|
```
|
||
8 months ago
|
|
||
|
- Ensure the `.env.development` file exists and has the following values:
|
||
|
|
||
|
```env
|
||
|
VITE_DEFAULT_ENDORSER_API_SERVER=http://127.0.0.1:3000
|
||
|
```
|
||
|
|
||
8 months ago
|
- Install dependencies and run in dev mode. For now don't worry about configuring the app. All we
|
||
|
need is to generate the first root user and this happens automatically on app startup.
|
||
8 months ago
|
|
||
8 months ago
|
```bash
|
||
|
npm clean install # or npm ci
|
||
|
npm run dev
|
||
|
```
|
||
8 months ago
|
|
||
|
- Open the app in a browser and go to the developer tools. It is recommended to use a completely
|
||
|
separate browser profile so you do not clear out your existing user account. We will be
|
||
|
completely resetting the PWA app state prior to generating the first user.
|
||
|
|
||
|
In the Developer Tools go to the Application tab.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/b1eaa/b1eaa63e70dfd1f9ce186d20d391bea0d22add34" alt=""{width=350px}
|
||
|
|
||
|
Click the "Clear site data" button and then refresh the page.
|
||
|
|
||
|
- Click the account button in the bottom right corner of the page.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/8b283/8b283aee953768109019d405fbc13fdef4cfd0b0" alt=""{width=150px}
|
||
|
|
||
|
- This will take you to the account page titled "Your Identity" on which you can see your DID,
|
||
|
a `did:ethr` DID in this case.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/957ab/957abc668e820eaf328e73ba854947ced41c2417" alt=""{width=350px}
|
||
|
|
||
|
- Copy the DID by selecting it and copying it to the clipboard or by clicking the copy and paste
|
||
|
button as shown in the image.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/de8e0/de8e0b4b322c59903d59c76f9bfac8c7b6c5a16d" alt=""{width=200px}
|
||
|
|
||
|
In our case this DID is:\
|
||
|
`did:ethr:0xe4B783c74c8B0e229524e44d0cD898D272E02CD6`
|
||
|
|
||
|
- Add that DID to the following echoed SQL statement where it says `YOUR_DID`
|
||
|
|
||
|
```bash
|
||
|
echo "INSERT INTO registration (did, maxClaims, maxRegs, epoch)
|
||
|
VALUES ('YOUR_DID', 100, 10000, 1719348718092);"
|
||
|
| sqlite3 ./endorser-ch-dev.sqlite3
|
||
|
```
|
||
|
|
||
|
and run this command in the parent directory just above the `endorser-ch` directory.
|
||
|
|
||
|
It needs to be the parent directory of your `endorser-ch` repository because when
|
||
|
`endorser-ch` creates the SQLite database it depends on it creates it in the parent directory
|
||
|
of `endorser-ch`.
|
||
|
|
||
|
- You can verify with an SQL browser tool that your record has been added to the `registration`
|
||
|
table.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/23b35/23b35e5cf72f2c575a6a6d27b734fd0d588877a2" alt=""{width=350px}
|
||
8 months ago
|
|
||
8 months ago
|
3. Then start the Endorser service in development mode with the following commands.
|
||
|
|
||
8 months ago
|
```bash
|
||
8 months ago
|
cd ./endorser-ch
|
||
8 months ago
|
export NODE_ENV=dev
|
||
|
npm run dev
|
||
|
```
|
||
8 months ago
|
|
||
|
This starts the Endorser service on port 3000.
|
||
|
4. Create the second user by opening up a separate browser profile or incognito session, opening the
|
||
|
TimeSafari PWA at `http://localhost:8080`. You will see the yellow banner stating "Someone must
|
||
|
register you before you can give or offer."
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/a07fd/a07fd3c032732bc72374a32d8e5c7cad00175059" alt=""{width=350px}
|
||
|
|
||
|
- If you want to ensure you have a fresh user account then open the developer tools, clear the
|
||
|
Application data as before, and then refresh the page. This will generate a new user in the
|
||
|
browser's IndexedDB database.
|
||
|
5. Go to the second users' account page to copy the DID.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/e824c/e824c7a433b82edd5d133a8a04d38c6df4a64cf1" alt=""{width=350px}
|
||
|
|
||
|
6. Copy the DID and put it in the text bar on the "Your Contacts" page for the first account
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/12bff/12bff2ef2951e91c6b0fe251d012ccdfa8cd2a5d" alt=""{width=350px}
|
||
|
|
||
|
7. Click the "+" plus icon to add the user.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/f5a8d/f5a8df06dc63703b8f74e7a893136841e22ddeef" alt=""{width=350px}
|
||
|
|
||
|
8. Then click the register button to register the second user.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/cb757/cb757b347fa9c3daceb950e1ce420ad8c097bfad" alt=""{width=350px}
|
||
|
|
||
|
9. Click "YES" on the dialog that shows up.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/6c30f/6c30f9abb34be0a9dc7327386b765902c10f7e63" alt=""{width=350px}
|
||
|
|
||
|
After this a notification will pop up indicating whether registration was successful or not.
|
||
|
|
||
|
10. You have finished the initial set up of users.
|