UCWA Lync身份验证 - 500个Web票证无效

时间:2015-01-25 14:15:13

标签: node.js lync ucwa

我尝试使用Nodejs为Lync创建一个简单的客户端。 基于http://ucwa.lync.com/documentation/KeyTasks-CreateApplication,我已经做了这样的事情。 它可以工作到最后一步#9,当时我应该向UCWA注册我的应用程序。服务器响应代码500和愚蠢的解释

  

您要查找的资源存在问题,无法显示

标题

  

x-ms-diagnostics&#39;:&#39; 28032; source =&#34; mysource&#34 ;; reason =&#34;网络门票无效。&#34;&#39; < / p>

var http = require('request-promise');
var lync = {};

lync.setup = function(email, password){
    var self = this;
    var hostname = email.split('@');
    this.username = email;

    //discover urls
    return http.get('http://lyncdiscover.'+hostname[1])
        .then(function(d) {
            var parsed = JSON.parse(d);
            self.urls = {
                self: parsed._links.self.href,
                user: parsed._links.user.href,
                xframe: parsed._links.xframe.href
            };
            return http.get(self.urls.user);
        }).catch(function(err){
            if(err.statusCode == 401){
                var toParse = err.response.headers['www-authenticate'];
                var Oauth = toParse.match(/https:\/\/[\d\w\./_-]*/i)[0];

                var loginPost = {
                    grant_type: 'password',
                    username: email,
                    password: password
                };

                return http.post(Oauth, {form:loginPost});
            }
            return false
        }).then(function(data){
            var parsed = JSON.parse(data);
            //setup authorization
            http = http.defaults({
                headers: {Authorization: parsed.token_type + ' ' + parsed.access_token}
            });
            //console.log(self.urls.user);
            //console.log('Authorization:'+ parsed.token_type + ' ' + parsed.access_token);
            return http.get(self.urls.user);

        }).then(function(data){
            var parsed = JSON.parse(data);
            self.urls.applications = parsed._links.applications.href;

            var registerApp = {
                culture : "en-us",
                endpointId : "2d9dc28d-4673-4035-825c-feb64be28e4e",
                userAgent : "Test"
            };
            var r = "{'userAgent': 'NodeJs',  'endpointId' : '2d9dc28d-4673-4035-825c-feb64be28e4e', 'culture': 'en-US'}";
            return http.post(self.urls.applications, {body: registerApp, json:true});
        })
        .then(function(data){
            console.log(data);
        })
        .catch(function(err){

            console.log(err);
            return false;
        });
};



//run app
lync.setup('login@domain.com', 'password').then(function(ret){

});

这里有一个关键点。它不是我的服务器。我只是在那里有一个帐户,我可以使用官方Lync客户端或Pidgin插件登录。 是否有一些额外的步骤来允许&#34;我的应用程序与UCWA合作?

@ShelbyZ 我可以轻松授权使用Oauth。我正在接收授权令牌,因此我已登录。

我收到类似于

的json
  

&#34; _links&#34;:{       &#34;自&#34; {&#34; HREF&#34;:&#34;连结&#34;},       &#34;应用程序&#34;:{&#34; href&#34;:&#34;我需要这个&#34;},       &#34; xframe&#34; {&#34; HREF&#34;:&#34;连结&#34;}   }}

现在。我需要注册我的应用程序&#34;做POST。 在最后一步中,我获得了500个代码响应。 我希望它与@Matthew Proctor说的无关...... 因为我不能简单地管理服务器

2 个答案:

答案 0 :(得分:2)

谢谢@ShelbyZ 你是对的,这是分区域方案。现在授权有效,我可以注册我的应用程序。也是后代的榜样

var http = require('request-promise');


var lync = {};

lync._authorize = function(){

    var self = this;

    var orgDomain = self.urls.user.match(/https:\/\/([\w\d\.]+)/i)[0];
    //console.log(orgDomain);

    http.get(self.urls.user).catch(function(err){
        if(err.statusCode == 401){
            var toParse = err.response.headers['www-authenticate'];
            var Oauth = toParse.match(/https:\/\/[\d\w\./_-]+/i)[0];

            var loginPost = {
                grant_type: 'password',
                username: self.username,
                password: self.password
            };

            return http.post(Oauth, {form:loginPost});
        }
    }).then(function(data){
        if(data) {
            var parsed = JSON.parse(data);
            //setup authorization
            http = http.defaults({
                headers: {Authorization: parsed.token_type + ' ' + parsed.access_token}
            });
            return http.get(self.urls.user);
        }
    }).then(function(data){
        //check for split-domain scenario
        var parsed = JSON.parse(data);
        var domain = parsed._links.self.href.match(/https:\/\/([\w\d\.]+)/i)[0];
        console.log('[1] '+orgDomain);
        console.log('[2] '+domain);

        if(domain!== orgDomain){
            //split domain scenario
            self.urls.user = self.urls.user.replace(orgDomain, domain);
            http = http.defaults({
                headers: {Authorization: null}
            });

            self._authorize();
        } else { //create app
            var parsed = JSON.parse(data);
            self.urls.applications = parsed._links.applications.href;

            var registerApp = {
                culture : "en-us",
                endpointId : "2d9dc28d-4673-4035-825c-feb64be28e4e",
                userAgent : "NodeJs client"
            };
            return http.post(self.urls.applications, {body: registerApp, json:true});
        }
    }).then(function(app){
        console.log(app);
    });

};

lync.setup = function(email, password){
    var self = this;
    var hostname = email.split('@');
    this.username = email;
    this.password = password;

    //discover urls
    return http.get('http://lyncdiscover.'+hostname[1])
        .then(function(d) {
            var parsed = JSON.parse(d);
            self.urls = {
                self: parsed._links.self.href,
                user: parsed._links.user.href,
                xframe: parsed._links.xframe.href
            };
            return self._authorize();
        });

};



//run app
lync.setup('username@domain.com', 'password');

答案 1 :(得分:0)

在将测试域添加到允许域列表之前,我遇到了同样的错误。

可以通过PowerShell更新,详情如下:

Enabling UCWA and Configuring Allowed Domains

我从http://localhost/运行我的代码后,客户看到了类似的错误,他们的修正是在FQDN上测试他们的代码(即http://testmyucwacode.mydomain.com/)。