mirror of
https://gitlab.com/Kwoth/nadekobot.git
synced 2025-09-11 01:38:27 -04:00
Compare commits
10 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
93df4f3bf3 | ||
|
073b832065 | ||
|
a01e580e03 | ||
|
6124e2fab5 | ||
|
4dd31d6a0b | ||
|
e8706d4006 | ||
|
140cc43c98 | ||
|
26b7149435 | ||
|
b354ee7269 | ||
|
b829ca0109 |
@@ -2,6 +2,15 @@
|
|||||||
|
|
||||||
Experimental changelog. Mostly based on [keepachangelog](https://keepachangelog.com/en/1.0.0/) except date format. a-c-f-r-o
|
Experimental changelog. Mostly based on [keepachangelog](https://keepachangelog.com/en/1.0.0/) except date format. a-c-f-r-o
|
||||||
|
|
||||||
|
## [4.3.15] - 21.05.2023
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
|
||||||
|
- Fixed -w 0 in trivia
|
||||||
|
- Fixed `.rps` amount field in the response
|
||||||
|
- Fixed `.showembed` output
|
||||||
|
- Fixed bank award's incorrect output message
|
||||||
|
|
||||||
## [4.3.14] - 02.04.2023
|
## [4.3.14] - 02.04.2023
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
|
@@ -123,7 +123,7 @@ In order to use music commands, you need ffmpeg and youtube-dl installed.
|
|||||||
- [ffmpeg-32bit] | [ffmpeg-64bit] - Download the **appropriate version** for your system (32 bit if you're running a 32 bit OS, or 64 if you're running a 64bit OS). Unzip it, and move `ffmpeg.exe` to a path that's in your PATH environment variable. If you don't know what that is, just move the `ffmpeg.exe` file to `NadekoBot/output`.
|
- [ffmpeg-32bit] | [ffmpeg-64bit] - Download the **appropriate version** for your system (32 bit if you're running a 32 bit OS, or 64 if you're running a 64bit OS). Unzip it, and move `ffmpeg.exe` to a path that's in your PATH environment variable. If you don't know what that is, just move the `ffmpeg.exe` file to `NadekoBot/output`.
|
||||||
- [youtube-dl] - Click to download the file, then move `youtube-dl.exe` to a path that's in your PATH environment variable. If you don't know what that is, just move the `youtube-dl.exe` file to `NadekoBot/system`.
|
- [youtube-dl] - Click to download the file, then move `youtube-dl.exe` to a path that's in your PATH environment variable. If you don't know what that is, just move the `youtube-dl.exe` file to `NadekoBot/system`.
|
||||||
|
|
||||||
[Updater]: https://dl.nadeko.bot/
|
[Updater]: https://dl.nadeko.bot/v3/
|
||||||
[Notepad++]: https://notepad-plus-plus.org/
|
[Notepad++]: https://notepad-plus-plus.org/
|
||||||
[.net]: https://dotnet.microsoft.com/download/dotnet/5.0
|
[.net]: https://dotnet.microsoft.com/download/dotnet/5.0
|
||||||
[Redis]: https://github.com/MicrosoftArchive/redis/releases/download/win-3.0.504/Redis-x64-3.0.504.msi
|
[Redis]: https://github.com/MicrosoftArchive/redis/releases/download/win-3.0.504/Redis-x64-3.0.504.msi
|
||||||
|
@@ -89,6 +89,5 @@ Some features have their own specific placeholders which are noted in that featu
|
|||||||
|
|
||||||
- `%rngX-Y%` - Returns a random number between X and Y
|
- `%rngX-Y%` - Returns a random number between X and Y
|
||||||
- `%target%` - Returns anything the user has written after the trigger (only works on Expressions)
|
- `%target%` - Returns anything the user has written after the trigger (only works on Expressions)
|
||||||
- `%img:stuff%` - Returns an `imgur.com` search for "stuff" (only works on Expressions)
|
|
||||||
|
|
||||||

|

|
||||||
|
@@ -1,5 +1,6 @@
|
|||||||
#nullable disable warnings
|
#nullable disable warnings
|
||||||
using SixLabors.ImageSharp.PixelFormats;
|
using SixLabors.ImageSharp.PixelFormats;
|
||||||
|
using System.Text.Json.Serialization;
|
||||||
|
|
||||||
namespace NadekoBot;
|
namespace NadekoBot;
|
||||||
|
|
||||||
@@ -7,14 +8,14 @@ public sealed record SmartEmbedArrayElementText : SmartEmbedTextBase
|
|||||||
{
|
{
|
||||||
public string Color { get; init; } = string.Empty;
|
public string Color { get; init; } = string.Empty;
|
||||||
|
|
||||||
public SmartEmbedArrayElementText() : base()
|
public SmartEmbedArrayElementText()
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public SmartEmbedArrayElementText(IEmbed eb) : base(eb)
|
public SmartEmbedArrayElementText(IEmbed eb) : base(eb)
|
||||||
{
|
{
|
||||||
|
Color = eb.Color is { } c ? new Rgba32(c.R, c.G, c.B).ToHex() : string.Empty;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override EmbedBuilder GetEmbedInternal()
|
protected override EmbedBuilder GetEmbedInternal()
|
||||||
@@ -63,6 +64,7 @@ public abstract record SmartEmbedTextBase : SmartText
|
|||||||
public SmartTextEmbedFooter Footer { get; init; }
|
public SmartTextEmbedFooter Footer { get; init; }
|
||||||
public SmartTextEmbedField[] Fields { get; init; }
|
public SmartTextEmbedField[] Fields { get; init; }
|
||||||
|
|
||||||
|
[JsonIgnore]
|
||||||
public bool IsValid
|
public bool IsValid
|
||||||
=> !string.IsNullOrWhiteSpace(Title)
|
=> !string.IsNullOrWhiteSpace(Title)
|
||||||
|| !string.IsNullOrWhiteSpace(Description)
|
|| !string.IsNullOrWhiteSpace(Description)
|
||||||
@@ -100,7 +102,7 @@ public abstract record SmartEmbedTextBase : SmartText
|
|||||||
IconUrl = ef.IconUrl
|
IconUrl = ef.IconUrl
|
||||||
}
|
}
|
||||||
: null;
|
: null;
|
||||||
|
|
||||||
if (eb.Fields.Length > 0)
|
if (eb.Fields.Length > 0)
|
||||||
{
|
{
|
||||||
Fields = eb.Fields.Select(field
|
Fields = eb.Fields.Select(field
|
||||||
|
@@ -1,4 +1,6 @@
|
|||||||
#nullable disable
|
#nullable disable
|
||||||
|
using System.Text.Json.Serialization;
|
||||||
|
|
||||||
namespace NadekoBot;
|
namespace NadekoBot;
|
||||||
|
|
||||||
public sealed record SmartEmbedTextArray : SmartText
|
public sealed record SmartEmbedTextArray : SmartText
|
||||||
@@ -6,6 +8,7 @@ public sealed record SmartEmbedTextArray : SmartText
|
|||||||
public string Content { get; set; }
|
public string Content { get; set; }
|
||||||
public SmartEmbedArrayElementText[] Embeds { get; set; }
|
public SmartEmbedArrayElementText[] Embeds { get; set; }
|
||||||
|
|
||||||
|
[JsonIgnore]
|
||||||
public bool IsValid
|
public bool IsValid
|
||||||
=> Embeds?.All(x => x.IsValid) ?? false;
|
=> Embeds?.All(x => x.IsValid) ?? false;
|
||||||
|
|
||||||
|
@@ -1,16 +1,20 @@
|
|||||||
#nullable disable
|
#nullable disable
|
||||||
using Newtonsoft.Json.Linq;
|
using Newtonsoft.Json.Linq;
|
||||||
|
using System.Text.Json.Serialization;
|
||||||
|
|
||||||
namespace NadekoBot;
|
namespace NadekoBot;
|
||||||
|
|
||||||
public abstract record SmartText
|
public abstract record SmartText
|
||||||
{
|
{
|
||||||
|
[JsonIgnore]
|
||||||
public bool IsEmbed
|
public bool IsEmbed
|
||||||
=> this is SmartEmbedText;
|
=> this is SmartEmbedText;
|
||||||
|
|
||||||
|
[JsonIgnore]
|
||||||
public bool IsPlainText
|
public bool IsPlainText
|
||||||
=> this is SmartPlainText;
|
=> this is SmartPlainText;
|
||||||
|
|
||||||
|
[JsonIgnore]
|
||||||
public bool IsEmbedArray
|
public bool IsEmbedArray
|
||||||
=> this is SmartEmbedTextArray;
|
=> this is SmartEmbedTextArray;
|
||||||
|
|
||||||
|
@@ -91,14 +91,10 @@ public partial class Gambling
|
|||||||
{
|
{
|
||||||
if (await _bank.AwardAsync(userId, amount))
|
if (await _bank.AwardAsync(userId, amount))
|
||||||
{
|
{
|
||||||
await ReplyErrorLocalizedAsync(strs.take_fail(N(amount),
|
await ctx.OkAsync();
|
||||||
_client.GetUser(userId)?.ToString()
|
|
||||||
?? userId.ToString(),
|
|
||||||
CurrencySign));
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
await ctx.OkAsync();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
[Cmd]
|
[Cmd]
|
||||||
|
@@ -840,7 +840,7 @@ public partial class Gambling : GamblingModule<GamblingService>
|
|||||||
else if (result.Result == RpsResultType.Win)
|
else if (result.Result == RpsResultType.Win)
|
||||||
{
|
{
|
||||||
if ((long)result.Won > 0)
|
if ((long)result.Won > 0)
|
||||||
embed.AddField(GetText(strs.won), N(amount.Value));
|
embed.AddField(GetText(strs.won), N((long)result.Won));
|
||||||
|
|
||||||
msg = GetText(strs.rps_win(ctx.User.Mention,
|
msg = GetText(strs.rps_win(ctx.User.Mention,
|
||||||
GetRpsPick(pick),
|
GetRpsPick(pick),
|
||||||
|
@@ -36,7 +36,7 @@ public partial class Games
|
|||||||
var (opts, _) = OptionsParser.ParseFrom(new TriviaOptions(), args);
|
var (opts, _) = OptionsParser.ParseFrom(new TriviaOptions(), args);
|
||||||
|
|
||||||
var config = _gamesConfig.Data;
|
var config = _gamesConfig.Data;
|
||||||
if (config.Trivia.MinimumWinReq > 0 && config.Trivia.MinimumWinReq > opts.WinRequirement)
|
if (opts.WinRequirement != 0 && config.Trivia.MinimumWinReq > 0 && config.Trivia.MinimumWinReq > opts.WinRequirement)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
var trivia = new TriviaGame(opts, _cache);
|
var trivia = new TriviaGame(opts, _cache);
|
||||||
|
@@ -157,7 +157,7 @@ public sealed class TriviaGame
|
|||||||
|
|
||||||
var isWin = false;
|
var isWin = false;
|
||||||
// if user won the game, tell the game to stop
|
// if user won the game, tell the game to stop
|
||||||
if (val >= _opts.WinRequirement)
|
if (_opts.WinRequirement != 0 && val >= _opts.WinRequirement)
|
||||||
{
|
{
|
||||||
_isStopped = true;
|
_isStopped = true;
|
||||||
isWin = true;
|
isWin = true;
|
||||||
|
@@ -550,15 +550,20 @@ public partial class Utility : NadekoModule
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var embed = msg.Embeds.FirstOrDefault();
|
if (!msg.Embeds.Any())
|
||||||
if (embed is null)
|
|
||||||
{
|
{
|
||||||
await ReplyErrorLocalizedAsync(strs.not_found);
|
await ReplyErrorLocalizedAsync(strs.not_found);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var json = SmartEmbedText.FromEmbed(embed, msg.Content).ToJson(_showEmbedSerializerOptions);
|
var json = new SmartEmbedTextArray()
|
||||||
await SendConfirmAsync(Format.Sanitize(json).Replace("](", "]\\("));
|
{
|
||||||
|
Content = msg.Content,
|
||||||
|
Embeds = msg.Embeds
|
||||||
|
.Map(x => new SmartEmbedArrayElementText(x))
|
||||||
|
}.ToJson(_showEmbedSerializerOptions);
|
||||||
|
|
||||||
|
await SendConfirmAsync(Format.Code(json, "json").Replace("](", "]\\("));
|
||||||
}
|
}
|
||||||
|
|
||||||
[Cmd]
|
[Cmd]
|
||||||
|
@@ -7,7 +7,7 @@ namespace NadekoBot.Services;
|
|||||||
|
|
||||||
public sealed class StatsService : IStatsService, IReadyExecutor, INService
|
public sealed class StatsService : IStatsService, IReadyExecutor, INService
|
||||||
{
|
{
|
||||||
public const string BOT_VERSION = "4.3.14";
|
public const string BOT_VERSION = "4.3.15";
|
||||||
|
|
||||||
public string Author
|
public string Author
|
||||||
=> "Kwoth#2452";
|
=> "Kwoth#2452";
|
||||||
|
@@ -1559,7 +1559,7 @@ timezones:
|
|||||||
args:
|
args:
|
||||||
- ""
|
- ""
|
||||||
timezone:
|
timezone:
|
||||||
desc: "Sets this guilds timezone. This affects bot's time output in this server (logs, etc..)"
|
desc: "Sets this guilds timezone. This affects bot's time output in this server (logs, etc..) **Setting timezone requires Administrator server permission.**"
|
||||||
args:
|
args:
|
||||||
- ""
|
- ""
|
||||||
- "GMT Standard Time"
|
- "GMT Standard Time"
|
||||||
|
Reference in New Issue
Block a user