n0th1ng-else / voice-to-text-bot Goto Github PK
View Code? Open in Web Editor NEWTelegram bot that converts Voice messages into text
Home Page: https://t.me/AudioMessBot
License: MIT License
Telegram bot that converts Voice messages into text
Home Page: https://t.me/AudioMessBot
License: MIT License
cache last 50-100 get requests into DB
Cover DB cache by tests and turn it on on the production env
I can see duplications happen to be in production DB and service resolves them. But I dont know the difference between this or that duplicated record. We need to put more details into logs
add badges (sonar, version, usages)
make table responsive
level:error
message:[Id] [ChatId] Unable to recognize the file AwACAgIAAxkBAAIxXF8FxNuSKWTDCsW3Hv5CxnDXq70fAAIoBwACR30wSBrbPQABj2tXZxoE
metadata-0-code:ETELEGRAM
timestamp:2020-07-08T13:07:06.488Z
metadata-0-response:{ headers: { date: "Wed, 08 Jul 2020 13:07:05 GMT", access-control-allow-origin: "*", server: "nginx/1.16.1", content-length: "84", content-type: "application/json", connection: "keep-alive", strict-transport-security: "max-age=31536000; includeSubDomains; preload", access-control-expose-headers: "Content-Length,Content-Type,Date,Server,Connection" }, request: { headers: { content-length: 3034, content-type: "application/x-www-form-urlencoded" }, method: "POST", uri: { path: "/:/sendMessage", protocol: "https:", hostname: "api.telegram.org", port: 443, host: "api.telegram.org", href: "https://api.telegram.org/sendMessage", slashes: true, pathname: "/:/sendMessage" } }, body: { description: "Forbidden: bot was blocked by the user", error_code: 403, ok: false }, statusCode: 403 }
Currently, Google recognition engine does not support 44100, so need to get some research
d:telegram-bot
level:error
message:Unable to get the lang
timestamp:2020-06-16T09:28:33.200Z
0:
code:100
message:XMLHttpRequest failed: {"UNSENT":0,"OPENED":1,"HEADERS_RECEIVED":2,"LOADING":3,"DONE":4,"readyState":4,"responseText":"","responseXML":"","status":503,"statusText":null,"withCredentials":false}
make sure we did not use the same twice
not sure if this is the case
We want to run a daemon on destroy to pick up telegram messages
telegram api supports setMyCommands
thing. gonna use it
So it will be more secured and less smelling
https://sonarcloud.io/pricing
seems that we have a lifecycle event that fires on pod restart. We want to implement a triggert for that event
For some reason, there are duplicates in development DB, so it seems that we need to handle such cases and avoid duplications as much as possible
Use google analytics to collect the insights.
{
"@timestamp": "2023-01-02T15:27:39.766Z",
"severity": "error",
"message": "ETELEGRAM Request failed with status code 400",
"level": "error",
"title": "Unable to recognize the file",
"id": "telegram-bot",
"prefix": "thread-1",
"appVersion": "app.0f1f995f3fb5622ec474a956c1261c5b111369ce",
"code": 400,
"response": {
"ok": false,
"error_code": 400,
"description": "Bad Request: message is too long"
},
"url": "/bot/sendMessage",
"stack": "Error: ETELEGRAM Request failed with status code 400\n at /usr/src/app/dist/src/telegram/api/index.js:127:19\n at runMicrotasks (<anonymous>)\n at processTicksAndRejections (node:internal/process/task_queues:96:5)\nAxiosError: Request failed with status code 400\n at settle (/usr/src/app/node_modules/axios/dist/node/axios.cjs:1855:12)\n at IncomingMessage.handleStreamEnd (/usr/src/app/node_modules/axios/dist/node/axios.cjs:2704:11)\n at IncomingMessage.emit (node:events:539:35)\n at IncomingMessage.emit (node:domain:475:12)\n at endReadableNT (node:internal/streams/readable:1345:12)\n at processTicksAndRejections (node:internal/process/task_queues:83:21)",
"@timestamp_received": "2023-01-02T15:27:41.101Z",
"logsene_orig_type": "application-logs"
}
tag:app.8cf913a16282f43bfdad831afe02f5adf638a0d0
logtype:json
http:
clientHost:54.74.88.42
contentType:application/json
json:
id:telegram-bot
level:error
message:Unable to recognize the file
metadata-0-code:13
metadata-0-details:Received RST_STREAM with code 2 (Internal server error)
metadata-0-note:Exception occurred in retry method that was not classified as transient
prefix:no
timestamp:2020-08-12T17:24:01.039Z
in groups users use commands like /support@AudioMessBot - we should support it
Right now logs do now show what happened with the replica when external system tries to shut it down. We want to try to track such events
2020-07-22T10:13:06.966690+00:00 app[web.1]: /usr/src/app/node_modules/prism-media/src/opus/OggDemuxer.js:56
2020-07-22T10:13:06.966690+00:00 app[web.1]: throw Error(`capture_pattern is not ${OGGS_HEADER}`);
2020-07-22T10:13:06.966691+00:00 app[web.1]: ^
2020-07-22T10:13:06.966692+00:00 app[web.1]:
2020-07-22T10:13:06.966693+00:00 app[web.1]: Error: capture_pattern is not OggS
2020-07-22T10:13:06.966693+00:00 app[web.1]: at OggDemuxer._readPage (/usr/src/app/node_modules/prism-media/src/opus/OggDemuxer.js:56:13)
2020-07-22T10:13:06.966694+00:00 app[web.1]: at OggDemuxer._transform (/usr/src/app/node_modules/prism-media/src/opus/OggDemuxer.js:36:27)
2020-07-22T10:13:06.966694+00:00 app[web.1]: at OggDemuxer.Transform._read (_stream_transform.js:191:10)
2020-07-22T10:13:06.966695+00:00 app[web.1]: at OggDemuxer.Transform._write (_stream_transform.js:179:12)
2020-07-22T10:13:06.966695+00:00 app[web.1]: at doWrite (_stream_writable.js:403:12)
2020-07-22T10:13:06.966695+00:00 app[web.1]: at writeOrBuffer (_stream_writable.js:387:5)
2020-07-22T10:13:06.966696+00:00 app[web.1]: at OggDemuxer.Writable.write (_stream_writable.js:318:11)
2020-07-22T10:13:06.966696+00:00 app[web.1]: at IncomingMessage.ondata (_stream_readable.js:717:22)
2020-07-22T10:13:06.966696+00:00 app[web.1]: at IncomingMessage.emit (events.js:315:20)
2020-07-22T10:13:06.966697+00:00 app[web.1]: at IncomingMessage.EventEmitter.emit (domain.js:482:12)
2020-07-22T10:13:06.978649+00:00 app[web.1]: npm ERR! code ELIFECYCLE
Right now stat contains last user name who applied a voice message, should be group name for groups
TypeError: Cannot convert undefined or null to object
at Function.getOwnPropertyNames (<anonymous>)
at convertDataItem (/usr/src/app/dist/src/logger/integration.js:39:19)
at /usr/src/app/dist/src/logger/integration.js:78:30
at Array.reduce (<anonymous>)
at sendLogs (/usr/src/app/dist/src/logger/integration.js:77:16)
at Logger.warn (/usr/src/app/dist/src/logger/index.js:52:36)
at /usr/src/app/dist/src/recognition/wit.ai.js:75:24
at runMicrotasks (<anonymous>)
at processTicksAndRejections (node:internal/process/task_queues:96:5) at async Promise.all (index 0)
enable donations via robokassa
url tag is not supported, so we want to make it plain string
node-telegram-bot-api seems to be packed with features. It is more than enough for the bot. Gonna write own telegram api client that will implement only features bot need
retry if telegram threw a error during the init
server
level:error
message:Unknown route /bot/message/c4b247a3e37e43eb7e140a2576138926
timestamp:2020-07-01T19:49:03.595Z
Sounds like we want to handle everything /bot/message/:id
and then show some error/warn if it is not our entrypoint
since the process is all set, it is interesting if we can implement the same feature in whatsapp messager
Add language command for bot so it will suggest switching between RU and EN
Currently, the bot is disabled for groups. So it might be a worthy case to have it in there. need some research
Since I am not a designer I am having troubles to get an awesome bot picture. Looking for one, any suggestions are welcome!
Right now it is unclear what kind of action user called to analyze particular issue in logs. We need to enrich logs with more data. WHat kind of action do they call, was it successful or not etc
A declarative, efficient, and flexible JavaScript library for building user interfaces.
๐ Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
An Open Source Machine Learning Framework for Everyone
The Web framework for perfectionists with deadlines.
A PHP framework for web artisans
Bring data to life with SVG, Canvas and HTML. ๐๐๐
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
Some thing interesting about web. New door for the world.
A server is a program made to process requests and deliver data to clients.
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
Some thing interesting about visualization, use data art
Some thing interesting about game, make everyone happy.
We are working to build community through open source technology. NB: members must have two-factor auth.
Open source projects and samples from Microsoft.
Google โค๏ธ Open Source for everyone.
Alibaba Open Source for everyone
Data-Driven Documents codes.
China tencent open source team.