πClient
Last updated
Last updated
The Client consists of the Front End, which is written in Typescript and hosted using Firebase Hosting. This is a Firebase web application and directly reads and writes to the underlying backend Firestore.
The Front End is open sourced at the tnc-br github organization.
The client contains the following functionality
TimberID uses built in Firebase functionality to sign up with Google or email/password.
signInWithEmailAndPassword is built into Firebase as are GoogleAuthProvider.
Users must choose an Organization when they sign in, which determines what data they see.
Security Rules are described in depth in the Server section.
User data and permissions are stored in the "users" collection in Firestore. Each user has their own document where the document ID is the user's Firebase auth user ID making it easy to know which document to fetch when checking which permissions a user has. The following data is stored for each user:
We know what a user's permissions are based on the role they have. A member can only create/view/edite samples in their organization. An admin is an org admin and has full control of all aspects of their organization including approving new members, promoting other members to admin status, and removing members from their organization. A site_admin has full control of all aspects of the site including approving any member request, removing any member from any org, viewing any sample created on the application, and promoting members or admins to site_admin status.
These roles must be checked when a user attempts to access a page that is meant only for specific user roles. For example the following snippet shows how to check if a user is an admin or site_admin and forwards them away from the page if they aren't.
Even if a user falls through this test without the correct role, the Firestore security rules will make sure they don't see any privileged information however it is best if they don't have access to the pages in the first place. Only an admin has permissions to update the data in a user's user document.
When a new user attempts to join the application their data is added as a new document to the "new_users" collection with the new users firebase auth user ID as the document ID.
When an org admin goes to the "Sign up requests" page, the "new_users" collection is searched for users attempting to join the same organization as the admin and are shown to the admin to be approved/rejected. If a user is approved, a new entry is made for them in the "users" collection with the data shown above.
If a new user attempts to create a new organization when they sign up, their data is added to the "new_orgs" document in the "new_users" collection. These requests are only shown to the site_admin to be approved/rejected.
It's very likely that the list for Species or Municipalities will need to be updated in the future. These can be found below.
Species
State List
List of states in Brazil
Municipalities
List of valid municipalities in Brazil
Translation to Portuguese may be incorrect as the original source of TimberID is english. You can find all translated snippets here.
There also may be cases where the text had never been translated at all. If that happens, you can follow the pattern of another localized snippet and reference translations.json.
For example, meanAnnualPrecipitation is localized in sample_data_input via t('meanAnnualPrecipitation'):
Add your string to translations.json for every language and then use the style above to pull it from the localization table.
You should first install the firebase CLI to manage deployments. This tool allows you to view and test your changes before going live.
The github repository has github actions already configured to generate live previews URLS for all PRs. You can find out more about how these actions were configured here.
Merging code into the Main branch will automatically update the development environment: test.timberid.org.
Before merging a PR to Main, you should have unit tests and manually test with the generated hosted url github actions created for you.
Merging code into the PRD branch will automatically update the production environment.
Before merging code from Main into the PRD branch, you should run through the manual test procedures on test.timberid.org, which should have latest source from the Main branch.
Currently, TimberID.org has two domains
TimerID.org
Production website automatically sync'd to the PRD branch
Test.TimberID.org
Test branch with separate database and functions, automatically sync'd to the main branch
Originally obtained from imaflora. An outstanding item is to query this data dynamically from