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
- 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
- Have a collection with each IP as a document in an indexed field.
- 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.
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
[Solved] best way to load and query a IP block list
Recommended threads
- It says domain already used but I have d...
I accidentally deleted the project in which I used my domain originally (orexia.app) from name.com. Now I am trying to add it to a different project and it says...
- ISO help
I’m writing a project specification paper. Please let me know if anyone has ISO/IEC/IEEE 29148:2018 — Requirements Engineering, or if someone can check the docu...
- No server error on selfhosted appwrite
Please help me, my clients is ask what happen on their data? How can i make it up again?