--- name: crud_update_handler kind: function lang: go domain: infra version: "1.0.0" purity: impure signature: "func CRUDUpdateHandler(res CRUDResource, db *sql.DB) http.HandlerFunc" description: "Genera un handler HTTP PUT /{id} que hace partial update del registro. Solo actualiza campos presentes en el body JSON, valida cada uno contra la definicion, actualiza updated_at y retorna el registro. 404 si no existe, 400 si falla validacion, 409 si viola UNIQUE." tags: [crud, update, handler, http, sqlite, partial, infra] uses_functions: [http_json_response_go_infra, http_error_response_go_infra, http_parse_body_go_infra] uses_types: [CRUDResource_go_infra, HTTPError_go_infra] returns: [] returns_optional: false error_type: "error_go_core" imports: [database/sql, fmt, net/http, strings, time] params: - name: res desc: "definicion del recurso" - name: db desc: "conexion *sql.DB a SQLite" output: "http.HandlerFunc que actualiza parcialmente un registro" tested: true tests: ["actualiza solo los campos enviados", "retorna 404 si no existe", "valida campos enviados", "actualiza updated_at"] test_file_path: "functions/infra/crud_test.go" file_path: "functions/infra/crud_update_handler.go" --- ## Ejemplo ```go handler := CRUDUpdateHandler(res, db) mux.Handle("PUT /api/projects/{id}", handler) // curl -X PUT localhost:8080/api/projects/abc -H 'Content-Type: application/json' -d '{"description":"X"}' ``` ## Notas Impura. Usa PUT con semantica de partial update por pragmatismo (en vez de PATCH). Los campos no enviados se preservan tal cual. updated_at se actualiza siempre, aunque el body este vacio (el handler de igual modo ejecuta UPDATE, consulta la bd). Id va en la ruta, no en el body.