0
votes

Express / Typescript:


export const updateSettings = catchErrors(async (req, res) => {

  console.log("updateSettings req.body: ", req.body)
  
  const { organizationId, formdata, updatedItems, updateQuota } = req.body; 

  console.log("organizationId: ", organizationId);
  console.log("formdata: ", formdata);
  console.log("updatedItems: ", updatedItems);
  console.log("updateQuota: ", updateQuota);
  console.log("req.body.updateQuota: ", req.body.updateQuota);

  res.respond({'message': 'Settings updated successfully!' })

}); 

the console log for req.body is as follows:

updateSettings req.body:  {
  username: 'staff_a',
  organizationId: '2',
  formData: '{"offDays":[0,6,1],"officeHourStart":"1899-12-31T09:00:00.000+09:00","officeHourEnd":"1899-12-31T18:00:00.000+09:00","displayLanguage":"cn","timezone":"beijing","doctorQuotas":{"5":5,"6":10}}',
  updatedItems: [ 'displayLanguage', 'timezone', 'billingClosingDay', 'offDays' ],
  updatedQuota: [ 6, 5 ]
}

As you can see, there are fields updatedQuota and updatedItems. One is an array of strings and the other is an array of numbers;

However, after the destructoring line const { organizationId, formdata, updatedItems, updateQuota } = req.body; , some of fields are fine, but some fields becomes undefined:

organizationId:  2
formdata:  undefined
updatedItems:  [ 'displayLanguage', 'timezone', 'billingClosingDay', 'offDays' ]
updateQuota:  undefined

if I access the req.body.updateQuota alone by printing it console.log("req.body.updateQuota: ", req.body.updateQuota);, it is also empty:

req.body.updateQuota:  undefined

Why is it that things are clearly contained in req.body, but cannot be accessed or extracted?

2

2 Answers

1
votes

formData or formdata ?

updatedQuota or updateQuota ?

0
votes

req.body has updatedQuota not "updateQuota"