[whatwg] createObjectURL(stream) protocol issue

Harald Alvestrand harald at alvestrand.no
Mon Aug 15 06:54:25 PDT 2011


On 08/13/11 01:48, Darin Fisher wrote:
> Putting implementation details aside, I agree that it is a bit unfortunate
> to refer to a stream as a blob.  So far, blobs have always referred to
> static, fixed-size things.
>
> This function was originally named createBlobURL, but it was renamed
> createObjectURL precisely because we imagined it being useful to pass things
> that were not blobs to it.  It seems reasonable that passing a Foo object to
> createObjectURL might mint a different URL type than what we would mint for
> a Bar object.
>
> It could also be the case that using blob: for referring to Blobs was
> unfortunate.  Maybe we do not really need separate URL schemes for static,
> fixed size things and streams.
Back in ancient history (late 90s, I think), when I wrote the first 
version of stuff that eventually merged into RFC 4395, "New URI 
schemes", I thought the set of operations an URI supported was pretty 
important.

In fact the text of RFC 4395 says:

2.4.  Definition of Operations

    As part of the definition of how a URI identifies a resource, a URI
    scheme definition SHOULD define the applicable set of operations that
    may be performed on a resource using the URI as its identifier.  A
    model for this is HTTP; an HTTP resource can be operated on by GET,
    POST, PUT, and a number of other operations available through the
    HTTP protocol.  The URI scheme definition should describe all
    well-defined operations on the URI identifier, and what they are
    supposed to do.

    Some URI schemes don't fit into the "information access" paradigm of
    URIs.  For example, "telnet" provides location information for
    initiating a bi-directional data stream to a remote host; the only
    operation defined is to initiate the connection.  In any case, the
    operations appropriate for a URI scheme should be documented.

    Note: It is perfectly valid to say that "no operation apart from GET
    is defined for this URI".  It is also valid to say that "there's only
    one operation defined for this URI, and it's not very GET-like".  The
    important point is that what is defined on this scheme is described.

So if that consideration is still of concern, the next question is of 
course "are there operations that make sense for a stream that don't 
make sense for (current uses of) blob:, or vice versa"?

If "blob:" was intended to mean "reference to internal object, hand it 
to APIs, the APIs will tell you if they don't like them", that 
consideration may not be that important.

> Hmm...
> -Darin
>
>
>
> On Thu, Aug 11, 2011 at 2:13 AM, Tommy Widenflycht (ᛏᚮᛘᛘᚤ)<
> tommyw at google.com>  wrote:
>
>> Would it be possible to give the associated URL for a mediastream to have
>> its own protocol, for example mediastream:, instead of the proposed blob:?
>>
>> window . URL . createObjectURL(stream)
>> Mints a Blob URL to refer to the given MediaStream.
>>
>>
>> This would tremendously help the implementation.
>>
>> Thanks in advance,
>> Tommy
>>
>>
>> --
>> Tommy Widenflycht, Senior Software Engineer
>> Google Sweden AB, Kungsbron 2, SE-11122 Stockholm, Sweden
>> Org. nr. 556656-6880
>> And yes, I have to include the above in every outgoing email according to
>> EU
>> law.
>>




More information about the whatwg mailing list