Module: Discordrb::API::User

Defined in:
lib/discordrb/api/user.rb

Overview

API calls for User object

Class Method Summary collapse

Class Method Details

.avatar_url(user_id, avatar_id, format = nil) ⇒ Object

Make an avatar URL from the user and avatar IDs


139
140
141
142
143
144
145
146
# File 'lib/discordrb/api/user.rb', line 139

def avatar_url(user_id, avatar_id, format = nil)
  format ||= if avatar_id.start_with?('a_')
               'gif'
             else
               'webp'
             end
  "#{Discordrb::API.cdn_url}/avatars/#{user_id}/#{avatar_id}.#{format}"
end

.change_own_nickname(token, server_id, nick, reason = nil) ⇒ Object

Change the current bot's nickname on a server


30
31
32
33
34
35
36
37
38
39
40
41
# File 'lib/discordrb/api/user.rb', line 30

def change_own_nickname(token, server_id, nick, reason = nil)
  Discordrb::API.request(
    :guilds_sid_members_me_nick,
    server_id, # This is technically a guild endpoint
    :patch,
    "#{Discordrb::API.api_base}/guilds/#{server_id}/members/@me/nick",
    { nick: nick }.to_json,
    Authorization: token,
    content_type: :json,
    'X-Audit-Log-Reason': reason
  )
end

.change_status_setting(token, status) ⇒ Object

Change user status setting


120
121
122
123
124
125
126
127
128
129
130
# File 'lib/discordrb/api/user.rb', line 120

def change_status_setting(token, status)
  Discordrb::API.request(
    :users_me_settings,
    nil,
    :patch,
    "#{Discordrb::API.api_base}/users/@me/settings",
    { status: status }.to_json,
    Authorization: token,
    content_type: :json
  )
end

.connections(token) ⇒ Object


109
110
111
112
113
114
115
116
117
# File 'lib/discordrb/api/user.rb', line 109

def connections(token)
  Discordrb::API.request(
    :users_me_connections,
    nil,
    :get,
    "#{Discordrb::API.api_base}/users/@me/connections",
    Authorization: token
  )
end

.create_pm(token, recipient_id) ⇒ Object


95
96
97
98
99
100
101
102
103
104
105
# File 'lib/discordrb/api/user.rb', line 95

def create_pm(token, recipient_id)
  Discordrb::API.request(
    :users_me_channels,
    nil,
    :post,
    "#{Discordrb::API.api_base}/users/@me/channels",
    { recipient_id: recipient_id }.to_json,
    Authorization: token,
    content_type: :json
  )
end

.default_avatar(discrim = 0) ⇒ Object

Returns one of the "default" discord avatars from the CDN given a discriminator


133
134
135
136
# File 'lib/discordrb/api/user.rb', line 133

def default_avatar(discrim = 0)
  index = discrim.to_i % 5
  "#{Discordrb::API.cdn_url}/embed/avatars/#{index}.png"
end

.leave_server(token, server_id) ⇒ Object


71
72
73
74
75
76
77
78
79
# File 'lib/discordrb/api/user.rb', line 71

def leave_server(token, server_id)
  Discordrb::API.request(
    :users_me_guilds_sid,
    nil,
    :delete,
    "#{Discordrb::API.api_base}/users/@me/guilds/#{server_id}",
    Authorization: token
  )
end

.profile(token) ⇒ Object


19
20
21
22
23
24
25
26
27
# File 'lib/discordrb/api/user.rb', line 19

def profile(token)
  Discordrb::API.request(
    :users_me,
    nil,
    :get,
    "#{Discordrb::API.api_base}/users/@me",
    Authorization: token
  )
end

.resolve(token, user_id) ⇒ Object


7
8
9
10
11
12
13
14
15
# File 'lib/discordrb/api/user.rb', line 7

def resolve(token, user_id)
  Discordrb::API.request(
    :users_uid,
    nil,
    :get,
    "#{Discordrb::API.api_base}/users/#{user_id}",
    Authorization: token
  )
end

.servers(token) ⇒ Object


59
60
61
62
63
64
65
66
67
# File 'lib/discordrb/api/user.rb', line 59

def servers(token)
  Discordrb::API.request(
    :users_me_guilds,
    nil,
    :get,
    "#{Discordrb::API.api_base}/users/@me/guilds",
    Authorization: token
  )
end

.update_profile(token, email, password, new_username, avatar, new_password = nil) ⇒ Object


45
46
47
48
49
50
51
52
53
54
55
# File 'lib/discordrb/api/user.rb', line 45

def update_profile(token, email, password, new_username, avatar, new_password = nil)
  Discordrb::API.request(
    :users_me,
    nil,
    :patch,
    "#{Discordrb::API.api_base}/users/@me",
    { avatar: avatar, email: email, new_password: new_password, password: password, username: new_username }.to_json,
    Authorization: token,
    content_type: :json
  )
end

.user_dms(token) ⇒ Object


83
84
85
86
87
88
89
90
91
# File 'lib/discordrb/api/user.rb', line 83

def user_dms(token)
  Discordrb::API.request(
    :users_me_channels,
    nil,
    :get,
    "#{Discordrb::API.api_base}/users/@me/channels",
    Authorization: token
  )
end