SlugHandlerInterface.php 2.2 KB

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