Control of cache headers
The cache headers for a feed request can be influenced with the class attribute
\Brotkrueml\. One can pass the number in
seconds that a feed should be cached by a browser or feed reader:
// use Brotkrueml\FeedGenerator\Attributes\Cache
#[Feed('/your-feed.atom', FeedFormat::ATOM])]
#[Cache(3600)] // Cache for one hour
final class YourFeed implements FeedInterface
{
   // ...
}To clarify that the number stands for seconds, you can also use a named argument:
// use Brotkrueml\FeedGenerator\Attributes\Cache
#[Feed('/your-feed.atom', FeedFormat::ATOM)]
#[Cache(seconds: 3600)] // Cache for one hour
final class YourFeed implements FeedInterface
{
   // ...
}Both examples will result in the following HTTP headers:
Cache-Control: max-age=3600
Expires: Mon, 20 Jun 2022 08:06:03 GMTHint
When developing with ddev, the nginx proxy used overwrites the Cache-
and Expires headers set by the middleware. Use the URL 127.
to see the correct headers, for example:
curl -I https://127.0.0.1:49155/your-feed.atomYou can find out the current port number with the command
ddev describe.
If you want to define the cache headers for all available feeds, you can also set them directly in the configuration of your Apache web server according to the content type:
# Apache module "mod_expires" has to be active
# For Atom feeds
ExpiresByType application/atom+xml "access plus 1 hour"
# For JSON feeds
ExpiresByType application/feed+json "access plus 1 hour"
# For RSS feeds
ExpiresByType application/rss+xml "access plus 1 hour"