Go to file
2024-02-22 11:45:35 +07:00
.github/workflows Add github CI for running lint (#5) 2023-12-11 12:04:33 +05:30
.husky Add husky to run pre-commit lint (#3) 2023-12-08 09:59:45 +05:30
.vscode 🔧 chore: add vscode settings to enable tailwind variant intellisense 2024-02-20 23:24:27 +07:00
packages ️ feat: implement toast contexts 2024-02-22 11:45:35 +07:00
.gitignore Implement monorepo with lerna (#1) 2023-12-06 16:07:12 +05:30
.npmrc Publish app deployment record in Laconic registry on creating new deployments (#62) 2024-02-12 11:34:01 +05:30
lerna.json Add husky to run pre-commit lint (#3) 2023-12-08 09:59:45 +05:30
package.json Update instructions and general package cleanup (#29) 2024-02-01 11:37:57 +05:30
README.md Merge remote-tracking branch 'origin/main' 2024-02-21 11:00:14 +07:00
yarn.lock ⚒️ build: add @radix-ui/react-toast 2024-02-22 11:43:31 +07:00

snowballtools

Setup

  • Clone the snowballtools repo

    git clone git@github.com:snowball-tools/snowballtools-base.git
    
  • In root of the repo, install depedencies

    yarn
    
  • Build packages

    yarn build --ignore frontend
    

Backend

  • Change directory to packages/backend

    cd packages/backend
    
  • Load fixtures in database

    yarn test:db:load:fixtures
    
  • Set gitHub.oAuth.clientId and gitHub.oAuth.clientSecret in backend config file

  • Run the laconicd stack following this doc

  • Get the private key and set registryConfig.privateKey in backend config file

    laconic-so --stack fixturenet-laconic-loaded deploy exec laconicd "laconicd keys export mykey --unarmored-hex --unsafe"
    # WARNING: The private key will be exported as an unarmored hexadecimal string. USE AT YOUR OWN RISK. Continue? [y/N]: y
    # 754cca7b4b729a99d156913aea95366411d072856666e95ba09ef6c664357d81
    
  • Get the REST and GQL endpoint ports of Laconicd and replace the ports for registryConfig.restEndpoint and registryConfig.gqlEndpoint in backend config file

    # For registryConfig.restEndpoint
    laconic-so --stack fixturenet-laconic-loaded deploy port laconicd 1317
    # 0.0.0.0:32777
    
    # For registryConfig.gqlEndpoint
    laconic-so --stack fixturenet-laconic-loaded deploy port laconicd 9473
    # 0.0.0.0:32771
    
  • Run the script to create bond, reserve the authority and set authority bond

    yarn test:registry:init
    # snowball:initialize-registry bondId: 6af0ab81973b93d3511ae79841756fb5da3fd2f70ea1279e81fae7c9b19af6c4 +0ms
    
    • Get the bond id and set registryConfig.bondId in backend config file
  • Setup ngrok for GitHub webhooks

    • https://ngrok.com/docs/getting-started/
    • Start ngrok and point to backend server endpoint
      ngrok http http://localhost:8000
      
    • Look for the forwarding URL in ngrok
      ...
      Forwarding                    https://19c1-61-95-158-116.ngrok-free.app -> http://localhost:8000
      ...
      
    • Set gitHub.webhookUrl in backend config file
      ...
      [gitHub]
        webhookUrl = "https://19c1-61-95-158-116.ngrok-free.app"
      ...
      
  • Start the server in packages/backend

    yarn start
    

Frontend

  • Change directory to packages/frontend in a new terminal

    cd packages/frontend
    
  • Copy the graphQL endpoint from terminal and add the endpoint in the .env file present in packages/frontend

    REACT_APP_GQL_SERVER_URL = 'http://localhost:8000/graphql'
    
  • Copy the GitHub OAuth app client ID from previous steps and set it in frontend .env file

    REACT_APP_GITHUB_CLIENT_ID = <CLIENT_ID>
    
  • Set REACT_APP_GITHUB_TEMPLATE_REPO in .env file

    REACT_APP_GITHUB_TEMPLATE_REPO = cerc-io/test-progressive-web-app
    

Development

  • Start the React application

    yarn start
    
  • The React application will be running in http://localhost:3000/

Production

  • Build the React application

    yarn build
    
  • Use a web server for hosting static built files

    python3 -m http.server -d build 3000