У меня есть нижеуказанная AWS лямбда-функция, которую я создал с целью определения мягкого удаления и жесткого удаления моего продукта.
exports.handler = async (event) => {
const product = JSON.parse(event.body);
let sql;
let msg;
let values;
if (product.action == 'delete') {
sql = "UPDATE product_table SET isDeleted=1, deletedon=? WHERE product_id=?";
msg = 'The product has been sucessfully deleted';
values = new Date();
} else if (product.action == 'restore') {
sql = "UPDATE product_table SET isDeleted=0, deletedon=? WHERE product_id=?";
msg = 'The product has been successfully restored';
values = null;
}
try {
const data = await new Promise((resolve, reject) => {
connection.getConnection(function (err) {
if (err) {
reject(err);
}
connection.query(sql, [values, product.product_id], function (err, result) {
if (err) {
console.log("Error->" + err);
reject(err);
}
resolve(result);
});
});
});
return {
statusCode: 200,
body: JSON.stringify(msg)
};
} catch (err) {
return {
statusCode: 400,
body: JSON.stringify(err.message)
};
}
};
Идея состоит в том, чтобы использовать один метод удаления из API и передавать значения идентификатора и действия в объекте JSON для переключения между удалением и восстановлением.
Я смог заставить это работать на Почтальоне, но не из моего Angular Приложения. Я передаю значения Сэм, как я бы сделал с методом POST. Не могли бы вы помочь мне в том, что мне не хватает?
Ниже приведен код angular:
deleteProductData(product_id:number,action:string) {
const header: HttpHeaders = new HttpHeaders()
.append('Content-Type', 'application/json; charset=UTF-8')
const httpOptions = {
headers: header,
body:JSON.stringify({ "product_id": product_id,"action":action })
};
return this.http.delete<any>(this.productGetUrl, httpOptions);
}