This commit is contained in:
Joseph Schorr 2013-11-11 17:53:29 -05:00
commit 743e95c50e
4 changed files with 34 additions and 14 deletions

View file

@ -1218,6 +1218,8 @@ def subscribe(user, plan, token, accepted_plans):
cus = stripe.Customer.retrieve(user.stripe_id)
if plan_found['price'] == 0:
if cus.subscription is not None:
# We only have to cancel the subscription if they actually have one
cus.cancel_subscription()
cus.save()

View file

@ -1,6 +1,4 @@
import json
import urllib
import json
import logging
import urlparse
@ -11,7 +9,7 @@ from data import model
from app import app, mixpanel
from auth.auth import (process_auth, get_authenticated_user,
get_validated_token)
from util.names import parse_namespace_repository, parse_repository_name
from util.names import parse_repository_name
from util.email import send_confirmation_email
from auth.permissions import (ModifyRepositoryPermission, UserPermission,
ReadRepositoryPermission,
@ -35,10 +33,14 @@ def generate_headers(role='read'):
if has_token_request:
repo = model.get_repository(namespace, repository)
if repo:
token = model.create_access_token(repo, role)
token_str = 'signature=%s' % token.code
response.headers['WWW-Authenticate'] = token_str
response.headers['X-Docker-Token'] = token_str
else:
logger.info('Token request in non-existing repo: %s/%s' %
(namespace, repository))
return response
return wrapper
@ -54,7 +56,7 @@ def create_user():
if username == '$token':
try:
token = model.load_token_data(password)
model.load_token_data(password)
return make_response('Verified', 201)
except model.InvalidTokenException:
abort(401)
@ -130,7 +132,7 @@ def create_repository(namespace, repository):
abort(403)
else:
permission = CreateRepoPermission('namespace')
permission = CreateRepositoryPermission(namespace)
if not permission.can():
logger.info('Attempt to create a new repo with insufficient perms.')
abort(403)
@ -151,7 +153,7 @@ def create_repository(namespace, repository):
existing.delete_instance(recursive=True)
for image_description in added_images.values():
image = model.create_image(image_description['id'], repo)
model.create_image(image_description['id'], repo)
response = make_response('Created', 201)
@ -213,7 +215,8 @@ def get_repository_images(namespace, repository):
return resp
abort(403)
# TODO Submit a pull to docker CLI to get it to accept 403s
abort(404)
@app.route('/v1/repositories/<path:repository>/images', methods=['DELETE'])

View file

@ -114,7 +114,7 @@ def put_image_layer(namespace, repository, image_id):
# compute checksums
csums = []
sr = SocketReader(input_stream)
tmp, store_hndlr = storage.temp_store_handler()
tmp, store_hndlr = store.temp_store_handler()
sr.add_handler(store_hndlr)
h, sum_hndlr = checksums.simple_checksum_handler(json_data)
sr.add_handler(sum_hndlr)

View file

@ -1,3 +1,6 @@
import tempfile
class Storage(object):
"""Storage is organized as follow:
@ -13,6 +16,18 @@ class Storage(object):
# Set the IO buffer to 64kB
buffer_size = 64 * 1024
@staticmethod
def temp_store_handler():
tmpf = tempfile.TemporaryFile()
def fn(buf):
try:
tmpf.write(buf)
except IOError:
pass
return tmpf, fn
#FIXME(samalba): Move all path resolver in each module (out of the base)
def images_list_path(self, namespace, repository):
return '{0}/{1}/{2}/_images_list'.format(self.repositories,