有贊移動(dòng)關(guān)于權(quán)限與審批流程的標(biāo)準(zhǔn)化

一槽畔、背景

有贊移動(dòng)有weex發(fā)布平臺(tái)栈妆、移動(dòng)配置中心平臺(tái)、App分發(fā)平臺(tái)厢钧、熱修復(fù)平臺(tái)等鳞尔。這些平臺(tái)都需要發(fā)布,而發(fā)布就需要規(guī)范化早直,需要審批制度寥假。如果為各個(gè)平臺(tái)開(kāi)發(fā)這個(gè)審批流程,看起來(lái)是一種浪費(fèi)霞扬。

首先想到第一種方案:接入現(xiàn)有的前后端發(fā)布平臺(tái)糕韧。

移動(dòng)側(cè)的發(fā)布基本是配置類的發(fā)布,跟后端應(yīng)用和前端應(yīng)用的發(fā)布不一樣喻圃。后端應(yīng)用和前端應(yīng)用的發(fā)布都是將指定的內(nèi)容推送到某臺(tái)或者多臺(tái)機(jī)器進(jìn)行部署萤彩、啟動(dòng)。兩者如果硬要做抽象斧拍,成本反而更大雀扶,而且不易維護(hù)。所以放棄第一種方案肆汹。

那么是否可以抽象成單獨(dú)的統(tǒng)一管理平臺(tái)愚墓,進(jìn)行標(biāo)準(zhǔn)化呢?

二昂勉、梳理

首先看一下標(biāo)準(zhǔn)的發(fā)布審批流程一般是怎么樣的浪册?

第一步:申請(qǐng)人提交發(fā)布單

第二步:負(fù)責(zé)人審批

第三步:申請(qǐng)人發(fā)布

而這里申請(qǐng)人和負(fù)責(zé)人就是以權(quán)限為區(qū)分。

一般的權(quán)限角色有模塊負(fù)責(zé)人硼啤、開(kāi)發(fā)议经、運(yùn)營(yíng)、測(cè)試等谴返。

其中煞肾,審批人是模塊負(fù)責(zé)人,而申請(qǐng)人可以是開(kāi)發(fā)嗓袱,也可以是模塊負(fù)責(zé)人籍救。而二方平臺(tái)還可以根據(jù)不同角色賦予不同的權(quán)限。

2.1 權(quán)限

權(quán)限實(shí)質(zhì)上指的是用戶和模塊之間的關(guān)系渠抹。所以只需要模塊的唯一標(biāo)識(shí)和用戶的唯一標(biāo)識(shí)蝙昙,用戶的唯一標(biāo)識(shí)由統(tǒng)一的用戶認(rèn)證服務(wù)提供闪萄,模塊的唯一標(biāo)識(shí)由各個(gè)二方平臺(tái)提供。對(duì)于二方平臺(tái)來(lái)說(shuō)奇颠,只要提供模塊唯一標(biāo)識(shí)和用戶唯一標(biāo)識(shí)败去,然后獲得角色即可,然后根據(jù)角色進(jìn)行相應(yīng)的操作烈拒。所以這一層就可以單獨(dú)抽離出來(lái)≡苍#現(xiàn)有的前后端發(fā)布平臺(tái)也已經(jīng)驗(yàn)證了這一點(diǎn)。

2.2 審批

審批需要哪些元素呢荆几? 申請(qǐng)人吓妆、審批內(nèi)容、審批人吨铸、審批狀態(tài)行拢。其中審批內(nèi)容在各個(gè)二方平臺(tái)是不一樣的。

盡管如此诞吱,還是可以抽象成兩個(gè)字段:審批單唯一標(biāo)識(shí)和用于查看審批詳情的鏈接舟奠。這兩個(gè)字段都可以由二方平臺(tái)提供。所以審批也是可以做抽象的狐胎。

三鸭栖、設(shè)計(jì)

如何設(shè)計(jì)這個(gè)統(tǒng)一的平臺(tái)將權(quán)限與審批流程標(biāo)準(zhǔn)化呢?首先看一下二方平臺(tái)和有贊移動(dòng)權(quán)限與審批統(tǒng)一管理平臺(tái)(以下簡(jiǎn)稱統(tǒng)一管理平臺(tái))的交互流程圖握巢。


首先晕鹊,二方平臺(tái)和統(tǒng)一管理平臺(tái)都要依賴CAS,CAS是有贊的用戶認(rèn)證平臺(tái)暴浦。這樣溅话,就可以基于同個(gè)用戶進(jìn)行權(quán)限管理。

3.1 二方平臺(tái)與統(tǒng)一管理平臺(tái)的交互

從圖中可以看到歌焦,二方平臺(tái)與統(tǒng)一管理平臺(tái)主要有四大交互:添加模塊飞几、獲取權(quán)限、提交發(fā)布單独撇、獲取發(fā)布單狀態(tài)屑墨。

3.1.1 添加模塊

模塊是最小的可配置權(quán)限的元素,比如weex發(fā)布平臺(tái)對(duì)應(yīng)的各個(gè)模塊纷铣、熱修復(fù)平臺(tái)對(duì)應(yīng)的App等卵史。需要在發(fā)布平臺(tái)配置權(quán)限的時(shí)候,就需要選擇模塊搜立。
所以以躯,二方平臺(tái)在注冊(cè)模塊的時(shí)候,需要同步到發(fā)布平臺(tái),帶上平臺(tái)和模塊的唯一標(biāo)識(shí)忧设,以及模塊的名稱刁标,增強(qiáng)可讀性。

3.1.2 獲取權(quán)限

權(quán)限由統(tǒng)一管理平臺(tái)管理址晕,模塊負(fù)責(zé)人可以編輯權(quán)限膀懈,其他人可以申請(qǐng)權(quán)限。

二方平臺(tái)通過(guò)攜帶平臺(tái)和模塊的唯一標(biāo)識(shí)斩箫,以及用戶的唯一標(biāo)識(shí)吏砂,從統(tǒng)一管理平臺(tái)獲取權(quán)限,依賴權(quán)限進(jìn)行相應(yīng)的操作乘客。

3.1.3 提交發(fā)布單

移動(dòng)側(cè)的各個(gè)二方平臺(tái)發(fā)布的內(nèi)容基本是配置類的信息,配置的內(nèi)容淀歇、格式易核、條件都不一樣。

比如weex發(fā)布的內(nèi)容包含平臺(tái)浪默、環(huán)境牡直、規(guī)則、描述纳决,和頁(yè)面列表碰逸,如圖:


而熱修復(fù)平臺(tái)發(fā)布的內(nèi)容包括應(yīng)用版本、補(bǔ)丁文件阔加、描述饵史、下發(fā)模式(規(guī)則)等:


首先想到的是將這些配置類內(nèi)容抽象成內(nèi)容、規(guī)則和描述胜榔。但是如果這么做的話胳喷,各個(gè)二方平臺(tái)展示時(shí)各自需要重新解析,也不便于根據(jù)內(nèi)容里的字段進(jìn)行搜索夭织。

所以吭露,各個(gè)二方平臺(tái)的發(fā)布頁(yè)面由各個(gè)平臺(tái)自己開(kāi)發(fā),提交發(fā)布單的時(shí)候尊惰,再將唯一標(biāo)識(shí)符(包含平臺(tái)讲竿、模塊、發(fā)布單ID等)和發(fā)布單詳情的url傳給統(tǒng)一管理平臺(tái)弄屡,統(tǒng)一管理平臺(tái)來(lái)維護(hù)一張審批表题禀,包含發(fā)布單唯一標(biāo)識(shí)符、狀態(tài)琢岩、申請(qǐng)人投剥、發(fā)布單詳情url等。

其中担孔,狀態(tài)包括待審批江锨、審批通過(guò)吃警、審批拒絕。發(fā)布單詳情url用于審批人在統(tǒng)一管理平臺(tái)審批時(shí)可以跳轉(zhuǎn)查看審批內(nèi)容詳情啄育。

3.1.4 獲取發(fā)布單狀態(tài)

各個(gè)二方平臺(tái)有各自的發(fā)布單詳情表酌心,而審批狀態(tài)統(tǒng)一從統(tǒng)一管理平臺(tái)獲取。二方平臺(tái)通過(guò)審批狀態(tài)挑豌,判斷是否可以進(jìn)行發(fā)布安券。

3.2 優(yōu)化改進(jìn)

3.2.1 權(quán)限申請(qǐng)入口

考慮到每次需要添加的權(quán)限的時(shí)候,都需要模塊負(fù)責(zé)人去權(quán)限管理頁(yè)面添加氓英,對(duì)于負(fù)責(zé)人來(lái)說(shuō)是一種不必要的時(shí)間浪費(fèi)侯勉。于是增加權(quán)限申請(qǐng)的入口,不僅在統(tǒng)一管理平臺(tái)可見(jiàn)铝阐,在各個(gè)二方平臺(tái)也開(kāi)發(fā)入口址貌,通過(guò)再url后面攜帶平臺(tái)、模塊徘键、角色等參數(shù)练对,跳轉(zhuǎn)到統(tǒng)一管理平臺(tái)的權(quán)限申請(qǐng)頁(yè)面。申請(qǐng)后吹害,模塊負(fù)責(zé)人會(huì)收到通知(企業(yè)微信螟凭、釘釘或者其他形式),同意申請(qǐng)即可它呀。既減少了模塊負(fù)責(zé)人的操作成本螺男,也減少了模塊負(fù)責(zé)人與申請(qǐng)人的溝通成本。

3.2.2 審批通知與審批結(jié)果通知

申請(qǐng)人發(fā)起發(fā)布申請(qǐng)后钟些,審批人會(huì)實(shí)時(shí)收到通知烟号。而審批人通過(guò)/拒絕申請(qǐng)后,申請(qǐng)人也會(huì)實(shí)時(shí)收到通知政恍。減少了二者的溝通成本汪拥。

3.2.3 允許關(guān)閉審批

可能有一些模塊的特殊性(測(cè)試模塊),或者環(huán)境的特殊性(有贊的網(wǎng)絡(luò)環(huán)境分為Daily篙耗、QA迫筑、Pre、Prod)宗弯,有些模塊在某些環(huán)境需要關(guān)閉審批脯燃,這樣更能提高效率。否則在測(cè)試環(huán)境蒙保,每次發(fā)布都要審批辕棚,著實(shí)比較麻煩。

四、總結(jié)

由此逝嚎,所有的審批操作和權(quán)限操作都在統(tǒng)一管理平臺(tái)進(jìn)行扁瓢。添加模塊、提交發(fā)布單和發(fā)布补君、回滾等操作在各自的二方平臺(tái)進(jìn)行引几。統(tǒng)一管理平臺(tái)以Dubbo的形式向二方平臺(tái)提供統(tǒng)一標(biāo)準(zhǔn)接口:

  • 接口一:在統(tǒng)一管理平臺(tái)創(chuàng)建模塊

  • 接口二:獲取到用戶在發(fā)布平臺(tái)的角色

  • 接口三:在統(tǒng)一管理平臺(tái)創(chuàng)建/撤回審批單

  • 接口四:獲取審批單的進(jìn)度

統(tǒng)一管理平臺(tái)的后臺(tái)操作頁(yè)面,主要是權(quán)限管理界面和審批界面挽铁。


由此就將發(fā)布的審批流程和權(quán)限管理進(jìn)行了標(biāo)準(zhǔn)化∥拔Γ現(xiàn)有的二方平臺(tái),以及將來(lái)更多二方平臺(tái)都可以通過(guò)統(tǒng)一管理平臺(tái)提供的接口接入叽掘,在統(tǒng)一管理平臺(tái)上進(jìn)行權(quán)限和審批流程的管理楣铁。后續(xù)隨著二方平臺(tái)的復(fù)雜度變高,權(quán)限角色的增加够掠,審批類型的增加都可以很方便地進(jìn)行擴(kuò)展和復(fù)用民褂。

標(biāo)準(zhǔn)化意義在于降低成本,包括開(kāi)發(fā)成本和使用成本疯潭。日常開(kāi)發(fā)中需要更多思考,識(shí)別業(yè)務(wù)中哪些可以標(biāo)準(zhǔn)化哪些需要個(gè)性化面殖,然后將可標(biāo)準(zhǔn)化的部分抽象出來(lái)做成服務(wù)竖哩,對(duì)于效率和擴(kuò)展性來(lái)說(shuō)都是更好的選擇。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末脊僚,一起剝皮案震驚了整個(gè)濱河市相叁,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌辽幌,老刑警劉巖增淹,帶你破解...
    沈念sama閱讀 217,542評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異乌企,居然都是意外死亡虑润,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門加酵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)拳喻,“玉大人,你說(shuō)我怎么就攤上這事猪腕∪叱海” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,912評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵陋葡,是天一觀的道長(zhǎng)亚亲。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么捌归? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,449評(píng)論 1 293
  • 正文 為了忘掉前任肛响,我火速辦了婚禮,結(jié)果婚禮上陨溅,老公的妹妹穿的比我還像新娘终惑。我一直安慰自己,他們只是感情好门扇,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,500評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布雹有。 她就那樣靜靜地躺著,像睡著了一般臼寄。 火紅的嫁衣襯著肌膚如雪霸奕。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,370評(píng)論 1 302
  • 那天吉拳,我揣著相機(jī)與錄音质帅,去河邊找鬼。 笑死留攒,一個(gè)胖子當(dāng)著我的面吹牛煤惩,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播炼邀,決...
    沈念sama閱讀 40,193評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼魄揉,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了拭宁?” 一聲冷哼從身側(cè)響起洛退,我...
    開(kāi)封第一講書(shū)人閱讀 39,074評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎杰标,沒(méi)想到半個(gè)月后兵怯,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,505評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡腔剂,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,722評(píng)論 3 335
  • 正文 我和宋清朗相戀三年媒区,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片桶蝎。...
    茶點(diǎn)故事閱讀 39,841評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡驻仅,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出登渣,到底是詐尸還是另有隱情噪服,我是刑警寧澤,帶...
    沈念sama閱讀 35,569評(píng)論 5 345
  • 正文 年R本政府宣布胜茧,位于F島的核電站粘优,受9級(jí)特大地震影響仇味,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜雹顺,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,168評(píng)論 3 328
  • 文/蒙蒙 一丹墨、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧嬉愧,春花似錦贩挣、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,783評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至裕便,卻和暖如春绒净,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背偿衰。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,918評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工挂疆, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人下翎。 一個(gè)月前我還...
    沈念sama閱讀 47,962評(píng)論 2 370
  • 正文 我出身青樓缤言,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親视事。 傳聞我的和親對(duì)象是個(gè)殘疾皇子墨闲,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,781評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 專業(yè)考題類型管理運(yùn)行工作負(fù)責(zé)人一般作業(yè)考題內(nèi)容選項(xiàng)A選項(xiàng)B選項(xiàng)C選項(xiàng)D選項(xiàng)E選項(xiàng)F正確答案 變電單選GYSZ本規(guī)程...
    小白兔去釣魚(yú)閱讀 8,988評(píng)論 0 13
  • When it comes to... 語(yǔ)言有一種力量,每每談到她的時(shí)候她總能給你制造一種意境郑口。(或許語(yǔ)言便是我們...
    三羊洋閱讀 229評(píng)論 0 0
  • 剛剛又重復(fù)到一個(gè)時(shí)間節(jié)點(diǎn) 很久之前做過(guò)的一個(gè)夢(mèng)境 然后在剛剛談話中出現(xiàn)了 場(chǎng)景 文字 一幕幕。 難道人生是一個(gè)輪回...
    憤怒的團(tuán)團(tuán)子閱讀 142評(píng)論 0 0
  • 安裝jdk 1盾鳞、輸入rpm -ivh 安裝包名字 2犬性、配置環(huán)境變量:輸入vi /etc/profile 在最后添加...
    老天愛(ài)笨小孩NB閱讀 184評(píng)論 0 0
  • 一級(jí)標(biāo)題 二級(jí)標(biāo)題 三級(jí)標(biāo)題 圖片插入 代碼塊 一盞燈, 一片昏黃腾仅; 一簡(jiǎn)書(shū)乒裆, 一杯淡茶。 守著那一份淡定推励, 品讀...
    o迎著風(fēng)o閱讀 188評(píng)論 0 0