@effect-ak/tg-bot-client 0.0.7 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (82) hide show
  1. package/dist/cjs/bot/factory/_service.js +20 -0
  2. package/dist/cjs/bot/factory/client-config.js +29 -0
  3. package/dist/cjs/bot/factory/make-bot.js +20 -0
  4. package/dist/cjs/bot/message-handler/_service.js +12 -0
  5. package/dist/cjs/bot/message-handler/types.js +5 -0
  6. package/dist/cjs/bot/message-handler/utils.js +19 -0
  7. package/dist/cjs/bot/run.js +10 -0
  8. package/dist/cjs/bot/update-poller/_service.js +39 -0
  9. package/dist/cjs/bot/update-poller/errors.js +5 -0
  10. package/dist/cjs/bot/update-poller/fetch-updates.js +70 -0
  11. package/dist/cjs/bot/update-poller/poll-and-handle.js +50 -0
  12. package/dist/cjs/bot/update-poller/settings.js +23 -0
  13. package/dist/cjs/client/_client.js +17 -14
  14. package/dist/cjs/client/config.js +17 -0
  15. package/dist/cjs/client/errors.js +8 -9
  16. package/dist/cjs/client/execute-request/_service.js +20 -0
  17. package/dist/cjs/client/execute-request/execute.js +59 -0
  18. package/dist/cjs/client/{request.js → execute-request/payload.js} +2 -2
  19. package/dist/cjs/client/file/_service.js +22 -0
  20. package/dist/cjs/client/file/get-file.js +38 -0
  21. package/dist/cjs/client/guards.js +12 -0
  22. package/dist/cjs/{client/const.js → const.js} +2 -1
  23. package/dist/cjs/index.js +19 -8
  24. package/dist/dts/bot/factory/_service.d.ts +37 -0
  25. package/dist/dts/bot/factory/client-config.d.ts +3 -0
  26. package/dist/dts/bot/factory/make-bot.d.ts +7 -0
  27. package/dist/dts/bot/message-handler/_service.d.ts +6 -0
  28. package/dist/dts/bot/message-handler/types.d.ts +16 -0
  29. package/dist/dts/bot/message-handler/utils.d.ts +6 -0
  30. package/dist/dts/bot/run.d.ts +7 -0
  31. package/dist/dts/bot/update-poller/_service.d.ts +21 -0
  32. package/dist/dts/bot/update-poller/errors.d.ts +1 -0
  33. package/dist/dts/bot/update-poller/fetch-updates.d.ts +17 -0
  34. package/dist/dts/bot/update-poller/poll-and-handle.d.ts +16 -0
  35. package/dist/dts/bot/update-poller/settings.d.ts +6 -0
  36. package/dist/dts/client/_client.d.ts +6 -17
  37. package/dist/dts/client/config.d.ts +8 -0
  38. package/dist/dts/client/errors.d.ts +6 -4
  39. package/dist/dts/client/execute-request/_service.d.ts +15 -0
  40. package/dist/dts/client/execute-request/execute.d.ts +5 -0
  41. package/dist/dts/client/file/_service.d.ts +16 -0
  42. package/dist/dts/client/file/get-file.d.ts +5 -0
  43. package/dist/dts/client/guards.d.ts +17 -0
  44. package/dist/dts/{client/const.d.ts → const.d.ts} +1 -0
  45. package/dist/dts/index.d.ts +2 -1
  46. package/dist/dts/specification/api.d.ts +786 -2776
  47. package/dist/dts/specification/types.d.ts +1387 -3547
  48. package/dist/esm/bot/factory/_service.js +12 -0
  49. package/dist/esm/bot/factory/client-config.js +20 -0
  50. package/dist/esm/bot/factory/make-bot.js +9 -0
  51. package/dist/esm/bot/message-handler/_service.js +4 -0
  52. package/dist/esm/bot/message-handler/types.js +1 -0
  53. package/dist/esm/bot/message-handler/utils.js +12 -0
  54. package/dist/esm/bot/run.js +6 -0
  55. package/dist/esm/bot/update-poller/_service.js +31 -0
  56. package/dist/esm/bot/update-poller/errors.js +1 -0
  57. package/dist/esm/bot/update-poller/fetch-updates.js +49 -0
  58. package/dist/esm/bot/update-poller/poll-and-handle.js +37 -0
  59. package/dist/esm/bot/update-poller/settings.js +15 -0
  60. package/dist/esm/client/_client.js +15 -14
  61. package/dist/esm/client/config.js +8 -0
  62. package/dist/esm/client/errors.js +6 -9
  63. package/dist/esm/client/execute-request/_service.js +12 -0
  64. package/dist/esm/client/execute-request/execute.js +37 -0
  65. package/dist/esm/client/{request.js → execute-request/payload.js} +2 -4
  66. package/dist/esm/client/file/_service.js +14 -0
  67. package/dist/esm/client/file/get-file.js +24 -0
  68. package/dist/esm/client/guards.js +7 -0
  69. package/dist/esm/{client/const.js → const.js} +1 -0
  70. package/dist/esm/index.js +2 -1
  71. package/package.json +12 -4
  72. package/readme.md +83 -24
  73. package/dist/cjs/client/download-file.js +0 -44
  74. package/dist/cjs/client/execute-request.js +0 -69
  75. package/dist/cjs/client/response.js +0 -22
  76. package/dist/dts/client/download-file.d.ts +0 -13
  77. package/dist/dts/client/execute-request.d.ts +0 -13
  78. package/dist/dts/client/response.d.ts +0 -7
  79. package/dist/esm/client/download-file.js +0 -36
  80. package/dist/esm/client/execute-request.js +0 -62
  81. package/dist/esm/client/response.js +0 -15
  82. /package/dist/dts/client/{request.d.ts → execute-request/payload.d.ts} +0 -0
@@ -1,69 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.makeExecute = void 0;
7
- var _request = require("./request.js");
8
- var _response = require("./response.js");
9
- var _errors = require("./errors.js");
10
- const makeExecute = config => {
11
- const execute = async (method, input) => {
12
- try {
13
- const httpResponse = await fetch(`${config.baseUrl}/bot${config.token}/${snakeToCamel(method)}`, {
14
- body: (0, _request.makePayload)(input) ?? null,
15
- method: "POST"
16
- });
17
- const response = await httpResponse.json();
18
- if (!(0, _response.isTgBotApiResponse)(response)) {
19
- return {
20
- error: new _errors.TgBotClientError({
21
- type: "UnexpectedResponse",
22
- response
23
- })
24
- };
25
- }
26
- if (!httpResponse.ok) {
27
- return {
28
- error: new _errors.TgBotClientError({
29
- type: "NotOkResponse",
30
- ...(response.error_code ? {
31
- errorCode: response.error_code
32
- } : undefined),
33
- ...(response.description ? {
34
- details: response.description
35
- } : undefined)
36
- })
37
- };
38
- }
39
- return {
40
- success: response.result
41
- };
42
- } catch (cause) {
43
- return {
44
- error: new _errors.TgBotClientError({
45
- type: "ClientInternalError",
46
- cause
47
- })
48
- };
49
- }
50
- };
51
- const unsafeExecute = async (method, input) => {
52
- const result = await execute(method, input);
53
- if (result.error) throw result.error;
54
- if (!("success" in result)) throw _errors.TgBotClientError.missingSuccess;
55
- return result.success;
56
- };
57
- return {
58
- execute,
59
- unsafeExecute
60
- };
61
- };
62
- exports.makeExecute = makeExecute;
63
- const snakeToCamel = methodName => methodName.split("_").reduce((result, word, step) => {
64
- if (step == 0) {
65
- return word;
66
- } else {
67
- return result + word.at(0)?.toUpperCase() + word.slice(1);
68
- }
69
- }, "");
@@ -1,22 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.isTgBotApiResponse = void 0;
7
- const isTgBotApiResponse = input => {
8
- if (typeof input !== "object" || input == null) {
9
- return false;
10
- }
11
- if (!("ok" in input && typeof input.ok == "boolean")) {
12
- return false;
13
- }
14
- if ("error_code" in input && typeof input.error_code != "number") {
15
- return false;
16
- }
17
- if ("description" in input && typeof input.description != "string") {
18
- return false;
19
- }
20
- return true;
21
- };
22
- exports.isTgBotApiResponse = isTgBotApiResponse;
@@ -1,13 +0,0 @@
1
- import type { BotConfig } from "./_client.js";
2
- import { TgBotClientError } from "./errors.js";
3
- import type { ExecuteRequest } from "./execute-request.js";
4
- type GetFileResult = {
5
- success?: File;
6
- error?: TgBotClientError;
7
- };
8
- export declare const makeDownloadFile: (config: BotConfig, execute: ExecuteRequest) => {
9
- readonly getFile: (input: {
10
- file_id: string;
11
- }) => Promise<GetFileResult>;
12
- };
13
- export {};
@@ -1,13 +0,0 @@
1
- import type { BotConfig } from "./_client.js";
2
- import type { Api } from "../specification/api.js";
3
- import { TgBotClientError } from "./errors.js";
4
- export type ExecuteRequest = ReturnType<typeof makeExecute>;
5
- type SafeExecuteResult<M extends keyof Api> = {
6
- success?: ReturnType<Api[M]>;
7
- error?: TgBotClientError;
8
- };
9
- export declare const makeExecute: (config: BotConfig) => {
10
- readonly execute: <M extends keyof Api>(method: M, input: Parameters<Api[M]>[0]) => Promise<SafeExecuteResult<M>>;
11
- readonly unsafeExecute: <M extends keyof Api>(method: M, input: Parameters<Api[M]>[0]) => Promise<ReturnType<Api[M]>>;
12
- };
13
- export {};
@@ -1,7 +0,0 @@
1
- export type TgBotApiResponse<O> = {
2
- ok: boolean;
3
- error_code?: number;
4
- description?: string;
5
- result?: O;
6
- };
7
- export declare const isTgBotApiResponse: <O>(input: unknown) => input is TgBotApiResponse<O>;
@@ -1,36 +0,0 @@
1
- import { TgBotClientError } from "./errors.js";
2
- export const makeDownloadFile = (config, execute) => {
3
- const getFile = async (input) => {
4
- const response = await execute.execute("get_file", input);
5
- if (response.error)
6
- return { error: response.error };
7
- const file_path = response.success?.file_path;
8
- if (!file_path || file_path.length == 0) {
9
- return {
10
- error: new TgBotClientError({
11
- type: "UnableToGetFile",
12
- cause: "File path not defined"
13
- })
14
- };
15
- }
16
- const file_name = file_path.replaceAll("/", "-");
17
- const url = `${config.baseUrl}/file/bot${config.token}/${file_path}`;
18
- try {
19
- const fileContent = await fetch(url).then(_ => _.arrayBuffer());
20
- const file = new File([new Uint8Array(fileContent)], file_name);
21
- return {
22
- success: file
23
- };
24
- }
25
- catch (cause) {
26
- return {
27
- error: new TgBotClientError({
28
- type: "UnableToGetFile", cause
29
- })
30
- };
31
- }
32
- };
33
- return {
34
- getFile
35
- };
36
- };
@@ -1,62 +0,0 @@
1
- import { makePayload } from "./request.js";
2
- import { isTgBotApiResponse } from "./response.js";
3
- import { TgBotClientError } from "./errors.js";
4
- export const makeExecute = (config) => {
5
- const execute = async (method, input) => {
6
- try {
7
- const httpResponse = await fetch(`${config.baseUrl}/bot${config.token}/${snakeToCamel(method)}`, {
8
- body: makePayload(input) ?? null,
9
- method: "POST",
10
- });
11
- const response = await httpResponse.json();
12
- if (!isTgBotApiResponse(response)) {
13
- return {
14
- error: new TgBotClientError({
15
- type: "UnexpectedResponse",
16
- response
17
- })
18
- };
19
- }
20
- if (!httpResponse.ok) {
21
- return {
22
- error: new TgBotClientError({
23
- type: "NotOkResponse",
24
- ...(response.error_code ? { errorCode: response.error_code } : undefined),
25
- ...(response.description ? { details: response.description } : undefined)
26
- })
27
- };
28
- }
29
- return {
30
- success: response.result
31
- };
32
- }
33
- catch (cause) {
34
- return {
35
- error: new TgBotClientError({
36
- type: "ClientInternalError", cause
37
- })
38
- };
39
- }
40
- };
41
- const unsafeExecute = async (method, input) => {
42
- const result = await execute(method, input);
43
- if (result.error)
44
- throw result.error;
45
- if (!("success" in result))
46
- throw TgBotClientError.missingSuccess;
47
- return result.success;
48
- };
49
- return {
50
- execute, unsafeExecute
51
- };
52
- };
53
- const snakeToCamel = (methodName) => methodName
54
- .split("_")
55
- .reduce((result, word, step) => {
56
- if (step == 0) {
57
- return word;
58
- }
59
- else {
60
- return result + word.at(0)?.toUpperCase() + word.slice(1);
61
- }
62
- }, "");
@@ -1,15 +0,0 @@
1
- export const isTgBotApiResponse = (input) => {
2
- if (typeof input !== "object" || input == null) {
3
- return false;
4
- }
5
- if (!("ok" in input && typeof input.ok == "boolean")) {
6
- return false;
7
- }
8
- if ("error_code" in input && typeof input.error_code != "number") {
9
- return false;
10
- }
11
- if ("description" in input && typeof input.description != "string") {
12
- return false;
13
- }
14
- return true;
15
- };