Database

[{"roles":["super_admin","admin"]},{"roles":["super_admin"]},{"roles":["manager","student"]},{"roles":["admin","student"]},{"roles":["super_admin","manager"]}]

Query

db.collection.aggregate([{$match:{$expr:{$gte:[{$reduce:{input:"$roles",initialValue:0,in:{$cond:[{$in:["$$this",["admin","super_admin","manager","student"]]},{$add:["$$value",1]},"$$value"]}}},2]}}}])

Result