API中的用戶權(quán)限控制

需求

服務(wù)器處理用戶對資源進行增刪改查的請求時刃永,需要判斷該用戶是否有權(quán)限進行相應(yīng)的操作:

POST
* 該用戶是否有權(quán)限創(chuàng)建此類資源茅撞?

GET
* 該用戶是否有權(quán)限查詢此類資源的權(quán)限煮落?
* 如果是查詢指定ID的資源,那么該用戶是否有查詢該資源的權(quán)限嚎莉?

PUT
* 該用戶是否有更新該資源的權(quán)限?

DELETE
* 該用戶是否有刪除該資源的權(quán)限佃蚜?

解決方案

通過oslo_policy庫實現(xiàn)RBAC。RBAC是指基于角色的訪問控制模型着绊,在該模型中谐算,包含四類對象:用戶、角色归露、許可洲脂、會話。一個用戶可以有多個角色靶擦,一個用戶可以發(fā)起多個會話腮考,每個角色擁有對某些特定資源的特定訪問權(quán)限雇毫。

實踐

Role:通過用戶的Token判斷用戶的角色

Rule:在配置文件中預(yù)定義訪問規(guī)則(WHO-WHAT-HOW)玄捕,程序啟動時加載規(guī)則。

三個租戶ID:一般控制器會帶有一個Context上下文對象棚放,Context對象又帶有一個Session會話對象枚粘,Session對象中帶有用戶請求的token,token中帶有租戶ID飘蚯;一般請求的URL中會帶有租戶的ID馍迄;如果是一個GET或PUT請求,所請求的資源一般也會有一個租戶ID字段局骤,需要校驗三個租戶ID是否一致攀圈。(這里倒不是RBAC,而是出于安全的考慮峦甩,一個租戶不能越權(quán)訪問到另一個租戶的資源)

在每個類型資源的控制器中添加控制邏輯:

  1. 指定本身資源類型
self.RBAC_TYPE = const.RESOURCE_TYPE_A
  1. POST
    • 該用戶是否有權(quán)限創(chuàng)建此類資源赘来?
      self._auth_check_action(context.session, self.project_id, const.RBAC_POST)
      
  2. GET
    • 該用戶是否有權(quán)限查詢此類資源的權(quán)限现喳?
    • 如果是查詢指定ID的資源,那么該用戶是否有查詢該資源的權(quán)限犬辰?
      db_obj = self._get_db_obj(id)
      self._auth_check_action(context.session, db_obj.project_id, const.RBAC_GET_ONE)
      # self._auth_check_action(context.session, db_obj.project_id, const.RBAC_GET_ALL)
      
  3. PUT
    • 該用戶是否有更新該資源的權(quán)限嗦篱?
      db_obj = self._get_db_obj(id)
      self._auth_check_action(context.session, db_obj.project_id, const.RBAC_PUT)
      
  4. DELETE
    • 該用戶是否有刪除該資源的權(quán)限?
      db_obj = self._get_db_obj(id)
      self._auth_check_action(context.session, db_obj.project_id, const.RBAC_DELETE)
      

其他注意點

  1. 查詢數(shù)據(jù)庫里的記錄時幌缝,為什么不指定租戶ID進行查詢灸促?
    這樣可以實現(xiàn)超級管理員的功能(如果指定租戶ID進行查詢,那么“超級管理員”就查詢不到所有資源了)涵卵。
  2. Token中的租戶ID和URL中的租戶ID是否匹配浴栽,應(yīng)該在Controller初始化時就統(tǒng)一進行校驗,而不是每個Controller分別進行實現(xiàn)或調(diào)用轿偎,在Controller中進行的校驗主要是:資源的所屬的租戶ID與請求token(或url)中的租戶ID是否匹配以及RBAC吃度。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市贴硫,隨后出現(xiàn)的幾起案子椿每,更是在濱河造成了極大的恐慌,老刑警劉巖英遭,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件间护,死亡現(xiàn)場離奇詭異,居然都是意外死亡挖诸,警方通過查閱死者的電腦和手機汁尺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來多律,“玉大人痴突,你說我怎么就攤上這事±擒瘢” “怎么了辽装?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長相味。 經(jīng)常有香客問我拾积,道長,這世上最難降的妖魔是什么丰涉? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任拓巧,我火速辦了婚禮,結(jié)果婚禮上一死,老公的妹妹穿的比我還像新娘肛度。我一直安慰自己,他們只是感情好投慈,可當(dāng)我...
    茶點故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布承耿。 她就那樣靜靜地躺著策吠,像睡著了一般。 火紅的嫁衣襯著肌膚如雪瘩绒。 梳的紋絲不亂的頭發(fā)上猴抹,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天,我揣著相機與錄音锁荔,去河邊找鬼蟀给。 笑死,一個胖子當(dāng)著我的面吹牛阳堕,可吹牛的內(nèi)容都是我干的跋理。 我是一名探鬼主播,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼恬总,長吁一口氣:“原來是場噩夢啊……” “哼前普!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起壹堰,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤拭卿,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后贱纠,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體峻厚,經(jīng)...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年谆焊,在試婚紗的時候發(fā)現(xiàn)自己被綠了惠桃。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,834評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡辖试,死狀恐怖辜王,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情罐孝,我是刑警寧澤呐馆,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站肾档,受9級特大地震影響摹恰,放射性物質(zhì)發(fā)生泄漏辫继。R本人自食惡果不足惜怒见,卻給世界環(huán)境...
    茶點故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望姑宽。 院中可真熱鬧遣耍,春花似錦、人聲如沸炮车。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至纪隙,卻和暖如春赊豌,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背绵咱。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工碘饼, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人悲伶。 一個月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓艾恼,卻偏偏與公主長得像,于是被迫代替她去往敵國和親麸锉。 傳聞我的和親對象是個殘疾皇子钠绍,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,779評論 2 354