#[Solved] best way to load and query a IP block list

2 messages · Page 1 of 1 (latest)

grave condor
#

Not really an issue but looking for suggestions on the best way to deal with the below use case.

I am trying to implement an IP whitelist allowing users to restrict access to, say a corporate network. Working on this got me thinking about the best way of implementing something like this for a large list of IP's. I know Appwrite DB (MariaDB) has full text search so

  1. I can create a single document that as part of a String field maintains a delimited IP address list and a cloud function that would validate and allow or reject requests

  2. Have a collection with each IP as a document in an indexed field.

  3. Save a CSV in storage and have function pull the file, read and validate IP against it.

Not sure what would be the right way, if there is one best way, of implementing something like this. Open to other ideas.

ivory cove
# grave condor Not really an issue but looking for suggestions on the best way to deal with the...

For the fastest lookup of a single IP (1.2.3.4), I would have a collection where the ID is the IP and use databases.getDocument() because databases.getDocument() fetches the document from cache (if available).

That said, for your use case, it's common to have ranges or even subnet masks or CIDR notation rather than a list of IP Addresses. If you're going this route, I would suggest finding a library that will accept the values and check against an IP. Then, you would figure out the best storage method based on what your library requires