首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将与用户电子邮件地址匹配

将与用户电子邮件地址匹配
EN

Stack Overflow用户
提问于 2017-06-05 16:35:09
回答 2查看 358关注 0票数 1

我正在寻找一种方法来确定谁上传了一个文件到一个云存储桶。所有有权写入桶的用户都是同一个G Suite域中的经过身份验证的用户。

云存储中的对象ACL显示了一个所有者标识符字符串,如下所示:

代码语言:javascript
复制
{
  "entity": "user-84fac329bceSAMPLE777d5d22b8SAMPLE77d85ac2SAMPLE2dfcf7c4adf34da46",
  "entityId": "84fac329bceSAMPLE777d5d22b8SAMPLE77d85ac2SAMPLE2dfcf7c4adf34da46",
  "role": "OWNER"
}

但是,似乎没有一种简单的方法可以将该ID映射回用户的电子邮件地址(或者确定我认识的用户的云存储ID,除非使用该用户帐户上载文件和查询对象ACL)。

这是真的吗?还是我不知道该怎么做?

谢谢你的帮助!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-07-05 12:24:16

再试一次得到ACL。我刚刚尝试了在2017年07年05日,返回的ACL包括电子邮件地址。看起来Google已经更新了API,用用户的电子邮件地址替换了旧的。

代码语言:javascript
复制
{
  "email": "email@domain.com",
  "entity": "user-email@domain.com",
  "role": "OWNER"
}
票数 1
EN

Stack Overflow用户

发布于 2017-06-12 20:45:55

虽然我不能给出具体的时间线,但我们正在积极地研究不推荐的规范I。在不久的将来,这将不再是一个问题。

与此同时,有..。选项。

首先:用户可以在这个页面上找到他们的规范ID (不幸的是,它会让您选择一个项目,因为该页面还显示了项目角色的规范ID)。https://console.cloud.google.com/storage/settings

然而,如果你真的需要找出一个随机的规范id的电子邮件地址,你应该能够做这个有点丑陋的解决办法。

1)通过API将用户添加到桶策略

代码语言:javascript
复制
    gsutil acl ch -u <canonical_id>:READ gs://<bucket>

2)获取桶IAM策略

代码语言:javascript
复制
    gsutil iam get gs://<bucket>

条目应该显示为电子邮件地址。

代码语言:javascript
复制
{
  "bindings": [
    {
      "members": [
        "projectOwner:<project-id>", 
        "projectEditor:<project-id>",
      ], 
      "role": "roles/storage.legacyBucketOwner"
    }, 
    {
      "members": [
        "projectViewer:<project-id>", 
        "user:<user email here>"
      ], 
      "role": "roles/storage.legacyBucketReader"
    }
  ], 
  "etag": "CAI="
}
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44373544

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档