discorb 0.15.1 → 0.17.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (120) hide show
  1. checksums.yaml +4 -4
  2. data/.gitattributes +1 -0
  3. data/.github/workflows/build_main.yml +2 -2
  4. data/.github/workflows/build_version.yml +1 -1
  5. data/.github/workflows/codeql-analysis.yml +1 -1
  6. data/.github/workflows/lint-push.yml +3 -5
  7. data/.github/workflows/lint.yml +1 -1
  8. data/.github/workflows/spec.yml +33 -0
  9. data/.gitignore +2 -0
  10. data/.lefthook/commit-msg/validator.rb +5 -0
  11. data/.rspec +2 -0
  12. data/.rspec_parallel +2 -0
  13. data/.rubocop.yml +43 -6
  14. data/Changelog.md +29 -1
  15. data/Gemfile +14 -8
  16. data/Rakefile +44 -28
  17. data/bin/console +3 -3
  18. data/docs/Examples.md +1 -1
  19. data/docs/application_command.md +156 -47
  20. data/docs/cli/irb.md +2 -2
  21. data/docs/cli/new.md +14 -9
  22. data/docs/cli/run.md +7 -11
  23. data/docs/cli.md +17 -10
  24. data/docs/events.md +224 -210
  25. data/docs/extension.md +1 -2
  26. data/docs/faq.md +0 -1
  27. data/docs/tutorial.md +12 -12
  28. data/docs/voice_events.md +106 -106
  29. data/examples/commands/message.rb +63 -0
  30. data/examples/commands/permission.rb +18 -0
  31. data/examples/commands/slash.rb +44 -0
  32. data/examples/commands/user.rb +51 -0
  33. data/examples/components/authorization_button.rb +2 -2
  34. data/examples/components/select_menu.rb +2 -2
  35. data/examples/extension/main.rb +1 -1
  36. data/examples/extension/message_expander.rb +5 -2
  37. data/examples/simple/eval.rb +2 -2
  38. data/examples/simple/ping_pong.rb +1 -1
  39. data/examples/simple/rolepanel.rb +2 -2
  40. data/examples/simple/shard.rb +17 -0
  41. data/examples/simple/wait_for_message.rb +1 -1
  42. data/exe/discorb +31 -16
  43. data/lefthook.yml +45 -0
  44. data/lib/discorb/allowed_mentions.rb +1 -0
  45. data/lib/discorb/app_command/command.rb +124 -65
  46. data/lib/discorb/app_command/common.rb +25 -0
  47. data/lib/discorb/app_command/handler.rb +117 -34
  48. data/lib/discorb/app_command.rb +2 -1
  49. data/lib/discorb/application.rb +1 -0
  50. data/lib/discorb/asset.rb +1 -2
  51. data/lib/discorb/attachment.rb +1 -1
  52. data/lib/discorb/audit_logs.rb +14 -9
  53. data/lib/discorb/channel/base.rb +108 -0
  54. data/lib/discorb/channel/category.rb +32 -0
  55. data/lib/discorb/channel/container.rb +44 -0
  56. data/lib/discorb/channel/dm.rb +28 -0
  57. data/lib/discorb/channel/guild.rb +245 -0
  58. data/lib/discorb/channel/stage.rb +140 -0
  59. data/lib/discorb/channel/text.rb +345 -0
  60. data/lib/discorb/channel/thread.rb +321 -0
  61. data/lib/discorb/channel/voice.rb +79 -0
  62. data/lib/discorb/channel.rb +2 -1165
  63. data/lib/discorb/client.rb +158 -66
  64. data/lib/discorb/common.rb +2 -1
  65. data/lib/discorb/components/button.rb +2 -1
  66. data/lib/discorb/components/select_menu.rb +4 -2
  67. data/lib/discorb/components/text_input.rb +12 -2
  68. data/lib/discorb/components.rb +1 -1
  69. data/lib/discorb/embed.rb +22 -7
  70. data/lib/discorb/emoji.rb +30 -3
  71. data/lib/discorb/emoji_table.rb +4969 -3
  72. data/lib/discorb/event.rb +29 -4
  73. data/lib/discorb/exe/about.rb +1 -0
  74. data/lib/discorb/exe/irb.rb +2 -4
  75. data/lib/discorb/exe/new.rb +95 -28
  76. data/lib/discorb/exe/run.rb +9 -37
  77. data/lib/discorb/exe/setup.rb +25 -12
  78. data/lib/discorb/exe/show.rb +4 -3
  79. data/lib/discorb/extend.rb +1 -0
  80. data/lib/discorb/extension.rb +6 -3
  81. data/lib/discorb/flag.rb +11 -0
  82. data/lib/discorb/gateway.rb +237 -148
  83. data/lib/discorb/guild.rb +188 -56
  84. data/lib/discorb/guild_template.rb +10 -4
  85. data/lib/discorb/http.rb +17 -10
  86. data/lib/discorb/integration.rb +4 -1
  87. data/lib/discorb/intents.rb +1 -1
  88. data/lib/discorb/interaction/autocomplete.rb +29 -17
  89. data/lib/discorb/interaction/command.rb +38 -14
  90. data/lib/discorb/interaction/components.rb +6 -3
  91. data/lib/discorb/interaction/modal.rb +0 -1
  92. data/lib/discorb/interaction/response.rb +63 -24
  93. data/lib/discorb/interaction/root.rb +14 -14
  94. data/lib/discorb/interaction.rb +1 -0
  95. data/lib/discorb/invite.rb +5 -2
  96. data/lib/discorb/member.rb +25 -5
  97. data/lib/discorb/message.rb +47 -14
  98. data/lib/discorb/message_meta.rb +1 -0
  99. data/lib/discorb/modules.rb +56 -14
  100. data/lib/discorb/presence.rb +2 -2
  101. data/lib/discorb/rate_limit.rb +8 -3
  102. data/lib/discorb/role.rb +19 -4
  103. data/lib/discorb/shard.rb +74 -0
  104. data/lib/discorb/sticker.rb +8 -7
  105. data/lib/discorb/user.rb +2 -1
  106. data/lib/discorb/utils/colored_puts.rb +1 -0
  107. data/lib/discorb/voice_state.rb +10 -6
  108. data/lib/discorb/webhook.rb +51 -27
  109. data/lib/discorb.rb +7 -5
  110. data/po/yard.pot +20 -20
  111. data/rbs_collection.lock.yaml +96 -0
  112. data/rbs_collection.yaml +17 -0
  113. data/sig/async.rbs +5 -0
  114. data/sig/discorb.rbs +8667 -6851
  115. data/template-replace/files/css/common.css +4 -0
  116. metadata +26 -6
  117. data/examples/commands/bookmarker.rb +0 -42
  118. data/examples/commands/hello.rb +0 -10
  119. data/examples/commands/inspect.rb +0 -25
  120. data/lib/discorb/log.rb +0 -81
@@ -13,12 +13,13 @@ From: [Discord API docs](https://discord.com/developers/docs/interactions/applic
13
13
  ## How do I register an application command?
14
14
 
15
15
  Write to your script:
16
+
16
17
  - {Discorb::ApplicationCommand::Handler.slash}, {Discorb::ApplicationCommand::Handler.slash_group} for slash commands,
17
18
  - {Discorb::ApplicationCommand::Handler.user_command} for user menu commands,
18
19
  - {Discorb::ApplicationCommand::Handler.message_command} for message menu commands.
19
20
 
20
21
  And then run `discorb setup` to register your application commands.
21
- {file:docs/cli/setup.md Learn more about `discorb setup`}.
22
+ {file:docs/cli/setup.md Learn more about `discorb setup`}.
22
23
 
23
24
  ### Note
24
25
 
@@ -43,41 +44,47 @@ client.run(ENV["DISCORD_BOT_TOKEN"])
43
44
 
44
45
  {Discorb::ApplicationCommand::Handler#slash} takes 5 arguments:
45
46
 
46
- | Argument | Description |
47
- |---------|-------------|
48
- | `command_name` | The name of the command. |
49
- | `description` | The description of the command. |
50
- | `options` | A hash of options. |
51
- | `guild_ids` | The ID of the guild to register the command in. |
52
- | `block` | A block that will be called when the command is invoked. |
47
+ | Argument | Description |
48
+ | -------------- | -------------------------------------------------------- |
49
+ | `command_name` | The name of the command. |
50
+ | `description` | The description of the command. |
51
+ | `options` | A hash of options. |
52
+ | `guild_ids` | The ID of the guild to register the command in. |
53
+ | `block` | A block that will be called when the command is invoked. |
53
54
 
54
55
  Block will be called with a {Discorb::Interaction} object and specified options.
55
56
 
57
+ #### Register options
58
+
59
+ You can set hash to `options` argument.
56
60
  In `options`, hash should be like this:
57
61
 
58
62
  ```ruby
59
63
  {
60
- "Name" => {
64
+ "name" => {
61
65
  type: :string,
62
66
  required: true,
63
67
  description: "The description of the command."
64
68
  }
65
69
  }
66
70
  ```
67
- | Key | Type | Description |
68
- | --- | --- | --- |
69
- | `:description` | `String` | Description of the option. |
70
- | `:required` | Whether the argument is required. `optional` will be used if not specified. |
71
- | `:optional` | Whether the argument is optional. `required` will be used if not specified. |
72
- | `:type` | `Object` | Type of the option. |
73
- | `:choice` | `Hash{String => String, Integer, Float}` | Choice of the option. |
74
- | `:default` | `Object` | Default value of the option. |
75
- | `:channel_types` | `Array<Class<Discorb::Channel>>` | Type of the channel option. |
76
- | `:autocomplete` | `Proc` | Autocomplete function. |
77
- | `:range` | `Range` | Range of the option. Only valid for numeric options. (`:int`, `:float`) |
71
+
72
+ | Key | Type | Description |
73
+ | ------------------------ | ---------------------------------------- | ------------------------------------------------------------------------------------- |
74
+ | `:name_localizations` | `Hash{Symbol => String}` | Localizations of option name. |
75
+ | `:description` | `String` | Description of the option. |
76
+ | `:required` | `Boolean(true\|false)` | Whether the argument is required. `optional` will be used if not specified. |
77
+ | `:optional` | `Boolean(true\|false)` | Whether the argument is optional. `required` will be used if not specified. |
78
+ | `:type` | `Object` | Type of the option. |
79
+ | `:choices` | `Hash{String => String, Integer, Float}` | Choice of the option. |
80
+ | `:choices_localizations` | `Hash{String => Hash{Symbol => String}}` | Localization of the choice. Key must be the name of a choice. (See below for example) |
81
+ | `:default` | `Object` | Default value of the option. |
82
+ | `:channel_types` | `Array<Class<Discorb::Channel>>` | Type of the channel option. |
83
+ | `:autocomplete` | `Proc` | Autocomplete function. |
84
+ | `:range` | `Range` | Range of the option. Only valid for numeric options. (`:int`, `:float`) |
78
85
 
79
86
  `choices` should be unspecified if you don't want to use it.
80
- `choices` is hash like this:
87
+ `choices` example:
81
88
 
82
89
  ```ruby
83
90
  {
@@ -103,15 +110,28 @@ The key will be displayed in the user menu, and the value will be used as the ar
103
110
 
104
111
  In `type`, You must use one of the following:
105
112
 
106
- | Name | Description | Aliases|
107
- | --- | --- | --- |
108
- | `:string` | String argument. | `:str` |
109
- | `:integer` | Integer argument. | `:int` |
110
- | `:float` | Float argument. | None |
111
- | `:boolean` | Boolean argument. | `:bool` |
112
- | `:user` | User argument. | `:member` |
113
- | `:channel` | Channel argument. | None |
114
- | `:role` | Role argument. | None |
113
+ | Name | Description | Aliases |
114
+ | ---------- | ----------------- | --------- |
115
+ | `:string` | String argument. | `:str` |
116
+ | `:integer` | Integer argument. | `:int` |
117
+ | `:float` | Float argument. | None |
118
+ | `:boolean` | Boolean argument. | `:bool` |
119
+ | `:user` | User argument. | `:member` |
120
+ | `:channel` | Channel argument. | None |
121
+ | `:role` | Role argument. | None |
122
+
123
+ The block will receive the options as arguments.
124
+
125
+ ```ruby
126
+ client.slash("hello", "Bot greets", {
127
+ "name" => {
128
+ type: :string,
129
+ description: "Name"
130
+ }
131
+ }) do |interaction, name|
132
+ interaction.post("Hello, #{name}!", ephemeral: true)
133
+ end
134
+ ```
115
135
 
116
136
  #### Group Slash Commands
117
137
 
@@ -277,21 +297,21 @@ client.user_command("hello") do |interaction, user|
277
297
  interaction.post("Hello, #{user.name}!")
278
298
  end
279
299
  ```
300
+
280
301
  {Discorb::ApplicationCommand::Handler.user_command} takes 3 arguments:
281
302
 
282
- | Parameter | Description |
283
- | --- | --- |
284
- | `command_name` | The name of the command. |
285
- | `guild_ids` | The ID of the guild to register the command in. |
286
- | `block` | A block that will be called when the command is invoked. |
303
+ | Parameter | Description |
304
+ | -------------- | -------------------------------------------------------- |
305
+ | `command_name` | The name of the command. |
306
+ | `guild_ids` | The ID of the guild to register the command in. |
307
+ | `block` | A block that will be called when the command is invoked. |
287
308
 
288
309
  `block` will be called with two arguments:
289
310
 
290
- | Parameter | Description |
291
- | --- | --- |
311
+ | Parameter | Description |
312
+ | ------------- | ----------------------- |
292
313
  | `interaction` | The interaction object. |
293
- | `user` | The user object. |
294
-
314
+ | `user` | The user object. |
295
315
 
296
316
  ### Register Message Context Menu Command
297
317
 
@@ -303,15 +323,104 @@ end
303
323
 
304
324
  {Discorb::ApplicationCommand::Handler.message_command} takes 3 arguments:
305
325
 
306
- | Parameter | Description |
307
- | --- | --- |
308
- | `command_name` | The name of the command. |
309
- | `guild_ids` | The ID of the guild to register the command in. |
310
- | `block` | A block that will be called when the command is invoked. |
326
+ | Parameter | Description |
327
+ | -------------- | -------------------------------------------------------- |
328
+ | `command_name` | The name of the command. |
329
+ | `guild_ids` | The ID of the guild to register the command in. |
330
+ | `block` | A block that will be called when the command is invoked. |
311
331
 
312
332
  `block` will be called with two arguments:
313
333
 
314
- | Parameter | Description |
315
- | --- | --- |
334
+ | Parameter | Description |
335
+ | ------------- | ----------------------- |
316
336
  | `interaction` | The interaction object. |
317
- | `message` | The message object. |
337
+ | `message` | The message object. |
338
+
339
+ ### Localizing command
340
+
341
+ You can localize commands with passing parameters, or setting Hash to name.
342
+ Also, you can change the text by checking `interaction.locale` and `interaction.guild_locale`.
343
+
344
+ Command name localize example:
345
+
346
+ ```ruby
347
+ localizations = {
348
+ localized: {
349
+ text: {
350
+ en: "Hello, %s!",
351
+ ja: "%sさん、こんにちは!",
352
+ },
353
+ },
354
+ }
355
+
356
+ client.slash({
357
+ default: "greet",
358
+ ja: "挨拶",
359
+ }, {
360
+ default: "Bot greets. Cute OwO",
361
+ ja: "Botが挨拶します。かわいいね",
362
+ }, {
363
+ "name" => {
364
+ name_localizations: {
365
+ ja: "名前",
366
+ },
367
+ description: {
368
+ default: "The name to greet.",
369
+ ja: "挨拶する人の名前。",
370
+ },
371
+ type: :string,
372
+ optional: true,
373
+ },
374
+ }) do |interaction, name|
375
+ interaction.post(
376
+ (localizations[:localized][:text][interaction.locale] || localizations[:localized][:text][:en]) % [name || interaction.target.to_s_user],
377
+ ephemeral: true,
378
+ )
379
+ end
380
+ ```
381
+
382
+ Option localize example:
383
+
384
+ ```ruby
385
+ {
386
+ "vocaloid" => {
387
+ name_localizations: {
388
+ ja: "ボカロ",
389
+ },
390
+ required: true,
391
+ description: "The vocaloid which you like.",
392
+ description_localizations: {
393
+ ja: "好きなボカロ。",
394
+ },
395
+ type: :string,
396
+ choices: {
397
+ "Hatsune Miku" => "miku",
398
+ "Kagamine Rin" => "rin",
399
+ "Kagamine Len" => "len",
400
+ "Megurine Luka" => "luka",
401
+ "MEIKO" => "meiko",
402
+ "KAITO" => "kaito",
403
+ },
404
+ choice_localizations: {
405
+ "Hatsune Miku" => {
406
+ ja: "初音ミク",
407
+ },
408
+ "Kagamine Rin" => {
409
+ ja: "鏡音リン",
410
+ },
411
+ "Kagamine Len" => {
412
+ ja: "鏡音レン",
413
+ },
414
+ "Megurine Luka" => {
415
+ ja: "巡音ルカ",
416
+ },
417
+ "MEIKO" => {
418
+ ja: "MEIKO",
419
+ },
420
+ "KAITO" => {
421
+ ja: "KAITO",
422
+ },
423
+ }
424
+ }
425
+ }
426
+ ```
data/docs/cli/irb.md CHANGED
@@ -6,7 +6,6 @@
6
6
 
7
7
  This command will start an interactive Ruby shell with connected client.
8
8
 
9
-
10
9
  ## Usage
11
10
 
12
11
  ```
@@ -16,6 +15,7 @@ discorb irb [options]
16
15
  ### Load a token
17
16
 
18
17
  discorb irb will load a token from...
18
+
19
19
  1. the `DISCORD_BOT_TOKEN` environment variable
20
20
  2. the `DISCORD_TOKEN` environment variable
21
21
  3. `token` file in the current directory(customizable with `-t` option)
@@ -36,4 +36,4 @@ Token file to load.
36
36
 
37
37
  #### `message`
38
38
 
39
- Last message received.
39
+ Last message received.
data/docs/cli/new.md CHANGED
@@ -56,16 +56,21 @@ Default to TOKEN.
56
56
  Whether to overwrite an existing directory.
57
57
  Default to false.
58
58
 
59
+ ### `--[no-]comment`
60
+
61
+ Whether to write comment in main.rb.
62
+ Default to true.
63
+
59
64
  ## File structure
60
65
 
61
66
  The following files will be created:
62
67
 
63
- | File | Description |
64
- | ---- | ----------- |
65
- | `.env` | Environment variables. |
66
- | `main.rb` | Main script. |
67
- | `.gitignore` | Git ignore file. Won't be created if `--git` is false. |
68
- | `Gemfile` | Gemfile. Won't be created if `--bundle` is false. |
69
- | `Gemfile.lock` | Gemfile lock file. Won't be created if `--bundle` is false. |
70
- | `README.md` | Readme file. Won't be created if `--desc` is false. |
71
- | `.env.sample` | Sample environment variables. Won't be created if `--desc` is false. |
68
+ | File | Description |
69
+ | -------------- | -------------------------------------------------------------------- |
70
+ | `.env` | Environment variables. |
71
+ | `main.rb` | Main script. |
72
+ | `.gitignore` | Git ignore file. Won't be created if `--git` is false. |
73
+ | `Gemfile` | Gemfile. Won't be created if `--bundle` is false. |
74
+ | `Gemfile.lock` | Gemfile lock file. Won't be created if `--bundle` is false. |
75
+ | `README.md` | Readme file. Won't be created if `--desc` is false. |
76
+ | `.env.sample` | Sample environment variables. Won't be created if `--desc` is false. |
data/docs/cli/run.md CHANGED
@@ -6,7 +6,6 @@
6
6
 
7
7
  This command will run a client.
8
8
 
9
-
10
9
  ## Usage
11
10
 
12
11
  ```
@@ -31,12 +30,12 @@ The title of the process.
31
30
  Specify the log level.
32
31
  Should be one of the following:
33
32
 
34
- * `none`
35
- * `debug`
36
- * `info`
37
- * `warn`
38
- * `error`
39
- * `fatal`
33
+ - `none`
34
+ - `debug`
35
+ - `info`
36
+ - `warn`
37
+ - `error`
38
+ - `fatal`
40
39
 
41
40
  #### `-f`, `--log-file`
42
41
 
@@ -47,6 +46,7 @@ You can use `stdout` to write to the standard output, and `stderr` to write to t
47
46
 
48
47
  Whether to colorize the log output.
49
48
  If not specified, the default will be:
49
+
50
50
  - `true` if the file to write logs to is `stdout` or `stderr`.
51
51
  - `false` otherwise.
52
52
 
@@ -57,7 +57,3 @@ Whether to set up application commands.
57
57
  #### `-e`, `--env`
58
58
 
59
59
  The name of the environment variable to use for token, or just `-t` or `--token` for intractive prompt.
60
-
61
- #### `-b`, `--bundler`
62
-
63
- Whether to use bundler to load the script.
data/docs/cli.md CHANGED
@@ -9,20 +9,27 @@ discorb has a CLI tool for developing.
9
9
  ## Usage
10
10
 
11
11
  ```bash
12
- bundle exec discorb <command> ...
12
+ Usage: discorb [options] [subcommand [options]]
13
13
  ```
14
14
 
15
+ ## Options
16
+
17
+ ### `-b`, `--[no-]bundler`
18
+
19
+ Whether to use bundler.
20
+ Default to true.
21
+
15
22
  ## Commands
16
23
 
17
24
  Currently, discorb has the following commands:
18
25
 
19
- | Command | Description |
20
- |---------|-------------|
21
- | {file:docs/cli/new.md `new`} | Create a new project. |
22
- | {file:docs/cli/irb.md `irb`} | Start an interactive Ruby shell with connected client. |
23
- | {file:docs/cli/run.md `run`} | Run a client. |
24
- | {file:docs/cli/setup.md `setup`} | Setup application commands. |
25
- | `show` | Show your environment. (No document) |
26
- | `about` | Show discorb's information. (No document) |
26
+ | Command | Description |
27
+ | -------------------------------- | ------------------------------------------------------ |
28
+ | {file:docs/cli/new.md `new`} | Create a new project. |
29
+ | {file:docs/cli/irb.md `irb`} | Start an interactive Ruby shell with connected client. |
30
+ | {file:docs/cli/run.md `run`} | Run a client. |
31
+ | {file:docs/cli/setup.md `setup`} | Setup application commands. |
32
+ | `show` | Show your environment. (No document) |
33
+ | `about` | Show discorb's information. (No document) |
27
34
 
28
- Click the command name to see the document.
35
+ Click the command name to see the document.