What's the right firestore architecture for managing client API keys?

Cutaraca

Can someone put me in the right direction? I need a Firestore collection to store user-related API keys. This means there are:

  • API key
  • User ID
  • (Created At, maybe other meta fields in the future)

So sometimes I want to retrieve a list of all API keys that belong to a user. But oftentimes, the scenario is that my API is getting a request with an API key attached and then I need to quickly validate whether this API key exists. It’s the first time playing with Firestore for me. And I’m just insecure about how to structure the collection. Should the API key be the ID? And will I be able to efficiently get a list of API keys that have a specific UID too?

Alex Mamo

Can someone put me in the right direction? I need a Firestore collection to store user-related API keys.

The simplest Firestore structure I can think of might look like this:

Firestore-root
  |
  --- users (collection)
       |
       --- $uid (document)
            |
            --- apiKeys: ["apiKeyOne", "apiKeyTwo", "apiKeyThree"] //Array
            |
            --- uid: "userId" //String
            |
            --- createdAt: October 21, 2021 at 2:46:19 PM UTC+3 //Timestamp

So sometimes I want to retrieve a list of all API keys that belong to a user.

Assuming that you are using Firebase Authentication, to do that, simply use the following lines of code:

firebase.auth().onAuthStateChanged((user) => {
  if (user) {
    var uidRef = db.collection("users").doc(user.uid);
    //Process the data
  }
});

But oftentimes, the scenario is that my API is getting a request with an API key attached and then I need to quickly validate whether this API key exists.

To solve that, you have to check whether a specific API key already exists using:

var queryByApiKey = db.collection("users").where("apiKeys", "array-contains", "apiKeyToCheck");

Should the API key be the ID?

No, there is no need for that.

And will I be able to efficiently get a list of API keys that have a specific UID too?

Sure, as already explained above.

Collected from the Internet

Please contact [email protected] to delete if infringement.

edited at
0

Comments

0 comments
Login to comment

Related

TOP Ranking

  1. 1

    Failed to listen on localhost:8000 (reason: Cannot assign requested address)

  2. 2

    Loopback Error: connect ECONNREFUSED 127.0.0.1:3306 (MAMP)

  3. 3

    How to import an asset in swift using Bundle.main.path() in a react-native native module

  4. 4

    pump.io port in URL

  5. 5

    Compiler error CS0246 (type or namespace not found) on using Ninject in ASP.NET vNext

  6. 6

    BigQuery - concatenate ignoring NULL

  7. 7

    ngClass error (Can't bind ngClass since it isn't a known property of div) in Angular 11.0.3

  8. 8

    ggplotly no applicable method for 'plotly_build' applied to an object of class "NULL" if statements

  9. 9

    Spring Boot JPA PostgreSQL Web App - Internal Authentication Error

  10. 10

    How to remove the extra space from right in a webview?

  11. 11

    java.lang.NullPointerException: Cannot read the array length because "<local3>" is null

  12. 12

    Jquery different data trapped from direct mousedown event and simulation via $(this).trigger('mousedown');

  13. 13

    flutter: dropdown item programmatically unselect problem

  14. 14

    How to use merge windows unallocated space into Ubuntu using GParted?

  15. 15

    Change dd-mm-yyyy date format of dataframe date column to yyyy-mm-dd

  16. 16

    Nuget add packages gives access denied errors

  17. 17

    Svchost high CPU from Microsoft.BingWeather app errors

  18. 18

    Can't pre-populate phone number and message body in SMS link on iPhones when SMS app is not running in the background

  19. 19

    12.04.3--- Dconf Editor won't show com>canonical>unity option

  20. 20

    Any way to remove trailing whitespace *FOR EDITED* lines in Eclipse [for Java]?

  21. 21

    maven-jaxb2-plugin cannot generate classes due to two declarations cause a collision in ObjectFactory class

HotTag

Archive