diff --git a/CHANGELOG.md b/CHANGELOG.md index 417035e2f..3d3077c2f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -107,6 +107,7 @@ changes. - Extend the eslint config to apply to the style guide of the project [Issue 514](https://github.com/IntersectMBO/govtool/issues/514) - Update frontend package readme to reflect recent changes [Issue 543](https://github.com/IntersectMBO/govtool/issues/543) - Change input selection strategy to 3 (random) [Issue 575](https://github.com/IntersectMBO/govtool/issues/575) +- Changed documents to prepare for open source [Issue 737](https://github.com/IntersectMBO/govtool/issues/737) ### Removed diff --git a/CODE-OF-CONDUCT.md b/CODE-OF-CONDUCT.md index 8ceedd39a..0e110ce14 100644 --- a/CODE-OF-CONDUCT.md +++ b/CODE-OF-CONDUCT.md @@ -60,7 +60,7 @@ representative at an online or offline event. Instances of abusive, harassing, or otherwise unacceptable behavior may be reported to the community leaders responsible for enforcement at -[XXXX@intersectmbo.org](XXXX@intersectmbo.org). +[oso@intersectmbo.org](oso@intersectmbo.org). All complaints will be reviewed and investigated promptly and fairly. All community leaders are obligated to respect the privacy and security of the diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index a6e724ba7..b348e3850 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,5 +1,12 @@ # Contributing to the `GovTool` project +⚠️ This is a work in progress document, more instruction on how-to contribute to come! + +Contributing todo: +- [ ] Align with latest OSC policies +- [ ] Refactor to reflect reality +- [ ] Make more friendly to open source contributors + Thanks for considering contributing and helping us on creating GovTool! 😎 The best way to contribute right now is to try things out and provide feedback, but we also accept contributions to the documentation and the obviously to the code itself. diff --git a/README.md b/README.md index 5fe34a9ff..ba9b51eeb 100644 --- a/README.md +++ b/README.md @@ -25,27 +25,19 @@ Learn more; [docs.sanchogov.tools](https://docs.sanchogov.tools/). - [GovTool Backend](./govtool/backend/README.md) - [GovTool Frontend](./govtool/frontend/README.md) -- [GovTool deployment setup](./scripts/govtool/README.md) +- [GovTool Infrastructure](./infra/) - [Documentation](./docs/) - [Tests](./tests/) ### Utilities -- [Governance Action Loader](./src/governance-action-loader/) - -## 🔩 Architecture - -GovTool consists of a Haskell backend and a React Typescript frontend. +- [Governance Action Loader](./governance-action-loader/) ### Backend GovTool backend implements an API wrapper around an instance of [DB-Sync](https://github.com/IntersectMBO/cardano-db-sync) which interfaces with a [Cardano Node](https://github.com/IntersectMBO/cardano-node). The API exposes endpoints making the querying of governance related data from DB-Sync straight forward. -#### API Reference - -[`Swagger documentation`](https://sanchogov.tools/api/swagger-ui/) - ### Frontend GovTool frontend web app communicates with the backend over a REST interface, reading and displaying on-chain governance data. @@ -54,4 +46,7 @@ Frontend is able to connect to Cardano wallets over the [CIP-30](https://github. ## 🤝 Contributing Thanks for considering contributing and helping us on creating GovTool! 😎 + +⚠️ We are in the process of improving our contributing documentation, improvements to come. + Please checkout our [Contributing Documentation](./CONTRIBUTING.md). diff --git a/SECURITY.md b/SECURITY.md index b7cf16805..208b4756c 100644 --- a/SECURITY.md +++ b/SECURITY.md @@ -2,7 +2,7 @@ ## Reporting a Vulnerability -Please report (suspected) security vulnerabilities to [XXXX@intersectmbo.org](XXXX@intersectmbo.org). +Please report (suspected) security vulnerabilities to [oso@intersectmbo.org](oso@intersectmbo.org). You will receive a response from us within 48 hours. If the issue is confirmed, we will release a patch as soon as possible. diff --git a/docs/architecture/.gitignore b/docs/architecture/.gitignore deleted file mode 100644 index 3434d617e..000000000 --- a/docs/architecture/.gitignore +++ /dev/null @@ -1,10 +0,0 @@ -# arch structurizr -arch-structurizr/.structurizr -arch-structurizr/workspace.json - -#other -.vscode - -#oura install -oura/ -./oura/ diff --git a/docs/architecture/arch-structurizr/README.md b/docs/architecture/arch-structurizr/README.md deleted file mode 100644 index da08652d9..000000000 --- a/docs/architecture/arch-structurizr/README.md +++ /dev/null @@ -1,28 +0,0 @@ -# Voltaire dApp Architecture Documentation - -## Architecture as code - -- Describe the architecture logically with a domain specific language and generate all the diagrams -with different levels of details based on the C4Model (Context, Containers, Components, Code). -- Accompanied diagrams with documentation setting the project within its environment. - -## How to Run - -```bash -docker-compose up -``` - -## Diagrams -```bash -http://localhost:8080/workspace/diagrams -``` - -## Documentation -```bash -http://localhost:8080/workspace/documentation/* -``` - -## Decision Log -```bash -http://localhost:8080/workspace/decisions/* -``` diff --git a/docs/architecture/arch-structurizr/dapp.dsl b/docs/architecture/arch-structurizr/dapp.dsl deleted file mode 100644 index a1b1795bd..000000000 --- a/docs/architecture/arch-structurizr/dapp.dsl +++ /dev/null @@ -1,79 +0,0 @@ - -user = person "ADA Holder" "😀" - -userDRep = person "dRep" "😎" -userCCMember = person "CC Member" "🧐" -userSPO = person "SPO" "🤠" - -userGovActSub = person "Gov Action Submitter" "😛" - -browser = softwareSystem "Browser" "Firefox, Chrome, Safari, Edge" "Browser" - -cardanoWallet = softwareSystem "Cardano Wallet" "" "Owned by Other Entities" - -hwWallet = softwareSystem "HW Wallet" "Cardano Hardware Wallet" "Owned by Other Entities" - -group "CardanoWorld" { - cardanoNode = softwareSystem "CardanoNode" - cardanoCLI = softwareSystem "cardano-cli Tool" - cardanoCLI -> cardanoNode "uses" -} - -group "Somewhere?" { - metadataServer = softwareSystem "dRep/Governance Action Metadata Server" "Off chain metadata storage used to fetch metadata from dRep registrations + governance actions that happen on chain" "" -} - -# group "Community Tooling" { -# communityFE = softwareSystem - -# } - - -group "Owned by Gov Analysis Squad"{ - dAppFrontEnd = softwareSystem "Voltaire dApp Frontend" "Web App" "" { - walletConnector = container "walletConnector" "" "" "" - httpClient = container "HTTP Client" "" "" "" - - walletConnector -> cardanoWallet "(dAPP CONNECTOR CIP) \nPOST /drep-reg/ \nPOST /vote\nPOST /drep-ret/\n GET /stake-key/ " - - } - - dAppBackEnd = softwareSystem "Voltaire dApp Backend" "HTTP Service in front of a chain follower and DB" { - - database = container "Database" "" "Some Database" "Database" - voltaireAPI = container "Voltaire DB API" "REST API that offers the ability for clients to find Voltaire related chain data" "" - chainFollower = container "Chain Follower" "Follows the Cardano chain, reduces data, sinks it a store" "txpipe/oura" - txValidationService = container "Validation Service" "Consumes ordered events read from the sink, validates the transactions and when valid stores in store" "" - kafka = container "Message Broker" "Message / Event broker" "apache/kafka" "Message Broker" - - chainFollower -> cardanoNode "follows" - chainFollower -> chainFollower "applyFilter(rawBlock)" - chainFollower -> kafka "sink filtered dapp registration" - kafka -> txValidationService "consumes dapp registrations" - txValidationService -> metadataServer "GET /gov-act-meta" - txValidationService -> database "stores dapp registrations" - voltaireAPI -> database "reads" - - dAppFrontEnd.httpClient -> voltaireAPI "GET /dreps \nGET /gov-act" - - dAppFrontEnd.httpClient -> metadataServer "GET /gov-metadata" - } -} - -user -> browser "uses" -userDRep -> browser "uses" -userDRep -> metadataServer "POST /drep-meta/" -userSPO -> cardanoCLI "uses" -userCCMember -> cardanoCLI "uses" - -userGovActSub -> metadataServer "POST /gov-act-meta/" - -# userGovActSub -> cardanoCLI "POST /gov-act/" - -browser -> dAppFrontEnd "connects" - -// Light wallet and HW wallet -hwWallet -> cardanoWallet "integrates" - -// User's browser attaches to GVC FE -browser -> dAppFrontEnd "connects" diff --git a/docs/architecture/arch-structurizr/decisions/0001-decision b/docs/architecture/arch-structurizr/decisions/0001-decision deleted file mode 100644 index 5673ab07c..000000000 --- a/docs/architecture/arch-structurizr/decisions/0001-decision +++ /dev/null @@ -1,17 +0,0 @@ -# 1. Record architecture decisions - -Date: 2023- - -## Status - -Accepted - -## Context - - - -## Decision - - - -## Consequences diff --git a/docs/architecture/arch-structurizr/docker-compose.yml b/docs/architecture/arch-structurizr/docker-compose.yml deleted file mode 100644 index ad387bf08..000000000 --- a/docs/architecture/arch-structurizr/docker-compose.yml +++ /dev/null @@ -1,10 +0,0 @@ -version: "3.6" - -services: - voltaire-structurizr: - container_name: voltaire-dapp-architecture - image: structurizr/lite:latest - ports: - - '8080:8080' - volumes: - - .:/usr/local/structurizr:rw diff --git a/docs/architecture/arch-structurizr/documentation/documentation.md b/docs/architecture/arch-structurizr/documentation/documentation.md deleted file mode 100644 index 6844a6b12..000000000 --- a/docs/architecture/arch-structurizr/documentation/documentation.md +++ /dev/null @@ -1 +0,0 @@ -## Voltaire Voting App diff --git a/docs/architecture/arch-structurizr/workspace.dsl b/docs/architecture/arch-structurizr/workspace.dsl deleted file mode 100644 index ee4cffc41..000000000 --- a/docs/architecture/arch-structurizr/workspace.dsl +++ /dev/null @@ -1,84 +0,0 @@ -workspace "Voltaire Implementation Draft" { - !docs ./documentation - !adrs ./decisions - !identifiers hierarchical - - model { - !include dapp.dsl - } - - views { - systemLandscape all { - title "Volatire Tech Implementation System Overview [Draft]" - include * - autoLayout lr - } - - systemContext dAppFrontEnd { - include * - autoLayout lr - } - - systemContext dAppBackEnd { - include * - autoLayout lr - } - - container dAppBackEnd { - include * - autolayout lr - } - - container dAppFrontEnd { - include * - autolayout lr - } - - // Colour pallette: https://colorbrewer2.org/#type=sequential&scheme=PuBu&n=4 - styles { - element "Software System" { - background #0570b0 - color #ffffff - shape RoundedBox - } - - element "Container" { - background #74a9cf - color #ffffff - shape RoundedBox - } - - element "Component" { - background #bdc9e1 - color #ffffff - shape RoundedBox - } - - element "Person" { - background #66c2a5 - color #ffffff - shape person - } - - element "Owned by Other Entities" { - background #999999 - color #ffffff - } - - element "Browser" { - background #999999 - color #ffffff - shape WebBrowser - } - - element "Database" { - shape Cylinder - } - } - - branding { - logo  - # font - } - } -} diff --git a/docs/architecture/dapp-arch-v1.1.PNG b/docs/architecture/dapp-arch-v1.1.PNG deleted file mode 100644 index 90ed44335..000000000 Binary files a/docs/architecture/dapp-arch-v1.1.PNG and /dev/null differ diff --git a/docs/architecture/dapp-user-states.PNG b/docs/architecture/dapp-user-states.PNG deleted file mode 100644 index ff04ecf3c..000000000 Binary files a/docs/architecture/dapp-user-states.PNG and /dev/null differ diff --git a/docs/architecture/sequence-diagrams/delegation-status.png b/docs/architecture/sequence-diagrams/delegation-status.png deleted file mode 100644 index 93bc3905e..000000000 Binary files a/docs/architecture/sequence-diagrams/delegation-status.png and /dev/null differ diff --git a/docs/architecture/sequence-diagrams/delegation.png b/docs/architecture/sequence-diagrams/delegation.png deleted file mode 100644 index e6e31ac0b..000000000 Binary files a/docs/architecture/sequence-diagrams/delegation.png and /dev/null differ diff --git a/docs/architecture/sequence-diagrams/drep-registration.png b/docs/architecture/sequence-diagrams/drep-registration.png deleted file mode 100644 index c826e3141..000000000 Binary files a/docs/architecture/sequence-diagrams/drep-registration.png and /dev/null differ diff --git a/docs/architecture/sequence-diagrams/drep-retirement.png b/docs/architecture/sequence-diagrams/drep-retirement.png deleted file mode 100644 index bf3db2611..000000000 Binary files a/docs/architecture/sequence-diagrams/drep-retirement.png and /dev/null differ diff --git a/docs/architecture/sequence-diagrams/drep-status.png b/docs/architecture/sequence-diagrams/drep-status.png deleted file mode 100644 index ada0d9fc3..000000000 Binary files a/docs/architecture/sequence-diagrams/drep-status.png and /dev/null differ diff --git a/docs/architecture/sequence-diagrams/login.png b/docs/architecture/sequence-diagrams/login.png deleted file mode 100644 index 3e8489247..000000000 Binary files a/docs/architecture/sequence-diagrams/login.png and /dev/null differ diff --git a/docs/architecture/sequence-diagrams/raw/delegation-status.txt b/docs/architecture/sequence-diagrams/raw/delegation-status.txt deleted file mode 100644 index 2d7f117de..000000000 --- a/docs/architecture/sequence-diagrams/raw/delegation-status.txt +++ /dev/null @@ -1,11 +0,0 @@ -title Is User Delegator - -participant dApp Frontend -participant Wallet -participant dApp Backend - -dApp Frontend->Wallet: ""API.getActiveStakeKeys()"" -Wallet->dApp Frontend: ""[pubStakeKey]"" - -dApp Frontend->dApp Backend: ""GET delegation/{pubStakeKey} -dApp Backend->dApp Frontend: ""delegationCert"" diff --git a/docs/architecture/sequence-diagrams/raw/delegation.txt b/docs/architecture/sequence-diagrams/raw/delegation.txt deleted file mode 100644 index 689907360..000000000 --- a/docs/architecture/sequence-diagrams/raw/delegation.txt +++ /dev/null @@ -1,13 +0,0 @@ -title Vote Delegation - -participant User -participant dApp Frontend -participant Wallet -participant Cardano Node - -User->dApp Frontend: Enter ""dRepID"" -dApp Frontend->Wallet:""API.submitDelegation(dRepID, PubStakeKey)"" -Wallet->User: Ask permission popup (Wallet UI) -User->Wallet: Access granted (Wallet UI) -Wallet->Cardano Node: Submit transaction: \n""POST /delegation/{delegation-cert} -Wallet->dApp Frontend: ""SignedDelegationCertificate"" diff --git a/docs/architecture/sequence-diagrams/raw/drep-registration.txt b/docs/architecture/sequence-diagrams/raw/drep-registration.txt deleted file mode 100644 index 5e701117f..000000000 --- a/docs/architecture/sequence-diagrams/raw/drep-registration.txt +++ /dev/null @@ -1,15 +0,0 @@ -title DRep Registration - -participant User -participant dApp Frontend -participant Wallet -participant Cardano Node - -User->dApp Frontend: 'Register as a dRep' button pressed -User->dApp Frontend: Supply metadata anchor -dApp Frontend->dApp Frontend: Construct ""DRepRegistrationCertificate"" -dApp Frontend->Wallet: Pass certificate to wallet:\n""API.submitDRepRegistration(DRepRegistrationCertificate)"" -Wallet->User: Ask permission popup (Wallet UI) -User->Wallet: Access granted (Wallet UI) -Wallet->Cardano Node: Submit transaction: \n""POST /registration/{registration-cert} -Wallet->dApp Frontend: ""SignedDRepRegistrationCertificate"" diff --git a/docs/architecture/sequence-diagrams/raw/drep-retirement.txt b/docs/architecture/sequence-diagrams/raw/drep-retirement.txt deleted file mode 100644 index 99a43a9ae..000000000 --- a/docs/architecture/sequence-diagrams/raw/drep-retirement.txt +++ /dev/null @@ -1,14 +0,0 @@ -title DRep Retirement - -participant User (dRep) -participant dApp Frontend -participant Wallet -participant Cardano Node - -User (dRep)->dApp Frontend: 'Retire' button pressed -dApp Frontend->dApp Frontend: Construct ""DRepRetirementCertificate"" -dApp Frontend->Wallet: Pass certificate to wallet:\n""API.submitDRepRetirementCertificate(DRepRetirementCertificate)"" -Wallet->User (dRep): Ask permission popup (Wallet UI) -User (dRep)->Wallet: Access granted (Wallet UI) -Wallet->Cardano Node: Submit transaction: \n""POST /retirement/{retirement-cert} -Wallet->dApp Frontend: ""SignedDRepRetirementCertificate"" diff --git a/docs/architecture/sequence-diagrams/raw/drep-status.txt b/docs/architecture/sequence-diagrams/raw/drep-status.txt deleted file mode 100644 index e668837c8..000000000 --- a/docs/architecture/sequence-diagrams/raw/drep-status.txt +++ /dev/null @@ -1,11 +0,0 @@ -title Is User DRep - -participant dApp Frontend -participant Wallet -participant dApp Backend - -dApp Frontend->Wallet: ""API.getDRepKey()"" -Wallet->dApp Frontend: ""pubDRepKey"" - -dApp Frontend->dApp Backend: ""GET drep/{pubDRepKey} -dApp Backend->dApp Frontend: ""bool"" diff --git a/docs/architecture/sequence-diagrams/raw/login.txt b/docs/architecture/sequence-diagrams/raw/login.txt deleted file mode 100644 index 4a772d98a..000000000 --- a/docs/architecture/sequence-diagrams/raw/login.txt +++ /dev/null @@ -1,36 +0,0 @@ -title User Login - -participant User -participant dApp Frontend -participant Wallet -participant dApp Backend - -note over dApp Frontend: Connect Wallet - -User->dApp Frontend: 'Connect Wallet' Button pressed -dApp Frontend->User: Wallet Selection prompt -User->dApp Frontend: Wallet Selected ""walletName -dApp Frontend->Wallet: ""cardano.{walletName}.enable({"cip": ?}) -Wallet->User: Ask permission popup (Wallet UI) -User->Wallet: Access granted (Wallet UI) -Wallet->dApp Frontend: ""API"" object - -note over dApp Frontend: Identify the user's stake key delegator status -dApp Frontend->Wallet: ""API.getActiveStakeKeys()"" -Wallet->dApp Frontend: ""[pubStakeKey]"" - -dApp Frontend->User: Select ""pubStakeKey"" to use -User->dApp Frontend: Choose which stake key to engage with - -dApp Frontend->dApp Backend: ""GET delegation/{pubStakeKey} -dApp Backend->dApp Frontend: ""delegationCert"" - -note over dApp Frontend: Identify the user's DRep status - -dApp Frontend->Wallet: ""API.getDRepKey()"" -Wallet->dApp Frontend: ""pubDRepKey"" - -dApp Frontend->dApp Backend: ""GET drep/{pubDRepKey} -dApp Backend->dApp Frontend: ""DRepCert"" - -dApp Frontend->User: Serve correct UI diff --git a/docs/architecture/sequence-diagrams/raw/voting.txt b/docs/architecture/sequence-diagrams/raw/voting.txt deleted file mode 100644 index 1767720c7..000000000 --- a/docs/architecture/sequence-diagrams/raw/voting.txt +++ /dev/null @@ -1,16 +0,0 @@ -title DRep Voting - -participant User (dRep) -participant dApp Frontend -participant Wallet -participant Cardano Node - -User (dRep)->dApp Frontend: Select Governance Action + choice -User (dRep)->dApp Frontend: Supply metadata anchor - -dApp Frontend->dApp Frontend: Construct ""Vote"" -dApp Frontend->Wallet: Pass object to wallet:\n""API.submitVote(Vote)"" -Wallet->User (dRep): Ask permission popup (Wallet UI) -User (dRep)->Wallet: Access granted (Wallet UI) -Wallet->Cardano Node: Submit transaction: \n""POST /vote/{vote} -Wallet->dApp Frontend: ""SignedVote"" diff --git a/docs/architecture/sequence-diagrams/raw/wallet-connect.txt b/docs/architecture/sequence-diagrams/raw/wallet-connect.txt deleted file mode 100644 index 6348fbce9..000000000 --- a/docs/architecture/sequence-diagrams/raw/wallet-connect.txt +++ /dev/null @@ -1,13 +0,0 @@ -title Wallet Connection - -participant User -participant dApp Frontend -participant Wallet - -User->dApp Frontend: 'Connect Wallet' Button pressed -dApp Frontend->User: Wallet Selection prompt -User->dApp Frontend: Wallet Selected ""walletName -dApp Frontend->Wallet: ""cardano.{walletName}.enable({"cip": ?}) -Wallet->User: Ask permission popup (Wallet UI) -User->Wallet: Access granted (Wallet UI) -Wallet->dApp Frontend: ""API"" object diff --git a/docs/architecture/sequence-diagrams/voting.png b/docs/architecture/sequence-diagrams/voting.png deleted file mode 100644 index fda17428b..000000000 Binary files a/docs/architecture/sequence-diagrams/voting.png and /dev/null differ diff --git a/docs/architecture/sequence-diagrams/wallet-connect.png b/docs/architecture/sequence-diagrams/wallet-connect.png deleted file mode 100644 index 4f849f7cf..000000000 Binary files a/docs/architecture/sequence-diagrams/wallet-connect.png and /dev/null differ