kijho-technologies / kijho-help-desk
Installs: 207
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 1
Open Issues: 0
Type:project
Requires
- php: >=5.3.9
- doctrine/doctrine-bundle: ~1.4
- doctrine/doctrine-fixtures-bundle: dev-master
- doctrine/orm: ^2.4.8
- incenteev/composer-parameter-handler: ~2.0
- sensio/distribution-bundle: ~4.0
- sensio/framework-extra-bundle: ^3.0.2
- symfony/monolog-bundle: ~2.4
- symfony/swiftmailer-bundle: ~2.3
- symfony/symfony: 2.8.*|3.0.*
Requires (Dev)
- sensio/generator-bundle: ~2.3
- symfony/phpunit-bridge: ~2.7
This package is not auto-updated.
Last update: 2025-01-02 03:09:37 UTC
README
kijho-help-desk
Bundle para Symfony >= 2.8, para administrar tickets de soporte de clientes
Aplicación Demo
Instalación
Requisitos:
"sensio/distribution-bundle": "~4.0", "symfony/swiftmailer-bundle": "~2.3",
En la consola del proyecto ejecute:
composer require kijho-technologies/kijho-help-desk dev-master
Registramos el bundle en el archivo AppKernel.php
$bundles = array( ... new Kijho\HelpDeskBundle\HelpDeskBundle(), );
En la consola del proyecto ejecute:
php app/console d:s:u --force
php app/console assets:install
Editamos los proveedores de usuarios del bundle de tickets en el archivo config.yml
# app/config.yml help_desk: client_provider: Acme\DemoBundle\Entity\YourClient operator_provider: Acme\DemoBundle\Entity\YourOperator
En tus entidades proveedores de usuarios, debes implementar la siguiente interface:
use Kijho\HelpDeskBundle\Model\UserInterface as HelpDeskUserInterface; /** * @ORM\Table() * @ORM\Entity */ class YourClient implements HelpDeskUserInterface { }
use Kijho\HelpDeskBundle\Model\UserInterface as HelpDeskUserInterface; /** * @ORM\Table() * @ORM\Entity */ class YourOperator implements HelpDeskUserInterface { }
Al implementar la interface anterior, es necesario implementar las siguientes funciones:
/** * Returns client or operator identifier * @return string */ public function getId(); /** * Returns client or operator name * @return string */ public function getName(); /** * Return client or operator email * @return string */ public function getEmail(); /** * Return boolean if the user is an allowed Ticket Operator * @return boolean */ public function getIsTicketOperator();
NOTA: Es posible usar una misma entidad para ser el proveedor de usuarios de Clientes y Operadores.
Los Operadores son las personas que atenderán los Tickets de Soporte enviados por los clientes, para ello la función getIsTicketOperator() debe retornar true, o una variable booleana de la entidad para elegir quienes de tus administradores podrán atender Tickets de Soporte.
Habilitamos el servicio "ticket_provider" en las variables globales de twig, archivo config.yml:
# app/config.yml # Twig Configuration twig: globals: ticket_provider: @ticket_provider
Asegurese de haber configurado el idioma:
# app/config.yml parameters: locale: es framework: #esi: ~ translator: { fallbacks: ["%locale%"] }
Configura las rutas del bundle de soporte en el archivo routing.yml
# app/routing.yml help_desk_clients: resource: "@HelpDeskBundle/Resources/config/routing/client.yml" prefix: /help-desk-client help_desk_operator: resource: "@HelpDeskBundle/Resources/config/routing/operator.yml" prefix: /help-desk-operator
Configura tus reglas de control de accesos en el archivo security.yml
access_control: - { path: '^/help-desk-client/*', roles: YOUR_CLIENT_ROLE } - { path: '^/help-desk-operator/*', roles: YOUR_ADMIN_ROLE }
Para acceder al menú del cliente, crea un enlace en cualquiera de tus templates con la siguiente ruta:
href="{{path('help_desk_client_tickets',{'status':'all'})}}"
Para acceder al menú del operador, crea un enlace en cualquiera de tus templates con la siguiente ruta:
href="{{path('help_desk_operator_tickets',{'status':'all'})}}"
NOTA: Puedes modificar el enlace para abrir el modulo en un iframe, en una ventana emergente o como lo desees.
Desde tus plantillas Twig, puedes acceder a diferentes funciones para obtener información acerca de los Tickets de soporte:
Para el cliente:
{# Número total de tickets del cliente #} {{ ticket_provider.getCountClientTickets(app.user.id) }} {# Número de tickets activos del cliente #} {{ticket_provider.getCountClientTickets(app.user.id, 'active')}} {# Número de tickets cerrados del cliente #} {{ticket_provider.getCountClientTickets(app.user.id, 'closed')}}
Para el administrador:
{# Número total de tickets #} {{ticket_provider.getCountTickets()}} {# Número de tickets activos #} {{ticket_provider.getCountTickets('active')}} {# Número de tickets cerrados #} {{ticket_provider.getCountTickets('closed')}}
Categorías de Tickets y Notificaciones por Correo: Para que un cliente pueda crear tickets de soporte, debe haber existir en base de datos al menos una categoría de tickets. Estas categorías son administradas por los operadores en su respectivo modulo, asi que una vez tengas todo configurado asegurate de crear tus categorías de tickets y colocar los emails a donde llegarán las notificaciones por correo electrónico.