mirror of
https://github.com/Dvorinka/PPve.git
synced 2026-06-04 12:32:59 +00:00
test
This commit is contained in:
@@ -1271,44 +1271,27 @@ func sendEmail(entry TripEntry, parsedDateStart, parsedDateEnd time.Time, czechM
|
|||||||
// Add these new handler functions before the existing banner handlers
|
// Add these new handler functions before the existing banner handlers
|
||||||
|
|
||||||
func handleUpdateReservation(w http.ResponseWriter, r *http.Request) {
|
func handleUpdateReservation(w http.ResponseWriter, r *http.Request) {
|
||||||
// Set CORS headers
|
|
||||||
w.Header().Set("Content-Type", "application/json")
|
|
||||||
w.Header().Set("Access-Control-Allow-Origin", "*")
|
|
||||||
w.Header().Set("Access-Control-Allow-Methods", "PUT, OPTIONS")
|
|
||||||
w.Header().Set("Access-Control-Allow-Headers", "Content-Type")
|
|
||||||
|
|
||||||
// Handle preflight
|
|
||||||
if r.Method == "OPTIONS" {
|
|
||||||
w.WriteHeader(http.StatusOK)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
vars := mux.Vars(r)
|
vars := mux.Vars(r)
|
||||||
id := vars["id"]
|
reservationID := vars["id"]
|
||||||
if id == "" {
|
|
||||||
http.Error(w, "Missing reservation ID", http.StatusBadRequest)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// Parse the updated reservation from request body
|
|
||||||
var updatedReservation Reservation
|
var updatedReservation Reservation
|
||||||
if err := json.NewDecoder(r.Body).Decode(&updatedReservation); err != nil {
|
if err := json.NewDecoder(r.Body).Decode(&updatedReservation); err != nil {
|
||||||
http.Error(w, "Invalid reservation data: "+err.Error(), http.StatusBadRequest)
|
http.Error(w, "Invalid reservation data", http.StatusBadRequest)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// Load existing reservations
|
// Load existing reservations
|
||||||
reservations, err := loadReservations()
|
reservations, err := loadReservations()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
http.Error(w, "Failed to load reservations: "+err.Error(), http.StatusInternalServerError)
|
http.Error(w, "Failed to load reservations", http.StatusInternalServerError)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// Find and update the reservation
|
// Find and update the reservation
|
||||||
found := false
|
found := false
|
||||||
for i, res := range reservations {
|
for i, res := range reservations {
|
||||||
if res.ID == id {
|
if res.ID == reservationID {
|
||||||
updatedReservation.ID = id // Ensure ID remains the same
|
updatedReservation.ID = reservationID // Ensure ID remains unchanged
|
||||||
reservations[i] = updatedReservation
|
reservations[i] = updatedReservation
|
||||||
found = true
|
found = true
|
||||||
break
|
break
|
||||||
@@ -1322,38 +1305,22 @@ func handleUpdateReservation(w http.ResponseWriter, r *http.Request) {
|
|||||||
|
|
||||||
// Save updated reservations
|
// Save updated reservations
|
||||||
if err := saveReservations(reservations); err != nil {
|
if err := saveReservations(reservations); err != nil {
|
||||||
http.Error(w, "Failed to save reservations: "+err.Error(), http.StatusInternalServerError)
|
http.Error(w, "Failed to save reservation", http.StatusInternalServerError)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return the updated reservation
|
w.Header().Set("Content-Type", "application/json")
|
||||||
json.NewEncoder(w).Encode(updatedReservation)
|
json.NewEncoder(w).Encode(updatedReservation)
|
||||||
}
|
}
|
||||||
|
|
||||||
func handleDeleteReservation(w http.ResponseWriter, r *http.Request) {
|
func handleDeleteReservation(w http.ResponseWriter, r *http.Request) {
|
||||||
// Set CORS headers
|
|
||||||
w.Header().Set("Content-Type", "application/json")
|
|
||||||
w.Header().Set("Access-Control-Allow-Origin", "*")
|
|
||||||
w.Header().Set("Access-Control-Allow-Methods", "DELETE, OPTIONS")
|
|
||||||
w.Header().Set("Access-Control-Allow-Headers", "Content-Type")
|
|
||||||
|
|
||||||
// Handle preflight
|
|
||||||
if r.Method == "OPTIONS" {
|
|
||||||
w.WriteHeader(http.StatusOK)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
vars := mux.Vars(r)
|
vars := mux.Vars(r)
|
||||||
id := vars["id"]
|
reservationID := vars["id"]
|
||||||
if id == "" {
|
|
||||||
http.Error(w, "Missing reservation ID", http.StatusBadRequest)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// Load existing reservations
|
// Load existing reservations
|
||||||
reservations, err := loadReservations()
|
reservations, err := loadReservations()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
http.Error(w, "Failed to load reservations: "+err.Error(), http.StatusInternalServerError)
|
http.Error(w, "Failed to load reservations", http.StatusInternalServerError)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1361,9 +1328,9 @@ func handleDeleteReservation(w http.ResponseWriter, r *http.Request) {
|
|||||||
found := false
|
found := false
|
||||||
var updatedReservations []Reservation
|
var updatedReservations []Reservation
|
||||||
for _, res := range reservations {
|
for _, res := range reservations {
|
||||||
if res.ID == id {
|
if res.ID == reservationID {
|
||||||
found = true
|
found = true
|
||||||
continue // Skip this reservation to remove it
|
continue
|
||||||
}
|
}
|
||||||
updatedReservations = append(updatedReservations, res)
|
updatedReservations = append(updatedReservations, res)
|
||||||
}
|
}
|
||||||
@@ -1375,10 +1342,9 @@ func handleDeleteReservation(w http.ResponseWriter, r *http.Request) {
|
|||||||
|
|
||||||
// Save updated reservations
|
// Save updated reservations
|
||||||
if err := saveReservations(updatedReservations); err != nil {
|
if err := saveReservations(updatedReservations); err != nil {
|
||||||
http.Error(w, "Failed to save reservations: "+err.Error(), http.StatusInternalServerError)
|
http.Error(w, "Failed to save reservations", http.StatusInternalServerError)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return success with no content
|
|
||||||
w.WriteHeader(http.StatusNoContent)
|
w.WriteHeader(http.StatusNoContent)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user