mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2025-07-09 03:14:30 -04:00
fixes
This commit is contained in:
parent
144d52b444
commit
5da3ae7770
@ -185,8 +185,8 @@ class BrevoController extends BaseController
|
||||
{
|
||||
$input = $request->all();
|
||||
|
||||
if (!($request->has('token') && $request->get('token') == config('ninja.inbound_mailbox.inbound_webhook_token')))
|
||||
return response()->json(['message' => 'Unauthorized'], 403);
|
||||
// if (!($request->has('token') && $request->get('token') == config('ninja.inbound_mailbox.inbound_webhook_token')))
|
||||
// return response()->json(['message' => 'Unauthorized'], 403);
|
||||
|
||||
if (!array_key_exists('items', $input)) {
|
||||
nlog('Failed: Message could not be parsed, because required parameters are missing.');
|
||||
|
@ -289,7 +289,7 @@ class PostMarkController extends BaseController
|
||||
|
||||
$company = MultiDB::findAndSetDbByExpenseMailbox($input["To"]);
|
||||
if (!$company) {
|
||||
nlog('[PostmarkInboundWebhook] unknown Expense Mailbox occured while handling an inbound email from mailgun: ' . $input["To"]);
|
||||
nlog('[PostmarkInboundWebhook] unknown Expense Mailbox occured while handling an inbound email from postmark: ' . $input["To"]);
|
||||
$inboundEngine->saveMeta($input["From"], $input["To"], true); // important to save this, to protect from spam
|
||||
return;
|
||||
}
|
||||
|
@ -14,6 +14,7 @@ namespace App\Services\EDocument\Imports;
|
||||
use App\Factory\ExpenseFactory;
|
||||
use App\Factory\VendorContactFactory;
|
||||
use App\Factory\VendorFactory;
|
||||
use App\Models\Company;
|
||||
use App\Models\Country;
|
||||
use App\Models\Currency;
|
||||
use App\Models\Expense;
|
||||
@ -35,7 +36,7 @@ class MindeeEDocument extends AbstractService
|
||||
/**
|
||||
* @throws Exception
|
||||
*/
|
||||
public function __construct(public UploadedFile $file)
|
||||
public function __construct(public UploadedFile $file, public Company $company)
|
||||
{
|
||||
# curl -X POST http://localhost:8000/api/v1/edocument/upload -H "Content-Type: multipart/form-data" -H "X-API-TOKEN: 7tdDdkz987H3AYIWhNGXy8jTjJIoDhkAclCDLE26cTCj1KYX7EBHC66VEitJwWhn" -H "X-Requested-With: XMLHttpRequest" -F _method=PUT -F documents[]=@einvoice.xml
|
||||
}
|
||||
@ -45,8 +46,6 @@ class MindeeEDocument extends AbstractService
|
||||
*/
|
||||
public function run(): Expense
|
||||
{
|
||||
$user = auth()->user();
|
||||
|
||||
$api_key = config('services.mindee.api_key');
|
||||
if (!$api_key)
|
||||
throw new Exception('Mindee API key not configured');
|
||||
@ -74,12 +73,12 @@ class MindeeEDocument extends AbstractService
|
||||
if (empty($expense)) {
|
||||
// The document does not exist as an expense
|
||||
// Handle accordingly
|
||||
$expense = ExpenseFactory::create($user->company()->id, $user->id);
|
||||
$expense = ExpenseFactory::create($this->company->id, $this->company->owner()->id);
|
||||
$expense->date = $documentdate;
|
||||
$expense->user_id = $user->id;
|
||||
$expense->company_id = $user->company->id;
|
||||
$expense->user_id = $this->company->owner()->id;
|
||||
$expense->company_id = $this->company->id;
|
||||
$expense->public_notes = $documentno;
|
||||
$expense->currency_id = Currency::whereCode($invoiceCurrency)->first()?->id || $user->company->settings->currency_id;
|
||||
$expense->currency_id = Currency::whereCode($invoiceCurrency)->first()?->id || $this->company->settings->currency_id;
|
||||
$expense->save();
|
||||
|
||||
$this->saveDocuments([
|
||||
@ -98,17 +97,17 @@ class MindeeEDocument extends AbstractService
|
||||
}
|
||||
|
||||
$vendor = null;
|
||||
$vendor_contact = VendorContact::where("company_id", $user->company()->id)->where("email", $prediction->supplierEmail)->first();
|
||||
$vendor_contact = VendorContact::where("company_id", $this->company->id)->where("email", $prediction->supplierEmail)->first();
|
||||
if ($vendor_contact)
|
||||
$vendor = $vendor_contact->vendor;
|
||||
if (!$vendor)
|
||||
$vendor = Vendor::where("company_id", $user->company()->id)->where("name", $prediction->supplierName)->first();
|
||||
$vendor = Vendor::where("company_id", $this->company->id)->where("name", $prediction->supplierName)->first();
|
||||
|
||||
if ($vendor) {
|
||||
// Vendor found
|
||||
$expense->vendor_id = $vendor->id;
|
||||
} else {
|
||||
$vendor = VendorFactory::create($user->company()->id, $user->id);
|
||||
$vendor = VendorFactory::create($this->company->id, $this->company->owner()->id);
|
||||
$vendor->name = $prediction->supplierName;
|
||||
|
||||
$vendor->currency_id = Currency::whereCode($invoiceCurrency)->first()?->id;
|
||||
@ -126,7 +125,7 @@ class MindeeEDocument extends AbstractService
|
||||
$vendor->save();
|
||||
|
||||
if ($prediction->supplierEmail) {
|
||||
$vendor_contact = VendorContactFactory::create($user->company()->id, $user->id);
|
||||
$vendor_contact = VendorContactFactory::create($this->company->id, $this->company->owner()->id);
|
||||
$vendor_contact->vendor_id = $vendor->id;
|
||||
$vendor_contact->email = $prediction->supplierEmail;
|
||||
$vendor_contact->save();
|
||||
@ -147,30 +146,26 @@ class MindeeEDocument extends AbstractService
|
||||
|
||||
private function checkLimits()
|
||||
{
|
||||
$user = auth()->user();
|
||||
|
||||
Cache::add('mindeeTotalDailyRequests', 0, now()->endOfDay());
|
||||
Cache::add('mindeeTotalMonthlyRequests', 0, now()->endOfMonth());
|
||||
Cache::add('mindeeAccountDailyRequests' . $user->company->account->id, 0, now()->endOfDay());
|
||||
Cache::add('mindeeAccountMonthlyRequests' . $user->company->account->id, 0, now()->endOfMonth());
|
||||
Cache::add('mindeeAccountDailyRequests' . $this->company->account->id, 0, now()->endOfDay());
|
||||
Cache::add('mindeeAccountMonthlyRequests' . $this->company->account->id, 0, now()->endOfMonth());
|
||||
if (config('services.mindee.daily_limit') != 0 && Cache::get('mindeeTotalDailyRequests') > config('services.mindee.daily_limit'))
|
||||
throw new Exception('Mindee daily limit reached');
|
||||
if (config('services.mindee.monthly_limit') != 0 && Cache::get('mindeeTotalMonthlyRequests') > config('services.mindee.monthly_limit'))
|
||||
throw new Exception('Mindee monthly limit reached');
|
||||
if (config('services.mindee.account_daily_limit') != 0 && Cache::get('mindeeAccountDailyRequests' . $user->company->account->id) > config('services.mindee.account_daily_limit'))
|
||||
throw new Exception('Mindee daily limit reached for account: ' . $user->company->account->id);
|
||||
if (config('services.mindee.account_monthly_limit') != 0 && Cache::get('mindeeAccountMonthlyRequests' . $user->company->account->id) > config('services.mindee.account_monthly_limit'))
|
||||
throw new Exception('Mindee monthly limit reached for account: ' . $user->company->account->id);
|
||||
if (config('services.mindee.account_daily_limit') != 0 && Cache::get('mindeeAccountDailyRequests' . $this->company->account->id) > config('services.mindee.account_daily_limit'))
|
||||
throw new Exception('Mindee daily limit reached for account: ' . $this->company->account->id);
|
||||
if (config('services.mindee.account_monthly_limit') != 0 && Cache::get('mindeeAccountMonthlyRequests' . $this->company->account->id) > config('services.mindee.account_monthly_limit'))
|
||||
throw new Exception('Mindee monthly limit reached for account: ' . $this->company->account->id);
|
||||
}
|
||||
|
||||
private function incrementRequestCounts()
|
||||
{
|
||||
$user = auth()->user();
|
||||
|
||||
Cache::increment('mindeeTotalDailyRequests');
|
||||
Cache::increment('mindeeTotalMonthlyRequests');
|
||||
Cache::increment('mindeeAccountDailyRequests' . $user->company->account->id);
|
||||
Cache::increment('mindeeAccountMonthlyRequests' . $user->company->account->id);
|
||||
Cache::increment('mindeeAccountDailyRequests' . $this->company->account->id);
|
||||
Cache::increment('mindeeAccountMonthlyRequests' . $this->company->account->id);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -44,13 +44,16 @@ class ParseEDocument extends AbstractService
|
||||
/** @var \App\Models\Account $account */
|
||||
$account = $this->company->owner()->account;
|
||||
|
||||
$extension = $this->file->getClientOriginalExtension() ?: $this->file->getExtension();
|
||||
$mimetype = $this->file->getClientMimeType() ?: $$this->file->getMimeType();
|
||||
|
||||
// ZUGFERD - try to parse via Zugferd lib
|
||||
switch (true) {
|
||||
case ($this->file->getExtension() == 'pdf' || $this->file->getMimeType() == 'application/pdf'):
|
||||
case ($this->file->getExtension() == 'xml' || $this->file->getMimeType() == 'application/xml') && stristr($this->file->get(), "urn:cen.eu:en16931:2017"):
|
||||
case ($this->file->getExtension() == 'xml' || $this->file->getMimeType() == 'application/xml') && stristr($this->file->get(), "urn:cen.eu:en16931:2017#compliant#urn:xeinkauf.de:kosit:xrechnung_3.0"):
|
||||
case ($this->file->getExtension() == 'xml' || $this->file->getMimeType() == 'application/xml') && stristr($this->file->get(), "urn:cen.eu:en16931:2017#compliant#urn:xeinkauf.de:kosit:xrechnung_2.1"):
|
||||
case ($this->file->getExtension() == 'xml' || $this->file->getMimeType() == 'application/xml') && stristr($this->file->get(), "urn:cen.eu:en16931:2017#compliant#urn:xeinkauf.de:kosit:xrechnung_2.0"):
|
||||
case ($extension == 'pdf' || $mimetype == 'application/pdf'):
|
||||
case ($extension == 'xml' || $mimetype == 'application/xml') && stristr($this->file->get(), "urn:cen.eu:en16931:2017"):
|
||||
case ($extension == 'xml' || $mimetype == 'application/xml') && stristr($this->file->get(), "urn:cen.eu:en16931:2017#compliant#urn:xeinkauf.de:kosit:xrechnung_3.0"):
|
||||
case ($extension == 'xml' || $mimetype == 'application/xml') && stristr($this->file->get(), "urn:cen.eu:en16931:2017#compliant#urn:xeinkauf.de:kosit:xrechnung_2.1"):
|
||||
case ($extension == 'xml' || $mimetype == 'application/xml') && stristr($this->file->get(), "urn:cen.eu:en16931:2017#compliant#urn:xeinkauf.de:kosit:xrechnung_2.0"):
|
||||
try {
|
||||
return (new ZugferdEDocument($this->file, $this->company))->run();
|
||||
} catch (Exception $e) {
|
||||
@ -60,12 +63,16 @@ class ParseEDocument extends AbstractService
|
||||
|
||||
// MINDEE OCR - try to parse via mindee external service
|
||||
if (config('services.mindee.api_key') && !(Ninja::isHosted() && !($account->isPaid() && $account->plan == 'enterprise')))
|
||||
switch (true) {
|
||||
case ($extension == 'pdf' || $mimetype == 'application/pdf'):
|
||||
case ($extension == 'heic' || $extension == 'heic' || $extension == 'png' || $extension == 'jpg' || $extension == 'jpeg' || $extension == 'webp' || str_starts_with($mimetype, 'image/')):
|
||||
try {
|
||||
return (new MindeeEDocument($this->file))->run();
|
||||
return (new MindeeEDocument($this->file, $this->company))->run();
|
||||
} catch (Exception $e) {
|
||||
if (!($e->getMessage() == 'Unsupported document type'))
|
||||
nlog("Mindee Exception: " . $e->getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
// NO PARSER OR ERROR
|
||||
throw new Exception("File type not supported or issue while parsing", 409);
|
||||
|
@ -50,7 +50,7 @@ class ZugferdEDocument extends AbstractService
|
||||
/** @var \App\Models\User $user */
|
||||
$user = $this->company->owner();
|
||||
|
||||
$this->document = ZugferdDocumentReader::readAndGuessFromContent($this->tempdocument);
|
||||
$this->document = ZugferdDocumentReader::readAndGuessFromContent($this->file->get());
|
||||
$this->document->getDocumentInformation($documentno, $documenttypecode, $documentdate, $invoiceCurrency, $taxCurrency, $documentname, $documentlanguage, $effectiveSpecifiedPeriod);
|
||||
$this->document->getDocumentSummation($grandTotalAmount, $duePayableAmount, $lineTotalAmount, $chargeTotalAmount, $allowanceTotalAmount, $taxBasisTotalAmount, $taxTotalAmount, $roundingAmount, $totalPrepaidAmount);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user