用户元数据 user-metadata

NOTE
此页面上的内容仅供参考。 使用此API需要来自Adobe的当前许可证。 不允许未经授权使用。

简介 intro

用户元数据功能使程序员能够访问由MVPD维护的不同类型的用户特定数据。 用户元数据类型包括邮政编码、家长评级、用户ID等。 用户 ​元数据是以前可用的​ 静态 ​元数据(身份验证令牌TTL、授权令牌TTL和设备ID)的扩展。

用户元数据关键点:

  • 在身份验证和授权流期间传递到程序员应用程序
  • 值将保存在令牌中
  • 如果不同的MVPD以不同的格式提供数据,则可以规范化值
  • 可以使用程序员的密钥(例如,邮政编码)对某些参数进行加密,请参阅用户元数据证书以进行加密以生成加密证书
  • 通过配置更改,可按Adobe提供特定值

获取用户元数据 obtaining

用户元数据可通过AccessEnabler getMetadata()函数和Clienless API中的/usermetadata端点供程序员使用。 请参阅平台API文档,了解有关使用getMetadata()及其相应回调setMetadataStatus()的详细信息(或无客户端API中使用的端点和参数)。

程序员通过为要获取的元数据类型提供键来获取元数据: getMetadata(key)

元数据返回如下: setMetadataStatus(key, encrypted, data)

参数
类型
描述
key
字符串
指定请求的元数据的类型
encrypted
布尔型
指示“value”是否已加密的布尔标记。 如果为“true”,则“value”实际上将是实际值的JSON Web加密表示形式。
data
对象
包含元数据表示形式的JSON对象

数据参数的结构,值在类型之间变化:

值类型
示例
描述
zip
JSON数组
["77754", "12345"]
邮政编码
householdID
JSON字符串
“1o7241p”
家庭标识符。 如果MVPD不支持子帐户,则它与userID相同
maxRating
JSON对象
{ MPAA: "NR",
VCHIP: "X",
URL: "http://manage.my/parental" }
用户的最大家长评级
userID
JSON字符串
“1o7241p”
用户标识符。 在MVPD支持子帐户并且用户不是主帐户的情况下,userID将不同于householdID
channelID
JSON数组
["channel-1", "channel-2" ]
用户有权查看的渠道列表
is_hoh
JSON字符串
"1"
标识用户是否为户主的标志
encryptedZip
JSON字符串
“”
Comcast会公开加密的邮政编码
typeID
JSON字符串
主要
标识用户帐户是否为主/辅助帐户的标志
primaryOID
JSON字符串
“uuidd1e19ec9-012c-124f-b520-acaf118d16a0”
家庭标识符。 如果typeID是主要的,将包含userID的值
hba状态
布尔型
"true" "false"
一个布尔标记,指示是否为特定集成启用基于主页的身份验证
allowMirroring
布尔型
"true" "false"
指示此设备是否允许屏幕镜像
NOTE
注意: ​如果数据参数已加密(如​ zip密钥 ​的通常情况),则元数据密钥的表示形式将为JSON字符串,而不是Array或Object。

重要信息: ​程序员可用的实际用户元数据取决于MVPD提供的内容。 在生产环境中提供敏感用户元数据(如邮政编码)之前,必须与MVPD签署法律协议。

名称
详细信息
需要加密
评论
用户标识
由MVPD提供
此值随后将通过Adobe进行哈希处理,并显示在media令牌和sendTrackingData()回调中。

此例中的哈希处理是出于历史原因而完成的

此ID可以是家庭ID或子帐户ID。 通常不指定,而是仅与当时使用的登录关联的ID(可以是主要帐户或子帐户)
上游用户Id
由MVPD提供,仅用于并发监控流
在MVPD和程序员网站和应用程序中强制实施并发限制时,可使用此值。

ID也可以包含并发监视策略

对于大多数MVPD,此值等于用户ID
家庭用户ID
由MVPD提供,主要用于家长控制流
允许程序员了解家庭与子帐户使用情况的ID。

如果无法获取真实评级,则它有时会被用作家长监控的替代项(如果用户以家庭帐户登录,则可以观看该帐户的内容,否则不会显示评级的内容)

MVPD的显示方式存在很大差异 — 家庭用户ID、户主ID、户主标志等。
户主
指示当前帐户是否为户主的标志
请参阅上文
类型ID/主ID
家庭帐户标识符
AT&T针对户主的特定指标。

类型ID =标识用户帐户是否为主/辅助帐户的标志

主OID =家庭标识符。 如果TypeID为Primary,则将包含userID的值
最大评级
当前帐户允许的最大评级
允许程序员过滤掉不适合帐户的内容。

具有MPAA或VCHIP评级
渠道排列
用户包中可用的渠道列表
用于从聚合多个网络的门户中快速允许/删除各种渠道

请注意,预检授权通常允许此用例更灵活,应该改用

OLCA规范允许将此用作AuthN响应中的AttributeStatement
HBA状态
指示是否已通过HBA进行身份验证
邮政编码
用户的计费邮政编码
用于广播或体育赛事

还可以提供AuthZ响应以进行快速更新

敏感数据,需要MVPD法律协议
加密的邮政编码
用户的计费邮政编码(Comcast)
如上所示,但由Comcast加密
语言
用户语言设置
用于根据用户的偏好显示消息
允许镜像
指示此设备是否允许屏幕镜像

可用元数据 available_metadata

下表列出了Adobe Pass身份验证生态系统中用户元数据的当前状态:

法律​

协议​

已签署(仅限zip)
身份验证时​ 用户ID ​

AuthN/Z 上的 ​邮政编码​​
AuthN/Z ​** 上的​ ​评分​

**​
​** 家庭​**

ID位于AuthN/Z
通道ID位于AuthN
户主在AuthN
AuthN的类型ID
AuthN ​上的主OID
语言
AuthN 上的上游用户ID
HBA状态
网络
inHome
允许在AuthZ上镜像
备注
正式名称
不适用
userID
zip
maxRating
householdID
channelID
is_hoh
typeID
primaryOID
语言
上游用户ID
hba状态
onNet
inHome
allowMirroring
1.对于AuthN — 必须更改OiosamlMetadataParser,以便所有解析器都启用此新属性
2。 对于AuthZ — 没有通用的方式,因为授权实施特定于MVPD
需要加密
不适用
敏感
不适用
AdobeIdP
是(仅限AuthN)
是(仅限AuthN)
是(仅限AuthN)
无需法律协议,可以启用。
Synacor
是(仅限AuthN)
是(仅限AuthN)
是(仅限AuthN)
法律协议未涵盖所有代理的MVPD。
这是对Synacor的通用支持 — 可能未汇总到其所有MVPD。
碟子
是(仅限AuthN)
是(仅限AuthN)
是(仅限AuthN)
与所有Synacor MVPD共享同一列表,外加upstreamUserID。
Comcast
是(仅限AuthZ)
是(仅限AuthZ)
AT&T
是(仅限AuthN)
是(仅限AuthN)
签署了法律协议。
Cablevision
是(仅限AuthN)
签署了法律协议。
HTC
代理马西隆
是(仅限AuthN)
是(仅限AuthN)
签署了法律协议。
代理Clearleap
是(仅限AuthN)
是(仅限AuthZ)
签署了法律协议。
罗杰斯
RCN
是(仅限AuthN)
是(仅限AuthN)
是(仅限AuthN)
Charter
是(仅限AuthN)
是(仅限AuthN)
是(仅限AuthN)
威里宗
是(仅限AuthN)
东链
是(仅限AuthN)
是(仅限AuthN)
是(仅限AuthN)
代理GLDS
是(仅限AuthN)
DTV
是(仅限AuthN)
COX
是(仅限AuthN)
Cogeco
是(仅限AuthN)
是(仅限AuthN)
Videotron
是(仅限AuthN)
*
显示与userID值相同的家庭ID
频谱
是(仅限AuthN)
是(仅限AuthN)
是(仅限AuthN)
所有其他​

MVPD
尚无法律协议,敏感元数据不可用于生产。
对于所有MVPD,用户ID可用,无需额外工作。

随着新类型可用并添加到Adobe Pass身份验证系统中,用户元数据类型的列表将会展开。

代码示例 code_samples

代码示例1 code_sample1

    // Assuming a reference to the AccessEnabler has been previously obtained and stored in the "ae" variable

    ae.setRequestor("SITE");
    ae.checkAuthentication();

    function setAuthenticationStatus(status, reason) {
      if(status ==1) {
        // User is authenticated, request metadata
        ae.getMetadata("zip");
        ae.getMetadata("maxRating");
      } else {
        ...
      }
    }

    // Implement the setMetadataStatus() callback
    function setMetadataStatus(key, encrypted, data) {
      if(encrypted) {
        // The metadata value is encrypted
        // Needs to be decrypted by the programmer
         data = decrypt(data);
      }
      alert(key + "=" + data);
    }

代码示例2 (模拟getMetadata) code_sample2

    // Assuming a reference to the AccessEnabler has been
    //   previously obtained and stored in the "ae" variable

    // Mock the getMetadata() method
    var aeMock = {
        getMetadata: function(key) {
          var data = null;
          // Set mock data based on the received key,
          // according to the format in the spec
          switch(key) {
            case 'zip':
              data = [ "1235", "23456" ];
              break;
            case 'maxRating':
              data = { "MPAA": "PG-13", "VCHIP": "TV-14" };
              break;
            default:
              break;
          }
          // Call the metadata status just like AccessEnabler does
          setMetadataStatus(key, false, data);
        }
     }

    ae.setRequestor("SITE");
    ae.checkAuthentication();

    function setAuthenticationStatus(status, reason) {
      if (status == 1) {
        // User is authenticated, request metadata using mock object
        aeMock.getMetadata("zip");
        aeMock.getMetadata("maxRating");
      } else {
        ...
      }
    }

    // Implement the  setMetadataStatus() callback
    function setMetadataStatus(key, encrypted, data) {
      if (encrypted) {
        // The metadata value is encrypted, so it
        //   needs to be decrypted by the programmer
         data = decrypt(data);
      }
      alert(key + "=" + data);
    }
recommendation-more-help
3f5e655c-af63-48cc-9769-2b6803cc5f4b