CakePHP 框架的工具

euromark a320e9d758 only validate if necessary and for sections if applicable 12 年 前
Config 3cf2d9b0c6 fix whitespace coding standard errors 12 年 前
Console bc54efd7b6 Fix lineLength and mimType for EmailLib/CakeEmail 12 年 前
Controller bc54efd7b6 Fix lineLength and mimType for EmailLib/CakeEmail 12 年 前
Lib 2501ef3397 fix failing tests 12 年 前
Locale 560d168a8b qlogin and fixes 14 年 前
Model a320e9d758 only validate if necessary and for sections if applicable 12 年 前
Test 9c81130353 add missing parent calls 12 年 前
TestSuite cd0f1eec24 Move some methods out of TextLib to clean up. 13 年 前
Vendor 83a5741614 NumberTextLib and Soros vendor package 13 年 前
View bc54efd7b6 Fix lineLength and mimType for EmailLib/CakeEmail 12 年 前
webroot bbb8cacfa2 doc update 14 年 前
.travis.yml 3c0fad3d89 add session folder to travis 13 年 前
CONTRIBUTING.md c4ac7a3318 contributing file 12 年 前
README.md c4ac7a3318 contributing file 12 年 前
USAGE 5c8f26c714 usage update 13 年 前
composer.json daae04ad12 adding composer.json 13 年 前

README.md

Tools

A cake2.x plugin

This plugin contains several useful tools that can be used in many projects. Please fork and help to improve (bugfixing, test cases, ...)

Please note: New functionality has been tested against cake2.3 only. Please upgrade if possible.

How to include

Installing the Plugin is pretty much as with every other CakePHP Plugin.

  • Put the files in APP/Plugin/Tools
  • Make sure you have CakePlugin::load('Tools') or CakePlugin::loadAll() in your bootstrap

Tip: You can also use packagist now @ https://packagist.org/packages/dereuromark/tools-cakephp

That's it. It should be up and running.

The basics

Include the Tools bootstrap file in your APP/Config/bootstrap.php with

App::import('Lib', 'Tools.Bootstrap/MyBootstrap');

You cannot use App::uses because this file does not contain a class and needs to be included right away (not lazy loaded).

MyModel can be extended to use more powerful validation and other improvements:

App::uses('MyModel', 'Tools.Model');

class AppModel extends MyModel {
}

MyController can be extended for DRY improvements and to fix some common bugs:

App::uses('MyController', 'Tools.Controller');

class MyController extends MyController {
}

MyHelper can be extended and used this way:

App::uses('MyHelper', 'Tools.View/Helper');

class AppHelper extends MyHelper {
}

The test suite improvements can be used via:

App::uses('MyCakeTestCase', 'Tools.TestSuite');

class SomeClassTest extends MyCakeTestCase {
}

To run any of the console commands (replace [ShellName] and [command]!):

cake Tools.[ShellName] [command]

The models, behaviors, helpers, libs and other classes are used the same way prefixing them with the plugin name:

App::uses('GooglLib', 'Tools.Lib');
App::uses('TimeLib', 'Tools.Utility');
App::uses('GeocoderBehavior', 'Tools.Model/Behavior');
...

Tip: For how to use them, try to find some information in the test cases. Usage for some larger modules: https://github.com/dereuromark/tools/blob/master/USAGE

Disclaimer

Use at your own risk. Please provide any fixes or enhancements via issue or better pull request. Some classes are still from 1.2 (and are merely upgraded to 2.x) and might still need some serious refactoring. If you are able to help on that one, that would be awesome.

Status

Build Status

Branching strategy

The master branch is the currently active and maintained one and works with the current 2.x stable version. Older versions might be found in their respective branches (1.3, 2.0, 2.3, ...). Please provide PRs mainly against master branch then.

For details on how to contribute please read the CONTRIBUTING page.

Recent changes (possibly BC breaking)

  • 2013-02 Removed PasswordChangeBehavior in favor of its new name Passwordable.
  • 2013-02-25 Removed deprecated bootstrap functions and moved DebugTab functionality into Bootstrap namespace (you need to now manually include it if needed).