Skip to content

Commit

Permalink
Discord OAuth2 Provider - Extended to support Guild Roles (#50)
Browse files Browse the repository at this point in the history
* Added fetch role ids from discord api call

* Added support for Discord Guild roles by id

* Reduce diff

* Add myself to the consent file
  • Loading branch information
michael94ellis authored Dec 2, 2023
1 parent 50f3edc commit e626f47
Show file tree
Hide file tree
Showing 2 changed files with 61 additions and 11 deletions.
3 changes: 3 additions & 0 deletions assets/cla/consent.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -39,3 +39,6 @@
email: [email protected]
- name: Nick Gregory
email: [email protected]
- name: Michael Ellis
email: [email protected]

69 changes: 58 additions & 11 deletions pkg/idp/oauth/user.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,10 @@ import (
"strings"
)

type discordMember struct {
Roles []string `json:"roles"`
}

type userData struct {
Groups []string `json:"groups,omitempty"`
}
Expand Down Expand Up @@ -425,25 +429,68 @@ func (b *IdentityProvider) fetchDiscordGuilds(authToken string) (*userData, erro
continue
}

b.logger.Debug(
"Checking Guild Permissions",
zap.String("guildName", guild["name"].(string)),
)

// Check if the user has special permissions
if _, exists := guild["permissions"]; exists {
perm, err := strconv.Atoi(guild["permissions"].(string))
// Parses to int64 for 32-bit system support
perm, err := strconv.ParseInt(guild["permissions"].(string), 10, 64)
if err != nil {
continue
}
if (perm & 0x08) == 0x08 { // Check for admin privileges
b.logger.Debug(
"Error converting Guild permissions to integer",
zap.Any("error", err),
)
} else if (perm & 0x08) == 0x08 { // Check for admin privileges
data.Groups = append(data.Groups, fmt.Sprintf("discord.com/%s/admins", guildID))
}
}
}

data.Groups = append(data.Groups, fmt.Sprintf("discord.com/%s/members", guildID))
}
// Fetch roles information for the guild
if b.ScopeExists("guilds.members.read") {
reqURL = fmt.Sprintf("https://discord.com/api/v10/users/@me/guilds/%s/member", guildID)
req, err = http.NewRequest("GET", reqURL, nil)
if err != nil {
return nil, err
}
req.Header.Set("Accept", "application/json")
req.Header.Add("Authorization", "Bearer " + authToken)

b.logger.Debug(
"Parsed additional user data",
zap.String("url", reqURL),
zap.Any("data", data),
)
resp, err = cli.Do(req)
if err != nil {
return nil, err
}

respBody, err = ioutil.ReadAll(resp.Body)
resp.Body.Close()
if err != nil {
return nil, err
}

var memberData discordMember
if err := json.Unmarshal(respBody, &memberData); err != nil {
b.logger.Debug(
"Guild Roles request failed",
zap.Any("response", respBody),
zap.Any("error", err),
)
return nil, err
}

for _, roleID := range memberData.Roles {
data.Groups = append(data.Groups, fmt.Sprintf("discord.com/%s/role/%s", guildID, roleID))
}
}

b.logger.Debug(
"Parsed additional discord user data",
zap.String("url", reqURL),
zap.Any("data", data),
)
}

return data, nil
}

0 comments on commit e626f47

Please sign in to comment.