mirror of
https://gitlab.com/gpvkt/twitchtts.git
synced 2025-04-06 03:50:08 +02:00
Compare commits
No commits in common. "v1.3.0" and "main" have entirely different histories.
10 changed files with 1629 additions and 630 deletions
5
.gitignore
vendored
5
.gitignore
vendored
|
@ -1,6 +1,9 @@
|
|||
config.yml
|
||||
build
|
||||
dist
|
||||
tts.spec
|
||||
tts.exe
|
||||
random*.txt
|
||||
quotes.txt
|
||||
tts.zip
|
||||
tts.log
|
||||
tts.log.?
|
103
CHANGELOG.md
103
CHANGELOG.md
|
@ -1,6 +1,107 @@
|
|||
# Change Log
|
||||
|
||||
All notable changes to this project will be documented in this file. If there is a `Changed` section please read carefully, as this often means that you will need to adapt your `config.yml`, otherwise the bot might fail to start.
|
||||
All notable changes to this project will be documented in this file. If there is a `Changed` section please read carefully, as this often means that you will need to adapt your `config.yml`.
|
||||
|
||||
## [1.8.1] - 2022-10-29
|
||||
|
||||
### Added 1.8.1
|
||||
|
||||
* Logging to file (tts.log)
|
||||
|
||||
### Fixed 1.8.1
|
||||
|
||||
* Error when checking black-/whitelist
|
||||
|
||||
## [1.8.0] - 2022-10-23
|
||||
|
||||
### Added 1.8.0
|
||||
|
||||
* Option to disable TTS audio output for !wiki function
|
||||
* Option to configure the number of sentences fetched by !wiki function
|
||||
* !wtoff command
|
||||
* !wton command
|
||||
|
||||
### Changed 1.8.0
|
||||
|
||||
* "oauth_token doesn't need to start with "oauth:" anymore
|
||||
* Improved oauth-token detection
|
||||
* Improved README.md
|
||||
|
||||
## [1.7.3] - 2022-10-20
|
||||
|
||||
### Fixed 1.7.3
|
||||
|
||||
* Crash when message has no/invalid metadata
|
||||
|
||||
## [1.7.2] - 2022-10-17
|
||||
|
||||
### Fixed 1.7.2
|
||||
|
||||
* Crash when evaluating !quickvote result
|
||||
|
||||
## [1.7.1] - 2022-10-02
|
||||
|
||||
### Fixed 1.7.1
|
||||
|
||||
* Allow usage of `!sq` command when TTS is disabled
|
||||
|
||||
## [1.7.0] - 2022-08-27
|
||||
|
||||
### Added 1.7.0
|
||||
|
||||
* Option to disable functions in `config.yml`
|
||||
|
||||
## [1.6.1] - 2022-08-25
|
||||
|
||||
### Fixed 1.6.1
|
||||
|
||||
* Type Error during pick
|
||||
* Improved command handling
|
||||
|
||||
## [1.6.0] - 2022-08-25
|
||||
|
||||
### Added 1.6.0
|
||||
|
||||
* `!pick` command
|
||||
|
||||
## [1.5.0] - 2022-08-24
|
||||
|
||||
### Added 1.5.0
|
||||
|
||||
* `!wiki` command
|
||||
* `!version` command
|
||||
|
||||
### Changed 1.5.0
|
||||
|
||||
* Added `!sq` as alias for `!smartquote`
|
||||
|
||||
### Fixed 1.5.0
|
||||
|
||||
* Darkmode: Options background color
|
||||
|
||||
## [1.4.0] - 2022-08-23
|
||||
|
||||
### Added 1.4.0
|
||||
|
||||
* `!usermap` command added
|
||||
* `!delay` command added
|
||||
* Darkmode added
|
||||
|
||||
## [1.3.2] - 2022-08-19
|
||||
|
||||
### Fixed 1.3.2
|
||||
|
||||
* `!smartquote` and `!addquote` are not longer Mods only.
|
||||
|
||||
## [1.3.1] - 2022-08-19
|
||||
|
||||
### Added 1.3.1
|
||||
|
||||
* Added `game_name` and date to quote
|
||||
|
||||
### Fixed (hopefully) 1.3.1
|
||||
|
||||
* Improved HTTP request handling (hopefully removes delay in Chrome)
|
||||
|
||||
## [1.3.0] - 2022-08-18
|
||||
|
||||
|
|
218
README.md
218
README.md
|
@ -1,21 +1,19 @@
|
|||
# Twitch TextToSpeech Bot
|
||||
|
||||
  
|
||||
  
|
||||
|
||||
A simple Twitch TTS bot (Web Speech API)
|
||||
|
||||
## Description
|
||||
|
||||
The goal of this project is to provide a simple to use Text to Speech IRC bot. It's mainly focused on Twitch, but might be easily adapt to other IRC chats as well. Anyway, right now some parts are Twitch specific (like `CAP REQ :twitch.tv/commands twitch.tv/tags`). There are some other projects providing TTS for IRC based chats, like [IRC Radio (TTS)](https://play.google.com/store/apps/details?id=com.earthflare.android.ircradio&hl=en&gl=US), but they are missing moderation features like Black-/Whitelists or deletion of single messages, before they are read. Therefore I created my own TTS bot, providing those features.
|
||||
The goal of this project is to provide a simple to use Text to Speech IRC bot. It's mainly focused on Twitch, but might be easily adapt to other IRC chats as well. Anyway, right now some parts are Twitch specific (like `CAP REQ :twitch.tv/commands twitch.tv/tags`). There are some other projects providing TTS for IRC based chats, like [IRC Radio (TTS)](https://play.google.com/store/apps/details?id=com.earthflare.android.ircradio&hl=en&gl=US), but they often are missing moderation features like Black-/Whitelists or deletion of single messages, before they are read. Therefore I created my own TTS bot, providing those features. Another very important aspect was that you should use almost any device capable running an HTML5-webbrowser as output. Therefore the bot uses a client-server "architecture". You can run the bot - for example - on your IRL server, but use your phone as output device. A mobile only solution always have the disadvantage of loosing messages, e.g. when your mobile connection drops.
|
||||
|
||||
The project consits of a very simple IRC client, which monitors the incoming messages. If a valid⃰ `!tts` command is detected the message will send into a queue. Depending on your config it will wait there a few seconds for deletion by you/your moderators. If nobody deletes the message, it will send into another queue. This queue will get fetched by the HTML frontend, which will be delivered by an internal webserver (backend). The HTML frontend will use the [Web Speech API](https://wicg.github.io/speech-api/) included in any modern webbrowser to read the incoming TTS message. When this is done it will report back to the webserver and the message will be removed from the queue.
|
||||
The project consits of a very simple IRC client, which monitors the incoming messages. If a valid (sender is not on the blacklist, message is not too long, etc.) `!tts` command is detected the message will send into a queue. Depending on your config it will wait there a few seconds for deletion by you/your moderators. If nobody deletes the message, it will send into another queue. This queue will get fetched by the HTML frontend, which will be delivered by an internal webserver (backend). The HTML frontend will use the [Web Speech API](https://wicg.github.io/speech-api/) included in any modern webbrowser to read the incoming TTS message. When this is done it will report back to the webserver and the message will be removed from the queue.
|
||||
|
||||
The server part is written in Python. The TTS part is written in Javascript.
|
||||
|
||||
By using Javascript for the actual TTS part it's not only very easy to access the Web Speech API and the underlying Speech features of your OS, it also makes it possible to use a wide range of devices to actually play the TTS output. You can start the backend on your PC/Server and open the frontend on your Android/iOS tablet or Mobile Phone. If you expose the backend to the internet (I would recommend to use a reverse proxy, rather than exposing the backend directly) you can also use the TTS bot on the go (e.g. your IRL setup).
|
||||
|
||||
(⃰sender is not on the blacklist, message is not too long, etc.)
|
||||
|
||||
## Getting Started
|
||||
|
||||
### Dependencies
|
||||
|
@ -28,11 +26,13 @@ By using Javascript for the actual TTS part it's not only very easy to access th
|
|||
|
||||
1. Clone the repo, or download and unzip the newest [Release](https://gitlab.com/gpvkt/twitchtts/-/releases)
|
||||
2. Rename/copy `config-dist.yml` to `config.yml`
|
||||
3. Move/copy `./dist/tts.exe` into the main directory (you can omit this step if you have Python installed)
|
||||
3. Adapt `config.yml` to your needs. See `Configuration` for details.
|
||||
|
||||
### Configuration
|
||||
|
||||
Adapt `config.yml` to your needs. Please use `UTF-8` as encoding. Example:
|
||||
Please use `UTF-8` as encoding, when editing `config.yml`.
|
||||
|
||||
Example:
|
||||
|
||||
``` lang=yaml
|
||||
irc:
|
||||
|
@ -51,10 +51,24 @@ bot:
|
|||
subonly: False
|
||||
modonly: False
|
||||
message_length: 200
|
||||
language: de
|
||||
|
||||
features:
|
||||
quote: True
|
||||
pick: True
|
||||
vote: True
|
||||
wiki: True
|
||||
wikitts: True
|
||||
wikisentences: 3
|
||||
random: True
|
||||
version: True
|
||||
ping: True
|
||||
|
||||
messages:
|
||||
toff: "TTS is now inactive."
|
||||
ton: "TTS is now active."
|
||||
wikitoff: "Wiki TTS is now inactive."
|
||||
wikiton: "Wiki TTS is now active."
|
||||
too_long: "Sorry, your TTS message is too long."
|
||||
disabled: "Sorry, TTS is disabled right now."
|
||||
denied: "Sorry, you are not allowed to use TTS."
|
||||
|
@ -67,6 +81,14 @@ messages:
|
|||
votenobody: "Nobody casted a vote. :("
|
||||
voteresult: "Voting has ended. The result is:"
|
||||
votes: "Votes"
|
||||
pickstart: "Pick started. Send #pickme to participate."
|
||||
pickresult: "Pick ended. The results are:"
|
||||
picknone: "Nobody was picked. :("
|
||||
quotenotfound: "Sorry, no quote found."
|
||||
quoteaddedprefix: "Quote:"
|
||||
quoteaddedsuffix: "added."
|
||||
wiki_too_many: "Sorry, there are too many possible results. Try a more narrow search."
|
||||
wiki_no_result: "Sorry, there was an error fetching the wikipedia answer."
|
||||
|
||||
log:
|
||||
level: "INFO"
|
||||
|
@ -103,11 +125,35 @@ Please note that the `oauth_token` is valid for approximately 60 days. If it bec
|
|||
* `subonly`: If `True` only Subs can use TTS
|
||||
* `modonly`: If `True` only Mods can use TTS
|
||||
* `message_length`: Maximum allowed message length for TTS
|
||||
* `language`: Language for `!wiki` command
|
||||
|
||||
##### features
|
||||
|
||||
* `quote`: Enable/Disable `!quote` function
|
||||
* `pick`: Enable/Disable `!pick` function
|
||||
* `wiki`: Enable/Disable `!wiki` function
|
||||
* `wikitts`: Enable/Disable audio output for `!wiki` function
|
||||
* `wikisentences`: Number of sentences fetched by `!wiki` function
|
||||
* `random`: Enable/Disable `!random` function
|
||||
* `version`: Enable/Disable `!version` function
|
||||
* `ping`: Enable/Disable `!ping` function
|
||||
|
||||
Please note, the text output from `!wiki` might been shorter that the TTS output. This is due to the Twitch chat message length restriction. Therefore the `wikisentences` option might not have any effects, when `wikitts` is set to `False`.
|
||||
|
||||
Please also note that every `.` in the wikipedia result is counted as a sentence. This might cause issues with certain date-formats, e.g. if `wikisentences` is set to `1` and `bot:language` is set to `de` the command `!wiki douglas adams` will only return:
|
||||
|
||||
```text
|
||||
Douglas Noël Adams (* 11.
|
||||
```
|
||||
|
||||
Therefore the recommended minimum value for `wikisentences` is `3`.
|
||||
|
||||
##### messages
|
||||
|
||||
* `toff`: The bots reply when `!toff` is used.
|
||||
* `ton`: The bots reply when `!ton` is used.
|
||||
* `wikitoff`: The bots reply when `!wikitoff` is used.
|
||||
* `wikiton`: The bots reply when `!wikiton` is used.
|
||||
* `too_long`: The bots reply if message exceeds `message_length`
|
||||
* `disabled`: The bots reply if TTS is disabled
|
||||
* `denied`: The bots reply if the user is not allowed to use TTS
|
||||
|
@ -115,14 +161,19 @@ Please note that the `oauth_token` is valid for approximately 60 days. If it bec
|
|||
* `whitelist`: The bots reply if `whitelist` is set and user isn't on the list.
|
||||
* `ready`: The bots init message
|
||||
* `says`: Prefix to add between username and message
|
||||
* `votestart`: Message when a quickvote is started.
|
||||
* `voteend`: Message if a quickvote ends.
|
||||
* `votenobody`: Message if quickvote ends, but nobody has voted.
|
||||
* `votestart`: Message when a quickvote was started.
|
||||
* `voteend`: Message when a quickvote ends.
|
||||
* `votenobody`: Message when quickvote ends, but nobody has voted.
|
||||
* `voteresult`: Prefix for the result (will be read out).
|
||||
* `votes`: Suffix to vote count.
|
||||
* `pickstart`: Message when `!pick` was started.
|
||||
* `pickresult`: Message when `!pick` ends.
|
||||
* `picknone`: Message if nobody was picked.
|
||||
* `quotenotfound`: Message if requests quote wasn't found.
|
||||
* `quoteaddedprefix`: Prefix for `Quote <number> added` message.
|
||||
* `quoteaddedsuffix`: Suffix for `Quote <number> added` message.
|
||||
* `wiki_too_many`: Message if `!wiki` command has more than one result.
|
||||
* `wiki_no_result`: Message if `!wiki` command hasn't a valid result.
|
||||
|
||||
##### log
|
||||
|
||||
|
@ -164,36 +215,156 @@ Connect to the configured Twitch channel and send a message starting with `!tts`
|
|||
Additional commands (broadcaster and mods only) are:
|
||||
|
||||
* `!ping`: Check if bot is alive (the bot should reply: `Pong!`)
|
||||
* `!version`: Print the bot version
|
||||
* `!toff`: Turn TTS off (will also empty the current TTS queue)
|
||||
* `!ton`: Turn TTS back on
|
||||
* `!wton`: Turn on TTS for `!wiki`
|
||||
* `!wtoff`: Turn off TTS for `!wiki`
|
||||
* `!dtts <username>`: Disable TTS for the given user
|
||||
* `!ptts <username>`: Allow TTS for the given user
|
||||
* `!usermap <username> <spoken name>`: Add an entry to the usermapping in `config.yml`
|
||||
* `!delay <int>`: Adjust the `clearmsg_timeout` in `config.yml`
|
||||
|
||||
### Additional features
|
||||
|
||||
You can enable/disable any feature in your `config.yml`:
|
||||
|
||||
``` lang=yaml
|
||||
features:
|
||||
quote: False
|
||||
pick: False
|
||||
vote: False
|
||||
wiki: False
|
||||
wikitts: False
|
||||
random: False
|
||||
version: True
|
||||
ping: True
|
||||
```
|
||||
|
||||
The default is enabled.
|
||||
|
||||
#### !quickvote
|
||||
|
||||
The `!quickvote` feature implements a simple vote system. If a broadcaster or moderator send the `!quickvote` command a vote will be started (or a already running vote will be ended). After a quickvote has been started your community can casts votes by sending a chat message starting with `#`. You can include a message after `!quickvote` (e.g. `!quickvote Is pizza hawaii any good? #yes/#no`). If you do so, this message will be repeated every 60 seconds, so everyone keeps in mind, that a vote is still active.
|
||||
A simple vote system.
|
||||
|
||||
**Usage:**
|
||||
|
||||
1. Broadcaster/Mods: `!quickvote <message>`
|
||||
2. User: `#choice`
|
||||
3. Broadcaster/Mods: `!quickvote`
|
||||
|
||||
**Example:**
|
||||
|
||||
``` lang=text
|
||||
mod: !quickvote Is pizza hawaii any good? #yes/#no
|
||||
chat: #no
|
||||
mod: !quickvote
|
||||
bot: The result is: #no
|
||||
```
|
||||
|
||||
If a message is given by the Mods it will be repeated every 60 seconds, so everyone keeps in mind, that a vote is still active.
|
||||
|
||||
#### !pick
|
||||
|
||||
Randomly choose users from chat (who wants to participate).
|
||||
|
||||
**Usage:**
|
||||
|
||||
1. Broadcaster/Mods: `!pick <int>`
|
||||
2. User: #pickme
|
||||
3. Broadcaster/Mods: `!pick`
|
||||
|
||||
**Example:**
|
||||
|
||||
``` lang=text
|
||||
mod: !pick 3
|
||||
user1: #pickme
|
||||
user2: #pickme
|
||||
user3: #pickme
|
||||
user4: #pickme
|
||||
user5: #pickme
|
||||
mod: !pick
|
||||
bot: The picked users are: user5, user3, user1
|
||||
```
|
||||
|
||||
#### !random
|
||||
|
||||
The `!random` command will read a random line from a file called `random.txt`. You can also use multiple files, if you call `!random foo` the bot fetch the random line from a file called `random_foo.txt` instead of `random.txt`. `!random bar` will use the file `random_bar.txt` and so on. The `!random` command is restricted to the broadcaster and moderators.
|
||||
Picks a random line from a file.
|
||||
|
||||
#### !smartvote
|
||||
**Usage:**
|
||||
|
||||
The `!smartvote` command will read a line from a file called `quotes.txt`. You can add a parameter after the command. If the parameter is numeric the bot will search for a line starting with `#$number`. If the parameter is a string it will search for a line matching the parameter. If no parameter is given it will search for a completely random line.
|
||||
* Broadcaster/Mod: `!random <file>`
|
||||
|
||||
The format of `quotes.txt` looks as follows:
|
||||
You can use multiple files, if you call `!random foo` the bot fetch the random line from a file called `random_foo.txt`, `!random bar` will use the file `random_bar.txt` and so on. If no `<file>` is given the command use the file `random.txt`.
|
||||
|
||||
**Example:**
|
||||
|
||||
``` lang=text
|
||||
#1: "the quote" -username (date)
|
||||
mod: !random
|
||||
bot: This is a random message
|
||||
```
|
||||
|
||||
#### !addquote
|
||||
|
||||
The `!addvote` command adds a new line to `quotes.txt`. It expects two parameters: `!addquote username quote` where `username` is the name of the user to be quoted.
|
||||
The `!addquote` command adds a new line to `quotes.txt`.
|
||||
|
||||
Only Subs, Mods and Broadcaster are allowed to add quotes.
|
||||
**Usage:**
|
||||
|
||||
* Chat: `!addquote <username> <quote>`
|
||||
|
||||
**Example:**
|
||||
|
||||
``` lang=text
|
||||
chat: !addquote gpkvt This is a very funny quote.
|
||||
bot: Quote #1 was added.
|
||||
```
|
||||
|
||||
#### !smartquote / !sq
|
||||
|
||||
Picks a random/specific line from `quotes.txt`.
|
||||
|
||||
**Usage:**
|
||||
|
||||
* Chat: `!smartquote`
|
||||
* Chat: `!smartquote <linenumber>`
|
||||
* Chat: `!smartquote <searchstring>`
|
||||
* Chat: `!sq`
|
||||
* Chat: `!sq <linenumber>`
|
||||
* Chat: `!sq <searchstring>`
|
||||
|
||||
(`!sq` is an alias for `!smartquote`)
|
||||
|
||||
**Example:**
|
||||
|
||||
``` lang=text
|
||||
chat: !smartquote
|
||||
bot: This is a random quote
|
||||
chat: !smartquote 1000
|
||||
bot: This is quote #1000
|
||||
chat: !smartquote something stupid
|
||||
bot: This is a quote containing something stupid (or similiar)
|
||||
```
|
||||
|
||||
The format of `quotes.txt` looks as follows:
|
||||
|
||||
``` lang=text
|
||||
#1: "the quote" -username/game (date)
|
||||
```
|
||||
|
||||
#### !wiki
|
||||
|
||||
Search the Wikipedia.
|
||||
|
||||
**Usage:**
|
||||
|
||||
* Chat: `!wiki <searchstring>`
|
||||
|
||||
**Example:**
|
||||
|
||||
``` lang=text
|
||||
chat: !wiki 42 answer
|
||||
bot: 42 is the "Answer to the Ultimate Question of Life, the Universe, and Everything".
|
||||
```
|
||||
|
||||
## Build
|
||||
|
||||
|
@ -210,6 +381,8 @@ The voices available depend on your Operating System and/or browser. On some sys
|
|||
|
||||
On Windows you can install additional voices via `Settings` > `Time & language` > `Speech` > `Add voices` or by simply run `Add speech voices`.
|
||||
|
||||
Do not use Online-Voices, as this will result in serious delays.
|
||||
|
||||
## Help
|
||||
|
||||
Feel free to use the [Issuetracker](https://gitlab.com/gpvkt/twitchtts/-/issues) or send an [E-Mail](mailto:contact-project+gpvkt-twitchtts-38486705-issue-@incoming.gitlab.com) if you experience any problems.
|
||||
|
@ -236,11 +409,14 @@ This project is licensed under the GPLv3 License - see [LICENSE](https://gitlab.
|
|||
|
||||
### Libraries
|
||||
|
||||
* [Python Software Foundation and contributors](https://www.python.org/)
|
||||
* [Python](https://www.python.org/)
|
||||
* [jQuery](https://jquery.org/)
|
||||
* [Bootstrap](https://getbootstrap.com/)
|
||||
* [PyYAML](https://pyyaml.org/)
|
||||
* [requests](https://requests.readthedocs.io/en/latest/)
|
||||
* [fuzzywuzzy](https://github.com/seatgeek/fuzzywuzzy)
|
||||
* [wikipedia](https://github.com/goldsmith/Wikipedia)
|
||||
* [pyinstaller](https://pyinstaller.org/)
|
||||
* [OpenJS Foundation and jQuery contributors](https://jquery.org/)
|
||||
* [Twitter Inc. and Bootstrap contributors](https://getbootstrap.com/)
|
||||
|
||||
## Disclaimer
|
||||
|
||||
|
|
12
bootstrap.min.css
vendored
12
bootstrap.min.css
vendored
File diff suppressed because one or more lines are too long
67
build.py
Normal file
67
build.py
Normal file
|
@ -0,0 +1,67 @@
|
|||
#!/usr/bin/python3
|
||||
# -*- coding: utf-8 -*-
|
||||
# pylint: disable=line-too-long,too-many-lines
|
||||
|
||||
""" buildscript """
|
||||
|
||||
from pprint import pprint
|
||||
import time
|
||||
import os
|
||||
|
||||
import yaml
|
||||
import requests
|
||||
|
||||
import PyInstaller.__main__
|
||||
|
||||
with open("config.yml", "r", encoding="UTF-8") as ymlfile:
|
||||
cfg = yaml.load(ymlfile, Loader=yaml.Loader)
|
||||
|
||||
apikey = cfg['virustotal']
|
||||
|
||||
PyInstaller.__main__.run(['tts.py', '--onefile',])
|
||||
|
||||
os.replace("./dist/tts.exe", "./tts.exe")
|
||||
|
||||
print("Uploading file")
|
||||
api_endpoint = "https://www.virustotal.com/api/v3/files" # pylint: disable=invalid-name
|
||||
headers = {
|
||||
"Accept": "application/json",
|
||||
"X-Apikey": apikey
|
||||
}
|
||||
files = {"file": open("./tts.exe", "rb")}
|
||||
req = requests.post(api_endpoint, headers=headers, files=files)
|
||||
print(" [OK]")
|
||||
|
||||
data = {}
|
||||
data['data'] = {}
|
||||
data['data']['attributes'] = {}
|
||||
data['data']['attributes']['status'] = "incomplete"
|
||||
|
||||
print("Waiting for results")
|
||||
while data['data']['attributes']['status'] != "completed":
|
||||
time.sleep(10)
|
||||
|
||||
print( " [CHK]")
|
||||
data = req.json()
|
||||
api_endpoint = f"https://www.virustotal.com/api/v3/analyses/{data['data']['id']}"
|
||||
headers = {
|
||||
'X-Apikey': apikey
|
||||
}
|
||||
req = requests.get(api_endpoint, headers=headers)
|
||||
data = req.json()
|
||||
|
||||
print(" [OK]")
|
||||
|
||||
try:
|
||||
pprint(data['data']['attributes']['results']['Microsoft'])
|
||||
except KeyError:
|
||||
pass
|
||||
|
||||
pprint(data['data']['attributes']['stats'])
|
||||
print("https://www.virustotal.com/gui/file/"+str(data['meta']['file_info']['sha256']))
|
||||
|
||||
try:
|
||||
if data['data']['attributes']['results']['Microsoft']['category'] != "undetected":
|
||||
print('FILE WILL BE DETECTED AS MALICIOUS. PLEASE RECOMPILE!')
|
||||
except KeyError:
|
||||
pass
|
|
@ -14,10 +14,24 @@ bot:
|
|||
subonly: False # Only Subs can use TTS
|
||||
modonly: False # Only Mods can use TTS
|
||||
message_length: 200 # Max. TTS message length
|
||||
language: de # Language for wikipedia
|
||||
|
||||
features:
|
||||
quote: True
|
||||
pick: True
|
||||
vote: True
|
||||
wiki: True
|
||||
wikitts: True
|
||||
wikisentences: 3
|
||||
random: True
|
||||
version: True
|
||||
ping: True
|
||||
|
||||
messages: # Things the bot can send as chat message
|
||||
toff: "TTS is now inactive."
|
||||
ton: "TTS is now active."
|
||||
wikitoff: "TTS is now inactive."
|
||||
wikiton: "TTS is now active."
|
||||
too_long: "Sorry, your TTS message is too long."
|
||||
disabled: "Sorry, TTS is disabled right now."
|
||||
denied: "Sorry, you are not allowed to use TTS."
|
||||
|
@ -31,6 +45,14 @@ messages: # Things the bot can send as chat message
|
|||
votenobody: "Nobody casted a vote. :("
|
||||
voteresult: "Voting has ended. The result is:"
|
||||
votes: "Votes"
|
||||
pickstart: "Pick started. Send #pickme to participate."
|
||||
pickresult: "Pick ended. The results are:"
|
||||
picknone: "Nobody was picked. :("
|
||||
quotenotfound: "Sorry, no quote found."
|
||||
quoteaddedprefix: "Quote:"
|
||||
quoteaddedsuffix: "added."
|
||||
wiki_too_many: "Sorry, there are too many possible results. Try a more narrow search."
|
||||
wiki_no_result: "Sorry, there was an error fetching the wikipedia answer."
|
||||
|
||||
log:
|
||||
level: "INFO" # Loglevel, valid values are: DEBUG, INFO, WARNING, ERROR, CRITICAL (do not use DEBUG in a production environment)
|
||||
|
|
|
@ -1,2 +1,5 @@
|
|||
fuzzywuzzy==0.18.0
|
||||
PyYAML==6.0
|
||||
fuzzywuzzy==0.18.0
|
||||
PyInstaller==5.3
|
||||
PyYAML==6.0
|
||||
requests==2.28.1
|
||||
wikipedia==1.4.0
|
||||
|
|
BIN
tts.exe
Normal file
BIN
tts.exe
Normal file
Binary file not shown.
84
tts.html
84
tts.html
|
@ -1,35 +1,49 @@
|
|||
<html lang="de">
|
||||
<head>
|
||||
<link href="./bootstrap.min.css" rel="stylesheet" />
|
||||
<title>TTS</title>
|
||||
<script src="./jquery.js"></script>
|
||||
</head>
|
||||
<body class="container mt-2">
|
||||
<p class="lead mt-2">Select Voice</p>
|
||||
<select id="voices" class="form-select bg-transparent"></select>
|
||||
<div class="d-flex mt-2">
|
||||
<div>
|
||||
<p class="lead">Volume</p>
|
||||
<input type="range" min="0" max="1" value="1" step="0.1" id="volume" />
|
||||
<span id="volume-label" class="ms-2">1</span>
|
||||
</div>
|
||||
<div class="mx-4">
|
||||
<p class="lead">Rate</p>
|
||||
<input type="range" min="0.1" max="10" value="1" id="rate" step="0.1" />
|
||||
<span id="rate-label" class="ms-2">1</span>
|
||||
</div>
|
||||
<div>
|
||||
<p class="lead">Pitch</p>
|
||||
<input type="range" min="0" max="2" value="1" step="0.1" id="pitch" />
|
||||
<span id="pitch-label" class="ms-2">1</span>
|
||||
</div>
|
||||
</div>
|
||||
<div>
|
||||
<button id="start" class="btn btn-success mt-4 me-2">Init</button>
|
||||
<button id="pause" class="btn btn-warning mt-4 me-2">Pause</button>
|
||||
<button id="resume" class="btn btn-info mt-4 me-2">Resume</button>
|
||||
<button id="cancel" class="btn btn-danger mt-4 me-2">Cancel</button>
|
||||
</div>
|
||||
</body>
|
||||
<script src="./tts.js"></script>
|
||||
</html>
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<link href="./bootstrap.min.css" rel="stylesheet" />
|
||||
<title>TTS</title>
|
||||
<script src="./jquery.js"></script>
|
||||
</head>
|
||||
<body class="container mt-2">
|
||||
<p class="lead mt-2">Select Voice</p>
|
||||
<select id="voices" class="form-select bg-transparent"></select>
|
||||
<div class="d-flex mt-2">
|
||||
<div>
|
||||
<p class="lead">Volume</p>
|
||||
<input type="range" min="0" max="1" value="1" step="0.1" id="volume" />
|
||||
<span id="volume-label" class="ms-2">1</span>
|
||||
</div>
|
||||
<div class="mx-4">
|
||||
<p class="lead">Rate</p>
|
||||
<input type="range" min="0.1" max="10" value="1" id="rate" step="0.1" />
|
||||
<span id="rate-label" class="ms-2">1</span>
|
||||
</div>
|
||||
<div>
|
||||
<p class="lead">Pitch</p>
|
||||
<input type="range" min="0" max="2" value="1" step="0.1" id="pitch" />
|
||||
<span id="pitch-label" class="ms-2">1</span>
|
||||
</div>
|
||||
</div>
|
||||
<div>
|
||||
<button id="start" class="btn btn-success mt-4 me-2">Init</button>
|
||||
<button id="pause" class="btn btn-warning mt-4 me-2">Pause</button>
|
||||
<button id="resume" class="btn btn-info mt-4 me-2">Resume</button>
|
||||
<button id="cancel" class="btn btn-danger mt-4 me-2">Cancel</button>
|
||||
</div>
|
||||
<script src="./tts.js"></script>
|
||||
<script>
|
||||
$(document).ready (function(){
|
||||
if (window.matchMedia) {
|
||||
if(window.matchMedia('(prefers-color-scheme: dark)').matches){
|
||||
$('body').addClass('bg-dark');
|
||||
$('p').addClass('text-light');
|
||||
$('select').addClass('text-light');
|
||||
$('option').addClass('bg-dark');
|
||||
$('span').addClass('text-light');
|
||||
}
|
||||
}
|
||||
});
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
|
|
Loading…
Add table
Reference in a new issue