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.
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.
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.
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:
- Find or create an issue describing a need or problem that needs to be solved.
- [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.
- Create a thread on the issue to discuss your proposal and bounty.
- 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.
- Review and revise the proposal with the maintainers.
- Flipstarter team pays the bounty from public donations only after a successful review, revision and merge process.
- Create a Merge/Pull Request with the proposed changes.
- Work with maintainers to review and revise the proposed changes.
- Maintainers merge changes if/when they meet Flipstarter needs.
HTML files are located in /views/
.
These are located in /static/
, in their respective folder.
To edit the main application script, edit /source.js
and run /webpack.sh
to process it.
application.js
directly
There are multiple ways to do this.
- Use Digital Ocean Marketplace
- Use a NodeJS image and serve
server.js
on port 80 or 443. You can also use a process manager like pm2 - 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
.
If you deployed the app via Digital Ocean Marketplace (method 1), follow the steps:
- Point your domain name (or subdomain) to the IP address of the host using an "A" record. See instructions for NameCheap, Cloudflare or GoDaddy.
- 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:
- Install Nginx, Apache or similar software.
- 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
). - Create a reverse proxy to serve port 3000 via Nginx/Apache.
- Install certbot and run it according to your OS and web server.