import os
import time
import requests
from watchdog.observers import Observer
from watchdog.events import FileSystemEventHandler

pdf_spool_dir = "/var/spool/cups-pdf/ANONYMOUS/"

api_url = "http://localhost:8000/api/driver/v1/upload"
api_key = "6YUF7bqwoKRC9HKd"


def send_pdf_to_laravel(pdf_path):
    try:
        with open(pdf_path, "rb") as file:
            files = {"file": (os.path.basename(pdf_path), file, "application/pdf")}
            headers = {"X-Authorization": f"Bearer {api_key}"}

            response = requests.post(api_url, files=files, headers=headers)

            if response.status_code == 200:
                print(f"PDF enviado com sucesso: {pdf_path}")
                os.remove(pdf_path)
            else:
                print(
                    f"Falha ao enviar o PDF: {pdf_path}, Status: {response.status_code}, Resposta: {response.text}"
                )
    except Exception as e:
        print(f"Erro ao processar o arquivo {pdf_path}: {e}")


class PdfEventHandler(FileSystemEventHandler):
    def on_created(self, event):
        if event.is_directory:
            return

        if event.src_path.endswith(".pdf"):
            print(f"Novo arquivo PDF detectado: {event.src_path}")
            send_pdf_to_laravel(event.src_path)


def monitor_pdf_spool():
    event_handler = PdfEventHandler()
    observer = Observer()
    observer.schedule(event_handler, path=pdf_spool_dir, recursive=False)
    observer.start()

    try:
        while True:
            time.sleep(1)
    except KeyboardInterrupt:
        observer.stop()

    observer.join()


if __name__ == "__main__":
    monitor_pdf_spool()
