xPeacefulDreams Posted September 12, 2024 Share Posted September 12, 2024 (edited) EDIT: Solved my own issue. I forgot to add options["headers"] and add options["headers"]["Content-Type"] = "application/json". Hi everybody, I am currently writing an API in NodeJS that reads from and writes to a MySQL database. This is used to retrieve and update players' accounts, vehicles etcetera on my server. To make calls to the API I am using the fetchRemote function and handle the data that comes back through a callback function. This works really well and I already have GET and POST requests that work perfectly. I am now at a point where I'm trying to use the HTTP 'PATCH' method to update a record via the API ( e.g. update a vehicle based on the current element's colors, model, etc.), but am running into an issue where using "PATCH" as the HTTP method does not send along any data (such as the postData variable) On the NodeJS side, I keep getting the message that no data was received. When I make this same call with a program like Postman, it works just fine. Is there another way to pass the data for a patch request that is perhaps not documented, and is the patch method even supported by fetchRemote? Lua code on the MTA server side (domains are whitelisted and the resource has the fetchRemote ACL permission) -- The Data to send data = { model = 411, name = 'Test Vehicle', color = '255,255,255,255,255,255,255,255,255,255,255,255', variant = '255,255' } -- fetchRemote options options = { method = "PATCH", postData = string.sub(toJSON(data), 2, -2), -- string.sub to remove [] brackets } -- fetchRemote function calling a vehicle endpoint fetchRemote( "http://localhost:3000/vehicles/3", options, -- URL updates vehicle with ID 3. function(responseData, responseInfo) -- Callback to process response outputDebugString('Status code: ' .. responseInfo['statusCode']) -- Output received statuscode. end ) For those familiar with NodeJS and the Express framework, this is the code on the NodeJS side: router.patch("/:id", bodyParser.json(), (req, res) => { const v = req.body const { id } = req.params const connection = mysql.createConnection( config.db ) console.log(`Attempting to update vehicle with ID: ${id}`) console.log(`Received data:`) console.log(v) if( v.model && v.name && v.variant && v.color && v.upgrades && id) { connection.query(`UPDATE mta.vehicles SET name = '${v.name}', model = '${v.model}', variant = '${v.variant}}', upgrades = '${v.upgrades}', spawn_type = '${v.spawn_type}', spawn_data = '${v.spawn_data}', plate = '${v.plate}' WHERE (\`id\` = '${id}'); `, (error, results, fields) => { if (error) throw error; if( results.changedRows == 1) { console.log("Updated vehicle") res.status(200).send() } else { console.log("Affected rows returned 0") res.status(500).send() } }); } else { console.log("Refusing to update: Missing essential data") res.status(500).send() } }); Edited September 12, 2024 by xPeacefulDreams Simpler code example. Link to comment
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now