-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathape.module
61 lines (53 loc) · 2.09 KB
/
ape.module
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
<?php
use Drupal\Core\Form\FormStateInterface;
/**
* @file
* Allows finer control of the Cache Control header.
*/
use Drupal\Core\Routing\RouteMatchInterface;
use Drupal\Core\Link;
use Drupal\Core\Url;
/**
* Implements hook_help().
*/
function ape_help($route_name, RouteMatchInterface $route_match) {
switch ($route_name) {
case 'ape.admin':
return '<p>' . t('Configure the max age header based on path and other criteria.') . '</p>';
case 'help.page.ape':
$output = '';
$output .= '<p>' . t('The advanced page expiration module is a lightweight solution to allow the max age header (used by external caching mechanisms such as Varnish) to be set based on different criteria, such as path or redirect code. This allows for more advanced scenarios such as having the homepage expire every five minutes while the rest of the site expires in one hour.') . '</p>';
$output .= '<p>' . t('The <a href="@settings">settings page</a> explains the different options available. There is also Rules integration and an alter hook available for more complex integrations.', array('@settings' => Url::fromRoute('ape.admin')->toString())) . '</p>';
return $output;
}
}
/**
* Implements hook_form_FORM_ID_alter().
*
* * Remove page_cache_maximum_age selection from main performance page and
* instead direct users to this module's config page. Also do a little cleanup
* to clarify external caching.
*/
function ape_form_system_performance_settings_alter(&$form, FormStateInterface $form_state) {
$form['caching']['page_cache_maximum_age']['#access'] = FALSE;
$form['caching']['#description'] = Link::fromTextAndUrl(t('Configure page caching strategy with APE.'), Url::fromRoute('ape.admin'))->toString();
}
/**
* Statically cache an expiration length.
*
* @param int $new_age
* The new value for age.
*
* @return int
* The resulting max age.
*/
function ape_cache_set($new_age = NULL) {
$max_age = &drupal_static(__FUNCTION__);
if (!isset($max_age)) {
$max_age = NULL;
}
if (is_null($max_age) && !is_null($new_age)) {
$max_age = $new_age;
}
return $max_age;
}