Skip to content

SoftwareVerde/flipstarter

Repository files navigation

Flipstarter

Flipstarter provides a way for any project to engage with potential funders in a way that encourages accountability for projects and fairness for funders.

The Flipstarter team has created these tools for anyone to use. Although we have worked hard to make Flipstarter easy to deploy and reliable to operate, the tools are offered as-is with no expectation of support. If you are not confident about your ability to deploy and manage a Flipstarter-based campaign, we recommend you work with a web developer who can manage everything for you.

Corentin Mercier offers a service here.

Note: Although this repository is called "backend", it currently contains both the backend and frontend code. The code for the Electron Cash plugin is here.

Forks and the Flipstarter Name/Logo

For any fork that puts funding campaigns into the hands of users, it is important for them to understand where their tools are coming from. Therefore, besides the MIT rules as usual:

  • Wherever users can see the name of the project, please use a name different from "Flipstarter". At a minimum, please attach a prefix/suffix to "Flipstarter" or attach a word before/after "Flipstarter".
  • Wherever users can see the logo of the project, please use a logo different from the Flipstarter logo. At a minimum, please significantly change the color scheme of the Flipstarter logo.
  • We would be happy if you include "Powered by Flipstarter" with or without the Flipstarter logo.

Development

Run the NodeJS development server

You need NodeJS installed on your machine, then run:

npm install
npm start

# or on windows:
npm run start-no-debug

And open up localhost:3000 in your browser.

Run the Docker container

You need Docker installed on your machine, then run:

docker build -t flipstarter .
docker volume create flipstarter
docker run -v flipstarter:/app/static/campaigns -p 3000:3000 flipstarter

And open up localhost:3000 in your browser.

Contribute

The Flipstarter team is a group of volunteers, and we welcome contributions.

General guidelines:

  • Submit merge requests for the campaign backend and frontend here.
  • Submit merge requests for the Electron Cash plugin here.
  • Keep each change minimal and self-contained. Note that "minimal" does not always mean small, but usually it does.
  • Avoid mixing moving stuff around with changing stuff. Do changes with renames on their own.
  • Code review is an important part of the development process. Contributors and maintainers should expect constructive communication from each other.
  • In some cases, merge requests are rejected. It is up to the MR author to convince the reviewers that the changes warrant the review effort.

Suggested workflow:

  1. Find or create an issue describing a need or problem that needs to be solved.
  2. [Optional] If you are interested in a bounty, please follow this guideline. Please note that although maintainers try to be realistic about bounty expectations, sometimes MRs are not accepted, and final payout of a bounty depends only on approval and merge of changes.
    1. Create a thread on the issue to discuss your proposal and bounty.
    2. Propose a problem to be solved (any clarification to the issue), the outline of a solution and a bounty.
      • Bounties are only paid in Bitcoin Cash.
      • Bounties are typically denominated in USD.
      • BCH conversion rates are determined at the time of transfer, typically by the Electron Cash wallet's price source.
    3. Review and revise the proposal with the maintainers.
    4. Flipstarter team pays the bounty from public donations only after a successful review, revision and merge process.
  3. Create a Merge/Pull Request with the proposed changes.
  4. Work with maintainers to review and revise the proposed changes.
  5. Maintainers merge changes if/when they meet Flipstarter needs.

Regarding dependency regressions

  • express-sse@0.5.1: Ensure that when updating package or package-lock that the version of express-sse remains at 0.5.1 and does not revert to 0.5.3. Alternatively if express-sse version needs to change, confirm with manual testing that pledges and campaign completion both work. Background: The express-sse dependency has a problem if installed at =0.5.3 or perhaps >0.5.3. An incompatibility happens at runtime and while campaigns are able to start, they are unable to process pledges without intermediate errors, and also completely unable to complete the campaign. See this thread more detail.

Edit front-end

HTML

HTML files are located in /views/.

CSS/images/fonts

These are located in /static/, in their respective folder.

JavaScript (front-end)

To edit the main application script, edit /source.js and run /webpack.sh to process it.

⚠️ Do NOT edit application.js directly ⚠️

add new languages

How you can add new languages

Deploy to production

There are multiple ways to do this.

  1. Use Digital Ocean Marketplace
  2. Use a NodeJS image and serve server.js on port 80 or 443. You can also use a process manager like pm2
  3. Deploy the docker container on port 80 or 443 using the following commands:
# download the latest version of flipstarter
docker pull flipstarter/flipstarter

# create a volume to store the database
docker volume create flipstarter

# run the container on ports 443 and 80
docker run -d --restart always --name flipstarter -v flipstarter:/app/static/campaigns -p 443:3000 -p 80:3000 flipstarter/flipstarter

You can start and stop the container with docker [start/stop] flipstarter.

Add a TLS/SSL certificate

If you deployed the app via Digital Ocean Marketplace (method 1), follow the steps:

  1. Point your domain name (or subdomain) to the IP address of the host using an "A" record. See instructions for NameCheap, Cloudflare or GoDaddy.
  2. Then, access your server via SSH and run the following commands:
sudo add-apt-repository ppa:certbot/certbot
sudo apt-get update
sudo apt-get install python-certbot-nginx
sudo certbot --nginx -d yourdomain.com

Make sure to replace yourdomain.com with your own domain or subdomain. Fill in the information, and select 2 when asked if you want HTTP traffic redirected to HTTPS.

Try reloading your campaign. Your browser should automatically show that the connection to the website is secure.

If you used method 2 or 3:

  1. Install Nginx, Apache or similar software.
  2. Run the Flipstarter Docker container on an available port - for example port 3000 (docker run -d --restart always --name flipstarter -v flipstarter:/app/static/campaigns -p 3000:3000 flipstarter/flipstarter).
  3. Create a reverse proxy to serve port 3000 via Nginx/Apache.
  4. Ensure that the reverse proxy is configured to handle websocket (WSS) requests as well.
  5. Install certbot and run it according to your OS and web server.