定制 praxigento/composer_plugin_templates 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

praxigento/composer_plugin_templates

最新稳定版本:1.0.8

Composer 安装命令:

composer require praxigento/composer_plugin_templates

包简介

Composer plugin to create locally specific configuration from set of template files and from file with configuration parameters.

README 文档

README

Build Status

What is this?

Plugin for PHP Composer to create locally specific configuration from set of template files and files with configuration parameters. Templates processing is occurred before any composer command (excluding 'install' cause plugin is not installed before command have been executed).

screenshot

Installation

Add to your project's composer.json:

{
  "require": {
    "praxigento/composer_plugin_templates": "*"
  }
}

Usage

Setup configuration file

Create plugin's configuration file ( ./templates.json, for example) and setup extra.praxigento_templates_config parameter in your project's composer.json::

{
  "extra": {
    "praxigento_templates_config": "./templates.json"
  }
}

Plugin can use more than one configuration file, data from all files will be merged into one config structure:

{
  "extra": {
    "praxigento_templates_config": ["./under_vc.json", "./not_under_vc.json"]
  }
}

This can be useful in case when set of templates is the same for all instances (this part of configuration can be under version control) and variables (all or part of them) are unique for each instance.

Configuration file structure

./templates.json:

{
  "vars": {
    "MYSQL_HOST": "localhost",
    "MYSQL_USER": "magento_github_user",
    "MYSQL_PASSWORD": "s8pTo3X5QCsr4SkY48zF",
    "MYSQL_DBNAME": "magento_github_db"
  },
  "templates": {
    "local.xml": {
      "src": "test/tmpl/local.xml",
      "dst": "test/mage/app/etc/local.xml",
      "rewrite": true
    },
    "dump.sh": {
      "src": "test/tmpl/dump.sh",
      "dst": "test/bin/dump_db/dump.sh",
      "rewrite": true
    }
  }
}

vars

Set of the template's placeholders ${MYSQL_HOST} and values localhost to be inserted into templates:

{
  "vars": {
    "MYSQL_HOST": "localhost",
    "MYSQL_USER": "magento_github_user",
    "MYSQL_PASSWORD": "s8pTo3X5QCsr4SkY48zF",
    "MYSQL_DBNAME": "magento_github_db"
  }
}

templates

Set of the templates to be processed on every composer command (install, update, status, ...):

{
  "templates": {
    "local.xml": {
      "src": "test/tmpl/local.xml",
      "dst": "test/mage/app/etc/local.xml",
      "rewrite": true
    },
    "dump.sh": {
      "src": "test/tmpl/dump.sh",
      "dst": "test/bin/dump_db/dump.sh",
      "rewrite": true,
      "condition": {
        "var": "MYSQL_HOST",
        "operation": "!=",
        "value": "localhost"
      }
    }
  }
}

Labels (local.xml & dump.sh) are for reference only.

  • src: (required) path to template file;
  • dst: (required) path to result file (where placeholders are replaced by its values);
  • rewrite: 'true' to rewrite destination file if exists ('false' by default);
  • condition: simple condition to process this template file;
    • var: name of the variable for left part of the condition;
    • operation: one of the two operations ('=' or '!=');
    • value: string value for compare (right part of the operation);

License

All contents of this package are licensed under the MIT license.

统计信息

  • 总下载量: 2.99k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 2
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-01-12