Wikipedia:Bots/Requests for approval/DOI bot
- The following discussion is an archived debate. Please do not modify it. Subsequent comments should be made in a new section. The result of the discussion was Approved.
Automatic or Manually Assisted: Automatic
Programming Language(s): PHP w/ Snoopy & BasicBot
Function Summary: Adds DOIs to citations provided using {{cite journal}}
Will do a thorough job every few months; will be available to be used on specific articles whenever requested.
Edit rate requested: 6 edits per minute. In reality the querying of other websites will be the rate limiting step.
Function Details: Adds a permanent link to any article cited using {{cite journal}}.
- The bot uses a variety of methods to locate the DOI, in the order stated:
- Check the DOI is not already encoded in the
url
parameter - Check the metadata of the web page linked to by the
url
paremeter for a DOI - Scour the page for a DOI
- If there is URL, perform an "advanced search" on Google Scholar using, for example, the
title
andauthor
parameters to form a precise query. The precise search guarantees that the URL is of relevance to the article. If this URL contains a DOI, this is added to the citation; if not, the URL is added. - Do a google web search for "article title" + each + author + name. If the first result only contains 1 DOI, it is a safe assumption that this belongs to the article cited, so it is used;
Operator: Verisimilus T
Discussion
[edit]That sounds really cool, who's operating it? SQLQuery me! 20:57, 12 March 2008 (UTC)[reply]
- Whoops. That would be me, sorry. Verisimilus T 21:02, 12 March 2008 (UTC)[reply]
A few questions:
For #3, how do you propose to know that the DOI you found belongs to the article you are looking for, and not for example, have it be from a list of references, or a see also section on the page. Are you going to do some kind of secondary check (i.e. resolve the DOI you found and see if it matches the author and title)? Also, what happens if the titles (or authors, for that matter) are exact matches (I know they should be, but lets consider reality).
For #4 and #5, are we going to run into the same problem as CorenSearchBot (see section 5.3 of the Google Terms of Service)? Quoted here for convenience:
5.3 You agree to access (or attempt to access) any of the Services by any means other than through the interface that is provided by Google, unless you have been specifically allowed to do so in a separate agreement with Google. You specifically agree to access (or attempt to access) any of the Services through any automated means (including use of scripts or web crawlers) and shall ensure that you comply with the instructions.
- For the record, I asked Google for permission; here's their reply:
Thank you for your interest in Google Scholar. At this time, we are allow automated queries on our index. This is for a number of reasons, both technical and due to agreements with content providers. While we have an API available for Google Scholar, I appreciate this feature request and have passed your email and comment on to the relevant engineers on our team.
Thanks. And this bot does sound really interesting. - AWeenieMan (talk) 23:29, 12 March 2008 (UTC)[reply]
- Hi, thanks for your input. Re #3, in my long experience of collecting DOIs, if an article's references contain DOIs, the article always has a DOI, stated earlier in the page code, and this isn't a problem. I'd be interested if you could find any examples to the contrary.
- DOIs could be resolved to confirm that they are the correct page, but this may be difficult - and is probably unnecessary.
- Inexact matching is a difficulty I'm not sure how to deal with. Problems are bound to arise, for example with italic text in titles, and accented characters in names. I'm sure it's somewhat trivial to check that a string is 95% similar (say), but it's outwith my coding experience. Help gratefully received!
- Thanks for pointing out the Google T&C. That's a pity. It looks like CorenSearchBot used Yahoo to get round this - is this a possible alternative? Verisimilus T 11:22, 13 March 2008 (UTC)[reply]
Adjusted logic
[edit]- I've checked Yahoo!'s terms and conditions and they do not prohibit their use by bots. Hurrah!
- So I've tweaked the DOI searching algorithms so they act as follows in the absence of a URL:
- Does the URL contain a doi? (e.g. http://example.com/view=article&id=10.1001/doi/ishere)
- If so, does the page contain data telling us we've got the right title?
- Sites that I've seen with DOIs in the URL are only BIOONE and Blackwell publishing. The former of these encodes the title in an invisible span.
- Do the <meta> tags contain a dc.Identifier or citation_doi?
- If so, check the dc.title or citation_title matches the title we want.
- Is there a DOI in the page, anywhere?
- Are there lots of DOIs?
- Do any occur in association with the title? If there are any <code><br>, <p>, <li> or <td></code> tags between the title and a DOI, the DOI could refer to a different reference, and we'll have to ignore it.
- Is there a unique DOI?
- Does the DOI appear in the first 5000 characters of the document? If so, it is probably part of the document description. Any later, and it's more likely to be a reference.
- Are there lots of DOIs?
- This is giving promising results so far... Verisimilus T 18:33, 13 March 2008 (UTC)[reply]
- Have you tested this in your userspace at all? SQLQuery me! 19:18, 13 March 2008 (UTC)[reply]
- Yes (as User:Botodo until I get my bot flag) - it's working surprisingly well! Just ironing out a few bugs now. Verisimilus T 19:49, 13 March 2008 (UTC)[reply]
I am liking your new logic, myself. It is too bad about Google, but not much can be done. Inexact title matching shouldn't be too hard to do (in a simple way), if you are interested. I usually use a Levenshtein distance algorithm (php.net) for such things. - AWeenieMan (talk) 20:39, 13 March 2008 (UTC)[reply]
- Thanks for that. Touch wood, I think I've ironed out all the problems and am ready to go. Any suggestions for pages to test are welcome! Verisimilus T 21:52, 13 March 2008 (UTC)[reply]
- Alright then, let's see what she's capable of :) Approved for trial (200 edits). Please provide a link to the relevant contributions and/or diffs when the trial is complete. SQLQuery me! 00:02, 14 March 2008 (UTC)[reply]
- Unfortunately, that's "nothing" at the moment. I'm being thwarted by captchas. Does getting a "bot" flag turn these off? I'm guessing it's alright to operate under the alias of User:Botodo for now? Verisimilus T 08:08, 14 March 2008 (UTC)[reply]
- Your bot user account is not autoconfirmed yet. That happens 4 days after creation, I believe. At that point, the captchas will disappear. - AWeenieMan (talk) 15:00, 14 March 2008 (UTC)[reply]
- Your bot account should be autoconfirmed now, so you should be good to go with your trial :) SQLQuery me! 06:48, 20 March 2008 (UTC)[reply]
What's the status of this request? — Werdna talk 13:55, 4 April 2008 (UTC)[reply]
- The bot is running quite smoothly. Only a few minor issues appeared, and they were easily fixed. I'm just waiting to get it set up on my toolserver account, and will then be ready to roll out into full scale operation. Verisimilus T 14:14, 4 April 2008 (UTC)[reply]
- You're at about 170 edits on this task, I'd go ahead and say trial complete :) I looked over a lot of the edits, and, they looked very good to me. I would suggest approval. SQLQuery me! 01:16, 12 April 2008 (UTC)[reply]
Approved. MaxSem(Han shot first!) 10:02, 12 April 2008 (UTC)[reply]
- The above discussion is preserved as an archive of the debate. Please do not modify it. Subsequent comments should be made in a new section.