MongoDB
 sql >> Database >  >> NoSQL >> MongoDB

come posso creare la mia query mongodb in base all'input dell'utente in node.js?

Se ho capito bene:

  • Se l'utente ha un device_id bannato , quindi bloccalo
  • Se l'utente ha un display_name bannato , quindi bloccalo

In tal caso, non importa se è anonymous oppure no.

let excludedUsernames, excludedDevices;

blockedUsers.forEach((e) => {
    excludedUsernames.puhs({ e["display_name"] });
    excludedDevices.push({ e["device_id"] });
});

query.$and.push({ 'display_name' : { $nin: excludedUsernames } });
query.$and.push({ 'device_id'    : { $nin: excludedDevices   } });

MODIFICA

query.$or.push({
    $and: [
        { 'device_id'    : { $nin: excludedDevices }},
        { 'display_name' : "anonymous" }
    ]
});
query.$or.push({ 'display_name' : { $nin: excludedUsernames } });