fix: no irc network created when adding a new indexer (#177)

This commit is contained in:
Ludvig Lundgren 2022-03-16 20:39:48 +01:00 committed by GitHub
parent aa196d8104
commit 8bf43dc1e0
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 56 additions and 27 deletions

View file

@ -6,7 +6,11 @@ import (
"net/http" "net/http"
) )
type encoder struct { type encoder struct{}
type errorResponse struct {
Message string `json:"message"`
Status int `json:"status"`
} }
func (e encoder) StatusResponse(ctx context.Context, w http.ResponseWriter, response interface{}, status int) { func (e encoder) StatusResponse(ctx context.Context, w http.ResponseWriter, response interface{}, status int) {
@ -14,14 +18,19 @@ func (e encoder) StatusResponse(ctx context.Context, w http.ResponseWriter, resp
w.Header().Set("Content-Type", "application/json; charset=utf=8") w.Header().Set("Content-Type", "application/json; charset=utf=8")
w.WriteHeader(status) w.WriteHeader(status)
if err := json.NewEncoder(w).Encode(response); err != nil { if err := json.NewEncoder(w).Encode(response); err != nil {
// log err w.WriteHeader(http.StatusInternalServerError)
return
} }
} else { } else {
w.WriteHeader(status) w.WriteHeader(status)
} }
} }
func (e encoder) StatusNoContent(w http.ResponseWriter) { func (e encoder) StatusCreated(w http.ResponseWriter) {
w.WriteHeader(http.StatusCreated)
}
func (e encoder) NoContent(w http.ResponseWriter) {
w.WriteHeader(http.StatusNoContent) w.WriteHeader(http.StatusNoContent)
} }
@ -32,3 +41,13 @@ func (e encoder) StatusNotFound(ctx context.Context, w http.ResponseWriter) {
func (e encoder) StatusInternalError(w http.ResponseWriter) { func (e encoder) StatusInternalError(w http.ResponseWriter) {
w.WriteHeader(http.StatusInternalServerError) w.WriteHeader(http.StatusInternalServerError)
} }
func (e encoder) Error(w http.ResponseWriter, err error) {
res := errorResponse{
Message: err.Error(),
}
w.Header().Set("Content-Type", "application/json; charset=utf=8")
w.WriteHeader(http.StatusInternalServerError)
json.NewEncoder(w).Encode(res)
}

View file

@ -47,7 +47,7 @@ func (h ircHandler) listNetworks(w http.ResponseWriter, r *http.Request) {
networks, err := h.service.GetNetworksWithHealth(ctx) networks, err := h.service.GetNetworksWithHealth(ctx)
if err != nil { if err != nil {
// h.encoder.Error(w, err)
} }
h.encoder.StatusResponse(ctx, w, networks, http.StatusOK) h.encoder.StatusResponse(ctx, w, networks, http.StatusOK)
@ -63,30 +63,27 @@ func (h ircHandler) getNetworkByID(w http.ResponseWriter, r *http.Request) {
network, err := h.service.GetNetworkByID(int64(id)) network, err := h.service.GetNetworkByID(int64(id))
if err != nil { if err != nil {
// h.encoder.Error(w, err)
} }
h.encoder.StatusResponse(ctx, w, network, http.StatusOK) h.encoder.StatusResponse(ctx, w, network, http.StatusOK)
} }
func (h ircHandler) storeNetwork(w http.ResponseWriter, r *http.Request) { func (h ircHandler) storeNetwork(w http.ResponseWriter, r *http.Request) {
var ( var data domain.IrcNetwork
ctx = r.Context()
data domain.IrcNetwork
)
if err := json.NewDecoder(r.Body).Decode(&data); err != nil { if err := json.NewDecoder(r.Body).Decode(&data); err != nil {
h.encoder.Error(w, err)
return return
} }
err := h.service.StoreNetwork(ctx, &data) err := h.service.StoreNetwork(r.Context(), &data)
if err != nil { if err != nil {
// h.encoder.Error(w, err)
h.encoder.StatusResponse(ctx, w, nil, http.StatusBadRequest)
return return
} }
h.encoder.StatusResponse(ctx, w, nil, http.StatusCreated) h.encoder.NoContent(w)
} }
func (h ircHandler) updateNetwork(w http.ResponseWriter, r *http.Request) { func (h ircHandler) updateNetwork(w http.ResponseWriter, r *http.Request) {
@ -96,22 +93,21 @@ func (h ircHandler) updateNetwork(w http.ResponseWriter, r *http.Request) {
) )
if err := json.NewDecoder(r.Body).Decode(&data); err != nil { if err := json.NewDecoder(r.Body).Decode(&data); err != nil {
h.encoder.Error(w, err)
return return
} }
err := h.service.UpdateNetwork(ctx, &data) err := h.service.UpdateNetwork(ctx, &data)
if err != nil { if err != nil {
// h.encoder.Error(w, err)
h.encoder.StatusResponse(ctx, w, nil, http.StatusBadRequest)
return return
} }
h.encoder.StatusResponse(ctx, w, nil, http.StatusCreated) h.encoder.NoContent(w)
} }
func (h ircHandler) storeChannel(w http.ResponseWriter, r *http.Request) { func (h ircHandler) storeChannel(w http.ResponseWriter, r *http.Request) {
var ( var (
ctx = r.Context()
data domain.IrcChannel data domain.IrcChannel
networkID = chi.URLParam(r, "networkID") networkID = chi.URLParam(r, "networkID")
) )
@ -119,15 +115,17 @@ func (h ircHandler) storeChannel(w http.ResponseWriter, r *http.Request) {
id, _ := strconv.Atoi(networkID) id, _ := strconv.Atoi(networkID)
if err := json.NewDecoder(r.Body).Decode(&data); err != nil { if err := json.NewDecoder(r.Body).Decode(&data); err != nil {
h.encoder.Error(w, err)
return return
} }
err := h.service.StoreChannel(int64(id), &data) err := h.service.StoreChannel(int64(id), &data)
if err != nil { if err != nil {
// h.encoder.Error(w, err)
return
} }
h.encoder.StatusResponse(ctx, w, nil, http.StatusCreated) h.encoder.NoContent(w)
} }
func (h ircHandler) deleteNetwork(w http.ResponseWriter, r *http.Request) { func (h ircHandler) deleteNetwork(w http.ResponseWriter, r *http.Request) {
@ -140,8 +138,9 @@ func (h ircHandler) deleteNetwork(w http.ResponseWriter, r *http.Request) {
err := h.service.DeleteNetwork(ctx, int64(id)) err := h.service.DeleteNetwork(ctx, int64(id))
if err != nil { if err != nil {
// h.encoder.Error(w, err)
return
} }
h.encoder.StatusResponse(ctx, w, nil, http.StatusNoContent) h.encoder.NoContent(w)
} }

View file

@ -145,5 +145,5 @@ func (h releaseHandler) deleteReleases(w http.ResponseWriter, r *http.Request) {
return return
} }
h.encoder.StatusNoContent(w) h.encoder.NoContent(w)
} }

View file

@ -89,7 +89,7 @@ export const APIClient = {
}, },
irc: { irc: {
getNetworks: () => appClient.Get<IrcNetworkWithHealth[]>("api/irc"), getNetworks: () => appClient.Get<IrcNetworkWithHealth[]>("api/irc"),
createNetwork: (network: IrcNetwork) => appClient.Post("api/irc", network), createNetwork: (network: IrcNetworkCreate) => appClient.Post("api/irc", network),
updateNetwork: (network: IrcNetwork) => appClient.Put(`api/irc/network/${network.id}`, network), updateNetwork: (network: IrcNetwork) => appClient.Put(`api/irc/network/${network.id}`, network),
deleteNetwork: (id: number) => appClient.Delete(`api/irc/network/${id}`), deleteNetwork: (id: number) => appClient.Delete(`api/irc/network/${id}`),
}, },

View file

@ -148,7 +148,7 @@ export function IndexerAddForm({ isOpen, toggle }: AddProps) {
}) })
const ircMutation = useMutation( const ircMutation = useMutation(
(network: IrcNetwork) => APIClient.irc.createNetwork(network) (network: IrcNetworkCreate) => APIClient.irc.createNetwork(network)
); );
const onSubmit = (formData: any) => { const onSubmit = (formData: any) => {
@ -170,13 +170,11 @@ export function IndexerAddForm({ isOpen, toggle }: AddProps) {
}); });
} }
const network: IrcNetwork = { const network: IrcNetworkCreate = {
id: 0,
name: ind.irc.network, name: ind.irc.network,
pass: "", pass: "",
enabled: false, enabled: false,
connected: false, connected: false,
connected_since: 0,
server: ind.irc.server, server: ind.irc.server,
port: ind.irc.port, port: ind.irc.port,
tls: ind.irc.tls, tls: ind.irc.tls,

View file

@ -13,6 +13,19 @@ interface IrcNetwork {
connected_since: Time; connected_since: Time;
} }
interface IrcNetworkCreate {
name: string;
enabled: boolean;
server: string;
port: number;
tls: boolean;
pass: string;
invite_command: string;
nickserv?: NickServ; // optional
channels: IrcChannel[];
connected: boolean;
}
interface IrcChannel { interface IrcChannel {
id: number; id: number;
enabled: boolean; enabled: boolean;