我正在尝试实现 SMAPI 服务,但遇到了一些问题。
我构建了一个“假”服务,它为这些端点提供硬编码的响应:
- 获取媒体URI
- 获取最后更新
- 获取媒体元数据
- 获取元数据
- 获取扩展元数据
- 获取会话 ID
我已按照说明添加自定义服务,保持所有功能未选中。
我看到我的 Sonos iPhone 应用程序中列出了我的新测试服务,但是当我选择它时,我看到一个屏幕显示“无法浏览音乐”。
我不确定如何调试正在发生的事情,所以感觉就像我在黑暗中刺伤。我不想投机地做出可能与问题无关的更改 - 这似乎是浪费大量精力的秘诀。
有没有办法查看 Sonos Controller 应用程序(客户端)出现的错误?我查看了http://[device ip]:1400/support/aggregate
日志,但没有看到任何提及我的服务的域名,也没有看到任何似乎相关的内容。
我知道(至少有一些)请求正在影响我的服务,特别是调用getLastUpdate
and getMetadata
。这是日志的输出:
2016-02-23T18:55:24.316373+00:00 app[web.1]: Started POST "/soap/action" for 213.86.218.202 at 2016-02-23 18:55:24 +0000
2016-02-23T18:55:24.316485+00:00 app[web.1]: Started POST "/soap/action" for 213.86.218.202 at 2016-02-23 18:55:24 +0000
2016-02-23T18:55:24.431603+00:00 app[web.1]: Processing by SoapController#get_last_update as HTML
2016-02-23T18:55:24.431611+00:00 app[web.1]: Processing by SoapController#get_last_update as HTML
2016-02-23T18:55:24.438452+00:00 app[web.1]: params.inspect: {}
2016-02-23T18:55:24.438458+00:00 app[web.1]: params.inspect: {}
2016-02-23T18:55:24.447855+00:00 app[web.1]: Rendered vendor/bundle/ruby/2.2.0/gems/wash_out-0.10.0/app/views/wash_out/document/response.builder (7.6ms)
2016-02-23T18:55:24.447907+00:00 app[web.1]: Rendered vendor/bundle/ruby/2.2.0/gems/wash_out-0.10.0/app/views/wash_out/document/response.builder (7.6ms)
2016-02-23T18:55:24.448279+00:00 app[web.1]: Completed 200 OK in 17ms (Views: 9.5ms | ActiveRecord: 0.0ms)
2016-02-23T18:55:24.457801+00:00 app[web.1]: Started POST "/soap/action" for 213.86.218.202 at 2016-02-23 18:55:24 +0000
2016-02-23T18:55:24.448327+00:00 app[web.1]: Completed 200 OK in 17ms (Views: 9.5ms | ActiveRecord: 0.0ms)
2016-02-23T18:55:24.464365+00:00 app[web.1]: Processing by SoapController#get_metadata as HTML
2016-02-23T18:55:24.457861+00:00 app[web.1]: Started POST "/soap/action" for 213.86.218.202 at 2016-02-23 18:55:24 +0000
2016-02-23T18:55:24.464428+00:00 app[web.1]: Processing by SoapController#get_metadata as HTML
2016-02-23T18:55:24.465101+00:00 app[web.1]: params.inspect: {"id"=>"root", "index"=>0, "count"=>100}
2016-02-23T18:55:24.465154+00:00 app[web.1]: params.inspect: {"id"=>"root", "index"=>0, "count"=>100}
2016-02-23T18:55:24.472056+00:00 app[web.1]: Rendered vendor/bundle/ruby/2.2.0/gems/wash_out-0.10.0/app/views/wash_out/document/response.builder (3.4ms)
2016-02-23T18:55:24.472049+00:00 app[web.1]: Rendered vendor/bundle/ruby/2.2.0/gems/wash_out-0.10.0/app/views/wash_out/document/response.builder (3.4ms)
2016-02-23T18:55:24.472248+00:00 app[web.1]: Completed 200 OK in 8ms (Views: 6.9ms | ActiveRecord: 0.0ms)
2016-02-23T18:55:24.472251+00:00 app[web.1]: Completed 200 OK in 8ms (Views: 6.9ms | ActiveRecord: 0.0ms)
任何帮助将不胜感激!
更新 这是使用 SoapUI 对我的假服务发出请求的输出:
getLastUpdate
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:tns="http://www.sonos.com/Services/1.1"> <soap:Body> <tns:getLastUpdateResponse> <getLastUpdateResult> <catalog>Catalog last updated 2016-02-18 11:52:30</catalog> <favorites>User: Rob last updated favorites 2016-02-18 12:01:00</favorites> <pollInterval>30</pollInterval> </getLastUpdateResult> </tns:getLastUpdateResponse> </soap:Body> </soap:Envelope>
getSessionId
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:tns="http://www.sonos.com/Services/1.1"> <soap:Body> <tns:getSessionIdResponse> <getSessionIdResult>user0001</getSessionIdResult> </tns:getSessionIdResponse> </soap:Body> </soap:Envelope>
getMetadata
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:tns="http://www.sonos.com/Services/1.1"> <soap:Body> <tns:getMetadataResponse> <getMetadataResult> <index>0</index> <count>2</count> <total>2</total> <mediaMetadata> <id>some_id_1</id> <title>Title 1</title> <mimeType>audio/mp4</mimeType> <itemType>track</itemType> <displayType>List</displayType> <summary>Summary text 1. Summary text 1. Summary text 1.</summary> <trackMetadata> <artistId/> <artist/> <composerId/> <composer/> <albumId/> <album/> <albumArtURI/> <albumArtistId/> <albumArtist/> <genreId/> <genre/> <duration/> <canPlay/> <canSkip/> <canAddToFavorites/> <rating/> <trackNumber/> </trackMetadata> <streamMetadata></streamMetadata> </mediaMetadata> <mediaMetadata> <id>some_id_2</id> <title>Title 2</title> <mimeType>audio/mp4</mimeType> <itemType>track</itemType> <displayType>List</displayType> <summary>Summary text 2. Summary text 2. Summary text 2.</summary> <trackMetadata> <artistId/> <artist/> <composerId/> <composer/> <albumId/> <album/> <albumArtURI/> <albumArtistId/> <albumArtist/> <genreId/> <genre/> <duration/> <canPlay/> <canSkip/> <canAddToFavorites/> <rating/> <trackNumber/> </trackMetadata> <streamMetadata></streamMetadata> </mediaMetadata> </getMetadataResult> </tns:getMetadataResponse> </soap:Body> </soap:Envelope>
getExtendedMetadata
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:tns="http://www.sonos.com/Services/1.1"> <soap:Body> <tns:getExtendedMetadataResponse> <getExtendedMetadataResult> <mediaMetadata> <id>some_id_1</id> <title>Title 1</title> <mimeType>audio/mp4</mimeType> <itemType>track</itemType> <displayType>List</displayType> <summary>Summary text 1. Summary text 1. Summary text 1.</summary> <trackMetadata> <artistId/> <artist/> <composerId/> <composer/> <albumId/> <album/> <albumArtURI/> <albumArtistId/> <albumArtist/> <genreId/> <genre/> <duration/> <canPlay/> <canSkip/> <canAddToFavorites/> <rating/> <trackNumber/> </trackMetadata> <streamMetadata></streamMetadata> </mediaMetadata> </getExtendedMetadataResult> </tns:getExtendedMetadataResponse> </soap:Body> </soap:Envelope>
getMediaMetadata
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:tns="http://www.sonos.com/Services/1.1"> <soap:Body> <tns:getMediaMetadataResponse> <getMediaMetadataResult> <id/> <title>Fake Track Title</title> <mimeType>audio/mp4</mimeType> <itemType>track</itemType> <displayType/> <summary/> <trackMetadata> <artistId>artist:12345</artistId> <artist>Bach</artist> <composerId/> <composer/> <albumId/> <album/> <albumArtURI>https://sonos.therocketfuel.com/images/istockphoto_1945235_satisfaction.jpg</albumArtURI> <albumArtistId/> <albumArtist/> <genreId/> <genre>Classical</genre> <duration>459</duration> <canPlay>true</canPlay> <canSkip>true</canSkip> <canAddToFavorites>false</canAddToFavorites> <rating/> <trackNumber/> </trackMetadata> <streamMetadata></streamMetadata> </getMediaMetadataResult> </tns:getMediaMetadataResponse> </soap:Body> </soap:Envelope>
getMediaURI
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:tns="http://www.sonos.com/Services/1.1"> <soap:Body> <tns:getMediaURIResponse> <getMediaURIResult>https://sonos.therocketfuel.com/audio/960bpm.m4a</getMediaURIResult> </tns:getMediaURIResponse> </soap:Body> </soap:Envelope>