modera/direct-bundle

Symfony ExtDirect Bundle

Maintainers

👁 modera

Package info

github.com/modera/ModeraDirectBundle

Type:symfony-bundle

pkg:composer/modera/direct-bundle

Statistics

Installs: 5 884

Dependents: 1

Suggesters: 0

Stars: 2

Open Issues: 0

v5.0.0 2025-02-12 13:20 UTC

Requires

Requires (Dev)

None

Suggests

None

Provides

None

Conflicts

None

Replaces

None

MIT 6828705f10c97e6ad70bffebb79bb20fec73fe70

  • Sergei Vizel <sergei.vizel.woop@modera.org>

extjsextdirect


README

ModeraDirectBundle is an implementation of ExtDirect specification to Symfony framework.

Installation

Step 1: Download the Bundle

composer require modera/direct-bundle:5.x-dev

This command requires you to have Composer installed globally, as explained in the installation chapter of the Composer documentation.

Step 2: Enable the Bundle

This bundle should be automatically enabled by Flex. In case you don't use Flex, you'll need to manually enable the bundle by adding the following line in the config/bundles.php file of your project:

<?php
// config/bundles.php

return [
 // ...
 Modera\DirectBundle\ModeraDirectBundle::class => ['all' => true],
];

Step 3: Add routing

// config/routes.yaml

direct:
 resource: "@ModeraDirectBundle/Resources/config/routing.yml"

How to use

Add the ExtDirect API into your page

If you is using Twig engine, only add the follow line in your views page at the script section:

<script type="text/javascript" src="{{ url('api') }}"></script>

Or if you are not using a template engine:

<script type="text/javascript" src="/api.js"></script>

Expose your controller methods to ExtDirect Api

// .../Acme/DemoBundle/Controller/ExampleController.php

namespace Acme\DemoBundle\Controller;

use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Modera\DirectBundle\Annotation\Remote;
use Modera\DirectBundle\Annotation\Form;

class ExampleController extends AbstractController
{
 /**
 * Single exposed method.
 *
 * @Remote // this annotation expose the method to API
 *
 * @param array $params
 * @return string
 */
 public function indexAction(array $params)
 {
 return 'Hello ' . $params['name'];
 }

 /**
 * An action to handle forms.
 *
 * @Remote // this annotation expose the method to API
 * @Form // this annotation expose the method to API with formHandler option
 *
 * @param array $params Form submitted values
 * @param array $files Uploaded files like $_FILES
 */
 public function testFormAction(array $params, array $files)
 {
 // your proccessing
 return true;
 }
}

Call the exposed methods from JavaScript

// 'AcmeDemo' is the Bundle name without 'Bundle'
// 'Example' is the Controller name without 'Controller'
// 'index' is the method name without 'Action'
Actions.AcmeDemo_Example.index({ name: 'ExtDirect' }, function(r) {
 alert(r);
});

Licensing

This bundle is under the MIT license. See the complete license in the bundle: Resources/meta/LICENSE