Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

intialize function never resolves #1

Open
petethomas opened this issue Feb 9, 2016 · 1 comment
Open

intialize function never resolves #1

petethomas opened this issue Feb 9, 2016 · 1 comment

Comments

@petethomas
Copy link

We're running into an issue with the initialize function for the ApiClient never resolving or rejecting. It just hangs forever. When we connect to https://test.openchain.org with the client, it will initialize, but not when connecting to a local instance at http://localhost:8080. In this case we're running the Openchain docker image on OSX 10.10.5. Below is a test script that replicates our issue:

var openchain = require('openchain');
var client = new openchain.ApiClient('http://localhost:8080');
console.log('Initializing Openchain client');
client.initialize().then(function () {
    console.log('Openchain client initialized');
}, function (err) {
    console.error(err.stack);
});

When we run the script, 'Initializing Openchain client' is logged, and nothing else happens. The promise that is returned from getInfo() never resolves, though if we run curl http://localhost:8080/info in a terminal, we get a 200 and the JSON containing the namespace back.

We noticed that if we run docker-compose restart to restart the openchain-server container while that script is running, after a few seconds, the promise returned from initialize resolves.

Provided this is not a configuration issue on our side, could our issue have something to do with differences between httpinvoke in the browser and httpinvoke running in node, e.g. jakutis/httpinvoke#17

@Flavien
Copy link
Member

Flavien commented Feb 9, 2016

The current version of the Kestrel web server used by Openchain (RC1) has a bug whereby requests have to be made with keep alive on when called from Node.

This will be fixed as soon as RC2 is released, but in the meantime, there are a couple of solutions:

  1. Expose Openchain behind IIS or Nginx, which will handle the incoming calls correctly, or
  2. Override the httpGet and httpPost methods of the API client object:
var httpinvoke = require("httpinvoke");

client.httpGet = function (url) {
    return httpinvoke(url, "GET", { headers: { 'Connection': 'keep-alive' } })
    .then(function (data) {
        return JSON.parse(data.body);
    });
};

client.httpPost = function (url, body) {
    return httpinvoke(url, "POST", { headers: { 'Connection': 'keep-alive' }, input: body })
    .then(function (data) {
        return JSON.parse(data.body);
    });
};

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants