Changes between Version 81 and Version 82 of XMLRPC
- Timestamp:
- 05/11/2015 04:37:51 AM (10 years ago)
Legend:
- Unmodified
- Added
- Removed
- Modified
-
XMLRPC
v81 v82 10 10 11 11 = Instructions = 12 * [wiki:DevReadFirst Read this first] 13 * before using this XML-RPC is vital to have implementation for [wiki:HashSourceCodes OS HASH] 14 * '''API server domain changed''': XML-RPC requests send to '''http://api.opensubtitles.org/xml-rpc''' 15 * From 21.4.2015 we support HTTPS for LogIn() if you need it - you can use '''https://api.opensubtitles.org:443/xml-rpc''', for other methods use standard http to save some resources... 16 * Before developing let us know, we assign useragent to you, empty useragent or unregistered UA will not work. 12 * [wiki:DevReadFirst Read this first] - Before developing let us know, we assign useragent to you, empty useragent or unregistered UA will not work. 13 * before using this XML-RPC is required to have implementation for [wiki:HashSourceCodes OS HASH] 14 * XML-RPC requests send to '''http://api.opensubtitles.org/xml-rpc''', you may be interested in more verbose version of [wiki:XmlRpcIntro XML-RPC methods with examples] 15 * we start support HTTPS, if you need it - you can use '''https://api.opensubtitles.org:443/xml-rpc''' 17 16 * For languages codes, check [http://en.wikipedia.org/wiki/List_of_ISO_639-2_codes ISO639], use '''pb/pob''' for Portuguese (Brazil) - [http://www.opensubtitles.org/addons/export_languages.php Download OS languages table dump] 18 17 * IMDB ID is meant to be NUMBER from link of IMDB movie. Example: http://www.imdb.com/title/tt0133093/ - IMDB ID is '0133093' (removing trailing zero is also OK). … … 21 20 * Handle properly HTTP status codes, sometimes you might get 5xx 22 21 * if you get '''407 Download limit reached''', do not use persistent connections (HTTP keep-alive) and don't download more than 200 subtitles per 24 hour per IP/User. If user wants more, he can [http://www.opensubtitles.org/en/support#vip Donate] 23 * you may be interested in more verbose version of [wiki:XmlRpcIntro XML-RPC methods with examples]24 22 * if you want search uploads by useragent, use this link: http://www.opensubtitles.org/search/sublanguageid-all/useragent-$UserAgent 25 23 * for testing XML-RPC without programming, follow these [wiki:XML-RPC-debugger instructions] 26 24 * please support '''GZIP compression for XML-RPC''' (in your HTTP request should be Accept-Encoding: gzip), it can save around [http://forum.opensubtitles.org/viewtopic.php?f=8&t=14246&p=27911 97.5% of bandwidth], so it is faster, it is better. 27 25 * for '''XML-RPC and HTTP''' request use registered USERAGENT in HTTP HEADERs, invalid UA could result for blocking users. 26 * You can specify preferred language for response also by sending HTTP HEADER "Accept-Language" 28 27 * when downloading subtitles using standard HTTP we added HTTP RESPONSE HEADER: Download-Quota: %d, where %d is number how many subtitles can user still download. 29 28 * it is '''REQUIRED''' that your implementation supports '''!LogIn() with user credentials''' (manually input user and password), because there are quite a lot of IPs, which are proxy (some service providers NAT, Singapore, Iran and others), and there is download limit per IP, so those users will hit limit very soon and OS will be not usable for them. Also there is other important reasons why to support this (VIP membership and so on). Also '''NEVER''' put in your application registered username and password, it might be blocked. 30 29 30 31 31 = Common errors = 32 32 After reviewing database with movie-hashes, we found developers often make these errors 33 * moviebytesize set to low integer, so overflow happens. Don't forget files can be more than 8GB big (8.589.934.592 bytes), so make sure you allocate right variable for moviebytesize !33 * moviebytesize set to low integer, so overflow happens. Don't forget files can be more than 8GB big (8.589.934.592 bytes), so make sure you allocate right variable for moviebytesize (string is OK)! 34 34 * moviehash in 99,999% can not be '0000000000000000' (we are ignoring them now, but it is error) 35 35 * always pass all Method Parameters as string, because some unwanted conversion can occur. For example moviebytesize pass as string "4249049694" and NOT as int 4249049694.