CodingBasic - Understand Blockstack Auth

FROM : https://docs.blockstack.org/develop/overview_auth.html#manifest-file

Blockstack Auth提供单点登录和认证,无需第三方或远程服务器。在这个页面上,您将从开发人员和用户的角度获得身份验证的概述。包括以下主题:

用户体验流程
DApp身份验证流程
作用域
blockstack:自定义协议处理程序
清单文件
密钥对
——— 交通私钥
——— Blockstack ID身份地址私钥
——— 应用私钥
JSON Web令牌签名
——— 示例:authRequest有效负载模式
——— 示例:authResponse有效负载模式

用户体验流程

Blockstack认证是一种基于承载令牌的认证系统。从应用程序用户的角度来看,blockstack身份验证类似于他们熟悉的传统第三方身份验证技术。应用程序向用户提供一个带有Blockstack按钮的登录。

image

假设用户Alice在应用程序上单击带有Blockstack按钮的Sign in。她将被重定向到她的Blockstack浏览器副本。用户看到的blockstack登录对话框取决于用户是否已经为当前设备拥有了一个现有的blockstack浏览器会话。

[图片上传失败...(image-2cb3d5-1563951125179)]

使用标识登录是用户授予DApp访问权限的方法。访问取决于DApp请求的范围。默认的store_write范围允许DApp读取用户配置文件,并为DApp读取/写入用户数据。数据在Gaia存储中心上的唯一URL处加密。

Alice可以使用自己的一个blockstack ID选择身份验证并登录到DApp中。

  • 你的应用程序的来源
  • 你的应用程序的名字
  • 你的应用程序的标志
  • 应用程序请求的权限和数据类型

当她选择一个ID(或创建一个新ID)时,Alice被重定向回她登录的DApp。

DApp身份验证流

对于应用程序开发人员,应用程序流类似于集中登录服务(例如OAuth)使用的典型客户机-服务器流。然而,使用Blockstack,身份验证流程完全在客户端进行。

去中心化应用程序(DApp)和blockstack浏览器在身份验证流期间通过来回传递两个令牌进行通信。请求应用程序向块堆栈浏览器发送一个authRequest令牌。一旦用户批准登录,块堆栈浏览器就会使用authResponse令牌响应应用程序。这些令牌是JSON Web令牌,它们通过URL查询字符串传递。

image

当用户选择在DApp上使用Blockstack登录时,它调用redirectToSignIn()方法,该方法向Blockstack浏览器发送authRequest。Blockstack通过authRequest参数中的URL查询字符串传递令牌:

https://browser.blockstack.org/auth?authRequest=j902120cn829n1jnvoa

当Blockstack浏览器接收到请求时,它使用临时传输键向应用程序生成一个(authResponse)令牌。临时传输键仅用于应用程序的特定实例,在本例中,用于签名authRequest。应用程序在请求生成期间存储临时传输密钥。传输密钥的公共部分在authRequest令牌中传递。blockstack浏览器使用密钥的公共部分加密通过authResponse返回的应用程序私有密钥。

在登录期间,blockstack浏览器从用户的身份地址私钥和应用程序的appDomain生成应用程序私钥。app私钥有三个功能:

  • 它用于创建凭据,让应用程序访问特定应用程序的Gaia存储桶。
  • 它用于在用户的Gaia存储中对应用程序存储的文件进行端到端加密。
  • 它作为一个密码秘密,应用程序可以使用它来执行其他密码功能。

最后,app私钥是确定性的,这意味着对于给定的用户ID和域名,每次都会生成相同的私钥。

作用域

作用域定义用户通过登录对话框请求的权限和接受的权限。DApp可要求下列任何范围:

范围 定义
store_write 在特定于应用程序的存储桶中读写数据到用户的Gaia Hub。
publish_data 发布数据,以便应用程序的其他用户可以发现并与用户交互。
email 如果可用,请求用户的电子邮件。

权限范围应该通过AppConfig对象指定。如果redirectToSignIn或makeAuthRequest函数没有提供作用域数组,则默认为request ['store_write’]。

blockstack:自定义协议处理程序

blockstack :自定义协议处理程序是blockstack应用程序如何将其身份验证请求发送到blockstack浏览器的。用户可以在自己的设备上本地安装blockstack浏览器,也可以使用web版本的blockstack浏览器。如果在用户的计算机上安装了blockstack浏览器,它将自己注册为blockstack:customer协议的处理程序。

当应用程序调用redirectToSignIn或redirectToSignInWithAuthRequest时,blockstack.js检查是否安装了blockstack: protocol handler,如果安装了,则将用户重定向到blockstack:<authRequestToken>。这将身份验证请求令牌从应用程序传递到本地blockstack浏览器。如果没有安装本地blockstack浏览器,调用将定向到blockstack浏览器的web版本。

清单文件

Blockstack应用程序有一个清单文件。此文件基于W3C web应用程序清单规范。下面是一个示例清单文件。

{
"name": "Todo App”,
"start_url": "http://blockstack-todos.appartisan.com”,
"description": "A simple todo app build on blockstack”,
"icons": [{
"src": "http://blockstack-todos.appartisan.com/logo.png”,
"sizes": “400x400”,
"type": "image/png”
}]
}

Blockstack浏览器在身份验证过程中从应用程序检索清单文件,并在其中显示信息,如应用程序名称和用户登录期间。应用程序清单文件的位置在身份验证请求令牌中是特定的,并且必须与请求身份验证的应用程序位于同一原点。

清单文件必须具有跨源资源共享(Cross-origin resource sharing, CORS)头文件,允许从任意源获取清单文件。这通常意味着返回像这样的头部:

Access-Control-Allow-Origin: *

如何实现CORS在一定程度上取决于您使用哪个平台/服务来服务您的应用程序。例如,Netlify和Firebase有两种配置CORS的不同方法。有关更多信息,请参考供应商文档。

密钥对

Blockstack Auth广泛使用公钥加密技术。blockstack使用ECDSA和secp256k1曲线。以下各节描述认证过程中使用的三对公钥对:

  • 他们是如何生成的
  • 他们使用
  • 向谁公开私钥

传输私钥

transit private是一个临时密钥,用于加密需要在身份验证过程中从Blockstack浏览器传递给应用程序的秘密。它是由应用程序在身份验证响应开始时随机生成的。

与传输私钥对应的公钥存储在身份验证请求令牌的public_keys密钥中的单个元素数组中。Blockstack浏览器使用这个公钥加密应用程序的私钥等秘密数据,并在用户登录应用程序时将其发送回应用程序。

Blockstack ID身份地址私钥

私钥的身份地址来自用户的密钥链短语和私钥Blockstack ID,用户选择使用登录到应用程序。这是一个秘密由用户和从未离开过的用户实例Blockstack浏览器拥有。

此私钥为应用程序签署身份验证响应令牌,以指示用户批准登录该应用程序。

应用私钥

app私钥是一个特定于app的私钥,它使用domain_name作为输入,从用户的身份地址私钥生成。这是确定的,因为对于给定的blockstack ID和domain_name,每次都会生成相同的私钥。

应用程序私钥在每次身份验证时与应用程序安全共享,并由blockstack浏览器使用传输公钥加密。

JSON Web令牌签名

authRequest和authResponse令牌都是JSON Web令牌,它们通过URL查询字符串传递。

Blockstack的认证令牌基于RFC 7519 OAuth JSON Web令牌(JWT),并支持比特币和许多其他加密货币使用的secp256k1曲线。

该签名算法通过在令牌的alg密钥中指定ES256K来表示,指定JWT签名使用ECDSA和secp256k1曲线。Blockstack为JavaScript和Ruby JWT库提供了对这种签名算法的支持。

示例:authRequest有效负载模式

const requestPayload = {
jti, // UUID
iat, // JWT creation time in seconds
exp, // JWT expiration time in seconds
iss, // legacy decentralized identifier generated from transit key
public_keys, // single entry array with public key of transit key
domain_name, // app origin
manifest_uri, // url to manifest file - must be hosted on app origin
redirect_uri, // url to which browser redirects user on auth approval - must be hosted on app origin
version, // version tuple
do_not_include_profile, // a boolean flag asking browser to send profile url instead of profile object
supports_hub_url, // a boolean flag indicating gaia hub support
scopes // an array of string values indicating scopes requested by the app
}

示例:authResponse有效负载模式

const responsePayload = {
jti, // UUID
iat, // JWT creation time in seconds
exp, // JWT expiration time in seconds
iss, // legacy decentralized identifier (string prefix + identity address) - this uniquely identifies the user
private_key, // encrypted private key payload
public_keys, // single entry array with public key
profile, // profile object or null if passed by profile_url
username, // blockstack id username (if any)
core_token, // encrypted core token payload
email, // email if email scope is requested & email available
profile_url, // url to signed profile token
hubUrl, // url pointing to user's gaia hub
version // version tuple
}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容