mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-07 12:30:28 +01:00
423 lines
19 KiB
PHP
423 lines
19 KiB
PHP
<?php
|
|
/*
|
|
**** COPYRIGHT & LICENSE NOTICE *** DO NOT REMOVE ****
|
|
*
|
|
* Xentral (c) Xentral ERP Sorftware GmbH, Fuggerstrasse 11, D-86150 Augsburg, * Germany 2019
|
|
*
|
|
* This file is licensed under the Embedded Projects General Public License *Version 3.1.
|
|
*
|
|
* You should have received a copy of this license from your vendor and/or *along with this file; If not, please visit www.wawision.de/Lizenzhinweis
|
|
* to obtain the text of the corresponding license version.
|
|
*
|
|
**** END OF COPYRIGHT & LICENSE NOTICE *** DO NOT REMOVE ****
|
|
*/
|
|
?>
|
|
<?php
|
|
|
|
use Xentral\Components\Filesystem\Adapter\FtpConfig;
|
|
use Xentral\Components\Filesystem\FilesystemFactory;
|
|
use Xentral\Components\Http\JsonResponse;
|
|
use Xentral\Modules\AmaInvoice\Service\AmaInvoiceService;
|
|
|
|
class Amainvoice
|
|
{
|
|
/** @var Application $app */
|
|
protected $app;
|
|
|
|
/** @var array $error */
|
|
protected $error;
|
|
|
|
/** @var AmaInvoiceService $service */
|
|
protected $service;
|
|
|
|
/** @var string MODULE_NAME */
|
|
const MODULE_NAME = 'AmaInvoice';
|
|
|
|
/** @var array $javascript */
|
|
public $javascript = [
|
|
'./classes/Modules/AmaInvoice/www/js/amainvoice.js',
|
|
];
|
|
|
|
/**
|
|
* Amainvoice constructor.
|
|
*
|
|
* @param Application $app
|
|
* @param bool $intern
|
|
*/
|
|
public function __construct($app, $intern = false)
|
|
{
|
|
$this->app = $app;
|
|
$this->service = $this->app->Container->get('AmaInvoiceService');
|
|
if($intern){
|
|
return;
|
|
}
|
|
|
|
$this->app->ActionHandlerInit($this);
|
|
|
|
$this->app->ActionHandler('list', 'AmainvoiceList');
|
|
|
|
$this->app->ActionHandlerListen($app);
|
|
}
|
|
|
|
|
|
/**
|
|
* @param Application $app
|
|
* @param string $name
|
|
* @param array $erlaubtevars
|
|
*
|
|
* @return array
|
|
*/
|
|
public function TableSearch($app, $name, $erlaubtevars)
|
|
{
|
|
switch($name)
|
|
{
|
|
case 'amainvoice_list':
|
|
$allowed = ['amainvoice' => ['list']];
|
|
$heading = ['','Datum','Typ','Anzahl gesamt','Anzahl importiert','in Warteschlange', ''];
|
|
$width = ['1%','10%','10%','5%','5%','5%','1%'];
|
|
$findcols = ['t.id','t.date','t.type','t.count_all','t.count_imported','count_queue','t.id'];
|
|
$searchsql = ["DATE_FORMAT(t.date,'%d.%m.%Y')",'t.type'];
|
|
$datecols = [1];
|
|
$alignright = [4,5,6];
|
|
$sql = "
|
|
SELECT SQL_CALC_FOUND_ROWS t.date,
|
|
CONCAT('<input class=\"select\" type=\"checkbox\" data-id=\"',t.id,'\" />'),
|
|
DATE_FORMAT(t.date,'%d.%m.%Y'),
|
|
t.type, t.count_all,t.count_imported, t.count_queue,
|
|
t.id
|
|
FROM (
|
|
SELECT IF(ap.rem_date = '', 'Rechnung', 'Gutschrift') AS `type`,
|
|
IF(ap.rem_date = '', ap.inv_date , ap.rem_date) AS `date`,
|
|
COUNT(ap.id) AS `count_all`,
|
|
SUM(IF(ap.doctype_id > 0,1,0)) AS `count_imported`,
|
|
SUM(IF(ap.create > 0 AND ap.doctype_id = 0,1,0)) AS `count_queue`,
|
|
IF(ap.rem_date = '', CONCAT('inv',ap.inv_date) , CONCAT('rem', ap.rem_date)) AS `id`
|
|
FROM `amazoninvoice_position` AS `ap`
|
|
GROUP BY IF(ap.rem_date = '', 'Rechnung', 'Gutschrift'), IF(ap.rem_date = '', ap.inv_date , ap.rem_date),
|
|
IF(ap.rem_date = '', CONCAT('inv',ap.inv_date) , CONCAT('rem', ap.rem_date))
|
|
) AS `t`
|
|
";
|
|
|
|
break;
|
|
}
|
|
|
|
|
|
$erg = [];
|
|
|
|
foreach($erlaubtevars as $k => $v) {
|
|
if(isset($$v)) {
|
|
$erg[$v] = $$v;
|
|
}
|
|
}
|
|
return $erg;
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
public function getCheckBoxes()
|
|
{
|
|
return ['ftp', 'createorder'];
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
public function getTextFields()
|
|
{
|
|
return ['dir', 'user', 'server', 'port', 'firmkeyid', 'startdate', 'projectfbm', 'projectfba', 'paymentmethod',];
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
public function getPasswordFields()
|
|
{
|
|
return ['pass', 'clientidentifier'];
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
public function getFields()
|
|
{
|
|
return array_merge($this->getCheckBoxes(), $this->getTextFields(), $this->getPasswordFields());
|
|
}
|
|
|
|
public function AmainvoiceMenu()
|
|
{
|
|
$this->app->erp->MenuEintrag('index.php?module=appstore&action=list', 'Zurück zur Übersicht');
|
|
$this->app->erp->MenuEintrag('index.php?module=amainvoice&action=list', 'Details');
|
|
}
|
|
|
|
/**
|
|
* @return JsonResponse
|
|
*/
|
|
public function HandleAmaInvoiceImportListAjax()
|
|
{
|
|
$list = $this->app->Secure->GetPOST('list');
|
|
$changed = 0;
|
|
if(!empty($list)){
|
|
foreach ($list as $element) {
|
|
$date = new DateTime(substr($element, 3));
|
|
if(strpos($element,'inv') === 0) {
|
|
$this->service->markDbEntriesToImport($date, $date, false);
|
|
$changed++;
|
|
}
|
|
elseif(strpos($element,'rem') === 0) {
|
|
$this->service->markDbEntriesToImport($date, $date, true);
|
|
$changed++;
|
|
}
|
|
}
|
|
}
|
|
|
|
return new JsonResponse(['changed' => $changed, 'success' => true]);
|
|
}
|
|
|
|
public function AmainvoiceList()
|
|
{
|
|
$cmd = $this->app->Secure->GetGET('cmd');
|
|
if($cmd === 'importlist') {
|
|
|
|
return $this->HandleAmaInvoiceImportListAjax();
|
|
}
|
|
$this->AmainvoiceMenu();
|
|
$passwordFields = $this->getPasswordFields();
|
|
if($this->app->Secure->GetPOST('save')){
|
|
$arr = [];
|
|
foreach ($this->getFields() as $field) {
|
|
$value = empty($this->app->Secure->POST[$field]) ? '' : $this->app->Secure->POST[$field];
|
|
if($value === '*****' && in_array($field, $passwordFields)){
|
|
continue;
|
|
}
|
|
if($field === 'startdate'){
|
|
if(strpos($value, '.') !== false){
|
|
$value = $this->app->String->Convert($value, '%1.%2.%3', '%3-%2-%1');
|
|
}
|
|
}
|
|
if(in_array($field, ['projectfbm', 'projectfba',])) {
|
|
$value = $this->app->erp->ReplaceProjekt(1, $value, 1);
|
|
}
|
|
$arr[$field] = $value;
|
|
}
|
|
|
|
$this->service->setConfig($arr);
|
|
$this->app->Location->execute('index.php?module=amainvoice&action=list');
|
|
}
|
|
|
|
$arr = $this->service->getConfig();
|
|
foreach ($this->getCheckBoxes() as $field) {
|
|
if(!empty($arr[$field])){
|
|
$this->app->Tpl->Set(strtoupper($field), ' checked="checked" ');
|
|
}
|
|
}
|
|
foreach ($this->getTextFields() as $field) {
|
|
$value = !empty($arr[$field]) ? $arr[$field] : '';
|
|
if($field === 'startdate'){
|
|
if(strpos($value, '-') !== false){
|
|
$value = $this->app->String->Convert($value, '%3-%2-%1', '%1.%2.%3');
|
|
}
|
|
$this->app->YUI->DatePicker('startdate');
|
|
}
|
|
if(in_array($field, ['projectfbm','projectfba'])) {
|
|
$value = $this->app->erp->ReplaceProjekt(0, $value, 0);
|
|
$this->app->YUI->AutoComplete($field, 'projektname', 1);
|
|
}
|
|
if($field === 'paymentmethod') {
|
|
$paymentmethods = $this->app->erp->GetZahlungsweise();
|
|
foreach ($paymentmethods as $type => $paymentmethod) {
|
|
$this->app->Tpl->Add(
|
|
'SELPAYMENTMETHOD',
|
|
'<option value="' . $type .'"'
|
|
. ($value === $type ? ' selected="selected"' : '') . '>' . $paymentmethod
|
|
. '</option>'
|
|
);
|
|
}
|
|
continue;
|
|
}
|
|
$this->app->Tpl->Set(strtoupper($field), $value);
|
|
}
|
|
|
|
foreach ($passwordFields as $field) {
|
|
if(!empty($arr[$field])){
|
|
$this->app->Tpl->Set(strtoupper($field), '*****');
|
|
}
|
|
}
|
|
/** @var Appstore $appstore */
|
|
$module = 'amainvoice';
|
|
$appstore = $this->app->erp->LoadModul('appstore');
|
|
if($appstore === null || !method_exists($appstore, 'isBeta')) {
|
|
return;
|
|
}
|
|
$this->app->erp->Headlines('Amainvoice');
|
|
if($appstore->isBeta($module)) {
|
|
$this->app->erp->Headlines('Amainvoice', '<span class="beta">BETA</span>');
|
|
$this->app->Tpl->Add(
|
|
'MESSAGE',
|
|
'<div class="info">Dieses Modul ist noch im Beta Stadium.</div>'
|
|
);
|
|
}
|
|
$this->app->erp->checkActiveCronjob('amainvoice', 'MESSAGE');
|
|
$this->app->YUI->TableSearch('TAB2', 'amainvoice_list', 'show', '', '', basename(__FILE__), __CLASS__);
|
|
$this->app->Tpl->Parse('PAGE', 'amainvoice_list.tpl');
|
|
}
|
|
|
|
public function Install()
|
|
{
|
|
$this->app->erp->CheckTable('amainvoice_config');
|
|
$this->app->erp->CheckColumn('name', 'varchar(255)', 'amainvoice_config', "DEFAULT '' NOT NULL");
|
|
$this->app->erp->CheckColumn('value', 'varchar(255)', 'amainvoice_config', "DEFAULT '' NOT NULL");
|
|
$this->app->erp->CheckIndex('amainvoice_config', 'name', true);
|
|
|
|
$this->app->erp->CheckTable('amainvoice_files');
|
|
$this->app->erp->CheckColumn('filename', 'varchar(255)', 'amainvoice_files', "DEFAULT '' NOT NULL");
|
|
$this->app->erp->CheckColumn('type', 'varchar(32)', 'amainvoice_files', "DEFAULT '' NOT NULL");
|
|
$this->app->erp->CheckColumn('status', 'varchar(32)', 'amainvoice_files', "DEFAULT '' NOT NULL");
|
|
$this->app->erp->CheckColumn('created_at', 'TIMESTAMP', 'amainvoice_files', 'DEFAULT CURRENT_TIMESTAMP NOT NULL');
|
|
$this->app->erp->CheckIndex('amainvoice_files', 'filename');
|
|
|
|
$this->app->erp->CheckTable('amazoninvoice_position');
|
|
$this->app->erp->CheckColumn('id', 'int(11)', 'amazoninvoice_position', " auto_increment");
|
|
$this->app->erp->CheckColumn('doctype', 'varchar(32)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('doctype_id', 'int(11)', 'amazoninvoice_position', " DEFAULT '0' ");
|
|
$this->app->erp->CheckColumn('position_id', 'int(11)', 'amazoninvoice_position', " DEFAULT '0' ");
|
|
$this->app->erp->CheckColumn('inv_rech_nr', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('inv_date', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('amazonorderid', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shipmentdate', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('buyeremail', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('buyerphonenumber', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('buyername', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('sku', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('productname', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('quantitypurchased', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('quantityshipped', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('currency', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('mwst', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('taxrate', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('brutto_total', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('netto_total', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('tax_total', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('itemprice', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('itemprice_netto', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('itemprice_tax', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shippingprice', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shippingprice_netto', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shippingprice_tax', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('giftwrapprice', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('giftwrapprice_netto', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('giftwrapprice_tax', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('itempromotiondiscount', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('itempromotiondiscount_netto', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('itempromotiondiscount_tax', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shippromotiondiscount', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shippromotiondiscount_netto', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shippromotiondiscount_tax', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('giftwrappromotiondiscount', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('giftwrappromotiondiscount_netto', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('giftwrappromotiondiscount_tax', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shipservicelevel', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('recipientname', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shipaddress1', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shipaddress2', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shipaddress3', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shipcity', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shipstate', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shippostalcode', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shipcountry', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('shipphonenumber', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('billaddress1', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('billaddress2', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('billaddress3', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('billcity', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('billstate', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('billpostalcode', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('billcountry', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('carrier', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('trackingnumber', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('fulfillmentcenterid', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('fulfillmentchannel', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('saleschannel', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('asin', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('conditiontype', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('quantityavailable', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('isbusinessorder', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('uid', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('vatcheck', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('documentlink', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('order_id', 'int(11)', 'amazoninvoice_position', " DEFAULT '0' ");
|
|
$this->app->erp->CheckColumn('rem_gs_nr', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('orderid', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('rem_date', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('returndate', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('buyercompanyname', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('quantity', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('remreturnshipcost', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('remsondererstattung', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('itempromotionid', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('reason', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('rem_gs_nr_real', 'varchar(255)', 'amazoninvoice_position', " DEFAULT '' ");
|
|
$this->app->erp->CheckColumn('create', 'tinyint(1)', 'amazoninvoice_position', ' DEFAULT 0 ');
|
|
$this->app->erp->CheckColumn('create_order', 'tinyint(1)', 'amazoninvoice_position', ' DEFAULT 0 ');
|
|
$this->app->erp->CheckColumn('created_at', 'timestamp', 'amazoninvoice_position', 'DEFAULT CURRENT_TIMESTAMP');
|
|
$this->app->erp->CheckProzessstarter('AmaInvoice', 'periodisch', 60, '', 'cronjob', 'amainvoice', 1);
|
|
}
|
|
|
|
/**
|
|
* @param string $host
|
|
* @param string $user
|
|
* @param string $pass
|
|
* @param string $dir
|
|
* @param int $port
|
|
*
|
|
* @return array
|
|
*/
|
|
protected function ftp($host, $user, $pass, $dir, $port = 21)
|
|
{
|
|
/** @var FilesystemFactory $fsFactory */
|
|
$fsFactory = $this->app->Container->get('FilesystemFactory');
|
|
$ftpConfig = new FtpConfig($host, $user, $pass, $dir, $port);
|
|
$ftp = $fsFactory->createFtp($ftpConfig);
|
|
|
|
$files = $ftp->listFiles('', false);
|
|
$fileNames = [];
|
|
foreach ($files as $index => $file) {
|
|
$fileNames[] = $file->getFilename();
|
|
}
|
|
|
|
return $fileNames;
|
|
}
|
|
|
|
/**
|
|
* @param string $dir
|
|
*
|
|
* @return array
|
|
*/
|
|
protected function local($dir)
|
|
{
|
|
$fileSystemConfig = ['permissions' => [
|
|
'file' => [
|
|
'public' => 0664,
|
|
'private' => 0664,
|
|
],
|
|
'dir' => [
|
|
'public' => 0775,
|
|
'private' => 0775,
|
|
],
|
|
]];
|
|
|
|
/** @var FilesystemFactory $factory */
|
|
$factory = $this->app->Container->get('FilesystemFactory');
|
|
$fileSystem = $factory->createLocal($dir, $fileSystemConfig);
|
|
|
|
$files = $fileSystem->listFiles('');
|
|
$fileNames = [];
|
|
foreach ($files as $index => $file) {
|
|
$fileNames[] = $file->getFilename();
|
|
}
|
|
|
|
return $fileNames;
|
|
}
|
|
|
|
}
|