How to call GoodReads API using YQL

June 20, 2017
💫 Originally posted here. Broken? Let me know ~

Featured Image – “Reading” by Sam Greenhalgh, used under CC BY 2.0

I have been trying to use GoodReads data to display my reading statistics and to find patterns using Javascript.

The problem is that GoodReads API did not enable Cross-origin resource sharing (CORS) headers thus AjAX calls were failing.

How can we get around the issue?

1st Hurdle

Here is the code for the first attempt.

Above code returns following error message.

XMLHttpRequest cannot load<secret>&user_id=25927588&page=1&format=json. No ‘Access-Control-Allow-Origin’ header is present on the requested resource. Origin ‘http://localhost:8080’ is therefore not allowed access.

This GoodReads Developer forum post shows that other people are having the same issue.

There is a workaround found in this post that one of the workarounds is to use a proxy server.

2nd Hurdle

If you have never set up a proxy server, you’d need to search for documentations and read them and so on.

Instead of setting up your own proxy server, you can use Yahoo’s YQL (Yahoo Query Language) as an external proxy.

The following code snippet wraps a GoodReads URL using YqlAjax, which does an AJAX request and returns a promise. secondAttempt runs without an issue and returns a record from GoodReads.

3rd Hurdle

The last problem is that it’s quite a pain to generate a YQL URL and is error prone. Creating another Javascript file (yql_ajax.js) seems unnecessary.

There is an NPM package called proxify-url, which returns a new YQL URL given any URL. Now the code becomes simpler and you have one less file to create/maintain.

One thing to note is that GoodReads API returns data in XML format instead of JSON. So you need to pass { inputFormat: 'xml' } as an option to proxyfy method.

The code is now much more readable using existing library.


Using Yahoo Proxy with YQL, we can circumvent CORS restriction and query GoodReads API.

You can find the source code on here. Refer to the file on how to set up the project and run it.