#!/usr/bin/env python

import sys
import time

from catsnap import Config
from catsnap.image_truck import ImageTruck
from catsnap.document.tag import Tag
from catsnap.document.image import Image

from boto.exception import DynamoDBResponseError

USAGE = """
Usage:
    catsnap add [image_url] tag1 tag2 ...
    catsnap find tag1 tag2 ...
"""

def main():
    if len(sys.argv) < 2:
        show_help()
    command = sys.argv[1]
    if command == 'add':
        if len(sys.argv) < 4:
            show_help()
        add(sys.argv[2], sys.argv[3:])
    elif command == 'find':
        if len(sys.argv) < 3:
            show_help()
        find(sys.argv[2:])
    else:
        show_help()

def add(url, tags):
    truck = ImageTruck.new_from_url(url)
    truck.upload()
    image = Image(truck.calculate_filename(), truck.source_url)
    image.add_tags(tags)
    for tag_name in tags:
        tag = Tag(tag_name)
        tag.add_file(image.filename)

    print truck.url()

def find(tags):
    for tag_name in tags:
        tag = Tag(tag_name)
        for filename in tag.get_filenames():
            image = Image(filename)
            image_tags = ' '.join(image.get_tags())
            url = ImageTruck.url_for_filename(filename)
            print '%s   |   %s' % (url, image_tags)


def show_help():
    sys.stderr.write(USAGE)
    sys.exit(1)

try:
    main()
except DynamoDBResponseError, e:
    if e.status == 400 and e.error_code == u'ResourceNotFoundException':
        sys.stderr.write("""
######
######
######
I caught a ResourceNotFoundException while trying to interact with DynamoDB.
This can happen sometimes right after creating a new DB table--it takes a while
before the table is ready for queries. Please wait a bit and try again...
######
######
######
""")
    raise

