novactive / ezprotectedcontentbundle
Novactive eZ Protected Content Bundle is an Ibexa bundle that provides quick protection on Contents
Installs: 7 608
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 16
Forks: 3
Open Issues: 2
Type:ibexa-bundle
Requires
- php: ^7.3 || ^8.0
- ext-json: *
- ramsey/uuid: ^3.0
- dev-master
- v2.1.0
- v2.0.6
- v2.0.5
- v2.0.4
- v2.0.3
- v2.0.2
- v2.0.1
- v2.0.0
- 1.1.0
- 1.0.0
- 0.9.0
- dev-dev-feat-108625-ibexa-4-form-mail-protection-object-states
- dev-feat-108625-ibexa-4-form-mail-protection-object-states
- dev-feat-108625-ibexa-4-form-mail-protection--status
- dev-feat-108625-form-mail-protection
- dev-feat-108625-ibexa-4-form-mail-protection
- dev-feat-119001-fix-type-mismatch
- dev-feat-108625-form-mail-protection-fix
- dev-release-0.x.x
- dev-private-content-access-2
- dev-private-content-access
This package is auto-updated.
Last update: 2025-09-05 16:14:45 UTC
README
This repository is what we call a "subtree split": a read-only copy of one directory of the main repository. It is used by Composer to allow developers to depend on specific bundles.
If you want to report or contribute, you should instead open your issue on the main repository: https://github.com/Novactive/Nova-eZPlatform-Bundles
Documentation is available in this repository via .md
files but also packaged here: https://novactive.github.io/Nova-eZPlatform-Bundles/master/ProtectedContentBundle/README.md.html
A bundle that provides quick password protection on Contents.
How it works
Allows you to add 1 on N password on a Content in the Admin UI. Once a protection is set, the Content becomes Protected. In this situation you can have 3 new variables in the view full
- canReadProtectedContent (always)
- requestProtectedContentPasswordForm (if content is protected by password)
- requestProtectedContentEmailForm (if content is protected with email verification)
Allowing you do:
<h2>{{ ibexa_content_name(content) }}</h2> {% if not canReadProtectedContent %} {% if requestProtectedContentPasswordForm is defined %} <p>This content has been protected by a password</p> <div class="protected-content-form"> {{ form(requestProtectedContentPasswordForm) }} </div> {% elseif requestProtectedContentEmailForm is defined %} <p>This content has been protected by an email verification</p> <div class="protected-content-form"> {{ form(requestProtectedContentEmailForm) }} </div> {% endif %} {% else %} {% for field in content.fieldsByLanguage(language|default(null)) %} <h3>{{ field.fieldDefIdentifier }}</h3> {{ ez_render_field(content, field.fieldDefIdentifier) }} {% endfor %} {% endif %}
You can also manage this globally through the pagelayout wrapping the content block.
Once you have unlocked the content, canReadProtectedContent will be true
HTTP Cache is disabled for Protected Content.
Installation
Installation steps
Add the lib to your composer.json, run composer require novactive/ezprotectedcontentbundle
to refresh dependencies.
Then inject the bundle in the bundles.php
of your application.
Novactive\Bundle\eZProtectedContentBundle\NovaeZProtectedContentBundle::class => [ 'all'=> true ],
Add routes
_novaezprotectedcontent_routes: resource: '@NovaeZProtectedContentBundle/Resources/config/routing/main.yml'
Install the database schema
bin/console novaezprotectedcontent:install
Varnish
This module add a cookie to unlock the contents that match it, for that reason you want to keep all the cookie that starts with PasswordProvided::COOKIE_PREFIX (i.e: protected-content-).
// Remove all cookies besides Session ID, as JS tracker cookies and so will make the responses effectively un-cached if (req.http.cookie) { set req.http.cookie = ";" + req.http.cookie; set req.http.cookie = regsuball(req.http.cookie, "; +", ";"); set req.http.cookie = regsuball(req.http.cookie, ";[ ]*(eZSESSID[^=]*|protected-content-[^=]*)=", "; \1="); set req.http.cookie = regsuball(req.http.cookie, ";[^ ][^;]*", ""); set req.http.cookie = regsuball(req.http.cookie, "^[; ]+|[; ]+$", ""); }