comparison mod_groups_oidc/mod_groups_oidc.lua @ 5504:7d9dce4e7dd0

mod_groups_oidc: Expose groups to OAuth clients
author Kim Alvefur <zash@zash.se>
date Thu, 01 Jun 2023 18:32:59 +0200
parents
children
comparison
equal deleted inserted replaced
5503:320593cf7d90 5504:7d9dce4e7dd0
1 local array = require "util.array";
2
3 module:add_item("openid-claim", "groups");
4
5 local group_memberships = module:open_store("groups", "map");
6 local function user_groups(username)
7 return pairs(group_memberships:get_all(username) or {});
8 end
9
10 module:hook("token/userinfo", function(event)
11 local userinfo = event.userinfo;
12 if event.claims:contains("groups") then
13 userinfo.groups = array(user_groups(event.username));
14 end
15 end);