Database

[{"_id":ObjectId("5e3dd3d57f8bc30a7513e843"),"deleted":true,"products":[{"name":"new","quantity":1,"price":20},{"name":"new2","quantity":10,"price":2},{"name":"new3","quantity":1,"price":10},{"name":"new4","quantity":2,"price":210}],"total":3},{"_id":ObjectId("5e3dd3e97f8bc30a7513e99b"),"deleted":false,"products":[{"name":"old","quantity":1,"price":20},{"name":"old2","quantity":10,"price":2},{"name":"old3","quantity":1,"price":10},{"name":"old4","quantity":2,"price":210}],"total":10}]

Query

db.collection.aggregate([{$addFields:{"total":{$reduce:{input:"$products",initialValue:"$total",in:{$add:[{$multiply:["$$this.quantity","$$this.price"]},"$$value"]}}}}}])

Result