PHPackages                             kijho-technologies/kijho-help-desk - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Admin Panels](/categories/admin)
4. /
5. kijho-technologies/kijho-help-desk

ActiveProject[Admin Panels](/categories/admin)

kijho-technologies/kijho-help-desk
==================================

02071PHP

Since May 5Pushed 10y ago1 watchersCompare

[ Source](https://github.com/cesar-giraldo/kijho-help-desk)[ Packagist](https://packagist.org/packages/kijho-technologies/kijho-help-desk)[ RSS](/packages/kijho-technologies-kijho-help-desk/feed)WikiDiscussions master Synced 4w ago

READMEChangelogDependenciesVersions (2)Used By (0)

kijho-help-desk
===============

[](#kijho-help-desk)

Bundle para Symfony &gt;= 2.8, para administrar tickets de soporte de clientes

 Aplicación Demo
================

[](#-aplicación-demo)

[Descargue la aplicación demo](https://github.com/cesar-giraldo/kijho-help-desk/tree/help-desk-demo)

Instalación
===========

[](#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.

###  Health Score

23

—

LowBetter than 26% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity12

Limited adoption so far

Community8

Small or concentrated contributor base

Maturity43

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

### Community

Maintainers

![](https://avatars.githubusercontent.com/u/12103527?v=4)[Cesar Giraldo](/maintainers/cesar-giraldo)[@cesar-giraldo](https://github.com/cesar-giraldo)

---

Top Contributors

[![cesar-giraldo](https://avatars.githubusercontent.com/u/12103527?v=4)](https://github.com/cesar-giraldo "cesar-giraldo (26 commits)")

### Embed Badge

![Health badge](/badges/kijho-technologies-kijho-help-desk/health.svg)

```
[![Health](https://phpackages.com/badges/kijho-technologies-kijho-help-desk/health.svg)](https://phpackages.com/packages/kijho-technologies-kijho-help-desk)
```

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
