Re: [webfinger] feedback for multiple "rel"

Dick Hardt <dick.hardt@gmail.com> Sun, 23 December 2012 01:39 UTC

Return-Path: <dick.hardt@gmail.com>
X-Original-To: webfinger@ietfa.amsl.com
Delivered-To: webfinger@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id D86CB21F8802 for <webfinger@ietfa.amsl.com>; Sat, 22 Dec 2012 17:39:58 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -3.598
X-Spam-Level:
X-Spam-Status: No, score=-3.598 tagged_above=-999 required=5 tests=[AWL=-0.000, BAYES_00=-2.599, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_LOW=-1]
Received: from mail.ietf.org ([64.170.98.30]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id PBXgCBkQEh54 for <webfinger@ietfa.amsl.com>; Sat, 22 Dec 2012 17:39:58 -0800 (PST)
Received: from mail-pb0-f43.google.com (mail-pb0-f43.google.com [209.85.160.43]) by ietfa.amsl.com (Postfix) with ESMTP id DDC5B21F8797 for <webfinger@ietf.org>; Sat, 22 Dec 2012 17:39:57 -0800 (PST)
Received: by mail-pb0-f43.google.com with SMTP id um15so3418139pbc.16 for <webfinger@ietf.org>; Sat, 22 Dec 2012 17:39:54 -0800 (PST)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=x-received:content-type:mime-version:subject:from:in-reply-to:date :cc:message-id:references:to:x-mailer; bh=F1waLTLovyXOxApsUapWBAMAOG2MjlosVSSS6LWJy1Q=; b=Df4UDZSY/B7qhUwUnOSbZcHBi5A4bpetErrBhhWif3b/JVghmNp+pAQ4b5ZgFtZVFT IHRT6ShazRSw+OwFAn8RDLGvcpXKG1NvsjzGk+KZ0vPdaeHyUvnT3JB6S5NTy2F5ukM7 PKfkvRxjqu5Mx8wbfXattQ+mHPzqbW5EBly4ZikxuF6/VCRF2fii8LHsxwftMsn/Lqd+ NWe0nphHdnzTd1AuIfErE7T/+CDt7AAkaBECYGQUoGhzktydV30SDqsLx+lyfLWWJEg2 yBsnLOazBKGlnJo9oknMH19kNqIcGTsgw3ij70RRPURqYPokgIboMkbb0SQXx8OWzCCs bjJw==
X-Received: by 10.66.78.168 with SMTP id c8mr50466194pax.16.1356226794029; Sat, 22 Dec 2012 17:39:54 -0800 (PST)
Received: from [10.0.0.4] (c-24-5-69-173.hsd1.ca.comcast.net. [24.5.69.173]) by mx.google.com with ESMTPS id rq7sm9651325pbc.69.2012.12.22.17.39.51 (version=TLSv1/SSLv3 cipher=OTHER); Sat, 22 Dec 2012 17:39:53 -0800 (PST)
Content-Type: multipart/alternative; boundary="Apple-Mail=_ED55068D-24CA-4B2D-9091-058D82CD29CF"
Mime-Version: 1.0 (Mac OS X Mail 6.2 \(1499\))
From: Dick Hardt <dick.hardt@gmail.com>
In-Reply-To: <004d01cde0ad$175b5d00$46121700$@packetizer.com>
Date: Sat, 22 Dec 2012 17:39:49 -0800
Message-Id: <57CE8BD9-286D-460E-92D8-E4E64C3377D0@gmail.com>
References: <58036BAD-2161-4420-A724-343883F627B7@gmail.com> <CAKaEYhKGP0aMxsStNxTfYy3D=TbrnwtCVNz3yF3Su0TVkBXrOQ@mail.gmail.com> <7E9916BF-8D64-4F61-A40F-3A74533AEFD2@gmail.com> <001101cde0a0$7fda6220$7f8f2660$@packetizer.com> <CABP7RbcswbV=38LVZJobn5m6jJFW5N_a1O+8BkXu-S5+ixyKNA@mail.gmail.com> <004d01cde0ad$175b5d00$46121700$@packetizer.com>
To: "Paul E. Jones" <paulej@packetizer.com>
X-Mailer: Apple Mail (2.1499)
Cc: webfinger@ietf.org, 'James M Snell' <jasnell@gmail.com>, 'nov matake' <matake@gmail.com>, 'Melvin Carvalho' <melvincarvalho@gmail.com>
Subject: Re: [webfinger] feedback for multiple "rel"
X-BeenThere: webfinger@ietf.org
X-Mailman-Version: 2.1.12
Precedence: list
List-Id: Discussion of the Webfinger protocol proposal in the Applications Area <webfinger.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/webfinger>, <mailto:webfinger-request@ietf.org?subject=unsubscribe>
List-Archive: <http://www.ietf.org/mail-archive/web/webfinger>
List-Post: <mailto:webfinger@ietf.org>
List-Help: <mailto:webfinger-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/webfinger>, <mailto:webfinger-request@ietf.org?subject=subscribe>
X-List-Received-Date: Sun, 23 Dec 2012 01:39:59 -0000

FYI: multiple query string params with the same name are turned into arrays or parsed into arrays in node.js

the following script:

var querystring = require('querystring')
console.log( querystring.parse( 'foo=bar&rel=token1&rel=token2' ) )
console.log( querystring.stringify( {'foo':'bar','rel':['token1','token2']} ) )

outputs:

{ foo: 'bar', rel: [ 'token1', 'token2' ] }
foo=bar&rel=token1&rel=token2

Perhaps Ruby devs should just move to the next cool language? :-)
Seriously though, what does the query string parser do in Ruby?

-- Dick

On Dec 22, 2012, at 5:30 PM, "Paul E. Jones" <paulej@packetizer.com> wrote:

> That depends on where they’re used.  If I tell you the “rel” value is “http://example.com/first one”, I don’t escape that as I write it.  Or are you saying there is text somewhere that already makes that, as written, illegal?
>  
> I’m quite favorable to a space-separated list of rel values in a single rel parameter, too.  I was concerned before that spaces would present an issue, but figured we could either we make spaces illegal in rel values (which we can do since those are fabricated things!) or we double-escape.  My preference is a single escape and a single rel parameter and spaces are illegal in the “rel” values themselves.
>  
> But, the forces that be pushed pretty hard to change from &rel=token1%20token to &rel=token1&rel=token2.  At the end of the day, it makes no difference to me since I just need to know which way to deal with it.
>  
> So Ruby can really only support only a single parameter with a given name?  It will not collect those into an array or anything?
>  
> Paul
>  
> From: James M Snell [mailto:jasnell@gmail.com] 
> Sent: Saturday, December 22, 2012 7:51 PM
> To: Paul E. Jones
> Cc: nov matake; Melvin Carvalho; webfinger@ietf.org
> Subject: Re: [webfinger] feedback for multiple "rel"
>  
> Spaces in rel values are already illegal.. specifically, spaces are disallowed in registered link relations and non-escaped spaces are disallowed in absolute IRI's.. A comma delimited list of rel's is better than multiple individual parameters.. even with the potential need for double encoding.
>  
>  
>  
> 
> On Sat, Dec 22, 2012 at 4:00 PM, Paul E. Jones <paulej@packetizer.com> wrote:
> If we made it a requirement that “rel” values have no spaces (which I would argue is a damn good thing for many reasons) then we would not have to double-encode.
>  
> Paul
>  
> From: webfinger-bounces@ietf.org [mailto:webfinger-bounces@ietf.org] On Behalf Of nov matake
> Sent: Saturday, December 22, 2012 11:12 AM
> To: Melvin Carvalho
> 
> Cc: webfinger@ietf.org
> Subject: Re: [webfinger] feedback for multiple "rel"
>  
> BTW, why double encoding lead "problems with things like canonical urls and search engines"?
> Can you provide more details?
>  
> If 2 rel included, the response would be different than when only 1 rel given.
> So I feel those 2 are not the same, and can be indexed as 2 resources..
>  
> On 2012/12/23, at 0:44, Melvin Carvalho <melvincarvalho@gmail.com> wrote:
>  
> 
>  
> 
> On 22 December 2012 05:48, nov matake <matake@gmail.com> wrote:
> Hi,
> 
> I have a comment for they way to specify multiple "rel" values.
> 
> As a ruby library developer, my main target is rails developers.
> Since rails can't handle multiple same query keys, developers will need to hack query params parser in rails middleware layer.
> I can easily imagine it'll be an annoying part to support webfinger in rails.
> 
> Is the multiple "rel" case can be a space-delimitered (or some other character) strings like multiple redirect_uri in OAuth2?
> Or any reason for putting multiple same keys in query parameters?
> 
> each time you delimit a list, you have to be able to escape the delimiter, which can be a pain and also leads to problems with things like canonical urls and search engines
> 
> can you use mod_rewrite?
>  
> 
> Cheers,
> 
> Nov Matake
> _______________________________________________
> webfinger mailing list
> webfinger@ietf.org
> https://www.ietf.org/mailman/listinfo/webfinger
>  
>  
> 
> _______________________________________________
> webfinger mailing list
> webfinger@ietf.org
> https://www.ietf.org/mailman/listinfo/webfinger
> 
>  
> _______________________________________________
> webfinger mailing list
> webfinger@ietf.org
> https://www.ietf.org/mailman/listinfo/webfinger