Exemples¶
Voici quelques exemple pour réaliser certaines actions spécifiques. N’hésitez pas regarder directement la documentation des classes pour connaître les paramètres que vous pouvez utilisez ainsi que les fonctions disponibles.
Récupérer les projets accessibles par l’utilisateur¶
projects=aq.project.get_all()
Créer un dossier dans un projet¶
# projects is defined on the previous example
project = projects[0]
reference_folder=project.append(type='Group', data={'name': 'References'})
Uploader une image dans un dossier¶
# reference_folder is defined on the previous example
media = reference_folder.item.append(type='Media', path=r"/mnt/project/image.jpg")
Récupérer les dossiers d’un projet¶
# project is defined on previous example
folders = project.get_children(types="Group")
Créer un shot dans une séquence¶
sequence_key = 123456
shot = aq.item(sequence_key).append(type="Shot", data={'name': 's010_p100', frameIn: '101', frameOut: '256'})
Récupérer les tâches assignées de l’utilisateur courant¶
me=aq.get_current_user()
my_tasks=me.get_tasks()
Récupérer les tâches assignées au sein d’un projet de l’utilisateur courant¶
projectKey=123456
me=aq.get_current_user()
my_tasks=me.get_tasks(project_key=projectKey)
Récupérer les shots ou assets d’un projet¶
projectKey=123456
project=aq.project(123456).get()
shots=project.get_shots()
Conseil
En fonction de la structure de votre projet, il pourra être plus performant d’utiliser directement un traverse avec une requête personnalisée.
Récupérer les status disponibles pour une tâche¶
me=aq.get_current_user()
tasks=me.get_tasks()
statuses=tasks[0].get_statuses()
Créer une playlist avec les media uploadés aujourd’hui¶
# project is defined on the previous example
playlist = project.append(type="Playlist", data={'name': 'My playlist'})
medias = project.traverse(meshql="# -($Child, 5)> $Media AND item.updatedAt > DATE_ROUND(@now, 1, 'day') VIEW item")
medias = [aq.item(media) for media in medias]
for media in medias:
aq.edge.create(type="Child", from_key=playlist.item._key, to_key=media._key)
imported_media = playlist.item.get_medias()
Ecouter des événements¶
events = aq.events.listen()
callback = lambda event: print(event)
allEvents = events.subscribe('*', callback)
itemCreated = events.subscribe('item.created', callback)
events.unsubscribe('*', allEvents)
events.start()
Se connecter à Aquarium avec un bot¶
from aquarium import Aquarium
aq=Aquarium('https://your-aquarium-server')
aq.bot(AQ_BOT_KEY).connect(AQ_BOT_SECRET)