@jubbio/core 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (83) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +166 -0
  3. package/dist/Client.d.ts +147 -0
  4. package/dist/Client.js +471 -0
  5. package/dist/builders/ActionRowBuilder.d.ts +53 -0
  6. package/dist/builders/ActionRowBuilder.js +68 -0
  7. package/dist/builders/ButtonBuilder.d.ts +77 -0
  8. package/dist/builders/ButtonBuilder.js +96 -0
  9. package/dist/builders/EmbedBuilder.d.ts +157 -0
  10. package/dist/builders/EmbedBuilder.js +199 -0
  11. package/dist/builders/ModalBuilder.d.ts +122 -0
  12. package/dist/builders/ModalBuilder.js +162 -0
  13. package/dist/builders/SelectMenuBuilder.d.ts +123 -0
  14. package/dist/builders/SelectMenuBuilder.js +165 -0
  15. package/dist/builders/SlashCommandBuilder.d.ts +197 -0
  16. package/dist/builders/SlashCommandBuilder.js +324 -0
  17. package/dist/builders/index.d.ts +9 -0
  18. package/dist/builders/index.js +26 -0
  19. package/dist/enums.d.ts +196 -0
  20. package/dist/enums.js +216 -0
  21. package/dist/index.d.ts +25 -0
  22. package/dist/index.js +128 -0
  23. package/dist/managers/BaseManager.d.ts +69 -0
  24. package/dist/managers/BaseManager.js +106 -0
  25. package/dist/managers/ChannelManager.d.ts +98 -0
  26. package/dist/managers/ChannelManager.js +209 -0
  27. package/dist/managers/GuildMemberManager.d.ts +74 -0
  28. package/dist/managers/GuildMemberManager.js +156 -0
  29. package/dist/managers/RoleManager.d.ts +84 -0
  30. package/dist/managers/RoleManager.js +207 -0
  31. package/dist/managers/index.d.ts +7 -0
  32. package/dist/managers/index.js +24 -0
  33. package/dist/rest/REST.d.ts +483 -0
  34. package/dist/rest/REST.js +805 -0
  35. package/dist/rest/index.d.ts +1 -0
  36. package/dist/rest/index.js +18 -0
  37. package/dist/sharding/ShardingManager.d.ts +179 -0
  38. package/dist/sharding/ShardingManager.js +375 -0
  39. package/dist/sharding/index.d.ts +4 -0
  40. package/dist/sharding/index.js +21 -0
  41. package/dist/structures/Channel.d.ts +120 -0
  42. package/dist/structures/Channel.js +224 -0
  43. package/dist/structures/Collection.d.ts +53 -0
  44. package/dist/structures/Collection.js +115 -0
  45. package/dist/structures/Guild.d.ts +59 -0
  46. package/dist/structures/Guild.js +90 -0
  47. package/dist/structures/GuildMember.d.ts +130 -0
  48. package/dist/structures/GuildMember.js +208 -0
  49. package/dist/structures/Interaction.d.ts +224 -0
  50. package/dist/structures/Interaction.js +404 -0
  51. package/dist/structures/Message.d.ts +93 -0
  52. package/dist/structures/Message.js +145 -0
  53. package/dist/structures/User.d.ts +37 -0
  54. package/dist/structures/User.js +65 -0
  55. package/dist/structures/index.d.ts +7 -0
  56. package/dist/structures/index.js +25 -0
  57. package/dist/structures.d.ts +1 -0
  58. package/dist/structures.js +19 -0
  59. package/dist/types.d.ts +255 -0
  60. package/dist/types.js +3 -0
  61. package/dist/utils/BitField.d.ts +66 -0
  62. package/dist/utils/BitField.js +138 -0
  63. package/dist/utils/Collection.d.ts +116 -0
  64. package/dist/utils/Collection.js +265 -0
  65. package/dist/utils/Collector.d.ts +152 -0
  66. package/dist/utils/Collector.js +314 -0
  67. package/dist/utils/DataResolver.d.ts +61 -0
  68. package/dist/utils/DataResolver.js +146 -0
  69. package/dist/utils/Formatters.d.ts +145 -0
  70. package/dist/utils/Formatters.js +213 -0
  71. package/dist/utils/IntentsBitField.d.ts +85 -0
  72. package/dist/utils/IntentsBitField.js +99 -0
  73. package/dist/utils/Partials.d.ts +105 -0
  74. package/dist/utils/Partials.js +149 -0
  75. package/dist/utils/PermissionsBitField.d.ts +118 -0
  76. package/dist/utils/PermissionsBitField.js +145 -0
  77. package/dist/utils/SnowflakeUtil.d.ts +63 -0
  78. package/dist/utils/SnowflakeUtil.js +93 -0
  79. package/dist/utils/Sweepers.d.ts +127 -0
  80. package/dist/utils/Sweepers.js +270 -0
  81. package/dist/utils/index.d.ts +13 -0
  82. package/dist/utils/index.js +30 -0
  83. package/package.json +37 -0
@@ -0,0 +1,156 @@
1
+ "use strict";
2
+ /**
3
+ * Manager for guild members with caching and lazy loading
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.GuildMemberManager = void 0;
7
+ const BaseManager_1 = require("./BaseManager");
8
+ const Collection_1 = require("../utils/Collection");
9
+ /**
10
+ * Manages guild members
11
+ */
12
+ class GuildMemberManager extends BaseManager_1.CachedManager {
13
+ /** The guild this manager belongs to */
14
+ guild;
15
+ constructor(guild, iterable) {
16
+ // Use a simple object as placeholder since we don't have GuildMember class yet
17
+ super(guild.client, Object, iterable);
18
+ this.guild = guild;
19
+ }
20
+ /**
21
+ * Add a member to the cache
22
+ */
23
+ _add(data, cache = true) {
24
+ const id = data.user?.id ?? data.id;
25
+ const existing = this.cache.get(id);
26
+ if (existing) {
27
+ if (cache) {
28
+ Object.assign(existing, data);
29
+ }
30
+ return existing;
31
+ }
32
+ const member = {
33
+ id,
34
+ guildId: this.guild.id,
35
+ user: data.user,
36
+ nick: data.nick,
37
+ roles: data.roles ?? [],
38
+ joinedAt: data.joined_at ? new Date(data.joined_at) : null,
39
+ premiumSince: data.premium_since ? new Date(data.premium_since) : null,
40
+ deaf: data.deaf ?? false,
41
+ mute: data.mute ?? false,
42
+ pending: data.pending ?? false,
43
+ permissions: data.permissions,
44
+ communicationDisabledUntil: data.communication_disabled_until
45
+ ? new Date(data.communication_disabled_until)
46
+ : null,
47
+ // Helper methods
48
+ get displayName() {
49
+ return this.nick ?? this.user?.display_name ?? this.user?.username ?? 'Unknown';
50
+ },
51
+ toString() {
52
+ return `<@${this.id}>`;
53
+ },
54
+ };
55
+ if (cache) {
56
+ this.cache.set(id, member);
57
+ }
58
+ return member;
59
+ }
60
+ /**
61
+ * Fetch a member from the API
62
+ */
63
+ async fetch(id, options) {
64
+ if (!options?.force) {
65
+ const existing = this.cache.get(id);
66
+ if (existing)
67
+ return existing;
68
+ }
69
+ const data = await this.client.rest.request('GET', `/guilds/${this.guild.id}/members/${id}`);
70
+ return this._add(data, options?.cache ?? true);
71
+ }
72
+ /**
73
+ * Fetch multiple members
74
+ */
75
+ async fetchMany(options) {
76
+ const params = new URLSearchParams();
77
+ if (options?.limit)
78
+ params.set('limit', String(options.limit));
79
+ if (options?.after)
80
+ params.set('after', options.after);
81
+ if (options?.query)
82
+ params.set('query', options.query);
83
+ const data = await this.client.rest.request('GET', `/guilds/${this.guild.id}/members?${params}`);
84
+ const members = new Collection_1.Collection();
85
+ for (const memberData of data) {
86
+ const member = this._add(memberData);
87
+ members.set(member.id, member);
88
+ }
89
+ return members;
90
+ }
91
+ /**
92
+ * Search for members by query
93
+ */
94
+ async search(options) {
95
+ return this.fetchMany({ query: options.query, limit: options.limit ?? 10 });
96
+ }
97
+ /**
98
+ * Kick a member
99
+ */
100
+ async kick(id, reason) {
101
+ await this.client.rest.request('DELETE', `/guilds/${this.guild.id}/members/${id}`, reason ? { reason } : undefined);
102
+ this.cache.delete(id);
103
+ }
104
+ /**
105
+ * Ban a member
106
+ */
107
+ async ban(id, options) {
108
+ await this.client.rest.request('PUT', `/guilds/${this.guild.id}/bans/${id}`, {
109
+ delete_message_days: options?.deleteMessageDays,
110
+ reason: options?.reason,
111
+ });
112
+ this.cache.delete(id);
113
+ }
114
+ /**
115
+ * Unban a user
116
+ */
117
+ async unban(id, reason) {
118
+ await this.client.rest.request('DELETE', `/guilds/${this.guild.id}/bans/${id}`, reason ? { reason } : undefined);
119
+ }
120
+ /**
121
+ * Edit a member
122
+ */
123
+ async edit(id, data) {
124
+ const body = {};
125
+ if (data.nick !== undefined)
126
+ body.nick = data.nick;
127
+ if (data.roles !== undefined)
128
+ body.roles = data.roles;
129
+ if (data.mute !== undefined)
130
+ body.mute = data.mute;
131
+ if (data.deaf !== undefined)
132
+ body.deaf = data.deaf;
133
+ if (data.channel_id !== undefined)
134
+ body.channel_id = data.channel_id;
135
+ if (data.communication_disabled_until !== undefined) {
136
+ body.communication_disabled_until = data.communication_disabled_until?.toISOString() ?? null;
137
+ }
138
+ const result = await this.client.rest.request('PATCH', `/guilds/${this.guild.id}/members/${id}`, body);
139
+ return this._add(result);
140
+ }
141
+ /**
142
+ * Add a role to a member
143
+ */
144
+ async addRole(memberId, roleId, reason) {
145
+ await this.client.rest.request('PUT', `/guilds/${this.guild.id}/members/${memberId}/roles/${roleId}`, reason ? { reason } : undefined);
146
+ }
147
+ /**
148
+ * Remove a role from a member
149
+ */
150
+ async removeRole(memberId, roleId, reason) {
151
+ await this.client.rest.request('DELETE', `/guilds/${this.guild.id}/members/${memberId}/roles/${roleId}`, reason ? { reason } : undefined);
152
+ }
153
+ }
154
+ exports.GuildMemberManager = GuildMemberManager;
155
+ exports.default = GuildMemberManager;
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GuildMemberManager.js","sourceRoot":"","sources":["../../src/managers/GuildMemberManager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Manager for guild members with caching and lazy loading\r\n */\r\n\r\nimport { CachedManager } from './BaseManager';\r\nimport { Collection } from '../utils/Collection';\r\n\r\n/**\r\n * Manages guild members\r\n */\r\nexport class GuildMemberManager extends CachedManager<string, any> {\r\n  /** The guild this manager belongs to */\r\n  public readonly guild: any;\r\n\r\n  constructor(guild: any, iterable?: Iterable<any>) {\r\n    // Use a simple object as placeholder since we don't have GuildMember class yet\r\n    super(guild.client, Object as any, iterable);\r\n    this.guild = guild;\r\n  }\r\n\r\n  /**\r\n   * Add a member to the cache\r\n   */\r\n  _add(data: any, cache = true): any {\r\n    const id = data.user?.id ?? data.id;\r\n    const existing = this.cache.get(id);\r\n    \r\n    if (existing) {\r\n      if (cache) {\r\n        Object.assign(existing, data);\r\n      }\r\n      return existing;\r\n    }\r\n    \r\n    const member = {\r\n      id,\r\n      guildId: this.guild.id,\r\n      user: data.user,\r\n      nick: data.nick,\r\n      roles: data.roles ?? [],\r\n      joinedAt: data.joined_at ? new Date(data.joined_at) : null,\r\n      premiumSince: data.premium_since ? new Date(data.premium_since) : null,\r\n      deaf: data.deaf ?? false,\r\n      mute: data.mute ?? false,\r\n      pending: data.pending ?? false,\r\n      permissions: data.permissions,\r\n      communicationDisabledUntil: data.communication_disabled_until \r\n        ? new Date(data.communication_disabled_until) \r\n        : null,\r\n      \r\n      // Helper methods\r\n      get displayName() {\r\n        return this.nick ?? this.user?.display_name ?? this.user?.username ?? 'Unknown';\r\n      },\r\n      \r\n      toString() {\r\n        return `<@${this.id}>`;\r\n      },\r\n    };\r\n    \r\n    if (cache) {\r\n      this.cache.set(id, member);\r\n    }\r\n    \r\n    return member;\r\n  }\r\n\r\n  /**\r\n   * Fetch a member from the API\r\n   */\r\n  async fetch(id: string, options?: { cache?: boolean; force?: boolean }): Promise<any> {\r\n    if (!options?.force) {\r\n      const existing = this.cache.get(id);\r\n      if (existing) return existing;\r\n    }\r\n    \r\n    const data = await this.client.rest.request(\r\n      'GET',\r\n      `/guilds/${this.guild.id}/members/${id}`\r\n    );\r\n    \r\n    return this._add(data, options?.cache ?? true);\r\n  }\r\n\r\n  /**\r\n   * Fetch multiple members\r\n   */\r\n  async fetchMany(options?: { \r\n    limit?: number; \r\n    after?: string;\r\n    query?: string;\r\n  }): Promise<Collection<string, any>> {\r\n    const params = new URLSearchParams();\r\n    if (options?.limit) params.set('limit', String(options.limit));\r\n    if (options?.after) params.set('after', options.after);\r\n    if (options?.query) params.set('query', options.query);\r\n    \r\n    const data = await this.client.rest.request(\r\n      'GET',\r\n      `/guilds/${this.guild.id}/members?${params}`\r\n    );\r\n    \r\n    const members = new Collection<string, any>();\r\n    for (const memberData of data) {\r\n      const member = this._add(memberData);\r\n      members.set(member.id, member);\r\n    }\r\n    \r\n    return members;\r\n  }\r\n\r\n  /**\r\n   * Search for members by query\r\n   */\r\n  async search(options: { query: string; limit?: number }): Promise<Collection<string, any>> {\r\n    return this.fetchMany({ query: options.query, limit: options.limit ?? 10 });\r\n  }\r\n\r\n  /**\r\n   * Kick a member\r\n   */\r\n  async kick(id: string, reason?: string): Promise<void> {\r\n    await this.client.rest.request(\r\n      'DELETE',\r\n      `/guilds/${this.guild.id}/members/${id}`,\r\n      reason ? { reason } : undefined\r\n    );\r\n    this.cache.delete(id);\r\n  }\r\n\r\n  /**\r\n   * Ban a member\r\n   */\r\n  async ban(id: string, options?: { deleteMessageDays?: number; reason?: string }): Promise<void> {\r\n    await this.client.rest.request(\r\n      'PUT',\r\n      `/guilds/${this.guild.id}/bans/${id}`,\r\n      {\r\n        delete_message_days: options?.deleteMessageDays,\r\n        reason: options?.reason,\r\n      }\r\n    );\r\n    this.cache.delete(id);\r\n  }\r\n\r\n  /**\r\n   * Unban a user\r\n   */\r\n  async unban(id: string, reason?: string): Promise<void> {\r\n    await this.client.rest.request(\r\n      'DELETE',\r\n      `/guilds/${this.guild.id}/bans/${id}`,\r\n      reason ? { reason } : undefined\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Edit a member\r\n   */\r\n  async edit(id: string, data: {\r\n    nick?: string | null;\r\n    roles?: string[];\r\n    mute?: boolean;\r\n    deaf?: boolean;\r\n    channel_id?: string | null;\r\n    communication_disabled_until?: Date | null;\r\n  }): Promise<any> {\r\n    const body: any = {};\r\n    if (data.nick !== undefined) body.nick = data.nick;\r\n    if (data.roles !== undefined) body.roles = data.roles;\r\n    if (data.mute !== undefined) body.mute = data.mute;\r\n    if (data.deaf !== undefined) body.deaf = data.deaf;\r\n    if (data.channel_id !== undefined) body.channel_id = data.channel_id;\r\n    if (data.communication_disabled_until !== undefined) {\r\n      body.communication_disabled_until = data.communication_disabled_until?.toISOString() ?? null;\r\n    }\r\n    \r\n    const result = await this.client.rest.request(\r\n      'PATCH',\r\n      `/guilds/${this.guild.id}/members/${id}`,\r\n      body\r\n    );\r\n    \r\n    return this._add(result);\r\n  }\r\n\r\n  /**\r\n   * Add a role to a member\r\n   */\r\n  async addRole(memberId: string, roleId: string, reason?: string): Promise<void> {\r\n    await this.client.rest.request(\r\n      'PUT',\r\n      `/guilds/${this.guild.id}/members/${memberId}/roles/${roleId}`,\r\n      reason ? { reason } : undefined\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Remove a role from a member\r\n   */\r\n  async removeRole(memberId: string, roleId: string, reason?: string): Promise<void> {\r\n    await this.client.rest.request(\r\n      'DELETE',\r\n      `/guilds/${this.guild.id}/members/${memberId}/roles/${roleId}`,\r\n      reason ? { reason } : undefined\r\n    );\r\n  }\r\n}\r\n\r\nexport default GuildMemberManager;\r\n"]}
@@ -0,0 +1,84 @@
1
+ /**
2
+ * Manager for roles with caching and lazy loading
3
+ */
4
+ import { CachedManager } from './BaseManager';
5
+ import { Collection } from '../utils/Collection';
6
+ /**
7
+ * Manages roles for a guild
8
+ */
9
+ export declare class RoleManager extends CachedManager<string, any> {
10
+ /** The guild this manager belongs to */
11
+ readonly guild: any;
12
+ constructor(guild: any, iterable?: Iterable<any>);
13
+ /**
14
+ * Get the @everyone role
15
+ */
16
+ get everyone(): any;
17
+ /**
18
+ * Get the highest role
19
+ */
20
+ get highest(): any;
21
+ /**
22
+ * Get the bot's highest role
23
+ */
24
+ get botRoleFor(): (userId: string) => any | null;
25
+ /**
26
+ * Add a role to the cache
27
+ */
28
+ _add(data: any, cache?: boolean): any;
29
+ /**
30
+ * Fetch a role from the API
31
+ */
32
+ fetch(id: string, options?: {
33
+ cache?: boolean;
34
+ force?: boolean;
35
+ }): Promise<any>;
36
+ /**
37
+ * Fetch all roles for the guild
38
+ */
39
+ fetchAll(): Promise<Collection<string, any>>;
40
+ /**
41
+ * Create a new role
42
+ */
43
+ create(options?: {
44
+ name?: string;
45
+ color?: number | string;
46
+ hoist?: boolean;
47
+ position?: number;
48
+ permissions?: string | bigint;
49
+ mentionable?: boolean;
50
+ icon?: string;
51
+ unicodeEmoji?: string;
52
+ reason?: string;
53
+ }): Promise<any>;
54
+ /**
55
+ * Delete a role
56
+ */
57
+ delete(id: string, reason?: string): Promise<void>;
58
+ /**
59
+ * Edit a role
60
+ */
61
+ edit(id: string, data: {
62
+ name?: string;
63
+ color?: number | string;
64
+ hoist?: boolean;
65
+ position?: number;
66
+ permissions?: string | bigint;
67
+ mentionable?: boolean;
68
+ icon?: string | null;
69
+ unicodeEmoji?: string | null;
70
+ reason?: string;
71
+ }): Promise<any>;
72
+ /**
73
+ * Set role positions
74
+ */
75
+ setPositions(positions: Array<{
76
+ role: string;
77
+ position: number;
78
+ }>): Promise<Collection<string, any>>;
79
+ /**
80
+ * Compare two roles by position
81
+ */
82
+ comparePositions(role1: string | any, role2: string | any): number;
83
+ }
84
+ export default RoleManager;
@@ -0,0 +1,207 @@
1
+ "use strict";
2
+ /**
3
+ * Manager for roles with caching and lazy loading
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.RoleManager = void 0;
7
+ const BaseManager_1 = require("./BaseManager");
8
+ const Collection_1 = require("../utils/Collection");
9
+ /**
10
+ * Manages roles for a guild
11
+ */
12
+ class RoleManager extends BaseManager_1.CachedManager {
13
+ /** The guild this manager belongs to */
14
+ guild;
15
+ constructor(guild, iterable) {
16
+ super(guild.client, Object, iterable);
17
+ this.guild = guild;
18
+ }
19
+ /**
20
+ * Get the @everyone role
21
+ */
22
+ get everyone() {
23
+ return this.cache.get(this.guild.id) ?? null;
24
+ }
25
+ /**
26
+ * Get the highest role
27
+ */
28
+ get highest() {
29
+ return this.cache.reduce((prev, role) => (role.position > (prev?.position ?? -1)) ? role : prev, null);
30
+ }
31
+ /**
32
+ * Get the bot's highest role
33
+ */
34
+ get botRoleFor() {
35
+ return (userId) => {
36
+ const member = this.guild.members?.cache.get(userId);
37
+ if (!member)
38
+ return null;
39
+ return this.cache
40
+ .filter((role) => member.roles?.includes(role.id))
41
+ .sort((a, b) => b.position - a.position)
42
+ .first() ?? null;
43
+ };
44
+ }
45
+ /**
46
+ * Add a role to the cache
47
+ */
48
+ _add(data, cache = true) {
49
+ const id = data.id;
50
+ const existing = this.cache.get(id);
51
+ if (existing) {
52
+ if (cache)
53
+ Object.assign(existing, data);
54
+ return existing;
55
+ }
56
+ const role = {
57
+ id,
58
+ guildId: this.guild.id,
59
+ name: data.name,
60
+ color: data.color ?? 0,
61
+ hoist: data.hoist ?? false,
62
+ position: data.position ?? 0,
63
+ permissions: data.permissions ?? '0',
64
+ managed: data.managed ?? false,
65
+ mentionable: data.mentionable ?? false,
66
+ icon: data.icon ?? null,
67
+ unicodeEmoji: data.unicode_emoji ?? null,
68
+ tags: data.tags ?? null,
69
+ get hexColor() {
70
+ return `#${this.color.toString(16).padStart(6, '0')}`;
71
+ },
72
+ get createdAt() {
73
+ const timestamp = BigInt(this.id) >> 22n;
74
+ return new Date(Number(timestamp) + 1640995200000); // Jubbio epoch
75
+ },
76
+ toString() {
77
+ return this.id === this.guildId ? '@everyone' : `<@&${this.id}>`;
78
+ },
79
+ comparePositionTo(role) {
80
+ return this.position - (role?.position ?? 0);
81
+ },
82
+ async edit(data) {
83
+ return this.guild.roles.edit(this.id, data);
84
+ },
85
+ async delete(reason) {
86
+ return this.guild.roles.delete(this.id, reason);
87
+ },
88
+ async setPosition(position) {
89
+ return this.guild.roles.setPositions([{ role: this.id, position }]);
90
+ },
91
+ };
92
+ if (cache)
93
+ this.cache.set(id, role);
94
+ return role;
95
+ }
96
+ /**
97
+ * Fetch a role from the API
98
+ */
99
+ async fetch(id, options) {
100
+ if (!options?.force) {
101
+ const existing = this.cache.get(id);
102
+ if (existing)
103
+ return existing;
104
+ }
105
+ // Roles are fetched as part of guild, so fetch all
106
+ const roles = await this.fetchAll();
107
+ return roles.get(id) ?? null;
108
+ }
109
+ /**
110
+ * Fetch all roles for the guild
111
+ */
112
+ async fetchAll() {
113
+ const data = await this.client.rest.request('GET', `/guilds/${this.guild.id}/roles`);
114
+ const roles = new Collection_1.Collection();
115
+ for (const roleData of data) {
116
+ const role = this._add(roleData);
117
+ roles.set(role.id, role);
118
+ }
119
+ return roles;
120
+ }
121
+ /**
122
+ * Create a new role
123
+ */
124
+ async create(options) {
125
+ const body = {};
126
+ if (options?.name)
127
+ body.name = options.name;
128
+ if (options?.color !== undefined) {
129
+ body.color = typeof options.color === 'string'
130
+ ? parseInt(options.color.replace('#', ''), 16)
131
+ : options.color;
132
+ }
133
+ if (options?.hoist !== undefined)
134
+ body.hoist = options.hoist;
135
+ if (options?.permissions !== undefined)
136
+ body.permissions = String(options.permissions);
137
+ if (options?.mentionable !== undefined)
138
+ body.mentionable = options.mentionable;
139
+ if (options?.icon)
140
+ body.icon = options.icon;
141
+ if (options?.unicodeEmoji)
142
+ body.unicode_emoji = options.unicodeEmoji;
143
+ const data = await this.client.rest.request('POST', `/guilds/${this.guild.id}/roles`, body);
144
+ const role = this._add(data);
145
+ // Set position if specified
146
+ if (options?.position !== undefined) {
147
+ await this.setPositions([{ role: role.id, position: options.position }]);
148
+ }
149
+ return role;
150
+ }
151
+ /**
152
+ * Delete a role
153
+ */
154
+ async delete(id, reason) {
155
+ await this.client.rest.request('DELETE', `/guilds/${this.guild.id}/roles/${id}`, reason ? { reason } : undefined);
156
+ this.cache.delete(id);
157
+ }
158
+ /**
159
+ * Edit a role
160
+ */
161
+ async edit(id, data) {
162
+ const body = {};
163
+ if (data.name !== undefined)
164
+ body.name = data.name;
165
+ if (data.color !== undefined) {
166
+ body.color = typeof data.color === 'string'
167
+ ? parseInt(data.color.replace('#', ''), 16)
168
+ : data.color;
169
+ }
170
+ if (data.hoist !== undefined)
171
+ body.hoist = data.hoist;
172
+ if (data.permissions !== undefined)
173
+ body.permissions = String(data.permissions);
174
+ if (data.mentionable !== undefined)
175
+ body.mentionable = data.mentionable;
176
+ if (data.icon !== undefined)
177
+ body.icon = data.icon;
178
+ if (data.unicodeEmoji !== undefined)
179
+ body.unicode_emoji = data.unicodeEmoji;
180
+ const result = await this.client.rest.request('PATCH', `/guilds/${this.guild.id}/roles/${id}`, body);
181
+ return this._add(result);
182
+ }
183
+ /**
184
+ * Set role positions
185
+ */
186
+ async setPositions(positions) {
187
+ const body = positions.map(p => ({ id: p.role, position: p.position }));
188
+ const data = await this.client.rest.request('PATCH', `/guilds/${this.guild.id}/roles`, body);
189
+ const roles = new Collection_1.Collection();
190
+ for (const roleData of data) {
191
+ const role = this._add(roleData);
192
+ roles.set(role.id, role);
193
+ }
194
+ return roles;
195
+ }
196
+ /**
197
+ * Compare two roles by position
198
+ */
199
+ comparePositions(role1, role2) {
200
+ const r1 = typeof role1 === 'string' ? this.cache.get(role1) : role1;
201
+ const r2 = typeof role2 === 'string' ? this.cache.get(role2) : role2;
202
+ return (r1?.position ?? 0) - (r2?.position ?? 0);
203
+ }
204
+ }
205
+ exports.RoleManager = RoleManager;
206
+ exports.default = RoleManager;
207
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RoleManager.js","sourceRoot":"","sources":["../../src/managers/RoleManager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Manager for roles with caching and lazy loading\r\n */\r\n\r\nimport { CachedManager } from './BaseManager';\r\nimport { Collection } from '../utils/Collection';\r\n\r\n/**\r\n * Manages roles for a guild\r\n */\r\nexport class RoleManager extends CachedManager<string, any> {\r\n  /** The guild this manager belongs to */\r\n  public readonly guild: any;\r\n\r\n  constructor(guild: any, iterable?: Iterable<any>) {\r\n    super(guild.client, Object as any, iterable);\r\n    this.guild = guild;\r\n  }\r\n\r\n  /**\r\n   * Get the @everyone role\r\n   */\r\n  get everyone(): any {\r\n    return this.cache.get(this.guild.id) ?? null;\r\n  }\r\n\r\n  /**\r\n   * Get the highest role\r\n   */\r\n  get highest(): any {\r\n    return this.cache.reduce((prev, role) => \r\n      (role.position > (prev?.position ?? -1)) ? role : prev\r\n    , null as any);\r\n  }\r\n\r\n  /**\r\n   * Get the bot's highest role\r\n   */\r\n  get botRoleFor(): (userId: string) => any | null {\r\n    return (userId: string) => {\r\n      const member = this.guild.members?.cache.get(userId);\r\n      if (!member) return null;\r\n      return this.cache\r\n        .filter((role: any) => member.roles?.includes(role.id))\r\n        .sort((a: any, b: any) => b.position - a.position)\r\n        .first() ?? null;\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Add a role to the cache\r\n   */\r\n  _add(data: any, cache = true): any {\r\n    const id = data.id;\r\n    const existing = this.cache.get(id);\r\n    \r\n    if (existing) {\r\n      if (cache) Object.assign(existing, data);\r\n      return existing;\r\n    }\r\n    \r\n    const role = {\r\n      id,\r\n      guildId: this.guild.id,\r\n      name: data.name,\r\n      color: data.color ?? 0,\r\n      hoist: data.hoist ?? false,\r\n      position: data.position ?? 0,\r\n      permissions: data.permissions ?? '0',\r\n      managed: data.managed ?? false,\r\n      mentionable: data.mentionable ?? false,\r\n      icon: data.icon ?? null,\r\n      unicodeEmoji: data.unicode_emoji ?? null,\r\n      tags: data.tags ?? null,\r\n      \r\n      get hexColor() {\r\n        return `#${this.color.toString(16).padStart(6, '0')}`;\r\n      },\r\n      \r\n      get createdAt() {\r\n        const timestamp = BigInt(this.id) >> 22n;\r\n        return new Date(Number(timestamp) + 1640995200000); // Jubbio epoch\r\n      },\r\n      \r\n      toString() {\r\n        return this.id === this.guildId ? '@everyone' : `<@&${this.id}>`;\r\n      },\r\n      \r\n      comparePositionTo(role: any) {\r\n        return this.position - (role?.position ?? 0);\r\n      },\r\n      \r\n      async edit(data: any) {\r\n        return this.guild.roles.edit(this.id, data);\r\n      },\r\n      \r\n      async delete(reason?: string) {\r\n        return this.guild.roles.delete(this.id, reason);\r\n      },\r\n      \r\n      async setPosition(position: number) {\r\n        return this.guild.roles.setPositions([{ role: this.id, position }]);\r\n      },\r\n    };\r\n    \r\n    if (cache) this.cache.set(id, role);\r\n    return role;\r\n  }\r\n\r\n  /**\r\n   * Fetch a role from the API\r\n   */\r\n  async fetch(id: string, options?: { cache?: boolean; force?: boolean }): Promise<any> {\r\n    if (!options?.force) {\r\n      const existing = this.cache.get(id);\r\n      if (existing) return existing;\r\n    }\r\n    \r\n    // Roles are fetched as part of guild, so fetch all\r\n    const roles = await this.fetchAll();\r\n    return roles.get(id) ?? null;\r\n  }\r\n\r\n  /**\r\n   * Fetch all roles for the guild\r\n   */\r\n  async fetchAll(): Promise<Collection<string, any>> {\r\n    const data = await this.client.rest.request('GET', `/guilds/${this.guild.id}/roles`);\r\n    const roles = new Collection<string, any>();\r\n    for (const roleData of data) {\r\n      const role = this._add(roleData);\r\n      roles.set(role.id, role);\r\n    }\r\n    return roles;\r\n  }\r\n\r\n  /**\r\n   * Create a new role\r\n   */\r\n  async create(options?: {\r\n    name?: string;\r\n    color?: number | string;\r\n    hoist?: boolean;\r\n    position?: number;\r\n    permissions?: string | bigint;\r\n    mentionable?: boolean;\r\n    icon?: string;\r\n    unicodeEmoji?: string;\r\n    reason?: string;\r\n  }): Promise<any> {\r\n    const body: any = {};\r\n    if (options?.name) body.name = options.name;\r\n    if (options?.color !== undefined) {\r\n      body.color = typeof options.color === 'string' \r\n        ? parseInt(options.color.replace('#', ''), 16) \r\n        : options.color;\r\n    }\r\n    if (options?.hoist !== undefined) body.hoist = options.hoist;\r\n    if (options?.permissions !== undefined) body.permissions = String(options.permissions);\r\n    if (options?.mentionable !== undefined) body.mentionable = options.mentionable;\r\n    if (options?.icon) body.icon = options.icon;\r\n    if (options?.unicodeEmoji) body.unicode_emoji = options.unicodeEmoji;\r\n    \r\n    const data = await this.client.rest.request('POST', `/guilds/${this.guild.id}/roles`, body);\r\n    const role = this._add(data);\r\n    \r\n    // Set position if specified\r\n    if (options?.position !== undefined) {\r\n      await this.setPositions([{ role: role.id, position: options.position }]);\r\n    }\r\n    \r\n    return role;\r\n  }\r\n\r\n  /**\r\n   * Delete a role\r\n   */\r\n  async delete(id: string, reason?: string): Promise<void> {\r\n    await this.client.rest.request('DELETE', `/guilds/${this.guild.id}/roles/${id}`, \r\n      reason ? { reason } : undefined\r\n    );\r\n    this.cache.delete(id);\r\n  }\r\n\r\n  /**\r\n   * Edit a role\r\n   */\r\n  async edit(id: string, data: {\r\n    name?: string;\r\n    color?: number | string;\r\n    hoist?: boolean;\r\n    position?: number;\r\n    permissions?: string | bigint;\r\n    mentionable?: boolean;\r\n    icon?: string | null;\r\n    unicodeEmoji?: string | null;\r\n    reason?: string;\r\n  }): Promise<any> {\r\n    const body: any = {};\r\n    if (data.name !== undefined) body.name = data.name;\r\n    if (data.color !== undefined) {\r\n      body.color = typeof data.color === 'string' \r\n        ? parseInt(data.color.replace('#', ''), 16) \r\n        : data.color;\r\n    }\r\n    if (data.hoist !== undefined) body.hoist = data.hoist;\r\n    if (data.permissions !== undefined) body.permissions = String(data.permissions);\r\n    if (data.mentionable !== undefined) body.mentionable = data.mentionable;\r\n    if (data.icon !== undefined) body.icon = data.icon;\r\n    if (data.unicodeEmoji !== undefined) body.unicode_emoji = data.unicodeEmoji;\r\n    \r\n    const result = await this.client.rest.request('PATCH', `/guilds/${this.guild.id}/roles/${id}`, body);\r\n    return this._add(result);\r\n  }\r\n\r\n  /**\r\n   * Set role positions\r\n   */\r\n  async setPositions(positions: Array<{ role: string; position: number }>): Promise<Collection<string, any>> {\r\n    const body = positions.map(p => ({ id: p.role, position: p.position }));\r\n    const data = await this.client.rest.request('PATCH', `/guilds/${this.guild.id}/roles`, body);\r\n    \r\n    const roles = new Collection<string, any>();\r\n    for (const roleData of data) {\r\n      const role = this._add(roleData);\r\n      roles.set(role.id, role);\r\n    }\r\n    return roles;\r\n  }\r\n\r\n  /**\r\n   * Compare two roles by position\r\n   */\r\n  comparePositions(role1: string | any, role2: string | any): number {\r\n    const r1 = typeof role1 === 'string' ? this.cache.get(role1) : role1;\r\n    const r2 = typeof role2 === 'string' ? this.cache.get(role2) : role2;\r\n    return (r1?.position ?? 0) - (r2?.position ?? 0);\r\n  }\r\n}\r\n\r\nexport default RoleManager;\r\n"]}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Manager exports
3
+ */
4
+ export * from './BaseManager';
5
+ export * from './GuildMemberManager';
6
+ export * from './ChannelManager';
7
+ export * from './RoleManager';
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ /**
3
+ * Manager exports
4
+ */
5
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ var desc = Object.getOwnPropertyDescriptor(m, k);
8
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
9
+ desc = { enumerable: true, get: function() { return m[k]; } };
10
+ }
11
+ Object.defineProperty(o, k2, desc);
12
+ }) : (function(o, m, k, k2) {
13
+ if (k2 === undefined) k2 = k;
14
+ o[k2] = m[k];
15
+ }));
16
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
17
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
18
+ };
19
+ Object.defineProperty(exports, "__esModule", { value: true });
20
+ __exportStar(require("./BaseManager"), exports);
21
+ __exportStar(require("./GuildMemberManager"), exports);
22
+ __exportStar(require("./ChannelManager"), exports);
23
+ __exportStar(require("./RoleManager"), exports);
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlcnMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOztHQUVHOzs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsZ0RBQThCO0FBQzlCLHVEQUFxQztBQUNyQyxtREFBaUM7QUFDakMsZ0RBQThCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIE1hbmFnZXIgZXhwb3J0c1xyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vQmFzZU1hbmFnZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL0d1aWxkTWVtYmVyTWFuYWdlcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vQ2hhbm5lbE1hbmFnZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL1JvbGVNYW5hZ2VyJztcclxuIl19