mirror of
https://github.com/ditatompel/xmr-remote-nodes.git
synced 2025-01-08 05:52:10 +07:00
Adding prober delete action
This commit is contained in:
parent
32ef14d1d5
commit
09490a8250
5 changed files with 76 additions and 2 deletions
|
@ -1,8 +1,9 @@
|
||||||
<script>
|
<script>
|
||||||
import { DataHandler } from '@vincjo/datatables/remote';
|
import { DataHandler } from '@vincjo/datatables/remote';
|
||||||
import { format, formatDistance } from 'date-fns';
|
import { format, formatDistance } from 'date-fns';
|
||||||
import { loadData } from './api-handler';
|
import { loadData, deleteData } from './api-handler';
|
||||||
import { onMount, onDestroy } from 'svelte';
|
import { onMount, onDestroy } from 'svelte';
|
||||||
|
import { getModalStore, getToastStore } from '@skeletonlabs/skeleton';
|
||||||
import {
|
import {
|
||||||
DtSrRowsPerPage,
|
DtSrRowsPerPage,
|
||||||
DtSrThSort,
|
DtSrThSort,
|
||||||
|
@ -10,6 +11,37 @@
|
||||||
DtSrRowCount,
|
DtSrRowCount,
|
||||||
DtSrPagination
|
DtSrPagination
|
||||||
} from '$lib/components/datatables/server';
|
} from '$lib/components/datatables/server';
|
||||||
|
const modalStore = getModalStore();
|
||||||
|
const toastStore = getToastStore();
|
||||||
|
|
||||||
|
/** @param {number} id */
|
||||||
|
const handleDelete = (id) => {
|
||||||
|
modalStore.trigger({
|
||||||
|
type: 'confirm',
|
||||||
|
title: 'Please Confirm',
|
||||||
|
body: 'Are you sure you wish to proceed?',
|
||||||
|
/** @param {boolean} r */
|
||||||
|
response: async (r) => {
|
||||||
|
if (r) {
|
||||||
|
deleteData(id)
|
||||||
|
.then((res) => {
|
||||||
|
if (res.status !== 'ok') {
|
||||||
|
toastStore.trigger({ message: 'Failed to delete prober' });
|
||||||
|
} else {
|
||||||
|
toastStore.trigger({
|
||||||
|
message: 'Prober deleted',
|
||||||
|
background: 'variant-filled-success'
|
||||||
|
});
|
||||||
|
handler.invalidate();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.catch(() => {
|
||||||
|
toastStore.trigger({ message: 'Prober could not be deleted' });
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
const handler = new DataHandler([], { rowsPerPage: 10, totalRows: 0 });
|
const handler = new DataHandler([], { rowsPerPage: 10, totalRows: 0 });
|
||||||
let rows = handler.getRows();
|
let rows = handler.getRows();
|
||||||
|
@ -108,7 +140,16 @@
|
||||||
<tbody>
|
<tbody>
|
||||||
{#each $rows as row (row.id)}
|
{#each $rows as row (row.id)}
|
||||||
<tr>
|
<tr>
|
||||||
<td>{row.id}</td>
|
<td>
|
||||||
|
{row.id}
|
||||||
|
<button
|
||||||
|
class="variant-filled-error btn btn-sm mr-1"
|
||||||
|
name="delete_{row.id}"
|
||||||
|
on:click={() => {
|
||||||
|
handleDelete(row.id);
|
||||||
|
}}>Delete</button
|
||||||
|
>
|
||||||
|
</td>
|
||||||
<td>{row.name}</td>
|
<td>{row.name}</td>
|
||||||
<td>{row.api_key}</td>
|
<td>{row.api_key}</td>
|
||||||
<td>
|
<td>
|
||||||
|
|
|
@ -8,6 +8,15 @@ export const loadData = async (state) => {
|
||||||
return json.data.items ?? [];
|
return json.data.items ?? [];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export const deleteData = async (id) => {
|
||||||
|
const response = await fetch(apiUri(`/api/v1/prober/${id}`), {
|
||||||
|
method: 'DELETE',
|
||||||
|
credentials: 'include'
|
||||||
|
});
|
||||||
|
const json = await response.json();
|
||||||
|
return json;
|
||||||
|
};
|
||||||
|
|
||||||
const getParams = ({ pageNumber, rowsPerPage, sort, filters }) => {
|
const getParams = ({ pageNumber, rowsPerPage, sort, filters }) => {
|
||||||
let params = `page=${pageNumber}&limit=${rowsPerPage}`;
|
let params = `page=${pageNumber}&limit=${rowsPerPage}`;
|
||||||
|
|
||||||
|
|
|
@ -88,6 +88,22 @@ func Prober(c *fiber.Ctx) error {
|
||||||
"data": nil,
|
"data": nil,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
} else if c.Method() == "DELETE" {
|
||||||
|
id, _ := strconv.Atoi(c.Params("id"))
|
||||||
|
err := proberRepo.Delete(id)
|
||||||
|
if err != nil {
|
||||||
|
return c.Status(fiber.StatusInternalServerError).JSON(fiber.Map{
|
||||||
|
"status": "error",
|
||||||
|
"message": err.Error(),
|
||||||
|
"data": nil,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
return c.JSON(fiber.Map{
|
||||||
|
"status": "ok",
|
||||||
|
"message": "Success",
|
||||||
|
"data": nil,
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
query := repo.ProbersQueryParams{
|
query := repo.ProbersQueryParams{
|
||||||
|
|
|
@ -14,6 +14,7 @@ func V1Api(app *fiber.App) {
|
||||||
|
|
||||||
v1.Get("/prober", Prober)
|
v1.Get("/prober", Prober)
|
||||||
v1.Post("/prober", Prober)
|
v1.Post("/prober", Prober)
|
||||||
|
v1.Delete("/prober/:id", CookieProtected, Prober)
|
||||||
v1.Get("/nodes", MoneroNodes)
|
v1.Get("/nodes", MoneroNodes)
|
||||||
v1.Post("/nodes", AddNode)
|
v1.Post("/nodes", AddNode)
|
||||||
v1.Get("/nodes/id/:id", MoneroNode)
|
v1.Get("/nodes/id/:id", MoneroNode)
|
||||||
|
|
|
@ -14,6 +14,7 @@ type ProberRepository interface {
|
||||||
AddProber(name string) error
|
AddProber(name string) error
|
||||||
Probers(q ProbersQueryParams) (Probers, error)
|
Probers(q ProbersQueryParams) (Probers, error)
|
||||||
CheckApi(key string) (Prober, error)
|
CheckApi(key string) (Prober, error)
|
||||||
|
Delete(id int) error
|
||||||
}
|
}
|
||||||
|
|
||||||
type ProberRepo struct {
|
type ProberRepo struct {
|
||||||
|
@ -124,3 +125,9 @@ func (repo *ProberRepo) CheckApi(key string) (Prober, error) {
|
||||||
err := repo.db.QueryRow(query, key).Scan(&prober.Id, &prober.Name, &prober.ApiKey, &prober.LastSubmitTs)
|
err := repo.db.QueryRow(query, key).Scan(&prober.Id, &prober.Name, &prober.ApiKey, &prober.LastSubmitTs)
|
||||||
return prober, err
|
return prober, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (repo *ProberRepo) Delete(id int) error {
|
||||||
|
query := `DELETE FROM tbl_prober WHERE id = ?`
|
||||||
|
_, err := repo.db.Exec(query, id)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue