Database
[{Balance:4000,name:"Steph curry",password:"*****",created_At:ISODate("2022-04-19T07:17:29.243Z"),deposits:[{amount:1000,paid:false,expiry:28903708478,credit:150},{amount:1000,paid:false,credit:100,expiry:28903708478}]}]
Query
db.collection.update({"deposits.paid":false,"deposits.expiry":{$lt:28903708479}},[{$set:{Balance:{$add:["$Balance",{$sum:{$map:{input:"$deposits",as:"d",in:{$cond:{if:{$and:[{$not:"$$d.paid"},{$lt:["$d.expiry",28903708479]}]},then:"$$d.credit",else:0}}}}}]}}},{$set:{deposits:{$map:{input:"$deposits",as:"d",in:{$mergeObjects:["$$d",{paid:{$cond:{if:{$and:[{$not:"$$d.paid"},{$lt:["$d.expiry",28903708479]}]},then:true,else:false}}}]}}}}}],{multi:true})