ts-sidekiq 0.0.5 → 0.1.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.
package/README.md CHANGED
@@ -1 +1,3 @@
1
- # ts-sidekiq-dashboard
1
+ # ts-sidekiq
2
+
3
+ - [Recharts](https://recharts.org/)
@@ -0,0 +1,9 @@
1
+ import React from "react";
2
+ interface Props {
3
+ data: {
4
+ name: string;
5
+ value: number;
6
+ }[];
7
+ }
8
+ declare const CronLineChart: React.FC<Props>;
9
+ export default CronLineChart;
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const recharts_1 = require("recharts");
8
+ const CronLineChart = ({ data }) => (react_1.default.createElement(recharts_1.ResponsiveContainer, { width: "100%", height: 300 },
9
+ react_1.default.createElement(recharts_1.LineChart, { data: data },
10
+ react_1.default.createElement(recharts_1.CartesianGrid, { strokeDasharray: "3 3" }),
11
+ react_1.default.createElement(recharts_1.XAxis, { dataKey: "name" }),
12
+ react_1.default.createElement(recharts_1.YAxis, null),
13
+ react_1.default.createElement(recharts_1.Tooltip, null),
14
+ react_1.default.createElement(recharts_1.Legend, null),
15
+ react_1.default.createElement(recharts_1.Line, { type: "monotone", dataKey: "value", stroke: "#8884d8" }))));
16
+ exports.default = CronLineChart;
17
+ //# sourceMappingURL=cron-line-chart.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cron-line-chart.js","sourceRoot":"","sources":["../../src/components/cron-line-chart.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAC1B,uCASkB;AAOlB,MAAM,aAAa,GAAoB,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CACnD,8BAAC,8BAAmB,IAAC,KAAK,EAAC,MAAM,EAAC,MAAM,EAAE,GAAG;IAC3C,8BAAC,oBAAS,IAAC,IAAI,EAAE,IAAI;QACnB,8BAAC,wBAAa,IAAC,eAAe,EAAC,KAAK,GAAG;QACvC,8BAAC,gBAAK,IAAC,OAAO,EAAC,MAAM,GAAG;QACxB,8BAAC,gBAAK,OAAG;QACT,8BAAC,kBAAO,OAAG;QACX,8BAAC,iBAAM,OAAG;QACV,8BAAC,eAAI,IAAC,IAAI,EAAC,UAAU,EAAC,OAAO,EAAC,OAAO,EAAC,MAAM,EAAC,SAAS,GAAG,CAC/C,CACQ,CACvB,CAAC;AAEF,kBAAe,aAAa,CAAC"}
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ import { CronJob } from "../types";
3
+ interface Props {
4
+ cronJobs: CronJob[];
5
+ }
6
+ declare const CronStats: React.FC<Props>;
7
+ export default CronStats;
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const cron_table_1 = __importDefault(require("./cron-table"));
8
+ const CronStats = ({ cronJobs }) => {
9
+ // スケジュール定義のみをフィルタリング
10
+ const scheduleJobs = cronJobs.filter((job) => !job.key.includes("jid_history") && !job.key.includes("enqueued"));
11
+ return (react_1.default.createElement("div", null,
12
+ react_1.default.createElement(cron_table_1.default, { cronJobs: scheduleJobs })));
13
+ };
14
+ exports.default = CronStats;
15
+ //# sourceMappingURL=cron-stats.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cron-stats.js","sourceRoot":"","sources":["../../src/components/cron-stats.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAE1B,8DAAqC;AAYrC,MAAM,SAAS,GAAoB,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;IAClD,qBAAqB;IACrB,MAAM,YAAY,GAAG,QAAQ,CAAC,MAAM,CAClC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,UAAU,CAAC,CAC3E,CAAC;IAEF,OAAO,CACL;QACE,8BAAC,oBAAS,IAAC,QAAQ,EAAE,YAAY,GAAI,CACjC,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,SAAS,CAAC"}
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ import { CronJob } from "../types";
3
+ interface Props {
4
+ cronJobs: CronJob[];
5
+ }
6
+ declare const CronTable: React.FC<Props>;
7
+ export default CronTable;
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const styles_1 = require("../styles");
8
+ const CronTable = ({ cronJobs }) => (react_1.default.createElement("div", null,
9
+ react_1.default.createElement("h2", null, "Cron"),
10
+ react_1.default.createElement("table", { style: styles_1.tableStyle },
11
+ react_1.default.createElement("thead", null,
12
+ react_1.default.createElement("tr", null,
13
+ react_1.default.createElement("th", { style: styles_1.headerCellStyle }, "Name"),
14
+ react_1.default.createElement("th", { style: styles_1.headerCellStyle }, "Cron"),
15
+ react_1.default.createElement("th", { style: styles_1.headerCellStyle }, "Last queued at"))),
16
+ react_1.default.createElement("tbody", null, cronJobs.map((job, index) => {
17
+ var _a, _b;
18
+ return (react_1.default.createElement("tr", { key: index },
19
+ react_1.default.createElement("td", { style: styles_1.cellStyle }, job.key.replace("cron_job:", "")),
20
+ react_1.default.createElement("td", { style: styles_1.cellStyle }, (_a = job.details) === null || _a === void 0 ? void 0 : _a.cron),
21
+ react_1.default.createElement("td", { style: styles_1.cellStyle }, (_b = job.details) === null || _b === void 0 ? void 0 : _b.last_enqueue_time)));
22
+ })))));
23
+ exports.default = CronTable;
24
+ //# sourceMappingURL=cron-table.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cron-table.js","sourceRoot":"","sources":["../../src/components/cron-table.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAE1B,sCAAmE;AAMnE,MAAM,SAAS,GAAoB,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CACnD;IACE,iDAAa;IACb,yCAAO,KAAK,EAAE,mBAAU;QACtB;YACE;gBACE,sCAAI,KAAK,EAAE,wBAAe,WAAW;gBACrC,sCAAI,KAAK,EAAE,wBAAe,WAAW;gBACrC,sCAAI,KAAK,EAAE,wBAAe,qBAAqB,CAC5C,CACC;QACR,6CACG,QAAQ,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;;YAAC,OAAA,CAC5B,sCAAI,GAAG,EAAE,KAAK;gBACZ,sCAAI,KAAK,EAAE,kBAAS,IAAG,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,EAAE,CAAC,CAAM;gBAC7D,sCAAI,KAAK,EAAE,kBAAS,IAAG,MAAA,GAAG,CAAC,OAAO,0CAAE,IAAI,CAAM;gBAC9C,sCAAI,KAAK,EAAE,kBAAS,IAAG,MAAA,GAAG,CAAC,OAAO,0CAAE,iBAAiB,CAAM,CACxD,CACN,CAAA;SAAA,CAAC,CACI,CACF,CACJ,CACP,CAAC;AAEF,kBAAe,SAAS,CAAC"}
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ import { RetryJobDetail } from "../types";
3
+ type Props = {
4
+ data: RetryJobDetail[];
5
+ onSelectedJobs: (selectedJIDs: string[]) => void;
6
+ };
7
+ declare const RetryTable: React.FC<Props>;
8
+ export default RetryTable;
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ const react_1 = __importStar(require("react"));
27
+ const styles_1 = require("../styles");
28
+ const RetryTable = ({ data, onSelectedJobs }) => {
29
+ const [selectedJIDs, setSelectedJIDs] = (0, react_1.useState)([]);
30
+ const handleCheckboxChange = (jid, isChecked) => {
31
+ if (isChecked) {
32
+ // JIDを選択されたJIDのリストに追加
33
+ setSelectedJIDs([...selectedJIDs, jid]);
34
+ }
35
+ else {
36
+ // JIDを選択されたJIDのリストから削除
37
+ setSelectedJIDs(selectedJIDs.filter((selectedJID) => selectedJID !== jid));
38
+ }
39
+ };
40
+ // チェックボックスの状態が変更されるたびにコールバックを呼び出す
41
+ (0, react_1.useEffect)(() => {
42
+ onSelectedJobs(selectedJIDs);
43
+ }, [selectedJIDs, onSelectedJobs]);
44
+ return (react_1.default.createElement("table", { style: styles_1.tableStyle },
45
+ react_1.default.createElement("thead", null,
46
+ react_1.default.createElement("tr", null,
47
+ react_1.default.createElement("th", { style: styles_1.headerCellStyle }, "Select"),
48
+ react_1.default.createElement("th", { style: styles_1.headerCellStyle }, "JID"),
49
+ react_1.default.createElement("th", { style: styles_1.headerCellStyle }, "Queue"),
50
+ react_1.default.createElement("th", { style: styles_1.headerCellStyle }, "Error Message"),
51
+ react_1.default.createElement("th", { style: styles_1.headerCellStyle }, "Failed At"),
52
+ react_1.default.createElement("th", { style: styles_1.headerCellStyle }, "Retry Count"))),
53
+ react_1.default.createElement("tbody", null, data.map((job) => (react_1.default.createElement("tr", { key: job.jid },
54
+ react_1.default.createElement("td", { style: styles_1.cellStyle },
55
+ react_1.default.createElement("input", { type: "checkbox", onChange: (e) => handleCheckboxChange(job.jid, e.target.checked) })),
56
+ react_1.default.createElement("td", { style: styles_1.cellStyle }, job.jid),
57
+ react_1.default.createElement("td", { style: styles_1.cellStyle }, job.queue),
58
+ react_1.default.createElement("td", { style: styles_1.cellStyle }, job.error_message),
59
+ react_1.default.createElement("td", { style: styles_1.cellStyle }, new Date(job.failed_at * 1000).toLocaleString()),
60
+ react_1.default.createElement("td", { style: styles_1.cellStyle }, job.retry_count)))))));
61
+ };
62
+ exports.default = RetryTable;
63
+ //# sourceMappingURL=retry-table.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"retry-table.js","sourceRoot":"","sources":["../../src/components/retry-table.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAmD;AAEnD,sCAAmE;AAOnE,MAAM,UAAU,GAAoB,CAAC,EAAE,IAAI,EAAE,cAAc,EAAE,EAAE,EAAE;IAC/D,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,IAAA,gBAAQ,EAAW,EAAE,CAAC,CAAC;IAE/D,MAAM,oBAAoB,GAAG,CAAC,GAAW,EAAE,SAAkB,EAAE,EAAE;QAC/D,IAAI,SAAS,EAAE,CAAC;YACd,sBAAsB;YACtB,eAAe,CAAC,CAAC,GAAG,YAAY,EAAE,GAAG,CAAC,CAAC,CAAC;QAC1C,CAAC;aAAM,CAAC;YACN,uBAAuB;YACvB,eAAe,CACb,YAAY,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,KAAK,GAAG,CAAC,CAC1D,CAAC;QACJ,CAAC;IACH,CAAC,CAAC;IAEF,kCAAkC;IAClC,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,cAAc,CAAC,YAAY,CAAC,CAAC;IAC/B,CAAC,EAAE,CAAC,YAAY,EAAE,cAAc,CAAC,CAAC,CAAC;IAEnC,OAAO,CACL,yCAAO,KAAK,EAAE,mBAAU;QACtB;YACE;gBACE,sCAAI,KAAK,EAAE,wBAAe,aAAa;gBACvC,sCAAI,KAAK,EAAE,wBAAe,UAAU;gBACpC,sCAAI,KAAK,EAAE,wBAAe,YAAY;gBACtC,sCAAI,KAAK,EAAE,wBAAe,oBAAoB;gBAC9C,sCAAI,KAAK,EAAE,wBAAe,gBAAgB;gBAC1C,sCAAI,KAAK,EAAE,wBAAe,kBAAkB,CACzC,CACC;QACR,6CACG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CACjB,sCAAI,GAAG,EAAE,GAAG,CAAC,GAAG;YACd,sCAAI,KAAK,EAAE,kBAAS;gBAClB,yCACE,IAAI,EAAC,UAAU,EACf,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CACd,oBAAoB,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,GAEjD,CACC;YACL,sCAAI,KAAK,EAAE,kBAAS,IAAG,GAAG,CAAC,GAAG,CAAM;YACpC,sCAAI,KAAK,EAAE,kBAAS,IAAG,GAAG,CAAC,KAAK,CAAM;YACtC,sCAAI,KAAK,EAAE,kBAAS,IAAG,GAAG,CAAC,aAAa,CAAM;YAC9C,sCAAI,KAAK,EAAE,kBAAS,IACjB,IAAI,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC,CAAC,cAAc,EAAE,CAC7C;YACL,sCAAI,KAAK,EAAE,kBAAS,IAAG,GAAG,CAAC,WAAW,CAAM,CACzC,CACN,CAAC,CACI,CACF,CACT,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,UAAU,CAAC"}
@@ -0,0 +1,12 @@
1
+ import React from "react";
2
+ export type Stat = {
3
+ stat: string;
4
+ value: string;
5
+ };
6
+ type Props = {
7
+ stats: Stat[];
8
+ startDate?: string;
9
+ endDate?: string;
10
+ };
11
+ declare const StatsLineChart: React.FC<Props>;
12
+ export default StatsLineChart;
@@ -0,0 +1,69 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const recharts_1 = require("recharts");
8
+ const styles_1 = require("../styles");
9
+ const processData = (stats, startDate, endDate) => {
10
+ const processed = {};
11
+ const failed = {};
12
+ stats.forEach(({ stat, value }) => {
13
+ const [type, date] = stat.split(":");
14
+ if (!date)
15
+ return; // 'processed' と 'failed' の累計値を無視
16
+ if (type === "processed") {
17
+ processed[date] = (processed[date] || 0) + parseInt(value);
18
+ }
19
+ else if (type === "failed") {
20
+ failed[date] = (failed[date] || 0) + parseInt(value);
21
+ }
22
+ });
23
+ // データを昇順にソートする
24
+ const sortedData = Object.keys(processed)
25
+ .map((date) => ({
26
+ date,
27
+ processed: processed[date] || 0,
28
+ failed: failed[date] || 0,
29
+ }))
30
+ .sort((a, b) => new Date(a.date).getTime() - new Date(b.date).getTime());
31
+ let filteredData = sortedData;
32
+ if (startDate || endDate) {
33
+ const start = startDate
34
+ ? new Date(startDate).getTime()
35
+ : Number.MIN_SAFE_INTEGER;
36
+ const end = endDate ? new Date(endDate).getTime() : Number.MAX_SAFE_INTEGER;
37
+ filteredData = sortedData.filter((d) => {
38
+ const date = new Date(d.date).getTime();
39
+ return date >= start && date <= end;
40
+ });
41
+ }
42
+ else {
43
+ // 開始日と終了日の指定がない場合、直近3ヶ月分をフィルタリング
44
+ const threeMonthsAgo = new Date();
45
+ threeMonthsAgo.setMonth(threeMonthsAgo.getMonth() - 3);
46
+ filteredData = sortedData.filter((d) => new Date(d.date) >= threeMonthsAgo);
47
+ }
48
+ return filteredData;
49
+ };
50
+ const StatsLineChart = ({ stats, startDate, endDate }) => {
51
+ const data = processData(stats, startDate, endDate);
52
+ return (react_1.default.createElement("div", { style: styles_1.containerStyle },
53
+ react_1.default.createElement(recharts_1.ResponsiveContainer, { width: "100%", height: 300 },
54
+ react_1.default.createElement(recharts_1.LineChart, { width: 500, height: 300, data: data, margin: {
55
+ top: 5,
56
+ right: 30,
57
+ left: 20,
58
+ bottom: 5,
59
+ } },
60
+ react_1.default.createElement(recharts_1.CartesianGrid, { strokeDasharray: "3 3" }),
61
+ react_1.default.createElement(recharts_1.XAxis, { dataKey: "date" }),
62
+ react_1.default.createElement(recharts_1.YAxis, null),
63
+ react_1.default.createElement(recharts_1.Tooltip, null),
64
+ react_1.default.createElement(recharts_1.Legend, null),
65
+ react_1.default.createElement(recharts_1.Line, { type: "monotone", dataKey: "processed", stroke: "#8884d8", activeDot: { r: 8 } }),
66
+ react_1.default.createElement(recharts_1.Line, { type: "monotone", dataKey: "failed", stroke: "#82ca9d" })))));
67
+ };
68
+ exports.default = StatsLineChart;
69
+ //# sourceMappingURL=stats-line-chart.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stats-line-chart.js","sourceRoot":"","sources":["../../src/components/stats-line-chart.tsx"],"names":[],"mappings":"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"}
@@ -7,12 +7,16 @@ const react_1 = __importDefault(require("react"));
7
7
  const queue_status_1 = __importDefault(require("./components/queue-status"));
8
8
  const statistics_1 = __importDefault(require("./components/statistics"));
9
9
  const processes_1 = __importDefault(require("./components/processes"));
10
+ const stats_line_chart_1 = __importDefault(require("./components/stats-line-chart"));
11
+ const cron_stats_1 = __importDefault(require("./components/cron-stats"));
10
12
  const Dashboard = ({ data }) => {
11
13
  return (react_1.default.createElement("div", null,
12
14
  react_1.default.createElement("h1", null, "Sidekiq Dashboard"),
13
15
  react_1.default.createElement(queue_status_1.default, { queues: data.queues }),
16
+ react_1.default.createElement(processes_1.default, { processes: data.processes }),
14
17
  react_1.default.createElement(statistics_1.default, { stats: data.stats }),
15
- react_1.default.createElement(processes_1.default, { processes: data.processes })));
18
+ react_1.default.createElement(stats_line_chart_1.default, { stats: data.stats }),
19
+ react_1.default.createElement(cron_stats_1.default, { cronJobs: data.cronJobs })));
16
20
  };
17
21
  exports.default = Dashboard;
18
22
  //# sourceMappingURL=dashboard.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"dashboard.js","sourceRoot":"","sources":["../src/dashboard.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAC1B,6EAAoD;AACpD,yEAAiD;AACjD,uEAA+C;AAO/C,MAAM,SAAS,GAAG,CAAC,EAAE,IAAI,EAAS,EAAE,EAAE;IACpC,OAAO,CACL;QACE,8DAA0B;QAC1B,8BAAC,sBAAW,IAAC,MAAM,EAAE,IAAI,CAAC,MAAM,GAAI;QACpC,8BAAC,oBAAU,IAAC,KAAK,EAAE,IAAI,CAAC,KAAK,GAAI;QACjC,8BAAC,mBAAS,IAAC,SAAS,EAAE,IAAI,CAAC,SAAS,GAAI,CACpC,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,SAAS,CAAC"}
1
+ {"version":3,"file":"dashboard.js","sourceRoot":"","sources":["../src/dashboard.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAC1B,6EAAoD;AACpD,yEAAiD;AACjD,uEAA+C;AAE/C,qFAA2D;AAC3D,yEAAgD;AAMhD,MAAM,SAAS,GAAG,CAAC,EAAE,IAAI,EAAS,EAAE,EAAE;IACpC,OAAO,CACL;QACE,8DAA0B;QAC1B,8BAAC,sBAAW,IAAC,MAAM,EAAE,IAAI,CAAC,MAAM,GAAI;QACpC,8BAAC,mBAAS,IAAC,SAAS,EAAE,IAAI,CAAC,SAAS,GAAI;QACxC,8BAAC,oBAAU,IAAC,KAAK,EAAE,IAAI,CAAC,KAAK,GAAI;QACjC,8BAAC,0BAAc,IAAC,KAAK,EAAE,IAAI,CAAC,KAAK,GAAI;QACrC,8BAAC,oBAAS,IAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,GAAI,CAClC,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,SAAS,CAAC"}
@@ -1,4 +1,6 @@
1
+ import { RetryJobDetail } from "./types";
1
2
  export declare const getSidekiqData: (redisUrl?: string) => Promise<{
3
+ keys: string[];
2
4
  queues: {
3
5
  queue: string;
4
6
  size: number;
@@ -13,4 +15,45 @@ export declare const getSidekiqData: (redisUrl?: string) => Promise<{
13
15
  [x: string]: string;
14
16
  };
15
17
  }[];
18
+ cronJobs: ({
19
+ key: string;
20
+ type: "string";
21
+ value: string | null;
22
+ details?: undefined;
23
+ message?: undefined;
24
+ } | {
25
+ key: string;
26
+ type: "list";
27
+ value: string[];
28
+ details?: undefined;
29
+ message?: undefined;
30
+ } | {
31
+ key: string;
32
+ type: "set";
33
+ value: string[];
34
+ details?: undefined;
35
+ message?: undefined;
36
+ } | {
37
+ key: string;
38
+ type: "zset";
39
+ value: string[];
40
+ details?: undefined;
41
+ message?: undefined;
42
+ } | {
43
+ key: string;
44
+ type: "hash";
45
+ details: {
46
+ [x: string]: string;
47
+ };
48
+ value?: undefined;
49
+ message?: undefined;
50
+ } | {
51
+ key: string;
52
+ type: string;
53
+ message: string;
54
+ value?: undefined;
55
+ details?: undefined;
56
+ })[];
16
57
  } | undefined>;
58
+ export declare const getRetryJobsDetails: (redisUrl?: string) => Promise<RetryJobDetail[]>;
59
+ export declare const removeJobFromRetry: (jids: string[], redisUrl?: string) => Promise<void>;
@@ -9,7 +9,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
9
9
  });
10
10
  };
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.getSidekiqData = void 0;
12
+ exports.removeJobFromRetry = exports.getRetryJobsDetails = exports.getSidekiqData = void 0;
13
13
  const redis_1 = require("redis");
14
14
  const redisClient = (url) => __awaiter(void 0, void 0, void 0, function* () {
15
15
  return yield (0, redis_1.createClient)({ url: url || "redis://localhost:6379/5" })
@@ -19,6 +19,8 @@ const redisClient = (url) => __awaiter(void 0, void 0, void 0, function* () {
19
19
  const getSidekiqData = (redisUrl) => __awaiter(void 0, void 0, void 0, function* () {
20
20
  try {
21
21
  const client = yield redisClient(redisUrl);
22
+ // すべてのキーを取得
23
+ const allKeys = yield client.keys("*");
22
24
  const queueKeys = yield client.keys("queue:*");
23
25
  const queueData = yield Promise.all(queueKeys.map((key) => __awaiter(void 0, void 0, void 0, function* () {
24
26
  const size = yield client.lLen(key);
@@ -30,16 +32,92 @@ const getSidekiqData = (redisUrl) => __awaiter(void 0, void 0, void 0, function*
30
32
  const value = yield client.get(key);
31
33
  return { stat: key.replace("stat:", ""), value };
32
34
  })));
35
+ // "retry" キーのデータの件数を取得
36
+ const retryCount = yield client.zCard("retry");
37
+ statsData.push({ stat: "retry", value: retryCount.toString() });
33
38
  const processSet = yield client.sMembers("processes");
34
39
  const processData = yield Promise.all(processSet.map((processKey) => __awaiter(void 0, void 0, void 0, function* () {
35
40
  const processInfo = yield client.hGetAll(processKey);
36
41
  return { processKey, processInfo };
37
42
  })));
38
- return { queues: queueData, stats: statsData, processes: processData };
43
+ // cron_job:* にマッチするすべてのクロンジョブキーを取得
44
+ const cronJobKeys = yield client.keys("cron_job:*");
45
+ const cronJobsData = yield Promise.all(cronJobKeys.map((key) => __awaiter(void 0, void 0, void 0, function* () {
46
+ const type = yield client.type(key); // キーのタイプを取得
47
+ switch (type) {
48
+ case "string":
49
+ const stringValue = yield client.get(key);
50
+ return { key, type, value: stringValue };
51
+ case "list":
52
+ const listValues = yield client.lRange(key, 0, -1);
53
+ return { key, type, value: listValues };
54
+ case "set":
55
+ const setValues = yield client.sMembers(key);
56
+ return { key, type, value: setValues };
57
+ case "zset":
58
+ const zsetValues = yield client.zRange(key, 0, -1);
59
+ return { key, type, value: zsetValues };
60
+ case "hash":
61
+ const hashValues = yield client.hGetAll(key);
62
+ return { key, type, details: hashValues };
63
+ default:
64
+ return { key, type, message: "Unsupported type" };
65
+ }
66
+ })));
67
+ return {
68
+ keys: allKeys,
69
+ queues: queueData,
70
+ stats: statsData,
71
+ processes: processData,
72
+ cronJobs: cronJobsData,
73
+ };
39
74
  }
40
75
  catch (err) {
41
76
  console.error(err);
42
77
  }
43
78
  });
44
79
  exports.getSidekiqData = getSidekiqData;
80
+ const getRetryJobsDetails = (redisUrl) => __awaiter(void 0, void 0, void 0, function* () {
81
+ try {
82
+ const client = yield redisClient(redisUrl);
83
+ const retryJobs = yield client.zRange("retry", 0, -1);
84
+ const retryJobsData = retryJobs.map((jobString) => {
85
+ try {
86
+ const jobDetails = JSON.parse(jobString);
87
+ return jobDetails;
88
+ }
89
+ catch (err) {
90
+ console.error(`JSON parsing error for job: ${jobString}`, err);
91
+ // 失敗した場合は空のオブジェクトを返します(または適切なエラー処理を実施する)
92
+ return {};
93
+ }
94
+ });
95
+ return retryJobsData;
96
+ }
97
+ catch (err) {
98
+ console.error("失敗したジョブの取得中にエラーが発生しました:", err);
99
+ // エラーが発生した場合は空の配列を返します(または適切なエラー処理を実施する)
100
+ return [];
101
+ }
102
+ });
103
+ exports.getRetryJobsDetails = getRetryJobsDetails;
104
+ const removeJobFromRetry = (jids, redisUrl) => __awaiter(void 0, void 0, void 0, function* () {
105
+ try {
106
+ const client = yield redisClient(redisUrl);
107
+ const jobs = yield client.zRange("retry", 0, -1);
108
+ for (const jobString of jobs) {
109
+ const job = JSON.parse(jobString);
110
+ if (jids.includes(job.jid)) {
111
+ // 指定されたjidを持つジョブを削除
112
+ yield client.zRem("retry", jobString);
113
+ console.log(`Job with jid: ${job.jid} has been removed from retry queue.`);
114
+ }
115
+ }
116
+ }
117
+ catch (err) {
118
+ console.error("Error removing job from retry:", err);
119
+ throw err;
120
+ }
121
+ });
122
+ exports.removeJobFromRetry = removeJobFromRetry;
45
123
  //# sourceMappingURL=redis-client.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"redis-client.js","sourceRoot":"","sources":["../src/redis-client.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,iCAAqC;AAErC,MAAM,WAAW,GAAG,CAAO,GAAY,EAAE,EAAE;IACzC,OAAO,MAAM,IAAA,oBAAY,EAAC,EAAE,GAAG,EAAE,GAAG,IAAI,0BAA0B,EAAE,CAAC;SAClE,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,oBAAoB,EAAE,GAAG,CAAC,CAAC;SAC9D,OAAO,EAAE,CAAC;AACf,CAAC,CAAA,CAAC;AAEK,MAAM,cAAc,GAAG,CAAO,QAAiB,EAAE,EAAE;IACxD,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,QAAQ,CAAC,CAAC;QAE3C,MAAM,SAAS,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC/C,MAAM,SAAS,GAAG,MAAM,OAAO,CAAC,GAAG,CACjC,SAAS,CAAC,GAAG,CAAC,CAAO,GAAG,EAAE,EAAE;YAC1B,MAAM,IAAI,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACpC,OAAO,EAAE,KAAK,EAAE,GAAG,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC;QACpD,CAAC,CAAA,CAAC,CACH,CAAC;QAEF,6BAA6B;QAC7B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC7C,MAAM,SAAS,GAAG,MAAM,OAAO,CAAC,GAAG,CACjC,QAAQ,CAAC,GAAG,CAAC,CAAO,GAAG,EAAE,EAAE;YACzB,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACpC,OAAO,EAAE,IAAI,EAAE,GAAG,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC;QACnD,CAAC,CAAA,CAAC,CACH,CAAC;QAEF,MAAM,UAAU,GAAG,MAAM,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;QACtD,MAAM,WAAW,GAAG,MAAM,OAAO,CAAC,GAAG,CACnC,UAAU,CAAC,GAAG,CAAC,CAAO,UAAU,EAAE,EAAE;YAClC,MAAM,WAAW,GAAG,MAAM,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;YACrD,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,CAAC;QACrC,CAAC,CAAA,CAAC,CACH,CAAC;QAEF,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,WAAW,EAAE,CAAC;IACzE,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACrB,CAAC;AACH,CAAC,CAAA,CAAC;AAjCW,QAAA,cAAc,kBAiCzB"}
1
+ {"version":3,"file":"redis-client.js","sourceRoot":"","sources":["../src/redis-client.ts"],"names":[],"mappings":"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"}
package/build/styles.d.ts CHANGED
@@ -1,4 +1,5 @@
1
1
  import { CSSProperties } from "react";
2
+ export declare const containerStyle: CSSProperties;
2
3
  export declare const tableStyle: CSSProperties;
3
4
  export declare const cellStyle: CSSProperties;
4
5
  export declare const headerCellStyle: CSSProperties;
package/build/styles.js CHANGED
@@ -1,11 +1,15 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.headerCellStyle = exports.cellStyle = exports.tableStyle = void 0;
3
+ exports.headerCellStyle = exports.cellStyle = exports.tableStyle = exports.containerStyle = void 0;
4
+ exports.containerStyle = {
5
+ margin: "16px",
6
+ };
4
7
  exports.tableStyle = {
5
8
  width: "100%",
6
9
  borderCollapse: "collapse",
7
10
  };
8
11
  exports.cellStyle = {
12
+ padding: "4px",
9
13
  border: "1px solid black",
10
14
  };
11
15
  exports.headerCellStyle = {
@@ -1 +1 @@
1
- {"version":3,"file":"styles.js","sourceRoot":"","sources":["../src/styles.ts"],"names":[],"mappings":";;;AAEa,QAAA,UAAU,GAAkB;IACvC,KAAK,EAAE,MAAM;IACb,cAAc,EAAE,UAAU;CAC3B,CAAC;AAEW,QAAA,SAAS,GAAkB;IACtC,MAAM,EAAE,iBAAiB;CAC1B,CAAC;AAEW,QAAA,eAAe,GAAkB;IAC5C,MAAM,EAAE,iBAAiB;IACzB,eAAe,EAAE,SAAS;CAC3B,CAAC"}
1
+ {"version":3,"file":"styles.js","sourceRoot":"","sources":["../src/styles.ts"],"names":[],"mappings":";;;AAEa,QAAA,cAAc,GAAkB;IAC3C,MAAM,EAAE,MAAM;CACf,CAAC;AAEW,QAAA,UAAU,GAAkB;IACvC,KAAK,EAAE,MAAM;IACb,cAAc,EAAE,UAAU;CAC3B,CAAC;AAEW,QAAA,SAAS,GAAkB;IACtC,OAAO,EAAE,KAAK;IACd,MAAM,EAAE,iBAAiB;CAC1B,CAAC;AAEW,QAAA,eAAe,GAAkB;IAC5C,MAAM,EAAE,iBAAiB;IACzB,eAAe,EAAE,SAAS;CAC3B,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ts-sidekiq",
3
- "version": "0.0.5",
3
+ "version": "0.1.0",
4
4
  "description": "manage sidekiq",
5
5
  "main": "build/server.js",
6
6
  "browser": "build/index.js",
@@ -37,22 +37,23 @@
37
37
  },
38
38
  "peerDependencies": {
39
39
  "react": "^18.2.0",
40
- "react-dom": "^18.2.0"
40
+ "react-dom": "^18.2.0",
41
+ "recharts": "^2.10.3"
41
42
  },
42
43
  "devDependencies": {
43
44
  "@ladle/react": "^4.0.2",
44
45
  "@types/cors": "^2.8.17",
45
46
  "@types/express": "^4.17.21",
46
47
  "@types/jest": "^29.5.11",
47
- "@types/react": "^18.2.42",
48
- "@types/react-dom": "^18.2.17",
48
+ "@types/react": "^18.2.46",
49
+ "@types/react-dom": "^18.2.18",
49
50
  "concurrently": "^8.2.2",
50
51
  "cors": "^2.8.5",
51
52
  "express": "^4.18.2",
52
53
  "jest": "^29.7.0",
53
- "redis": "^4.6.11",
54
+ "redis": "^4.6.12",
54
55
  "ts-jest": "^29.1.1",
55
- "ts-node": "^10.9.1",
56
+ "ts-node": "^10.9.2",
56
57
  "typescript": "^5.3.3"
57
58
  }
58
59
  }