🎧☁️ Modern Music Server and Streamer compatible with Subsonic/Airsonic
Go to file
Deluan eae9f3168f renamed base_repository to ledis_repository 2016-03-03 20:16:09 -05:00
api Adding a "placeholder" to getUser.view endpoint 2016-03-03 18:44:39 -05:00
conf Adding a "placeholder" to getUser.view endpoint 2016-03-03 18:44:39 -05:00
consts Implemented ProperyRepository. Now the Scanner stores the LastScan timestamp 2016-03-01 14:40:26 -05:00
controllers go fmt 2016-03-02 13:18:39 -05:00
domain Implemented common parameter validation 2016-03-03 14:20:45 -05:00
persistence renamed base_repository to ledis_repository 2016-03-03 20:16:09 -05:00
scanner Converted scanner to a proper Import "class", to facilitate testing 2016-03-03 20:01:27 -05:00
static getCoverArt.view working 2016-03-03 12:08:44 -05:00
tests getCoverArt.view working 2016-03-03 12:08:44 -05:00
utils Fixed a problem with the injection code 2016-03-03 13:14:05 -05:00
.gitignore Implementing coverArt 2016-03-03 10:34:17 -05:00
.gopmfile Implementing coverArt 2016-03-03 10:34:17 -05:00
.travis.yml Implementing coverArt 2016-03-03 10:34:17 -05:00
LICENSE Adding Apache 2.0 license 2016-02-25 16:28:03 -05:00
README.md README 2016-02-29 14:16:51 -05:00
main.go go fmt 2016-03-02 13:18:39 -05:00

README.md

GoSonic

Build Status

About

This is still a work in progress, and has no releases available

GoSonic is an application that implements the Subsonic API, but instead of having its own music library like the original Subsonic application, it interacts directly with your iTunes library.

The project's main goals are:

  • Full compatibility with the available Subsonic clients (only being tested with DSub and Jamstash)
  • Use all metadata from iTunes, so that you can keep using iTunes to manage your music
  • Keep iTunes stats (play counts, last played dates, ratings, etc..) updated, at least on Mac OS X
  • Learning Go ;) Gopher

Supported Subsonic API version:

Version Notes
1.0.0 In Progress

Development Environment

You will need to install Go 1.6

Then install dependencies:

$ go get github.com/beego/bee   
$ go get github.com/gpmgo/gopm
$ gopm get -v -g

From here it's a normal BeeGo development cycle. Some useful commands:

# Start local server (with hot reload)
$ bee run

# Start test runner on the browser
$ NOLOG=1 goconvey --port 9090

# Run all tests
$ go test ./... -v

Frameworks/Projects

REST/Web

DB

Testing