<HTML dir=ltr><HEAD><TITLE>Re: [Tdwg-guid] Throttling searches [ Scanned for viruses ]</TITLE>
<META http-equiv=Content-Type content="text/html; charset=unicode">
<META content="MSHTML 6.00.2900.2912" name=GENERATOR><BASE href=https://mbgowa01.mobot.org/exchange/Chuck.Miller/Drafts/RE:%20%5BTdwg-guid%5D%20Throttling%20searches%20%5B%20Scanned%20for%20viruses%20%5D.EML/1_text.htm></HEAD>
<BODY>
<DIV id=idOWAReplyText13565 dir=ltr>
<DIV dir=ltr><FONT face=Arial color=#000000 size=2>This is probably a dumb question and exposes my ignorance, but what if the originating query is actually "Get all LSIDs where&nbsp;Family = Orchidaceae".&nbsp; That seems the more likely scenario to me rather than get one LSID.&nbsp; And that's the one that needs a throttle.&nbsp; </FONT></DIV>
<DIV dir=ltr><FONT face=Arial color=#000000 size=2></FONT>&nbsp;</DIV>
<DIV dir=ltr><FONT face=Arial color=#000000 size=2>Chuck&nbsp; </FONT></DIV></DIV>
<DIV dir=ltr><BR>
<HR tabIndex=-1>
<FONT face=Tahoma size=2><B>From:</B> Sally Hinchcliffe [mailto:S.Hinchcliffe@kew.org]<BR><B>Sent:</B> Mon 6/19/2006 7:01 AM<BR><B>To:</B> roger@tdwg.org<BR><B>Cc:</B> tdwg-guid@mailman.nhm.ku.edu<BR><B>Subject:</B> Re: [Tdwg-guid] Throttling searches [ Scanned for viruses ]<BR></FONT><BR></DIV>
<DIV>
<P><FONT size=2>Hi Roger</FONT> <BR><FONT size=2>Thanks for this ... I _think_ I understand it but Nicky is on leave </FONT><BR><FONT size=2>this week so I won't know if I do or not till after she returns</FONT> </P>
<P><FONT size=2>The system doesn't have to be completely villain proof, just slow </FONT><BR><FONT size=2>down most of the villains so everyone else can get a look in</FONT> <BR><FONT size=2>Sally</FONT> </P>
<P><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; You don't! The LSID resolves to the binding to the getMetadata() method </FONT><BR><FONT size=2>&gt; - which is a plain old fashioned URL. At this point the LSID authority </FONT><BR><FONT size=2>&gt; has done its duty and we are just on a plain HTTP GET call so you can do </FONT><BR><FONT size=2>&gt; whatever you can do with any regular HTTP GET. You could stipulate </FONT><BR><FONT size=2>&gt; another header field or (more simply) give priority service for those </FONT><BR><FONT size=2>&gt; who append a valid user id to the URL (&amp;user_id=12345)</FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; So there is no throttle on resolving the LSID to the getMetadata binding </FONT><BR><FONT size=2>&gt; (which is cheap) but there is a throttle on the actual call to get the </FONT><BR><FONT size=2>&gt; metadata method. Really you need to do this because bad people may be </FONT><BR><FONT size=2>&gt; able to tell from the URL how to scrape the source and bypass the LSID </FONT><BR><FONT size=2>&gt; resolver after the first call anyhow. This is especially true if the URL </FONT><BR><FONT size=2>&gt; contains the IPNI record ID which is likely.</FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; Here is an example using Rod's tester.</FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; <A href="http://linnaeus.zoology.gla.ac.uk/~rpage/lsid/tester/?q=urn:lsid:ubio.org:namebank:11815">http://linnaeus.zoology.gla.ac.uk/~rpage/lsid/tester/?q=urn:lsid:ubio.org:namebank:11815</A></FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; The getMetadata() method for this LSID:</FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt;&nbsp; urn:lsid:ubio.org:namebank:11815</FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; Is bound to this URL:</FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; <A href="http://names.ubio.org/authority/metadata.php?lsid=urn:lsid:ubio.org:namebank:11815">http://names.ubio.org/authority/metadata.php?lsid=urn:lsid:ubio.org:namebank:11815</A></FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; So ubio would just have to give preferential services to calls like this:</FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; <A href="http://names.ubio.org/authority/metadata.php?lsid=urn:lsid:ubio.org:namebank:11815&amp;user_id=rogerhyam1392918790">http://names.ubio.org/authority/metadata.php?lsid=urn:lsid:ubio.org:namebank:11815&amp;user_id=rogerhyam1392918790</A></FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; If rogerhyam had paid his membership fees this year.</FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; Does this make sense?</FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; Roger</FONT> <BR><FONT size=2>&gt; p.s. You could do this on the web pages as well with a clever little </FONT><BR><FONT size=2>&gt; thing to write dynamic tokens into the links so that it doesn't degrade </FONT><BR><FONT size=2>&gt; the regular browsing experience and only stops scrapers - but that is </FONT><BR><FONT size=2>&gt; beyond my remit at the moment ;)</FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; p.p.s. You could wrap this in https if you were paranoid about people </FONT><BR><FONT size=2>&gt; stealing tokens - but this is highly unlikely I believe.</FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; Sally Hinchcliffe wrote:</FONT> <BR><FONT size=2>&gt; &gt; How can we pass a token with an LSID?</FONT> <BR><FONT size=2>&gt; &gt;</FONT> <BR><FONT size=2>&gt; &gt;</FONT> <BR><FONT size=2>&gt; &gt;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt; I think the only way to throttle in these situations is to have some </FONT><BR><FONT size=2>&gt; &gt;&gt; notion of who the client is and the only way to do that is to have some </FONT><BR><FONT size=2>&gt; &gt;&gt; kind of token exchange over HTTP saying who they are. Basically you have </FONT><BR><FONT size=2>&gt; &gt;&gt; to have some kind of client registration system or you can never </FONT><BR><FONT size=2>&gt; &gt;&gt; distinguish between a call from a new client and a repeat call. The use </FONT><BR><FONT size=2>&gt; &gt;&gt; of IP address is a pain because so many people are now behind some kind </FONT><BR><FONT size=2>&gt; &gt;&gt; of NAT gateway.</FONT> <BR><FONT size=2>&gt; &gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt; How about this for a plan:</FONT> <BR><FONT size=2>&gt; &gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt; You could give a degraded services to people who don't pass a token (a 5 </FONT><BR><FONT size=2>&gt; &gt;&gt; second delay perhaps) and offer a quicker service to registered users </FONT><BR><FONT size=2>&gt; &gt;&gt; who pass a token (but then perhaps limit the number of calls they make). </FONT><BR><FONT size=2>&gt; &gt;&gt; This would mean you could offer a universal service even to those with </FONT><BR><FONT size=2>&gt; &gt;&gt; naive client software but a better service to those who play nicely. You </FONT><BR><FONT size=2>&gt; &gt;&gt; could also get better stats on who is using the service.</FONT> <BR><FONT size=2>&gt; &gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt; So there are ways that this could be done. I expect people will come up </FONT><BR><FONT size=2>&gt; &gt;&gt; with a host of different ways. It is outside LSIDs though.</FONT> <BR><FONT size=2>&gt; &gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt; Roger</FONT> <BR><FONT size=2>&gt; &gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt; Sally Hinchcliffe wrote:</FONT> <BR><FONT size=2>&gt; &gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt; It's not an LSID issue per se, but LSIDs will make it harder to slow </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt; searches down. For instance, Google restricts use of its spell </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt; checker to 1000 a day by use of a key which is passed in with each </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt; request. Obviously this can't be done with LSIDs as then they </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt; wouldn't be the same for each user.</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt; The other reason why it's relevant to LSIDs is simply that providing </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt; a list of all relevant IPNI LSIDs (not necessary to the LSID </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt; implementation but a nice to have for caching / lookups for other </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt; systems using our LSIDs) also makes life easier for the datascrapers </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt; to operate</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt; Also I thought ... here's a list full of clever people perhaps they </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt; will have some suggestions </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt; Sally</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; Is this an LSID issue? LSIDs essential provide a binding service between </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; an name and one or more web services (we default to HTTP GET bindings). </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; It isn't really up to the LSID authority to administer any policies </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; regarding the web service but simply to point at it. It is up to the web </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; service to do things like throttling, authentication and authorization.</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; Imagine, for example, that the different services had different </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; policies. It may be reasonable not to restrict the getMetadata() calls </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; but to restrict the getData() calls.</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; The use of LSIDs does not create any new problems that weren't there </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; with web page scraping - or scraping of any other web service.</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; Just my thoughts...</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; Roger</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; Ricardo Scachetti Pereira wrote:</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; Sally,</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; You raised a really important issue that we had not really addressed </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; at the meeting. Thanks for that.</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; I would say that we should not constrain the resolution of LSIDs if </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; we expect our LSID infrastructure to work. LSIDs will be the basis of </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; our architecture so we better have good support for that.</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; However, that is sure a limiting factor. Also server efficiency will </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; likely vary quite a lot, depending on underlying system optimizations </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; and all.</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; So I think that the solution for this problem is in caching LSID </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; responses on the server LSID stack. Basically, after resolving an LSID </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; once, your server should be able to resolve it again and again really </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; quickly, until something on the metadata that is related to that id changes.</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; I haven't looked at this aspect of the LSID software stack, but </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; maybe others can say something about it. In any case I'll do some </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; research on it and get back to you.</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; Again, thanks for bringing it up.</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; Cheers,</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; Ricardo</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; Sally Hinchcliffe wrote:</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt; There are enough discontinuities in IPNI ids that 1,2,3 would quickly </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt; run into the sand. I agree it's not a new problem - I just hate to </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt; think I'm making life easier for the data scrapers</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt; Sally</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; It can be a problem but I'm not sure if there is a simple solution ... and how different is the LSID crawler scenario from an <A href="http://www.ipni.org/ipni/plantsearch?id=">http://www.ipni.org/ipni/plantsearch?id=</A> 1,2,3,4,5 ... 9999999 scenario?</FONT></P>
<P><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; Paul</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; -----Original Message-----</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; From: tdwg-guid-bounces@mailman.nhm.ku.edu</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; [<A href="mailto:tdwg-guid-bounces@mailman.nhm.ku.edu">mailto:tdwg-guid-bounces@mailman.nhm.ku.edu</A>]On Behalf Of Sally</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; Hinchcliffe</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; Sent: 15 June 2006 12:08</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; To: tdwg-guid@mailman.nhm.ku.edu</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; Subject: [Tdwg-guid] Throttling searches [ Scanned for viruses ]</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; Hi all</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; another question that has come up here. </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; As discussed at the meeting, we're thinking of providing a complete </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; download of all IPNI LSIDs plus a label (name and author, probably) </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; which will be available as an annually produced download</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; Most people will play nice and just resolve one or two LSIDs as </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; required, but by providing a complete list, we're making it very easy </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; for someone to write a crawler that hits every LSID in turn and </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; basically brings our server to its knees</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; Anybody know of a good way of enforcing more polite behaviour? We can </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; make the download only available under a data supply agreement that </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; includes a clause limiting hit rates, or we could limit by IP address </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; (but this would ultimately block out services like Rod's simple </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; resolver). I beleive Google's spell checker uses a key which has to </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; be passed in as part of the query - obviously we can't do that with </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; LSIDs</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; Any thoughts? Anyone think this is a problem? </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; Sally</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; *** Sally Hinchcliffe</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; *** Computer section, Royal Botanic Gardens, Kew</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; *** tel: +44 (0)20 8332 5708</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; *** S.Hinchcliffe@rbgkew.org.uk</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; _______________________________________________</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; TDWG-GUID mailing list</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; TDWG-GUID@mailman.nhm.ku.edu</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; <A href="http://mailman.nhm.ku.edu/mailman/listinfo/tdwg-guid">http://mailman.nhm.ku.edu/mailman/listinfo/tdwg-guid</A></FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; _______________________________________________</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; TDWG-GUID mailing list</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; TDWG-GUID@mailman.nhm.ku.edu</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt; <A href="http://mailman.nhm.ku.edu/mailman/listinfo/tdwg-guid">http://mailman.nhm.ku.edu/mailman/listinfo/tdwg-guid</A></FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt; *** Sally Hinchcliffe</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt; *** Computer section, Royal Botanic Gardens, Kew</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt; *** tel: +44 (0)20 8332 5708</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt; *** S.Hinchcliffe@rbgkew.org.uk</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt; _______________________________________________</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt; TDWG-GUID mailing list</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt; TDWG-GUID@mailman.nhm.ku.edu</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt; <A href="http://mailman.nhm.ku.edu/mailman/listinfo/tdwg-guid">http://mailman.nhm.ku.edu/mailman/listinfo/tdwg-guid</A></FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; _______________________________________________</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; TDWG-GUID mailing list</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; TDWG-GUID@mailman.nhm.ku.edu</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt; <A href="http://mailman.nhm.ku.edu/mailman/listinfo/tdwg-guid">http://mailman.nhm.ku.edu/mailman/listinfo/tdwg-guid</A></FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; -- </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; -------------------------------------</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&nbsp; Roger Hyam</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&nbsp; Technical Architect</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&nbsp; Taxonomic Databases Working Group</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; -------------------------------------</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&nbsp; <A href="http://www.tdwg.org/">http://www.tdwg.org</A></FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&nbsp; roger@tdwg.org</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&nbsp; +44 1578 722782</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt; -------------------------------------</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt; *** Sally Hinchcliffe</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt; *** Computer section, Royal Botanic Gardens, Kew</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt; *** tel: +44 (0)20 8332 5708</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt; *** S.Hinchcliffe@rbgkew.org.uk</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&gt;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;&gt; -- </FONT><BR><FONT size=2>&gt; &gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt; -------------------------------------</FONT> <BR><FONT size=2>&gt; &gt;&gt;&nbsp; Roger Hyam</FONT> <BR><FONT size=2>&gt; &gt;&gt;&nbsp; Technical Architect</FONT> <BR><FONT size=2>&gt; &gt;&gt;&nbsp; Taxonomic Databases Working Group</FONT> <BR><FONT size=2>&gt; &gt;&gt; -------------------------------------</FONT> <BR><FONT size=2>&gt; &gt;&gt;&nbsp; <A href="http://www.tdwg.org/">http://www.tdwg.org</A></FONT> <BR><FONT size=2>&gt; &gt;&gt;&nbsp; roger@tdwg.org</FONT> <BR><FONT size=2>&gt; &gt;&gt;&nbsp; +44 1578 722782</FONT> <BR><FONT size=2>&gt; &gt;&gt; -------------------------------------</FONT> <BR><FONT size=2>&gt; &gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;</FONT> <BR><FONT size=2>&gt; &gt;&gt;&nbsp;&nbsp;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; &gt;</FONT> <BR><FONT size=2>&gt; &gt; *** Sally Hinchcliffe</FONT> <BR><FONT size=2>&gt; &gt; *** Computer section, Royal Botanic Gardens, Kew</FONT> <BR><FONT size=2>&gt; &gt; *** tel: +44 (0)20 8332 5708</FONT> <BR><FONT size=2>&gt; &gt; *** S.Hinchcliffe@rbgkew.org.uk</FONT> <BR><FONT size=2>&gt; &gt;</FONT> <BR><FONT size=2>&gt; &gt;</FONT> <BR><FONT size=2>&gt; &gt;&nbsp;&nbsp; </FONT><BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; -- </FONT><BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; -------------------------------------</FONT> <BR><FONT size=2>&gt;&nbsp; Roger Hyam</FONT> <BR><FONT size=2>&gt;&nbsp; Technical Architect</FONT> <BR><FONT size=2>&gt;&nbsp; Taxonomic Databases Working Group</FONT> <BR><FONT size=2>&gt; -------------------------------------</FONT> <BR><FONT size=2>&gt;&nbsp; <A href="http://www.tdwg.org/">http://www.tdwg.org</A></FONT> <BR><FONT size=2>&gt;&nbsp; roger@tdwg.org</FONT> <BR><FONT size=2>&gt;&nbsp; +44 1578 722782</FONT> <BR><FONT size=2>&gt; -------------------------------------</FONT> <BR><FONT size=2>&gt; </FONT><BR><FONT size=2>&gt; </FONT></P>
<P><FONT size=2>*** Sally Hinchcliffe</FONT> <BR><FONT size=2>*** Computer section, Royal Botanic Gardens, Kew</FONT> <BR><FONT size=2>*** tel: +44 (0)20 8332 5708</FONT> <BR><FONT size=2>*** S.Hinchcliffe@rbgkew.org.uk</FONT> </P><BR>
<P><FONT size=2>_______________________________________________</FONT> <BR><FONT size=2>TDWG-GUID mailing list</FONT> <BR><FONT size=2>TDWG-GUID@mailman.nhm.ku.edu</FONT> <BR><FONT size=2><A href="http://mailman.nhm.ku.edu/mailman/listinfo/tdwg-guid">http://mailman.nhm.ku.edu/mailman/listinfo/tdwg-guid</A></FONT> </P></DIV></BODY></HTML>