August'24: Kamaelia is in maintenance mode and will recieve periodic updates, about twice a year, primarily targeted around Python 3 and ecosystem compatibility. PRs are always welcome. Latest Release: 1.14.32 (2024/3/24)
This component uses HTTP to stream MP3 audio from a SHOUTcast/Icecast server.
IcecastClient fetches the combined audio and metadata stream from the HTTP server hosting the stream. IcecastDemux separates the audio data from the metadata in stream and IcecastStreamWriter writes the audio data to disk (discarding metadata).
Receive an Icecast/SHOUTcast stream, demultiplex it, and write it to a file:
pipeline(
IcecastClient("http://64.236.34.97:80/stream/1049"),
IcecastDemux(),
IcecastStreamWriter("stream.mp3"),
).run()
The SHOUTcast/Icecast protocol is virtually identical to HTTP. As such, IcecastClient subclasses SingleShotHTTPClient modifying the request slightly to ask for stream metadata(e.g. track name) to be included (by adding the icy-metadata header). It is otherwise identical to its parent class.
IcecastClient(starturl) -> Icecast/SHOUTcast MP3 streaming component
Arguments: - starturl -- the URL of the stream
Warning!
You should be using the inbox/outbox interface, not these methods (except construction). This documentation is designed as a roadmap as to their functionalilty for maintainers and new component developers.
Overrides the standard HTTP request with an Icecast/SHOUTcast variant which includes the icy-metadata header required to get metadata with the stream
Splits a raw Icecast stream into A/V data and metadata
Warning!
You should be using the inbox/outbox interface, not these methods (except construction). This documentation is designed as a roadmap as to their functionalilty for maintainers and new component developers.
Convert metadata that was embedded in the stream into a dictionary.
Warning!
You should be using the inbox/outbox interface, not these methods (except construction). This documentation is designed as a roadmap as to their functionalilty for maintainers and new component developers.
Got a problem with the documentation? Something unclear that could be clearer? Want to help improve it? Constructive criticism is very welcome - especially if you can suggest a better rewording!
Please leave you feedback here in reply to the documentation thread in the Kamaelia blog.
-- Automatic documentation generator, 05 Jun 2009 at 03:01:38 UTC/GMT