2011-02-07 19:48:44 +13:00
|
|
|
# Access Control and Page Security
|
|
|
|
|
|
|
|
There is a fairly comprehensive security mechanism in place for SilverStripe. If you want to add premium content to your
|
|
|
|
site you have to figure this stuff out, and it's not entirely obvious.
|
|
|
|
|
|
|
|
## Ways to restrict access
|
|
|
|
|
|
|
|
There are a number of ways to restrict access in SilverStripe. In the security tab in the CMS you can create groups
|
|
|
|
that have access to certain parts. The options can be found on the [permissions](/reference/permission) documentation.
|
|
|
|
|
|
|
|
Once you have groups, you can set access for each page for a particular groups. This can be:
|
2013-12-05 21:20:49 +01:00
|
|
|
* anyone;
|
|
|
|
* any person who is logged in;
|
|
|
|
* a specific group.
|
2011-02-07 19:48:44 +13:00
|
|
|
|
|
|
|
It is unclear how this works for data-objects that are not pages.
|
|
|
|
|
|
|
|
## The Security Groups in SilverStripe
|
|
|
|
|
|
|
|
In the security tab you can make groups for security. The way this was intended was as follows (this may be a counter
|
|
|
|
intuitive):
|
2011-03-09 10:05:51 +13:00
|
|
|
|
2013-12-05 21:20:49 +01:00
|
|
|
* employees
|
|
|
|
* marketing
|
|
|
|
* marketing executive
|
2011-03-09 10:05:51 +13:00
|
|
|
|
2011-02-07 19:48:44 +13:00
|
|
|
Thus, the further up the hierarchy you go the MORE privileges you can get. Similarly, you could have:
|
2011-03-09 10:05:51 +13:00
|
|
|
|
2013-12-05 21:20:49 +01:00
|
|
|
* members
|
|
|
|
* coordinators
|
|
|
|
* admins
|
2011-03-09 10:05:51 +13:00
|
|
|
|
2011-02-07 19:48:44 +13:00
|
|
|
Where members have some privileges, coordinators slightly more and administrators the most; having each group inheriting
|
|
|
|
privileges from its parent group.
|
|
|
|
|
|
|
|
## Permission checking is at class level
|
|
|
|
|
2011-03-09 10:05:51 +13:00
|
|
|
SilverStripe provides a security mechanism via the *Permission::check* method (see `[api:LeftAndMain]` for examples on how
|
2013-12-05 21:20:49 +01:00
|
|
|
the admin screens work).
|
2011-02-07 19:48:44 +13:00
|
|
|
|
2011-03-09 10:05:51 +13:00
|
|
|
(next step -- go from *Permission::checkMember*...)
|
2011-02-07 19:48:44 +13:00
|
|
|
|
|
|
|
### Nuts and bolts -- figuring it out
|
|
|
|
|
|
|
|
Here are my notes trying to figure this stuff out. Not really useful unless you're VERY interested in how exactly SS
|
|
|
|
works.
|
|
|
|
|
|
|
|
|
|
|
|
### Loading the admin page: looking at security
|
|
|
|
|
2011-03-09 10:05:51 +13:00
|
|
|
If you go to [your site]/admin *Director.php* maps the 'admin' URL request through a `[api:Director]` rule to the
|
|
|
|
`[api:CMSMain]` controller (see `[api:CMSMain]`, with no arguments).
|
2011-02-07 19:48:44 +13:00
|
|
|
|
2011-03-09 10:05:51 +13:00
|
|
|
*CMSMain.init()* calls its parent which, of all things is called `[api:LeftAndMain]`. It's in `[api:LeftAndMain]` that the
|
2011-02-07 19:48:44 +13:00
|
|
|
important security checks are made by calling *Permission::check*.
|
|
|
|
|
|
|
|
`[api:Security::permissionFailure]` is the next utility function you can use to redirect to the login form.
|
|
|
|
|
|
|
|
### Customizing Access Checks in CMS Classes
|
|
|
|
|
2013-12-05 21:20:49 +01:00
|
|
|
see `[api:LeftAndMain]`
|