将服务连接到现有的流星帐户
Connect service to existing meteor account
我正在建立一个流星应用程序,其中包括使用用户名和密码注册,然后希望将该帐户与facebook和twitter连接。
我有第一部分,运行起来很容易,只需要帐户包。但当我有一个登录用户调用Meteor.loginWithFacebook()时,它会将他们注销并创建一个新帐户。我想要的是向当前登录的用户添加facebook凭据。
流星文档有这个:
{
_id: "bbca5d6a-2156-41c4-89da-0329e8c99a4f", // Meteor.userId()
username: "cool_kid_13", // unique name
emails: [
// each email address can only belong to one user.
{ address: "cool@example.com", verified: true },
{ address: "another@different.com", verified: false }
],
createdAt: Wed Aug 21 2013 15:16:52 GMT-0700 (PDT),
profile: {
// The profile is writable by the user by default.
name: "Joe Schmoe"
},
services: {
facebook: {
id: "709050", // facebook id
accessToken: "AAACCgdX7G2...AbV9AZDZD"
},
resume: {
loginTokens: [
{ token: "97e8c205-c7e4-47c9-9bea-8e2ccc0694cd",
when: 1349761684048 }
]
}
}
}
这似乎是一个用户名的帐户,该帐户也通过了Facebook的认证。但我不确定这是否只是一个用基本的流星物质无法实现的例子。
我想做的基本上是
Meteor.connectWithExternalAccount();
它运行与Meteor.loginWithExternalAccount()相同的进程,但只是将信息添加到当前登录的用户。
如果有人能稍微解释一下账户基础包,让我知道从哪里开始,那就太好了。
此外,有人知道这是否会被包括在未来版本的流星中吗?
这里有一个对我有用的代码(在服务器文件夹中):
Accounts.onCreateUser(function(options, user) {
var email, oldUser, service;
/*
user.groups = {
created: "",
invited:"",
RSVP:{
coming:"",
notComing:"",
noReplay:""
}
};
*/
if (user.profile == null) {
user.profile = options.profile
}
if (user.services != null) {
service = _.keys(user.services)[0];
email = user.services[service].email;
if (email != null) {
oldUser = Meteor.users.findOne({
"emails.address": email
});
if (oldUser != null) {
if (oldUser.services == null) {
oldUser.services = {};
}
if (service === "google" || service === "facebook") {
oldUser.services[service] = user.services[service];
Meteor.users.remove(oldUser._id);
user = oldUser;
}
} else {
if (service === "google" || service === "facebook") {
if (user.services[service].email != null) {
user.emails = [
{
address: user.services[service].email,
verified: true
}
];
} else {
throw new Meteor.Error(500, "" + service + " account has no email attached");
}
user.profile.name = user.services[service].name;
}
}
}
}
return user;
});
userAddOauthCredentials: function(token, userId, service) {
var data, oldUser, selector, updateSelector;
switch (service) {
case "facebook":
data = Facebook.retrieveCredential(token).serviceData;
break;
case "google":
data = Google.retrieveCredential(token).serviceData;
}
selector = "services." + service + ".id";
oldUser = Meteor.users.findOne({
selector: data.id
});
if (oldUser != null) {
throw new Meteor.Error(500, ("This " + service + " account has already") + "been assigned to another user.");
}
updateSelector = "services." + service;
Meteor.users.update(userId, {
$set: {
updateSelector: data
}
});
if (!_.contains(Meteor.user().emails, data.email)) {
return Meteor.users.update(userId, {
$push: {
"emails": {
address: data.email,
verified: true
}
}
});
}
}
客户端js文件夹内部:
var addUserService;
addUserService = function(service) {
if (service === "email") {
} else {
switch (service) {
case "facebook":
return Facebook.requestCredential({
requestPermissions: ["email", "user_friends", "manage_notifications"]
}, function(token) {
return Meteor.call("userAddOauthCredentials", token, Meteor.userId(), service, function(err, resp) {
if (err != null) {
return Meteor.userError.throwError(err.reason);
}
});
});
case "google":
return Google.requestCredential({
requestPermissions: ["email", "https://www.googleapis.com/auth/calendar"],
requestOfflineToken: true
}, function(token) {
return Meteor.call("userAddOauthCredentials", token, Meteor.userId(), service, function(err, resp) {
if (err != null) {
return Meteor.userError.throwError(err.reason);
}
});
});
}
}
};
模板事件中的相同js文件:
"click a": function(e) {
var service;
e.preventDefault();
service = $(event.target).data("service");
return addUserService(service);
}
对于刚刚完成的html:
<div class="social"><a id="fb" data-service="facebook"><img src="/../facebook.png"></a></div>
<div class="social"><a id="go" data-service="google"><img src="/../googleplus.png"></a></div>
主要需要将数据服务设置为服务,然后模板点击事件获取数据服务并执行addUserService(传递的数据)。
希望它能起作用,请告诉我。
因此,我们一直在努力解决这个问题,但不幸的是,pull请求https://github.com/meteor/meteor/pull/1133从未合并。也许你最好的选择是查看流星核心谷歌群组,看看是否有任何评论,如果没有,看看你是否可以让核心开发者对此发表评论。
如果你仍然想使用pull请求,你可以做的是删除各种Meteor accounts-*
包,然后在你的项目的根目录中,创建一个/packages
文件夹,并在那里复制yubozhao的补丁accounts-*
包(可能很聪明地附加-custom
)。然后您可以meteor add accounts-base-custom
等将它们添加到您的项目中。
不过要注意的是,于博昭写这是6-7个月前的事了,你可能需要坚持使用当时最新版本的《流星》才能工作。
2014年4月更新:现在有一个Atmosphere包,它有一个类似的用例,可能很有用:https://atmospherejs.com/package/accounts-merge
- 如何使用WCF服务和javascript表单post上传.doc文件
- 监视函数从服务返回不起作用,但作用域函数起作用
- 通过Magento的网络服务检索运费
- 如何使用铁流星与流星的默认路线
- 在流星上使用微信js-sdk时出现拒绝权限错误
- 在同一个服务工作者中处理service-worker.js有任何影响吗
- 流星中DOM的繁殖
- 使用angular.js问题的JavaSpringREST服务
- AngularJS-需要在index.html页面中访问来自服务的数据
- 如何在Ionic2测试版中包含Ionic.io服务
- 基于api密钥的NodeJS web服务
- 保存串行端口列表与流星
- 将服务连接到现有的流星帐户
- 流星js中没有服务的用户身份验证
- 诊断流星(Node.js)服务挂起
- 流星可以在不依赖外部服务的情况下运行
- 如何使用流星服务(上传)图像
- 在流星中打开一个web服务url
- tomi:上传流星包503服务不可用错误
- 流星和云服务