Compare commits
No commits in common. "ea062e10aec607cd2045ecc31e776310002ed027" and "c05b11387dbf19168621e35480e21e8b2f0e3e8f" have entirely different histories.
ea062e10ae
...
c05b11387d
@ -470,51 +470,33 @@ class EconomicService:
|
|||||||
logger.info(f"📋 Trying invoice endpoint: {endpoint}")
|
logger.info(f"📋 Trying invoice endpoint: {endpoint}")
|
||||||
|
|
||||||
try:
|
try:
|
||||||
# Pagination: Keep fetching until no more pages
|
async with session.get(
|
||||||
page = 0
|
endpoint,
|
||||||
while True:
|
params={"pagesize": 1000},
|
||||||
async with session.get(
|
headers=self._get_headers()
|
||||||
endpoint,
|
) as response:
|
||||||
params={"pagesize": 1000, "skippages": page},
|
logger.info(f"🔍 [API] Response status from {endpoint}: {response.status}")
|
||||||
headers=self._get_headers()
|
|
||||||
) as response:
|
|
||||||
logger.info(f"🔍 [API] Response status from {endpoint} (page {page}): {response.status}")
|
|
||||||
|
|
||||||
if response.status == 200:
|
if response.status == 200:
|
||||||
data = await response.json()
|
data = await response.json()
|
||||||
invoices_from_endpoint = data.get('collection', [])
|
invoices_from_endpoint = data.get('collection', [])
|
||||||
logger.info(f"✅ Fetched {len(invoices_from_endpoint)} invoices from {endpoint} page {page}")
|
logger.info(f"✅ Successfully fetched {len(invoices_from_endpoint)} invoices from {endpoint}")
|
||||||
|
|
||||||
if not invoices_from_endpoint:
|
# Add new invoices (avoid duplicates by tracking invoice numbers)
|
||||||
# No more invoices on this page
|
existing_invoice_numbers = set()
|
||||||
break
|
for inv in all_invoices:
|
||||||
|
inv_num = inv.get('draftInvoiceNumber') or inv.get('bookedInvoiceNumber')
|
||||||
|
if inv_num:
|
||||||
|
existing_invoice_numbers.add(inv_num)
|
||||||
|
|
||||||
# Add new invoices (avoid duplicates by tracking invoice numbers)
|
for inv in invoices_from_endpoint:
|
||||||
existing_invoice_numbers = set()
|
inv_num = inv.get('draftInvoiceNumber') or inv.get('bookedInvoiceNumber')
|
||||||
for inv in all_invoices:
|
if inv_num and inv_num not in existing_invoice_numbers:
|
||||||
inv_num = inv.get('draftInvoiceNumber') or inv.get('bookedInvoiceNumber')
|
all_invoices.append(inv)
|
||||||
if inv_num:
|
existing_invoice_numbers.add(inv_num)
|
||||||
existing_invoice_numbers.add(inv_num)
|
else:
|
||||||
|
error_text = await response.text()
|
||||||
new_invoices_count = 0
|
logger.warning(f"⚠️ Endpoint {endpoint} returned {response.status}: {error_text[:200]}")
|
||||||
for inv in invoices_from_endpoint:
|
|
||||||
inv_num = inv.get('draftInvoiceNumber') or inv.get('bookedInvoiceNumber')
|
|
||||||
if inv_num and inv_num not in existing_invoice_numbers:
|
|
||||||
all_invoices.append(inv)
|
|
||||||
existing_invoice_numbers.add(inv_num)
|
|
||||||
new_invoices_count += 1
|
|
||||||
|
|
||||||
logger.info(f" Added {new_invoices_count} new unique invoices")
|
|
||||||
|
|
||||||
# Check if we got full page (1000) - if so, there might be more pages
|
|
||||||
if len(invoices_from_endpoint) < 1000:
|
|
||||||
break # Last page
|
|
||||||
|
|
||||||
page += 1
|
|
||||||
else:
|
|
||||||
error_text = await response.text()
|
|
||||||
logger.warning(f"⚠️ Endpoint {endpoint} returned {response.status}: {error_text[:200]}")
|
|
||||||
break
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
logger.warning(f"⚠️ Error trying endpoint {endpoint}: {e}")
|
logger.warning(f"⚠️ Error trying endpoint {endpoint}: {e}")
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user