update_archive_date.py 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. #!/usr/bin/env python3
  2. """Update the created_at date for a specific archive."""
  3. import argparse
  4. import sys
  5. from datetime import datetime
  6. from pathlib import Path
  7. # Add backend to path
  8. sys.path.insert(0, str(Path(__file__).parent.parent))
  9. from sqlalchemy import create_engine, text
  10. from backend.app.core.config import settings
  11. def update_archive_date(archive_id: int, new_date: datetime) -> bool:
  12. """Update created_at for an archive."""
  13. db_path = settings.base_dir / "bambuddy.db"
  14. engine = create_engine(f"sqlite:///{db_path}")
  15. with engine.connect() as conn:
  16. # Check if archive exists
  17. result = conn.execute(
  18. text("SELECT id, filename, created_at FROM print_archives WHERE id = :id"),
  19. {"id": archive_id},
  20. )
  21. row = result.fetchone()
  22. if not row:
  23. print(f"Archive ID {archive_id} not found!")
  24. return False
  25. print(f"Archive: {row[1]}")
  26. print(f"Current date: {row[2]}")
  27. print(f"New date: {new_date}")
  28. # Update
  29. conn.execute(
  30. text("UPDATE print_archives SET created_at = :date WHERE id = :id"),
  31. {"id": archive_id, "date": new_date},
  32. )
  33. conn.commit()
  34. print("✓ Updated successfully!")
  35. return True
  36. def main():
  37. parser = argparse.ArgumentParser(description="Update archive created_at date")
  38. parser.add_argument("archive_id", type=int, help="Archive ID to update")
  39. parser.add_argument(
  40. "date",
  41. type=str,
  42. help="New date (YYYY-MM-DD or YYYY-MM-DD HH:MM:SS)",
  43. )
  44. args = parser.parse_args()
  45. # Parse date
  46. try:
  47. if " " in args.date:
  48. new_date = datetime.strptime(args.date, "%Y-%m-%d %H:%M:%S")
  49. else:
  50. new_date = datetime.strptime(args.date, "%Y-%m-%d")
  51. except ValueError:
  52. print("Invalid date format. Use YYYY-MM-DD or YYYY-MM-DD HH:MM:SS")
  53. sys.exit(1)
  54. update_archive_date(args.archive_id, new_date)
  55. if __name__ == "__main__":
  56. main()