Affiliation:
1. University of Calgary, Canada
Abstract
Neo4j is a popular graph database that offers two versions: an
enterprise edition
and a
community edition
. The enterprise edition offers customizable Role-based Access Control features through custom developed
procedures
, while the community edition does not offer any access control support. Being a graph database, Neo4j appears to be a natural application for Relationship-Based Access Control (ReBAC), an access control paradigm where authorization decisions are based on relationships between subjects and resources in the system (i.e., an authorization graph). In this article, we present AReBAC, an attribute-supporting ReBAC model for Neo4j that provides finer-grained access control by operating over resources instead of procedures. AReBAC employs Nano-Cypher, a declarative policy language based on Neo4j’s Cypher query language, the result of which allows us to weave database queries with access control policies and evaluate both simultaneously. Evaluating the combined query and policy produces a result that (i) matches the search criteria, and (ii) the requesting subject is authorized to access. AReBAC is accompanied by the algorithms and their implementation required for the realization of the presented ideas, including
GP-Eval,
a query evaluation algorithm. We also introduce Live-End Backjumping (LBJ), a backtracking scheme that provides a significant performance boost over conflict-directed backjumping for evaluating queries. As demonstrated in our previous work, the original version of
GP-Eval
already performs significantly faster than the Neo4j’s Cypher evaluation engine. The optimized version of
GP-Eval
, which employs LBJ, further improves the performance significantly, thereby demonstrating the capabilities of the technique.
Publisher
Association for Computing Machinery (ACM)
Subject
Safety, Risk, Reliability and Quality,General Computer Science
Reference40 articles.
1. [n.d.]. Intro to Cypher. Retrieved from https://neo4j.com/developer/cypher-query-language/. [n.d.]. Intro to Cypher. Retrieved from https://neo4j.com/developer/cypher-query-language/.
2. [n.d.]. MySQL. Retrieved from http://www.mysql.com/. [n.d.]. MySQL. Retrieved from http://www.mysql.com/.
3. [n.d.]. Neo4J. Retrieved from http://neo4j.com/. [n.d.]. Neo4J. Retrieved from http://neo4j.com/.
4. [n.d.]. OpenMRS. Retrieved from http://openmrs.org/. [n.d.]. OpenMRS. Retrieved from http://openmrs.org/.
5. Stanford Large Network Dataset Collection. 2014. Retrieved from http://snap.stanford.edu/data. Stanford Large Network Dataset Collection. 2014. Retrieved from http://snap.stanford.edu/data.
Cited by
10 articles.
订阅此论文施引文献
订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献