sv1ft / exchange1c
Catalog Loader from 1c - CommerceML protocol
Requires
- php: >=7.1
- ext-simplexml: *
- carono/commerceml: ^0.2.3
Requires (Dev)
- illuminate/session: ^5.7
- phpunit/phpunit: ^7
- symfony/event-dispatcher: ^4.1
- symfony/http-foundation: ^4.1
README
Установка этой библиотеки, должна упрощать интеграцию 1С в ваш сайт.
Библиотека содержит набор интерфейсов, которые необходимо реализовать, чтобы получить возможность обмениваться товарами и документами с 1С. Предполагается, что у Вас есть 1С:Предприятие 8, Управление торговлей", редакция 11.3, версия 11.3.2 на платформе 8.3.9.2033.
Если у вас версия конфигурации ниже, то скорее всего библиотека все равно будет работать, т.к. по большей части, обмен с сайтами сильно не меняется в 1С от версии к версии.
Данная библиотека была написана на основе модуля https://github.com/carono/yii2-1c-exchange - все основные интерфейсы взяты именно из этого модуля.
Зависимости
- php ^7.1
- carono/commerceml
- symfony/http-foundation ^4.1
Установка
composer require Sv1fT/exchange1c
Использование
Для использования библиотеки вам неободимо определить массив конфигов и реализовать интерфейсы в ваших моделях. В примере используется адаптер для symfony/event-dispatcher - https://github.com/Sv1fT/exchange1c-symfony-bridge Также вы можете использовать пакет-адаптер для интеграции с Laravel https://github.com/Sv1fT/laravel-exchange1c
require_once './../vendor/autoload.php'; //Подулючаем автолоад // Определяем конфиг $configValues = [ 'import_dir' => '1c_exchange', 'login' => 'admin', 'password' => 'admin', 'use_zip' => false, 'file_part' => 0, 'models' => [ \Sv1fT\Exchange1C\Interfaces\GroupInterface::class => \Tests\Models\GroupTestModel::class, \Sv1fT\Exchange1C\Interfaces\ProductInterface::class => \Tests\Models\ProductTestModel::class, \Sv1fT\Exchange1C\Interfaces\OfferInterface::class => \Tests\Models\OfferTestModel::class, ], ]; $config = new \Sv1fT\Exchange1C\Config($configValues); $request = \Symfony\Component\HttpFoundation\Request::createFromGlobals(); $symfonyDispatcher = new \Symfony\Component\EventDispatcher\EventDispatcher(); $dispatcher = new \Sv1fT\Exchange1C\SymfonyEventDispatcher($symfonyDispatcher); $modelBuilder = new \Sv1fT\Exchange1C\ModelBuilder(); // Создаем необходимые сервисы $loaderService = new \Sv1fT\Exchange1C\Services\FileLoaderService($request, $config); $authService = new \Sv1fT\Exchange1C\Services\AuthService($request, $config); $categoryService = new \Sv1fT\Exchange1C\Services\CategoryService($request, $config, $dispatcher, $modelBuilder); $offerService = new \Sv1fT\Exchange1C\Services\OfferService($request, $config, $dispatcher, $modelBuilder); $catalogService = new \Sv1fT\Exchange1C\Services\CatalogService($request, $config, $authService, $loaderService, $categoryService, $offerService); $mode = $request->get('mode'); $type = $request->get('type'); try { if ($type == 'catalog') { if (!method_exists($catalogService, $mode)) { throw new Exception('not correct request, mode=' . $mode); } //Запускаем сервис импорта каталога $body = $catalogService->$mode(); $response = new \Symfony\Component\HttpFoundation\Response($body, 200, ['Content-Type', 'text/plain']); $response->send(); } else { throw new \LogicException(sprintf('Logic for method %s not released', $type)); } } catch (\Exception $e) { $body = "failure\n"; $body .= $e->getMessage() . "\n"; $body .= $e->getFile() . "\n"; $body .= $e->getLine() . "\n"; $response = new \Symfony\Component\HttpFoundation\Response($body, 500, ['Content-Type', 'text/plain']); $response->send(); }
Более подробную информацию по интерфейсам и их реализациям можно почитаь в документации https://github.com/carono/yii2-1c-exchange Документация будет добалена позже.
Лицензия
Данный пакет является открытым кодом под лицензией MIT license.