This repository has been archived on 2020-03-24. You can view files and clone it, but cannot push or open issues or pull requests.
quay/endpoints/v1/tag.py

88 lines
2.5 KiB
Python
Raw Normal View History

2013-09-25 21:50:03 +00:00
import logging
import json
2013-09-25 21:50:03 +00:00
from flask import abort, request, jsonify, make_response, session
2013-09-25 21:50:03 +00:00
from app import app
2015-10-05 20:36:33 +00:00
from util.names import TAG_ERROR, TAG_REGEX, parse_repository_name
2013-09-25 21:50:03 +00:00
from auth.auth import process_auth
from auth.permissions import (ReadRepositoryPermission,
ModifyRepositoryPermission)
from data import model
from endpoints.decorators import anon_protect
2015-06-22 21:37:13 +00:00
from endpoints.v1 import v1_bp
2013-09-25 21:50:03 +00:00
logger = logging.getLogger(__name__)
@v1_bp.route('/repositories/<path:repository>/tags', methods=['GET'])
2013-09-25 21:50:03 +00:00
@process_auth
@anon_protect
2013-09-25 21:50:03 +00:00
@parse_repository_name
def get_tags(namespace, repository):
permission = ReadRepositoryPermission(namespace, repository)
if permission.can() or model.repository.repository_is_public(namespace, repository):
tags = model.tag.list_repository_tags(namespace, repository)
2013-10-01 21:23:44 +00:00
tag_map = {tag.name: tag.image.docker_image_id for tag in tags}
2013-09-25 21:50:03 +00:00
return jsonify(tag_map)
abort(403)
@v1_bp.route('/repositories/<path:repository>/tags/<tag>', methods=['GET'])
2013-09-25 21:50:03 +00:00
@process_auth
@anon_protect
2013-09-25 21:50:03 +00:00
@parse_repository_name
def get_tag(namespace, repository, tag):
permission = ReadRepositoryPermission(namespace, repository)
if permission.can() or model.repository.repository_is_public(namespace, repository):
tag_image = model.tag.get_tag_image(namespace, repository, tag)
resp = make_response('"%s"' % tag_image.docker_image_id)
resp.headers['Content-Type'] = 'application/json'
return resp
2013-09-25 21:50:03 +00:00
abort(403)
@v1_bp.route('/repositories/<path:repository>/tags/<tag>', methods=['PUT'])
2013-09-25 21:50:03 +00:00
@process_auth
@anon_protect
2013-09-25 21:50:03 +00:00
@parse_repository_name
def put_tag(namespace, repository, tag):
permission = ModifyRepositoryPermission(namespace, repository)
if permission.can():
2015-10-05 20:36:33 +00:00
if not TAG_REGEX.match(tag):
abort(400, TAG_ERROR)
2013-10-01 21:23:44 +00:00
docker_image_id = json.loads(request.data)
model.tag.create_or_update_tag(namespace, repository, tag, docker_image_id)
2013-09-25 21:50:03 +00:00
# Store the updated tag.
if not 'pushed_tags' in session:
session['pushed_tags'] = {}
session['pushed_tags'][tag] = docker_image_id
2013-09-25 21:50:03 +00:00
return make_response('Created', 200)
abort(403)
@v1_bp.route('/repositories/<path:repository>/tags/<tag>', methods=['DELETE'])
2013-09-25 21:50:03 +00:00
@process_auth
@anon_protect
2013-09-25 21:50:03 +00:00
@parse_repository_name
def delete_tag(namespace, repository, tag):
permission = ModifyRepositoryPermission(namespace, repository)
if permission.can():
model.tag.delete_tag(namespace, repository, tag)
return make_response('Deleted', 200)
2013-09-25 21:50:03 +00:00
abort(403)