feat: initial prototype (#3)
Node.js CI / Lint and Test (push) Successful in 43s

### Explanation

_No response_

### Issue

_No response_

### Attestations

- [x] I have read and agree to the [Code of Conduct](https://docs.nhcarrigan.com/community/coc/)
- [x] I have read and agree to the [Community Guidelines](https://docs.nhcarrigan.com/community/guide/).
- [x] My contribution complies with the [Contributor Covenant](https://docs.nhcarrigan.com/dev/covenant/).

### Dependencies

- [x] I have pinned the dependencies to a specific patch version.

### Style

- [x] I have run the linter and resolved any errors.
- [x] My pull request uses an appropriate title, matching the conventional commit standards.
- [x] My scope of feat/fix/chore/etc. correctly matches the nature of changes in my pull request.

### Tests

- [ ] My contribution adds new code, and I have added tests to cover it.
- [ ] My contribution modifies existing code, and I have updated the tests to reflect these changes.
- [ ] All new and existing tests pass locally with my changes.
- [ ] Code coverage remains at or above the configured threshold.

### Documentation

_No response_

### Versioning

_No response_

Reviewed-on: #3
Co-authored-by: Naomi Carrigan <commits@nhcarrigan.com>
Co-committed-by: Naomi Carrigan <commits@nhcarrigan.com>
This commit was merged in pull request #3.
This commit is contained in:
2025-07-19 19:51:50 -07:00
committed by Naomi Carrigan
parent 78b4da6235
commit c84b984cb2
24 changed files with 5421 additions and 14 deletions
+37
View File
@@ -0,0 +1,37 @@
/**
* @copyright nhcarrigan
* @license Naomi's Public License
* @author Naomi Carrigan
*/
import { about } from "../commands/about.js";
import { config } from "../commands/config.js";
import type { Command } from "../interfaces/command.js";
import type { Sorielle } from "../interfaces/sorielle.js";
import type { ChatInputCommandInteraction } from "discord.js";
const handlers: { _default: Command } & Record<string, Command> = {
_default: async(_, interaction): Promise<void> => {
await interaction.reply({
content: `Unknown command: ${interaction.commandName}`,
});
},
about: about,
config: config,
};
/**
* Processes a slash command.
* @param sorielle - Sorielle's Discord instance.
* @param interaction - The command interaction payload from Discord.
*/
const chatInputInteractionCreate = async(
sorielle: Sorielle,
interaction: ChatInputCommandInteraction<"cached">,
): Promise<void> => {
const name = interaction.commandName;
// eslint-disable-next-line no-underscore-dangle -- We use _default as a fallback handler.
const handler = handlers[name] ?? handlers._default;
await handler(sorielle, interaction);
};
export { chatInputInteractionCreate };
+41
View File
@@ -0,0 +1,41 @@
/**
* @copyright nhcarrigan
* @license Naomi's Public License
* @author Naomi Carrigan
*/
import { checkGuildEntitlement } from "../utils/checkEntitlement.js";
import type { Sorielle } from "../interfaces/sorielle.js";
import type { Message } from "discord.js";
/**
* Processes a slash command.
* @param sorielle - Sorielle's Discord instance.
* @param message - The message payload from Discord.
*/
const messageCreate = async(
sorielle: Sorielle,
message: Message<true>,
): Promise<void> => {
const isEntitled = await checkGuildEntitlement(sorielle, message.guild);
if (!isEntitled) {
return;
}
const serverRecord = await sorielle.database.vents.findUnique({
where: {
serverId: message.guild.id,
},
});
if (!serverRecord) {
return;
}
if (serverRecord.channelId !== message.channel.id) {
return;
}
setTimeout(() => {
void message.delete().catch(() => {
return null;
});
}, serverRecord.ttl * 1000);
};
export { messageCreate };