Skip to content

responsibility-act/boiling-api

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

43 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

boiling-api

spicy hot stuff so spicy oh wow

Build Status Go Report Card GoDoc License

This is the home of the boiling project. Boiling aims to be an open-source software for private trackers.

Goals of the project

  • Develop a music-themed private tracker API as open-source software
  • Have strict abstraction between the API (this project) and any frontend (not this project)
  • Use the chihaya tracker backend
  • Produce well-tested, reliable (and hopefully fast) code
  • (Maybe) Have some fancy plugin architecture so people can extend it (honestly lowest priority for now)

Motivation

Although I always wanted to run a private tracker, I figured it's a lot of risk for a small reward. Even if you developed the coolest tracker ever, you couldn't put it on your CV or maybe even tell your friends about it. Running the infrastructure, managing the community, and doing all that while staying out of sight seems like a time-consuming task.

Nonetheless, I wanted to write a tracker software. After experimenting with a bunch of frameworks, languages, frontend-technologies and whatnot I got fed up with frontend development. So I had the idea of just writing a "backend" for the frontend - an API.

I noticed that most development of tracker software is done behind closed doors, in secret. This might make sense for some features, but is detrimental to the quality of the software in general.

So I came up with the idea of writing the API as an open-source project. I am not running a private tracker with this, I am not writing a frontend for this. I hope that staff of sites who might eventually run this software understand how open-source development works and communicate their ideas with me. This can only work properly if we can keep the development as centralized as possible. If every tracker grabs some alpha release and starts months of development on top of that, the community will not benefit from that work at all.

Technology

  • Language: Go
  • Database: Postgres
  • Transport: JSON
  • Web framework: Iris, for now

State of the project

  • Pre-everything
  • No tracker integration yet
  • Almost nothing is being cached yet
  • Some errors are just spilled to the user
  • Database layer basics somewhat fleshed out, proof-of-concept shows that unit-testing the DB layer works, is not too much work and is useful
  • API layer draft. End-to-end testing of API methods is a little cumbersome but works
  • API permissions draft. They work, but are a bit clumsy, needs fine-tuning
  • There's no classes, only permissions for certain endpoints/methods and certain parameter overrides. Might need to change at some point

Ideas

  • Maybe allow bot accounts?
  • All content is written in markdown and compiled... where?
  • Have own markdown flavor, to make linking easier? (something like :torrent:12345: ?)

FAQ

  • Why is this written in Go??

    Because I cba to write anything well-tested, reliable, and fast in PHP. Go has strong typing, is easy to deploy and runs pretty fast. We get out-of-the-box HTTP/2, a stdlib that does most of what we need and arguably the best tooling for any language available.

  • Why is this just an API??

    Because that way it's much easier to write safe and clean code. We can guarantee that a middleware to check permissions runs for every request. We can ensure that every interaction with the data has to pass through the API. Things like rate limiting or permissions, and input sanitization are trivial to implement.

  • Are you running a private tracker??

    No, I just write this software. Don't send me DMCA notices.

  • Can I test it?

    A public instance will be running at https://api.boiling.rip:8443 at some point, resets every 24 hours or so. You might need an API key in the future. Or just run your own.

  • Is this project affiliated with chihaya?

    No. I think they're doing a great job, which is why I chose their tracker and their contributing guidelines.

  • OMG why is this a music-only tracker??

    We're using a relational database with actual types and structure. No, we're not gonna switch to NoSQL or Mongo or whatever.

API Documentation

Refer to the API documentation draft.

Development

(This applies more and more the closer we get to a v1 release)
We're using pull requests. Adhere to the chihaya contributing guidelines. PRs must pass travis and be reviewed. Versioning will be dealt with when we have a v1 release. No breaking changes then.

License

MIT

About

spicy hot stuff so spicy oh wow

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 96.6%
  • TSQL 3.3%
  • Shell 0.1%