detailnet/dfw-varcrypt-module
最新稳定版本:0.1.2
Composer 安装命令:
composer require detailnet/dfw-varcrypt-module
包简介
Zend Framework 2 Module for dfw-varcrypt
README 文档
README
Introduction
This module integrates the DETAIL Framework library for for working with encrypted environment variables with Zend Framework 2.
Requirements
Zend Framework 2 Skeleton Application (or compatible architecture)
Installation
Install the module through Composer using the following steps:
-
cd my/project/directory -
Create a
composer.jsonfile with following contents (or update your existing file accordingly):{ "require": { "detailnet/dfw-varcrypt-module": "1.x-dev" } } -
Install Composer via
curl -s http://getcomposer.org/installer | php(on Windows, download the installer and execute it with PHP) -
Run
php composer.phar self-update -
Run
php composer.phar install -
Open
configs/application.config.phpand add following key to yourmodules:'service_manager' => array( 'delegators' => array( 'ModuleManager' => array( // By attaching this delegator the module Detail\VarCrypt is loaded before // all other modules so that the encrypted environment variables can be // applied before the configs of the other modules are merged/applied. 'Detail\VarCrypt\Factory\ModuleManager\ModuleManagerDelegatorFactory', ), ), ),
-
Copy
vendor/detailnet/dfw-varcrypt-module/config/detail_varcrypt.local.php.distinto your application'sconfig/autoloaddirectory, rename it todetail_varcrypt.local.phpand make the appropriate changes.
Usage
Save/encode config
Before the module can be used, a config (simple string or JSON encoded string) needs to be encoded and provided as environment variable.
Here's an example for providing MongoDB credentials as a single environment variable:
-
Define credentials as JSON:
{ "server": "localhost", "user": "root", "password": "root", "port": 27017, "dbname": null, "options": [] } -
Make sure an encryption key is set in
detail_varcrypt.local.php. -
Encode JSON:
php public/index.php varcrypt encode-value {"server": ...} -
Save the output as environment variable (e.g.
MONGO). -
Test that the environment variable can be accessed (at least from the CLI):
php public/index.php varcrypt decode-variable MONGO
Apply/decode config
The following steps are necessary, to use an encrypted/encoded environment variable in a ZF2 app.
-
Add the environment variable to the module's config (in
detail_varcrypt.local.php):'detail_varcrypt' => array( 'listeners' => array( 'Detail\VarCrypt\Listener\MultiEncryptorListener' => array( 'apply_variables' => array( 'mongo', ), ), ), ),
-
Access environment variables as you normally would:
array( 'doctrine' => array( 'connection' => array( 'odm_default' => array( 'server' => getenv('MONGO_SERVER') ?: 'localhost', ... ), ), ), )
统计信息
- 总下载量: 221
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2015-03-19