SlugHandlerInterface.php 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. <?php
  2. namespace Gedmo\Sluggable\Handler;
  3. use Doctrine\Common\Persistence\ObjectManager;
  4. use Doctrine\Common\Persistence\Mapping\ClassMetadata;
  5. use Gedmo\Sluggable\SluggableListener;
  6. use Gedmo\Sluggable\Mapping\Event\SluggableAdapter;
  7. /**
  8. * Sluggable handler interface is a common pattern for all
  9. * slug handlers which can be attached to the sluggable listener.
  10. * Usage is intented only for internal access of sluggable.
  11. * Should not be used outside of sluggable extension
  12. *
  13. * @author Gediminas Morkevicius <gediminas.morkevicius@gmail.com>
  14. * @package Gedmo.Sluggable.Handler
  15. * @subpackage SlugHandlerInterface
  16. * @link http://www.gediminasm.org
  17. * @license MIT License (http://www.opensource.org/licenses/mit-license.php)
  18. */
  19. interface SlugHandlerInterface
  20. {
  21. /**
  22. * Construct the slug handler
  23. *
  24. * @param Gedmo\Sluggable\SluggableListener $sluggable
  25. */
  26. function __construct(SluggableListener $sluggable);
  27. /**
  28. * Callback on slug handlers before the decision
  29. * is made whether or not the slug needs to be
  30. * recalculated
  31. *
  32. * @param Gedmo\Sluggable\Mapping\Event\SluggableAdapter $ea
  33. * @param array $config
  34. * @param object $object
  35. * @param string $slug
  36. * @param boolean $needToChangeSlug
  37. * @return void
  38. */
  39. function onChangeDecision(SluggableAdapter $ea, $slugFieldConfig, $object, &$slug, &$needToChangeSlug);
  40. /**
  41. * Callback on slug handlers right after the slug is built
  42. *
  43. * @param Gedmo\Sluggable\Mapping\Event\SluggableAdapter $ea
  44. * @param array $config
  45. * @param object $object
  46. * @param string $slug
  47. * @return void
  48. */
  49. function postSlugBuild(SluggableAdapter $ea, array &$config, $object, &$slug);
  50. /**
  51. * Callback for slug handlers on slug completion
  52. *
  53. * @param Gedmo\Sluggable\Mapping\Event\SluggableAdapter $ea
  54. * @param array $config
  55. * @param object $object
  56. * @param string $slug
  57. * @return void
  58. */
  59. function onSlugCompletion(SluggableAdapter $ea, array &$config, $object, &$slug);
  60. /**
  61. * Validate handler options
  62. *
  63. * @param array $options
  64. */
  65. static function validate(array $options, ClassMetadata $meta);
  66. }