diff options
author | Bharat Mediratta <bharat@menalto.com> | 2010-08-08 17:25:31 -0700 |
---|---|---|
committer | Bharat Mediratta <bharat@menalto.com> | 2010-08-08 17:25:31 -0700 |
commit | acb1faaa594fc5067c4340e073afca3b83f819d4 (patch) | |
tree | b515d4af75b0c2148b8b79efd0738aaa0edab624 /modules/gallery/helpers | |
parent | 6a8c1f5e855b1c4d768524e6e542218c234df6d3 (diff) |
Cache the group ids for a day to trade off performance for security updates.
Fixes ticket #1227.
Diffstat (limited to 'modules/gallery/helpers')
-rw-r--r-- | modules/gallery/helpers/identity.php | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/modules/gallery/helpers/identity.php b/modules/gallery/helpers/identity.php index 4febc4e2..5de05948 100644 --- a/modules/gallery/helpers/identity.php +++ b/modules/gallery/helpers/identity.php @@ -72,12 +72,14 @@ class identity_Core { auth::login(IdentityProvider::instance()->admin_user()); } - if (!$session->get("group_ids")) { + // Cache the group ids for a day to trade off performance for security updates. + if (!$session->get("group_ids") || $session->get("group_ids_timeout", 0) < time()) { $ids = array(); foreach ($user->groups() as $group) { $ids[] = $group->id; } $session->set("group_ids", $ids); + $session->set("group_ids_timeout", time() + 86400); } } catch (Exception $e) { // Log it, so we at least have so notification that we swallowed the exception. |