Security
Introduction
Neo4j has a complex security model stored in the system graph, maintained in a special database called the system database.
All administrative commands need to be executing against the system database.
When connected to the DBMS over bolt, administrative commands are automatically routed to the system database.
For more information on how to manage multiple databases, refer to the section on administering databases.
Neo4j 3.1 introduced the concept of role-based access control. It was possible to create users and assign them to roles to control whether the users could read, write and administer the database. In Neo4j 4.0 this model was enhanced significantly with the addition of privileges, which are the underlying access-control rules by which the users rights are defined.
The original built-in roles still exist with almost the exact same access rights, but they are no-longer statically defined (see Built-in roles). Instead they are defined in terms of their underlying privileges and they can be modified by adding an removing these access rights.
In addition, any new roles created can by assigned any combination of privileges to create the specific access control desired. A major additional capability is sub-graph access control whereby read-access to the graph can be limited to specific combinations of label, relationship-type and property.
Syntax summaries
Almost all administration commands have variations in the commands. Parts of the command that are optional or can have multiple values are most common. To show all versions of a command, a summary of the syntax will be presented. These summaries will use some special characters to indicate such variations.
The special characters and their meaning are as follows:
| Character | Meaning | Example | 
|---|---|---|
| 
 | Or, used to indicate alternative parts of a command. Needs to be part of a grouping. | If the syntax needs to specify either a name or  | 
| 
 | Used to group parts of the command, common together with  | To use the  | 
| 
 | Used to indicate an optional part of the command. It also groups alternatives together, when there can be either of the alternatives or nothing. | If a keyword in the syntax can either be in singular or plural, we can indicate that the  | 
| 
 | Repeated pattern, the command part immediately before this is repeated. | A comma separated list of names would be  | 
| 
 | When a special character is part of the syntax itself, we surround it with  | To include  | 
The special characters in the table above are the only ones that need to be escaped using " in the syntax summaries.
An example that uses all special characters is granting the READ privilege:
GRANT READ
    "{" { * | property[, ...] } "}"
    ON {DEFAULT GRAPH | GRAPH[S] { * | name[, ...] }}
        [
            ELEMENT[S] { * | label-or-rel-type[, ...] }
            | NODE[S] { * | label[, ...] }
            | RELATIONSHIP[S] { * | rel-type[, ...] }
        ]
    TO role[, ...]Some things to notice about this command is that it includes { and } in the syntax, and between them has a grouping of either a list of properties or the character *.
It also has multiple optional parts, including the entity part of the command which is the grouping following the graph name.
In difference, there is no need to escape any characters in the node property existence constraint creation command.
This is because ( and ) are not special characters, and the [ and ] indicate that the constraint name is optional, and are not part of the command.
CREATE CONSTRAINT [constraint_name] [IF NOT EXISTS]
ON (n:LabelName)
ASSERT EXISTS (n.propertyName)