@urugus/slack-cli 0.1.7 → 0.1.9
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.
- package/dist/commands/channels.d.ts.map +1 -1
- package/dist/commands/channels.js +3 -12
- package/dist/commands/channels.js.map +1 -1
- package/dist/commands/config-subcommands.d.ts +14 -0
- package/dist/commands/config-subcommands.d.ts.map +1 -0
- package/dist/commands/config-subcommands.js +65 -0
- package/dist/commands/config-subcommands.js.map +1 -0
- package/dist/commands/config.d.ts.map +1 -1
- package/dist/commands/config.js +7 -55
- package/dist/commands/config.js.map +1 -1
- package/dist/commands/history-display.d.ts +3 -0
- package/dist/commands/history-display.d.ts.map +1 -0
- package/dist/commands/history-display.js +33 -0
- package/dist/commands/history-display.js.map +1 -0
- package/dist/commands/history-validators.d.ts +5 -0
- package/dist/commands/history-validators.d.ts.map +1 -0
- package/dist/commands/history-validators.js +35 -0
- package/dist/commands/history-validators.js.map +1 -0
- package/dist/commands/history.d.ts.map +1 -1
- package/dist/commands/history.js +8 -51
- package/dist/commands/history.js.map +1 -1
- package/dist/utils/channel-formatter.d.ts +0 -3
- package/dist/utils/channel-formatter.d.ts.map +1 -1
- package/dist/utils/channel-formatter.js +8 -44
- package/dist/utils/channel-formatter.js.map +1 -1
- package/dist/utils/formatters/channels-list-formatters.d.ts +13 -0
- package/dist/utils/formatters/channels-list-formatters.d.ts.map +1 -0
- package/dist/utils/formatters/channels-list-formatters.js +53 -0
- package/dist/utils/formatters/channels-list-formatters.js.map +1 -0
- package/dist/utils/slack-api-client.d.ts +2 -3
- package/dist/utils/slack-api-client.d.ts.map +1 -1
- package/dist/utils/slack-api-client.js +9 -153
- package/dist/utils/slack-api-client.js.map +1 -1
- package/dist/utils/slack-operations/base-client.d.ts +10 -0
- package/dist/utils/slack-operations/base-client.d.ts.map +1 -0
- package/dist/utils/slack-operations/base-client.js +32 -0
- package/dist/utils/slack-operations/base-client.js.map +1 -0
- package/dist/utils/slack-operations/channel-operations.d.ts +15 -0
- package/dist/utils/slack-operations/channel-operations.d.ts.map +1 -0
- package/dist/utils/slack-operations/channel-operations.js +87 -0
- package/dist/utils/slack-operations/channel-operations.js.map +1 -0
- package/dist/utils/slack-operations/index.d.ts +4 -0
- package/dist/utils/slack-operations/index.d.ts.map +1 -0
- package/dist/utils/slack-operations/index.js +10 -0
- package/dist/utils/slack-operations/index.js.map +1 -0
- package/dist/utils/slack-operations/message-operations.d.ts +12 -0
- package/dist/utils/slack-operations/message-operations.d.ts.map +1 -0
- package/dist/utils/slack-operations/message-operations.js +80 -0
- package/dist/utils/slack-operations/message-operations.js.map +1 -0
- package/package.json +1 -1
- package/src/commands/channels.ts +4 -22
- package/src/commands/config-subcommands.ts +63 -0
- package/src/commands/config.ts +15 -69
- package/src/commands/history-display.ts +36 -0
- package/src/commands/history-validators.ts +46 -0
- package/src/commands/history.ts +13 -60
- package/src/utils/channel-formatter.ts +9 -53
- package/src/utils/formatters/channels-list-formatters.ts +59 -0
- package/src/utils/slack-api-client.ts +12 -181
- package/src/utils/slack-operations/base-client.ts +30 -0
- package/src/utils/slack-operations/channel-operations.ts +104 -0
- package/src/utils/slack-operations/index.ts +3 -0
- package/src/utils/slack-operations/message-operations.ts +94 -0
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ChannelsJsonFormatter = exports.ChannelsSimpleFormatter = exports.ChannelsTableFormatter = void 0;
|
|
4
|
+
exports.createChannelsListFormatter = createChannelsListFormatter;
|
|
5
|
+
const output_formatter_1 = require("./output-formatter");
|
|
6
|
+
class ChannelsTableFormatter extends output_formatter_1.BaseFormatter {
|
|
7
|
+
format(channels) {
|
|
8
|
+
// Print table header
|
|
9
|
+
console.log('Name Type Members Created Description');
|
|
10
|
+
console.log('─'.repeat(65));
|
|
11
|
+
// Print channel rows
|
|
12
|
+
channels.forEach((channel) => {
|
|
13
|
+
const name = channel.name.padEnd(17);
|
|
14
|
+
const type = channel.type.padEnd(9);
|
|
15
|
+
const members = channel.members.toString().padEnd(8);
|
|
16
|
+
const created = channel.created.padEnd(12);
|
|
17
|
+
const purpose = channel.purpose.length > 30 ? channel.purpose.substring(0, 27) + '...' : channel.purpose;
|
|
18
|
+
console.log(`${name} ${type} ${members} ${created} ${purpose}`);
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
exports.ChannelsTableFormatter = ChannelsTableFormatter;
|
|
23
|
+
class ChannelsSimpleFormatter extends output_formatter_1.BaseFormatter {
|
|
24
|
+
format(channels) {
|
|
25
|
+
channels.forEach((channel) => console.log(channel.name));
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
exports.ChannelsSimpleFormatter = ChannelsSimpleFormatter;
|
|
29
|
+
class ChannelsJsonFormatter extends output_formatter_1.BaseFormatter {
|
|
30
|
+
format(channels) {
|
|
31
|
+
console.log(JSON.stringify(channels.map((channel) => ({
|
|
32
|
+
id: channel.id,
|
|
33
|
+
name: channel.name,
|
|
34
|
+
type: channel.type,
|
|
35
|
+
members: channel.members,
|
|
36
|
+
created: channel.created + 'T00:00:00Z',
|
|
37
|
+
purpose: channel.purpose,
|
|
38
|
+
})), null, 2));
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
exports.ChannelsJsonFormatter = ChannelsJsonFormatter;
|
|
42
|
+
function createChannelsListFormatter(format) {
|
|
43
|
+
switch (format) {
|
|
44
|
+
case 'json':
|
|
45
|
+
return new ChannelsJsonFormatter();
|
|
46
|
+
case 'simple':
|
|
47
|
+
return new ChannelsSimpleFormatter();
|
|
48
|
+
case 'table':
|
|
49
|
+
default:
|
|
50
|
+
return new ChannelsTableFormatter();
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=channels-list-formatters.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"channels-list-formatters.js","sourceRoot":"","sources":["../../../src/utils/formatters/channels-list-formatters.ts"],"names":[],"mappings":";;;AAgDA,kEAUC;AA1DD,yDAAmD;AAGnD,MAAa,sBAAuB,SAAQ,gCAA0B;IACpE,MAAM,CAAC,QAAuB;QAC5B,qBAAqB;QACrB,OAAO,CAAC,GAAG,CAAC,+DAA+D,CAAC,CAAC;QAC7E,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QAE5B,qBAAqB;QACrB,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YAC3B,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;YACrC,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YACpC,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YACrD,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;YAC3C,MAAM,OAAO,GACX,OAAO,CAAC,OAAO,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;YAE3F,OAAO,CAAC,GAAG,CAAC,GAAG,IAAI,IAAI,IAAI,IAAI,OAAO,IAAI,OAAO,IAAI,OAAO,EAAE,CAAC,CAAC;QAClE,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AAlBD,wDAkBC;AAED,MAAa,uBAAwB,SAAQ,gCAA0B;IACrE,MAAM,CAAC,QAAuB;QAC5B,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;IAC3D,CAAC;CACF;AAJD,0DAIC;AAED,MAAa,qBAAsB,SAAQ,gCAA0B;IACnE,MAAM,CAAC,QAAuB;QAC5B,OAAO,CAAC,GAAG,CACT,IAAI,CAAC,SAAS,CACZ,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;YACzB,EAAE,EAAE,OAAO,CAAC,EAAE;YACd,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,YAAY;YACvC,OAAO,EAAE,OAAO,CAAC,OAAO;SACzB,CAAC,CAAC,EACH,IAAI,EACJ,CAAC,CACF,CACF,CAAC;IACJ,CAAC;CACF;AAjBD,sDAiBC;AAED,SAAgB,2BAA2B,CAAC,MAAc;IACxD,QAAQ,MAAM,EAAE,CAAC;QACf,KAAK,MAAM;YACT,OAAO,IAAI,qBAAqB,EAAE,CAAC;QACrC,KAAK,QAAQ;YACX,OAAO,IAAI,uBAAuB,EAAE,CAAC;QACvC,KAAK,OAAO,CAAC;QACb;YACE,OAAO,IAAI,sBAAsB,EAAE,CAAC;IACxC,CAAC;AACH,CAAC"}
|
|
@@ -60,14 +60,13 @@ export interface ChannelUnreadResult {
|
|
|
60
60
|
users: Map<string, string>;
|
|
61
61
|
}
|
|
62
62
|
export declare class SlackApiClient {
|
|
63
|
-
private
|
|
64
|
-
private
|
|
63
|
+
private channelOps;
|
|
64
|
+
private messageOps;
|
|
65
65
|
constructor(token: string);
|
|
66
66
|
sendMessage(channel: string, text: string): Promise<ChatPostMessageResponse>;
|
|
67
67
|
listChannels(options: ListChannelsOptions): Promise<Channel[]>;
|
|
68
68
|
getHistory(channel: string, options: HistoryOptions): Promise<HistoryResult>;
|
|
69
69
|
listUnreadChannels(): Promise<Channel[]>;
|
|
70
|
-
private listUnreadChannelsFallback;
|
|
71
70
|
getChannelUnread(channelNameOrId: string): Promise<ChannelUnreadResult>;
|
|
72
71
|
}
|
|
73
72
|
export declare const slackApiClient: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"slack-api-client.d.ts","sourceRoot":"","sources":["../../src/utils/slack-api-client.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"slack-api-client.d.ts","sourceRoot":"","sources":["../../src/utils/slack-api-client.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,171 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
3
|
exports.slackApiClient = exports.SlackApiClient = void 0;
|
|
7
|
-
const
|
|
8
|
-
const
|
|
9
|
-
const channel_resolver_1 = require("./channel-resolver");
|
|
10
|
-
const constants_1 = require("./constants");
|
|
4
|
+
const channel_operations_1 = require("./slack-operations/channel-operations");
|
|
5
|
+
const message_operations_1 = require("./slack-operations/message-operations");
|
|
11
6
|
class SlackApiClient {
|
|
12
7
|
constructor(token) {
|
|
13
|
-
this.
|
|
14
|
-
|
|
15
|
-
retries: 0, // Disable automatic retries to handle rate limits manually
|
|
16
|
-
},
|
|
17
|
-
logLevel: web_api_1.LogLevel.ERROR, // Reduce noise from WebClient logs
|
|
18
|
-
});
|
|
19
|
-
// Limit concurrent API calls to avoid rate limiting
|
|
20
|
-
this.rateLimiter = (0, p_limit_1.default)(constants_1.RATE_LIMIT.CONCURRENT_REQUESTS);
|
|
8
|
+
this.channelOps = new channel_operations_1.ChannelOperations(token);
|
|
9
|
+
this.messageOps = new message_operations_1.MessageOperations(token);
|
|
21
10
|
}
|
|
22
11
|
async sendMessage(channel, text) {
|
|
23
|
-
return
|
|
24
|
-
channel,
|
|
25
|
-
text,
|
|
26
|
-
});
|
|
12
|
+
return this.messageOps.sendMessage(channel, text);
|
|
27
13
|
}
|
|
28
14
|
async listChannels(options) {
|
|
29
|
-
|
|
30
|
-
let cursor;
|
|
31
|
-
// Paginate through all channels
|
|
32
|
-
do {
|
|
33
|
-
const response = await this.client.conversations.list({
|
|
34
|
-
types: options.types,
|
|
35
|
-
exclude_archived: options.exclude_archived,
|
|
36
|
-
limit: options.limit,
|
|
37
|
-
cursor,
|
|
38
|
-
});
|
|
39
|
-
if (response.channels) {
|
|
40
|
-
channels.push(...response.channels);
|
|
41
|
-
}
|
|
42
|
-
cursor = response.response_metadata?.next_cursor;
|
|
43
|
-
} while (cursor);
|
|
44
|
-
return channels;
|
|
15
|
+
return this.channelOps.listChannels(options);
|
|
45
16
|
}
|
|
46
17
|
async getHistory(channel, options) {
|
|
47
|
-
|
|
48
|
-
const channelId = await channel_resolver_1.channelResolver.resolveChannelId(channel, () => this.listChannels({
|
|
49
|
-
types: 'public_channel,private_channel,im,mpim',
|
|
50
|
-
exclude_archived: true,
|
|
51
|
-
limit: constants_1.DEFAULTS.CHANNELS_LIMIT,
|
|
52
|
-
}));
|
|
53
|
-
const response = await this.client.conversations.history({
|
|
54
|
-
channel: channelId,
|
|
55
|
-
limit: options.limit,
|
|
56
|
-
oldest: options.oldest,
|
|
57
|
-
});
|
|
58
|
-
const messages = response.messages;
|
|
59
|
-
// Get unique user IDs
|
|
60
|
-
const userIds = [...new Set(messages.filter((m) => m.user).map((m) => m.user))];
|
|
61
|
-
const users = new Map();
|
|
62
|
-
// Fetch user information
|
|
63
|
-
if (userIds.length > 0) {
|
|
64
|
-
for (const userId of userIds) {
|
|
65
|
-
try {
|
|
66
|
-
const userInfo = await this.client.users.info({ user: userId });
|
|
67
|
-
if (userInfo.user?.name) {
|
|
68
|
-
users.set(userId, userInfo.user.name);
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
catch (error) {
|
|
72
|
-
// If we can't get user info, we'll use the ID
|
|
73
|
-
users.set(userId, userId);
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
return { messages, users };
|
|
18
|
+
return this.messageOps.getHistory(channel, options);
|
|
78
19
|
}
|
|
79
20
|
async listUnreadChannels() {
|
|
80
|
-
|
|
81
|
-
// Use users.conversations to get unread counts in a single API call
|
|
82
|
-
const response = await this.client.users.conversations({
|
|
83
|
-
types: 'public_channel,private_channel,im,mpim',
|
|
84
|
-
exclude_archived: true,
|
|
85
|
-
limit: 1000,
|
|
86
|
-
user: undefined, // Current authenticated user
|
|
87
|
-
});
|
|
88
|
-
const channels = response.channels;
|
|
89
|
-
// Filter to only channels with unread messages
|
|
90
|
-
// The users.conversations endpoint includes unread_count_display
|
|
91
|
-
return channels.filter((channel) => (channel.unread_count_display || 0) > 0);
|
|
92
|
-
}
|
|
93
|
-
catch (error) {
|
|
94
|
-
// Fallback to the old method if users.conversations fails
|
|
95
|
-
console.warn('Failed to use users.conversations, falling back to conversations.list');
|
|
96
|
-
return this.listUnreadChannelsFallback();
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
async listUnreadChannelsFallback() {
|
|
100
|
-
// Get all conversations the user is a member of
|
|
101
|
-
const response = await this.client.conversations.list({
|
|
102
|
-
types: 'public_channel,private_channel,im,mpim',
|
|
103
|
-
exclude_archived: true,
|
|
104
|
-
limit: 1000,
|
|
105
|
-
});
|
|
106
|
-
const channels = response.channels;
|
|
107
|
-
const channelsWithUnread = [];
|
|
108
|
-
// Process channels one by one with delay to avoid rate limits
|
|
109
|
-
for (const channel of channels) {
|
|
110
|
-
try {
|
|
111
|
-
const info = await this.client.conversations.info({
|
|
112
|
-
channel: channel.id,
|
|
113
|
-
include_num_members: false,
|
|
114
|
-
});
|
|
115
|
-
const channelInfo = info.channel;
|
|
116
|
-
if (channelInfo.unread_count_display && channelInfo.unread_count_display > 0) {
|
|
117
|
-
channelsWithUnread.push({
|
|
118
|
-
...channel,
|
|
119
|
-
unread_count: channelInfo.unread_count || 0,
|
|
120
|
-
unread_count_display: channelInfo.unread_count_display || 0,
|
|
121
|
-
last_read: channelInfo.last_read,
|
|
122
|
-
});
|
|
123
|
-
}
|
|
124
|
-
// Add delay between API calls to avoid rate limiting
|
|
125
|
-
await new Promise((resolve) => setTimeout(resolve, 100));
|
|
126
|
-
}
|
|
127
|
-
catch (error) {
|
|
128
|
-
// Skip channels that fail
|
|
129
|
-
if (error instanceof Error && error.message?.includes('rate limit')) {
|
|
130
|
-
// If we hit rate limit, wait longer
|
|
131
|
-
await new Promise((resolve) => setTimeout(resolve, 5000));
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
return channelsWithUnread;
|
|
21
|
+
return this.channelOps.listUnreadChannels();
|
|
136
22
|
}
|
|
137
23
|
async getChannelUnread(channelNameOrId) {
|
|
138
|
-
|
|
139
|
-
const channelId = await channel_resolver_1.channelResolver.resolveChannelId(channelNameOrId, () => this.listChannels({
|
|
140
|
-
types: 'public_channel,private_channel,im,mpim',
|
|
141
|
-
exclude_archived: true,
|
|
142
|
-
limit: constants_1.DEFAULTS.CHANNELS_LIMIT,
|
|
143
|
-
}));
|
|
144
|
-
// Get channel info with unread count
|
|
145
|
-
const info = await this.client.conversations.info({
|
|
146
|
-
channel: channelId,
|
|
147
|
-
});
|
|
148
|
-
const channel = info.channel;
|
|
149
|
-
// Get unread messages
|
|
150
|
-
let messages = [];
|
|
151
|
-
let users = new Map();
|
|
152
|
-
if (channel.last_read && channel.unread_count > 0) {
|
|
153
|
-
const historyResult = await this.getHistory(channelId, {
|
|
154
|
-
limit: channel.unread_count,
|
|
155
|
-
oldest: channel.last_read,
|
|
156
|
-
});
|
|
157
|
-
messages = historyResult.messages;
|
|
158
|
-
users = historyResult.users;
|
|
159
|
-
}
|
|
160
|
-
return {
|
|
161
|
-
channel: {
|
|
162
|
-
...channel,
|
|
163
|
-
unread_count: channel.unread_count || 0,
|
|
164
|
-
unread_count_display: channel.unread_count_display || 0,
|
|
165
|
-
},
|
|
166
|
-
messages,
|
|
167
|
-
users,
|
|
168
|
-
};
|
|
24
|
+
return this.messageOps.getChannelUnread(channelNameOrId);
|
|
169
25
|
}
|
|
170
26
|
}
|
|
171
27
|
exports.SlackApiClient = SlackApiClient;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"slack-api-client.js","sourceRoot":"","sources":["../../src/utils/slack-api-client.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"slack-api-client.js","sourceRoot":"","sources":["../../src/utils/slack-api-client.ts"],"names":[],"mappings":";;;AACA,8EAA0E;AAC1E,8EAA0E;AAoE1E,MAAa,cAAc;IAIzB,YAAY,KAAa;QACvB,IAAI,CAAC,UAAU,GAAG,IAAI,sCAAiB,CAAC,KAAK,CAAC,CAAC;QAC/C,IAAI,CAAC,UAAU,GAAG,IAAI,sCAAiB,CAAC,KAAK,CAAC,CAAC;IACjD,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAAe,EAAE,IAAY;QAC7C,OAAO,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IACpD,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,OAA4B;QAC7C,OAAO,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IAC/C,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,OAAe,EAAE,OAAuB;QACvD,OAAO,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IACtD,CAAC;IAED,KAAK,CAAC,kBAAkB;QACtB,OAAO,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,CAAC;IAC9C,CAAC;IAED,KAAK,CAAC,gBAAgB,CAAC,eAAuB;QAC5C,OAAO,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC;IAC3D,CAAC;CACF;AA5BD,wCA4BC;AAEY,QAAA,cAAc,GAAG;IAC5B,YAAY,EAAE,KAAK,EAAE,KAAa,EAAE,OAA4B,EAAsB,EAAE;QACtF,MAAM,MAAM,GAAG,IAAI,cAAc,CAAC,KAAK,CAAC,CAAC;QACzC,OAAO,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IACtC,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { WebClient } from '@slack/web-api';
|
|
2
|
+
import pLimit from 'p-limit';
|
|
3
|
+
export declare class BaseSlackClient {
|
|
4
|
+
protected client: WebClient;
|
|
5
|
+
protected rateLimiter: ReturnType<typeof pLimit>;
|
|
6
|
+
constructor(token: string);
|
|
7
|
+
protected handleRateLimit(error: unknown): Promise<void>;
|
|
8
|
+
protected delay(ms: number): Promise<void>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=base-client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base-client.d.ts","sourceRoot":"","sources":["../../../src/utils/slack-operations/base-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAY,MAAM,gBAAgB,CAAC;AACrD,OAAO,MAAM,MAAM,SAAS,CAAC;AAG7B,qBAAa,eAAe;IAC1B,SAAS,CAAC,MAAM,EAAE,SAAS,CAAC;IAC5B,SAAS,CAAC,WAAW,EAAE,UAAU,CAAC,OAAO,MAAM,CAAC,CAAC;gBAErC,KAAK,EAAE,MAAM;cAWT,eAAe,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;cAO9C,KAAK,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAGjD"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.BaseSlackClient = void 0;
|
|
7
|
+
const web_api_1 = require("@slack/web-api");
|
|
8
|
+
const p_limit_1 = __importDefault(require("p-limit"));
|
|
9
|
+
const constants_1 = require("../constants");
|
|
10
|
+
class BaseSlackClient {
|
|
11
|
+
constructor(token) {
|
|
12
|
+
this.client = new web_api_1.WebClient(token, {
|
|
13
|
+
retryConfig: {
|
|
14
|
+
retries: 0, // Disable automatic retries to handle rate limits manually
|
|
15
|
+
},
|
|
16
|
+
logLevel: web_api_1.LogLevel.ERROR, // Reduce noise from WebClient logs
|
|
17
|
+
});
|
|
18
|
+
// Limit concurrent API calls to avoid rate limiting
|
|
19
|
+
this.rateLimiter = (0, p_limit_1.default)(constants_1.RATE_LIMIT.CONCURRENT_REQUESTS);
|
|
20
|
+
}
|
|
21
|
+
async handleRateLimit(error) {
|
|
22
|
+
if (error instanceof Error && error.message?.includes('rate limit')) {
|
|
23
|
+
// If we hit rate limit, wait longer
|
|
24
|
+
await new Promise((resolve) => setTimeout(resolve, 5000));
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
async delay(ms) {
|
|
28
|
+
await new Promise((resolve) => setTimeout(resolve, ms));
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
exports.BaseSlackClient = BaseSlackClient;
|
|
32
|
+
//# sourceMappingURL=base-client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base-client.js","sourceRoot":"","sources":["../../../src/utils/slack-operations/base-client.ts"],"names":[],"mappings":";;;;;;AAAA,4CAAqD;AACrD,sDAA6B;AAC7B,4CAA0C;AAE1C,MAAa,eAAe;IAI1B,YAAY,KAAa;QACvB,IAAI,CAAC,MAAM,GAAG,IAAI,mBAAS,CAAC,KAAK,EAAE;YACjC,WAAW,EAAE;gBACX,OAAO,EAAE,CAAC,EAAE,2DAA2D;aACxE;YACD,QAAQ,EAAE,kBAAQ,CAAC,KAAK,EAAE,mCAAmC;SAC9D,CAAC,CAAC;QACH,oDAAoD;QACpD,IAAI,CAAC,WAAW,GAAG,IAAA,iBAAM,EAAC,sBAAU,CAAC,mBAAmB,CAAC,CAAC;IAC5D,CAAC;IAES,KAAK,CAAC,eAAe,CAAC,KAAc;QAC5C,IAAI,KAAK,YAAY,KAAK,IAAI,KAAK,CAAC,OAAO,EAAE,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;YACpE,oCAAoC;YACpC,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC;QAC5D,CAAC;IACH,CAAC;IAES,KAAK,CAAC,KAAK,CAAC,EAAU;QAC9B,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;IAC1D,CAAC;CACF;AAzBD,0CAyBC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { BaseSlackClient } from './base-client';
|
|
2
|
+
import { Channel, ListChannelsOptions } from '../slack-api-client';
|
|
3
|
+
interface ChannelWithUnreadInfo extends Channel {
|
|
4
|
+
unread_count: number;
|
|
5
|
+
unread_count_display: number;
|
|
6
|
+
last_read?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare class ChannelOperations extends BaseSlackClient {
|
|
9
|
+
listChannels(options: ListChannelsOptions): Promise<Channel[]>;
|
|
10
|
+
listUnreadChannels(): Promise<Channel[]>;
|
|
11
|
+
private listUnreadChannelsFallback;
|
|
12
|
+
getChannelInfo(channelNameOrId: string): Promise<ChannelWithUnreadInfo>;
|
|
13
|
+
}
|
|
14
|
+
export {};
|
|
15
|
+
//# sourceMappingURL=channel-operations.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"channel-operations.d.ts","sourceRoot":"","sources":["../../../src/utils/slack-operations/channel-operations.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAGhD,OAAO,EAAE,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAEnE,UAAU,qBAAsB,SAAQ,OAAO;IAC7C,YAAY,EAAE,MAAM,CAAC;IACrB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,qBAAa,iBAAkB,SAAQ,eAAe;IAC9C,YAAY,CAAC,OAAO,EAAE,mBAAmB,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAuB9D,kBAAkB,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;YAahC,0BAA0B;IAwClC,cAAc,CAAC,eAAe,EAAE,MAAM,GAAG,OAAO,CAAC,qBAAqB,CAAC;CAe9E"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ChannelOperations = void 0;
|
|
4
|
+
const base_client_1 = require("./base-client");
|
|
5
|
+
const channel_resolver_1 = require("../channel-resolver");
|
|
6
|
+
const constants_1 = require("../constants");
|
|
7
|
+
class ChannelOperations extends base_client_1.BaseSlackClient {
|
|
8
|
+
async listChannels(options) {
|
|
9
|
+
const channels = [];
|
|
10
|
+
let cursor;
|
|
11
|
+
// Paginate through all channels
|
|
12
|
+
do {
|
|
13
|
+
const response = await this.client.conversations.list({
|
|
14
|
+
types: options.types,
|
|
15
|
+
exclude_archived: options.exclude_archived,
|
|
16
|
+
limit: options.limit,
|
|
17
|
+
cursor,
|
|
18
|
+
});
|
|
19
|
+
if (response.channels) {
|
|
20
|
+
channels.push(...response.channels);
|
|
21
|
+
}
|
|
22
|
+
cursor = response.response_metadata?.next_cursor;
|
|
23
|
+
} while (cursor);
|
|
24
|
+
return channels;
|
|
25
|
+
}
|
|
26
|
+
async listUnreadChannels() {
|
|
27
|
+
try {
|
|
28
|
+
// Use users.conversations to get unread counts in a single API call
|
|
29
|
+
// This endpoint doesn't return unread_count_display by default,
|
|
30
|
+
// so we'll use the fallback method instead
|
|
31
|
+
throw new Error('Using fallback method for unread counts');
|
|
32
|
+
}
|
|
33
|
+
catch (error) {
|
|
34
|
+
// Fallback to the old method if users.conversations fails
|
|
35
|
+
console.warn('Failed to use users.conversations, falling back to conversations.list');
|
|
36
|
+
return this.listUnreadChannelsFallback();
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
async listUnreadChannelsFallback() {
|
|
40
|
+
// Get all conversations the user is a member of
|
|
41
|
+
const response = await this.client.conversations.list({
|
|
42
|
+
types: 'public_channel,private_channel,im,mpim',
|
|
43
|
+
exclude_archived: true,
|
|
44
|
+
limit: 1000,
|
|
45
|
+
});
|
|
46
|
+
const channels = response.channels;
|
|
47
|
+
const channelsWithUnread = [];
|
|
48
|
+
// Process channels one by one with delay to avoid rate limits
|
|
49
|
+
for (const channel of channels) {
|
|
50
|
+
try {
|
|
51
|
+
const info = await this.client.conversations.info({
|
|
52
|
+
channel: channel.id,
|
|
53
|
+
include_num_members: false,
|
|
54
|
+
});
|
|
55
|
+
const channelInfo = info.channel;
|
|
56
|
+
if (channelInfo.unread_count_display && channelInfo.unread_count_display > 0) {
|
|
57
|
+
channelsWithUnread.push({
|
|
58
|
+
...channel,
|
|
59
|
+
unread_count: channelInfo.unread_count || 0,
|
|
60
|
+
unread_count_display: channelInfo.unread_count_display || 0,
|
|
61
|
+
last_read: channelInfo.last_read,
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
// Add delay between API calls to avoid rate limiting
|
|
65
|
+
await this.delay(100);
|
|
66
|
+
}
|
|
67
|
+
catch (error) {
|
|
68
|
+
// Skip channels that fail
|
|
69
|
+
await this.handleRateLimit(error);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return channelsWithUnread;
|
|
73
|
+
}
|
|
74
|
+
async getChannelInfo(channelNameOrId) {
|
|
75
|
+
const channelId = await channel_resolver_1.channelResolver.resolveChannelId(channelNameOrId, () => this.listChannels({
|
|
76
|
+
types: 'public_channel,private_channel,im,mpim',
|
|
77
|
+
exclude_archived: true,
|
|
78
|
+
limit: constants_1.DEFAULTS.CHANNELS_LIMIT,
|
|
79
|
+
}));
|
|
80
|
+
const info = await this.client.conversations.info({
|
|
81
|
+
channel: channelId,
|
|
82
|
+
});
|
|
83
|
+
return info.channel;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
exports.ChannelOperations = ChannelOperations;
|
|
87
|
+
//# sourceMappingURL=channel-operations.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"channel-operations.js","sourceRoot":"","sources":["../../../src/utils/slack-operations/channel-operations.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/utils/slack-operations/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MessageOperations = exports.ChannelOperations = exports.BaseSlackClient = void 0;
|
|
4
|
+
var base_client_1 = require("./base-client");
|
|
5
|
+
Object.defineProperty(exports, "BaseSlackClient", { enumerable: true, get: function () { return base_client_1.BaseSlackClient; } });
|
|
6
|
+
var channel_operations_1 = require("./channel-operations");
|
|
7
|
+
Object.defineProperty(exports, "ChannelOperations", { enumerable: true, get: function () { return channel_operations_1.ChannelOperations; } });
|
|
8
|
+
var message_operations_1 = require("./message-operations");
|
|
9
|
+
Object.defineProperty(exports, "MessageOperations", { enumerable: true, get: function () { return message_operations_1.MessageOperations; } });
|
|
10
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utils/slack-operations/index.ts"],"names":[],"mappings":";;;AAAA,6CAAgD;AAAvC,8GAAA,eAAe,OAAA;AACxB,2DAAyD;AAAhD,uHAAA,iBAAiB,OAAA;AAC1B,2DAAyD;AAAhD,uHAAA,iBAAiB,OAAA"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { ChatPostMessageResponse } from '@slack/web-api';
|
|
2
|
+
import { BaseSlackClient } from './base-client';
|
|
3
|
+
import { HistoryOptions, HistoryResult, ChannelUnreadResult } from '../slack-api-client';
|
|
4
|
+
export declare class MessageOperations extends BaseSlackClient {
|
|
5
|
+
private channelOps;
|
|
6
|
+
constructor(token: string);
|
|
7
|
+
sendMessage(channel: string, text: string): Promise<ChatPostMessageResponse>;
|
|
8
|
+
getHistory(channel: string, options: HistoryOptions): Promise<HistoryResult>;
|
|
9
|
+
getChannelUnread(channelNameOrId: string): Promise<ChannelUnreadResult>;
|
|
10
|
+
private fetchUserInfo;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=message-operations.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"message-operations.d.ts","sourceRoot":"","sources":["../../../src/utils/slack-operations/message-operations.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,gBAAgB,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAGhD,OAAO,EAAW,cAAc,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAGlG,qBAAa,iBAAkB,SAAQ,eAAe;IACpD,OAAO,CAAC,UAAU,CAAoB;gBAE1B,KAAK,EAAE,MAAM;IAKnB,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,uBAAuB,CAAC;IAO5E,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,aAAa,CAAC;IAyB5E,gBAAgB,CAAC,eAAe,EAAE,MAAM,GAAG,OAAO,CAAC,mBAAmB,CAAC;YA2B/D,aAAa;CAmB5B"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MessageOperations = void 0;
|
|
4
|
+
const base_client_1 = require("./base-client");
|
|
5
|
+
const channel_resolver_1 = require("../channel-resolver");
|
|
6
|
+
const constants_1 = require("../constants");
|
|
7
|
+
const channel_operations_1 = require("./channel-operations");
|
|
8
|
+
class MessageOperations extends base_client_1.BaseSlackClient {
|
|
9
|
+
constructor(token) {
|
|
10
|
+
super(token);
|
|
11
|
+
this.channelOps = new channel_operations_1.ChannelOperations(token);
|
|
12
|
+
}
|
|
13
|
+
async sendMessage(channel, text) {
|
|
14
|
+
return await this.client.chat.postMessage({
|
|
15
|
+
channel,
|
|
16
|
+
text,
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
async getHistory(channel, options) {
|
|
20
|
+
// Resolve channel name to ID if needed
|
|
21
|
+
const channelId = await channel_resolver_1.channelResolver.resolveChannelId(channel, () => this.channelOps.listChannels({
|
|
22
|
+
types: 'public_channel,private_channel,im,mpim',
|
|
23
|
+
exclude_archived: true,
|
|
24
|
+
limit: constants_1.DEFAULTS.CHANNELS_LIMIT,
|
|
25
|
+
}));
|
|
26
|
+
const response = await this.client.conversations.history({
|
|
27
|
+
channel: channelId,
|
|
28
|
+
limit: options.limit,
|
|
29
|
+
oldest: options.oldest,
|
|
30
|
+
});
|
|
31
|
+
const messages = response.messages;
|
|
32
|
+
// Get unique user IDs
|
|
33
|
+
const userIds = [...new Set(messages.filter((m) => m.user).map((m) => m.user))];
|
|
34
|
+
const users = await this.fetchUserInfo(userIds);
|
|
35
|
+
return { messages, users };
|
|
36
|
+
}
|
|
37
|
+
async getChannelUnread(channelNameOrId) {
|
|
38
|
+
const channel = await this.channelOps.getChannelInfo(channelNameOrId);
|
|
39
|
+
// Get unread messages
|
|
40
|
+
let messages = [];
|
|
41
|
+
let users = new Map();
|
|
42
|
+
if (channel.last_read && channel.unread_count > 0) {
|
|
43
|
+
const historyResult = await this.getHistory(channel.id, {
|
|
44
|
+
limit: channel.unread_count,
|
|
45
|
+
oldest: channel.last_read,
|
|
46
|
+
});
|
|
47
|
+
messages = historyResult.messages;
|
|
48
|
+
users = historyResult.users;
|
|
49
|
+
}
|
|
50
|
+
return {
|
|
51
|
+
channel: {
|
|
52
|
+
...channel,
|
|
53
|
+
unread_count: channel.unread_count || 0,
|
|
54
|
+
unread_count_display: channel.unread_count_display || 0,
|
|
55
|
+
},
|
|
56
|
+
messages,
|
|
57
|
+
users,
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
async fetchUserInfo(userIds) {
|
|
61
|
+
const users = new Map();
|
|
62
|
+
if (userIds.length > 0) {
|
|
63
|
+
for (const userId of userIds) {
|
|
64
|
+
try {
|
|
65
|
+
const userInfo = await this.client.users.info({ user: userId });
|
|
66
|
+
if (userInfo.user?.name) {
|
|
67
|
+
users.set(userId, userInfo.user.name);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
catch (error) {
|
|
71
|
+
// If we can't get user info, we'll use the ID
|
|
72
|
+
users.set(userId, userId);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return users;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
exports.MessageOperations = MessageOperations;
|
|
80
|
+
//# sourceMappingURL=message-operations.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"message-operations.js","sourceRoot":"","sources":["../../../src/utils/slack-operations/message-operations.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
package/src/commands/channels.ts
CHANGED
|
@@ -3,13 +3,8 @@ import { wrapCommand } from '../utils/command-wrapper';
|
|
|
3
3
|
import { createSlackClient } from '../utils/client-factory';
|
|
4
4
|
import { ERROR_MESSAGES } from '../utils/constants';
|
|
5
5
|
import { ChannelsOptions } from '../types/commands';
|
|
6
|
-
import {
|
|
7
|
-
|
|
8
|
-
formatChannelsAsTable,
|
|
9
|
-
formatChannelsAsSimple,
|
|
10
|
-
formatChannelsAsJson,
|
|
11
|
-
getChannelTypes,
|
|
12
|
-
} from '../utils/channel-formatter';
|
|
6
|
+
import { mapChannelToInfo, getChannelTypes } from '../utils/channel-formatter';
|
|
7
|
+
import { createChannelsListFormatter } from '../utils/formatters/channels-list-formatters';
|
|
13
8
|
|
|
14
9
|
export function setupChannelsCommand(): Command {
|
|
15
10
|
const channelsCommand = new Command('channels');
|
|
@@ -43,21 +38,8 @@ export function setupChannelsCommand(): Command {
|
|
|
43
38
|
|
|
44
39
|
// Format and display channels
|
|
45
40
|
const channelInfos = channels.map(mapChannelToInfo);
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
case 'simple':
|
|
49
|
-
formatChannelsAsSimple(channelInfos);
|
|
50
|
-
break;
|
|
51
|
-
|
|
52
|
-
case 'json':
|
|
53
|
-
formatChannelsAsJson(channelInfos);
|
|
54
|
-
break;
|
|
55
|
-
|
|
56
|
-
case 'table':
|
|
57
|
-
default:
|
|
58
|
-
formatChannelsAsTable(channelInfos);
|
|
59
|
-
break;
|
|
60
|
-
}
|
|
41
|
+
const formatter = createChannelsListFormatter(options.format);
|
|
42
|
+
formatter.format(channelInfos);
|
|
61
43
|
})
|
|
62
44
|
);
|
|
63
45
|
|