🎧☁️ Modern Music Server and Streamer compatible with Subsonic/Airsonic
Go to file
Deluan 757e1992d7 Bare bones getMusicDirectory for albums! 2016-03-02 23:15:17 -05:00
api Bare bones getMusicDirectory for albums! 2016-03-02 23:15:17 -05:00
conf Bare bones getMusicDirectory for albums! 2016-03-02 23:15:17 -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 Bare bones getMusicDirectory for albums! 2016-03-02 23:15:17 -05:00
persistence Bare bones getMusicDirectory for albums! 2016-03-02 23:15:17 -05:00
scanner Bare bones getMusicDirectory for albums! 2016-03-02 23:15:17 -05:00
tests Bare bones getMusicDirectory for albums! 2016-03-02 23:15:17 -05:00
utils go fmt 2016-03-02 13:18:39 -05:00
.gitignore Retrofitting with tests 2016-02-29 10:04:30 -05:00
.gopmfile Fixed AlbumId generation. Some code cleanup 2016-03-01 09:17:28 -05:00
.travis.yml Missing inject lib on CI 2016-03-01 12:47:13 -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