A Go client for OpenSubtitles.
This project allows you to search and download subtitles from OpenSubtitles. It
comes both as a command-line program, and a library that you can use from other
programs.
If you need to search or download subtitles, then you should find what you need
from the latest releases, otherwise the TODO
section highlights what remains to be done regarding API coverage.
Installation
If you want to compile the CLI interface for OpenSubtitles, then install the
latest Go release, and run:
go get github.com/oz/osdb && go install github.com/oz/osdb/cmd/osdb
Provided that you setup your Go environment correctly, you now have a basic
osdb
command to interact with OpenSubtitles' API.
$ osdb help
Search and download subtitles from the command-line.
Usage:
osdb
osdb [command]
Available Commands:
get Get subtitles for a file
hash Shows OSDB hash for file.
help Help about any command
imdb Search IMDB
put Upload subtitles for a file
version Print the version number of osdb
Use "osdb [command] --help" for more information about a command.
Hence, to download French subtitles for a sample file:
$ osdb get -l fra sample.avi
- Getting fra subtitles for file: sample.avi
- No subtitles found!
- Getting eng subtitles for file: sample.avi
- Downloading to: sample.srt
Hack...
The generated documentation for this package is available at:
http://godoc.org/github.com/oz/osdb
To get started...
- Install with
go get -d github.com/oz/osdb
, - and import
"github.com/oz/osdb"
in your Go code, - or try some of the examples in the README.
To access the OpenSubtitles' XML-RPC server you first need to allocate a
client, and then use it to login (even anonymously) in order to receive a
session token. With that, you are finally be allowed to talk. Here is a short
example:
package main
import "github.com/oz/osdb"
func main() {
c, err := osdb.NewClient()
if err != nil {
}
if err = c.LogIn("", "", ""); err != nil {
}
}
Basic examples
Getting a user session token
Although this library tries to be simple, to use OpenSubtitles' API you need to
login first so as to receive a session token: without it you will not be able
to call any API method.
c, err := osdb.NewClient()
if err != nil {
}
if err = c.LogIn("user", "password", "language"); err != nil {
}
However, you do not need to register a user. To login anonymously, just leave
the user
and password
parameters blank:
c.LogIn("", "", "")
Searching subtitles
Subtitle search can be done in a number of ways: using special file-hashes,
IMDB movie IDs, or even using full-text queries. Hash-based search will
generally yield the best results, so this is what is demoed next. However, in
order to search with this method, you must have a movie file to hash.
path := "/path/to/movie.avi"
languages := []string{"eng"}
res, err := client.FileSearch(path, languages)
if err != nil {
}
for _, sub := range res {
fmt.Printf("Found %s subtitles file \"%s\" at %s\n",
sub.LanguageName, sub.SubFileName, sub.ZipDownloadLink)
}
Downloading subtitles
Let's say you have just made a search, for example using FileSearch()
, and as
the API provided a few results, you decide to pick one for download:
subs, err := c.FileSearch(...)
if err := c.Download(&subs[0]); err != nil {
}
if err := c.DownloadTo(&subs[0], "safer-name.srt"); err != nil {
}
Checking if a subtitle exists
Before trying to upload an allegedly "new" subtitles file to OSDB, you should
always check whether they already have it.
As some movies fit on more than one "CD" (remember those?), you will need to
use the Subtitles
type (note the s?), one per subtitle file:
subs := osdb.Subtitles{
{
SubHash: subHash,
SubFileName: subFileName,
MovieHash: movieHash,
MovieByteSize: movieByteSize,
MovieFileName: movieFileName,
},
}
Then simply feed that to HasSubtitles
, and you will be done.
found, err := c.HasSubtitles(subs)
if err != nil {
}
Hashing a file
OSDB uses a custom checksum-hash to identify movie files. If you ever need
these:
hash, err := osdb.Hash("somefile.avi")
if err != nil {
}
fmt.Println("hash: %x\n", hash)
On user agents...
If you have read OSDB's developer documentation, you should notice that
you need to register an "official" user agent in order to use their API.
By default this library will present itself with the "osdb-go" agent, which is
fine for me. However, if you need to change this, simply set the client's
UserAgent
with:
c, err := osdb.NewClient()
if err != nil {
}
c.UserAgent = "My custom user agent"
TODO
License
BSD, see the LICENSE file.