本文整理匯總了Python中moneta.repository.models.Repository類的典型用法代碼示例。如果您正苦於以下問題:Python Repository類的具體用法?Python Repository怎麽用?Python Repository使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了Repository類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: create_repository
def create_repository(self, repo_cls, name='test_repo', author=None, states='qualif prod'):
assert issubclass(repo_cls, RepositoryModel)
if author is None:
author = User.objects.get_or_create(username='test_user')[0]
repo = Repository(author=author, name=name, on_index=True, archive_type=repo_cls.archive_type, is_private=False)
repo.save()
for state in states.split():
ArchiveState(repository=repo, name=state, author=author).save()
return repo
示例2: xr_search
def xr_search(request, rpc_args, self, rid, repo_slug, state_slug=None):
repo = get_object_or_404(Repository.reader_queryset(request), id=rid, archive_type=self.model)
state = get_object_or_404(ArchiveState, repository=repo, name=state_slug) if state_slug else None
global_and = len(rpc_args) == 0 or rpc_args[1] != 'or'
if len(rpc_args) == 0 or not isinstance(rpc_args[0], dict):
raise PermissionDenied
filters = None
for query_name, attr_name in (('name', 'archive'), ('version', 'version'), ('home_page', 'official_link'),
('description', 'long_description'),):
if query_name in rpc_args[0]:
value = rpc_args[0][query_name]
if isinstance(value, list):
if value:
value = value[0]
else:
value = ''
value = value.replace('-', '').replace('_', '')
sub_query = Q(**{attr_name + '__icontains': value})
if filters is None:
filters = sub_query
elif global_and:
filters = filters and sub_query
else:
filters = filters or sub_query
query = Element.objects.filter(repository=repo)
if state:
query = query.filter(states=state)
if filters is not None:
query = query.filter(filters)
res = [{'name': x.archive, 'version': x.version, 'summary': x.long_description,
'_pypi_ordering': 1.0} for x in query]
return res
示例3: modify_repository
def modify_repository(request: HttpRequest, rid):
repo = get_object_or_404(Repository.upload_queryset(request), id=rid)
author = None if request.user.is_anonymous() else request.user
if request.method == 'POST':
form = RepositoryUpdateForm(request.POST)
if form.is_valid():
new_state_names = set(form.cleaned_data['states'].split())
old_state_names = {x.name for x in repo.archivestate_set.all()}
for name in new_state_names - old_state_names: # new states
ArchiveState(name=name, repository=repo, author=author).save()
repo.on_index = form.cleaned_data['on_index']
repo.is_private = form.cleaned_data['is_private']
repo.save()
repo.admin_group.clear()
for group in form.cleaned_data['admin_group']:
repo.admin_group.add(group)
# repo.reader_group.clear()
# for group in form.cleaned_data['reader_group']:
# repo.reader_group.add(group)
removed_states = ArchiveState.objects.filter(name__in=old_state_names - new_state_names, repository=repo)
# noinspection PyUnresolvedReferences
Element.states.through.objects.filter(archivestate__in=removed_states).delete()
removed_states.delete()
messages.info(request, _('The repository %(repo)s has been modified.') % {'repo': repo.name})
return HttpResponseRedirect(reverse('moneta:modify_repository', kwargs={'rid': rid, }))
else:
form = RepositoryUpdateForm(initial={'on_index': repo.on_index, 'is_private': repo.is_private,
'reader_group': list(repo.reader_group.all()),
'states': ' '.join([x.name for x in repo.archivestate_set.all()]),
'admin_group': list(repo.admin_group.all())})
template_values = {'form': form, 'repo': repo, 'upload_allowed': repo.upload_allowed(request)}
return render_to_response('moneta/modify_repo.html', template_values, RequestContext(request))
示例4: index
def index(self, request, rid, repo_slug=None, state_slug=''):
repo = get_object_or_404(Repository.reader_queryset(request), id=rid, archive_type=self.archive_type)
base_query = Element.objects.filter(repository=repo)
if state_slug:
state = get_object_or_404(ArchiveState, repository=repo, name=state_slug)
base_query = base_query.filter(states=state)
base_query = base_query.order_by('archive', 'version')
element_infos = []
for element in base_query:
if not element.extra_data:
continue
provider = json.loads(element.extra_data)['provider']
element_infos.append(
(element.name,
reverse('vagrant:get_box',
kwargs={'rid': rid, 'repo_slug': repo.slug, 'eid': element.id, 'provider': provider,
'archive': element.archive, 'version': element.version}),
element.sha1)
)
states = [state for state in ArchiveState.objects.filter(repository=repo).order_by('name')]
tab_infos = [(reverse('vagrant:index', kwargs={'rid': repo.id, 'state_slug': ''}),
ArchiveState(name=_('All states'), slug='all-states'), states, ''), ]
tab_infos += [(reverse('vagrant:index',
kwargs={'rid': repo.id, 'state_slug': state.slug}),
state, [state], state.slug)
for state in states]
# list of (relative URL, name, list of states, state_slug)
template_values = {'repo': repo, 'states': states, 'upload_allowed': repo.upload_allowed(request),
'state_slug': state_slug, 'elements': element_infos,
'index_url': reverse(moneta_url(repo, 'index'), kwargs={'rid': repo.id, }),
'tab_infos': tab_infos, 'admin_allowed': repo.admin_allowed(request), }
return render_to_response(self.index_html, template_values, RequestContext(request))
示例5: get_providers_by_version
def get_providers_by_version(self, request, rid, state_slug, archive):
repo = get_object_or_404(Repository.reader_queryset(request), id=rid, archive_type=self.archive_type)
base_query = Element.objects.filter(repository=repo, archive=archive)
if state_slug:
state = get_object_or_404(ArchiveState, repository=repo, name=state_slug)
base_query = base_query.filter(states=state)
versions = {}
for element in base_query:
metadata = json.loads(element.extra_data)
versions.setdefault(element.version, []).append({
'name': metadata['provider'],
'url': '%s%s' % (settings.SERVER_NAME, element.get_direct_link()),
'checksum_type': 'sha1',
'checksum': element.sha1})
result = {'name': archive, 'description': _('This box contains %(name)s') % {'name': archive},
'versions': [{'version': k, 'status': 'active', 'providers': v} for (k, v) in versions.items()]}
return result
# Vagrant.configure(2) do |config|
#
# config.vm.box = "{$relativePathInfo|escape}"
# config.vm.box_url = '<a href="{$CATALOG_URI|escape}{$pathInfo|escape}">{$CATALOG_URI|escape}{$pathInfo|escape}</a>'
#
# # Whatever other config stuff you want to do
# end
示例6: browse_repository
def browse_repository(self, request: HttpRequest, rid, repo_slug, query_string='', state_slug=None) -> HttpResponse:
repo = get_object_or_404(Repository.reader_queryset(request), id=rid, archive_type=self.archive_type)
result = self.browse_repo_inner(rid, query_string, state_slug=state_slug)
if isinstance(result, str): # sha1/sha256/md5
return HttpResponse(result)
elif isinstance(result, Element):
return get_file(request, eid=result.pk, element=result)
assert isinstance(result, dict)
new_query_string = ''
bread_crumbs = [(_('Root'), self.get_browse_url(repo, new_query_string, state_slug=state_slug))]
while len(result) == 1 and isinstance(result, dict):
path_component, result = result.popitem()
new_query_string += path_component + '/'
bread_crumbs.append((path_component, self.get_browse_url(repo, new_query_string, state_slug=state_slug)))
if isinstance(result, set):
url_list = []
for elt in result:
new_gavf_elt_filename = new_query_string + elt.filename
elt_url = self.get_browse_url(repo, new_gavf_elt_filename, state_slug=state_slug)
url_list += [(new_gavf_elt_filename, elt_url, elt.id),
(new_gavf_elt_filename + '.sha1', elt_url + '.sha1', None),
(new_gavf_elt_filename + '.sha256', elt_url + '.sha256', None),
(new_gavf_elt_filename + '.md5', elt_url + '.md5', None),
]
else:
assert isinstance(result, dict)
url_list = [(new_query_string + key,
self.get_browse_url(repo, new_query_string + key, state_slug=state_slug), None)
for key in result]
template_values = {'repo': repo, 'upload_allowed': repo.upload_allowed(request), 'repo_slug': repo_slug,
'admin': True, 'paths': url_list, 'request_path': new_query_string, 'state_slug': state_slug,
'bread_crumbs': bread_crumbs, }
status_code = 200 if url_list else 404
return TemplateResponse(request, 'repositories/maven3/browse.html', template_values, status=status_code)
示例7: add_element
def add_element(request: HttpRequest, rid):
repo = get_object_or_404(Repository.upload_queryset(request), id=rid)
class ElementForm(forms.Form):
package = forms.FileField(label=_('Package'))
states = forms.ModelMultipleChoiceField(repo.archivestate_set.all(), label=_('States'))
def clean(self):
data_ = super().clean()
if 'package' in self.cleaned_data:
if not repo.get_model().is_file_valid(self.cleaned_data['package']):
raise ValidationError(_('This repository is unable to handle this file.'))
return data_
if request.method == 'POST':
form = ElementForm(request.POST, files=request.FILES)
if form.is_valid():
try:
element = generic_add_element(request, repo, form.cleaned_data['package'],
[x.name for x in form.cleaned_data['states']])
messages.info(request, _('The package %(n)s has been successfully uploaded.') % {'n': element.filename})
except InvalidRepositoryException as e:
messages.error(request, _('Unable to add the package to this repository: %(msg)s.') % {'msg': str(e)})
return HttpResponseRedirect(reverse('moneta:add_element', kwargs={'rid': rid}))
else:
form = ElementForm()
template_values = {'form': form, 'repo': repo, 'upload_allowed': repo.upload_allowed(request)}
return render_to_response('moneta/add_package.html', template_values, RequestContext(request))
示例8: plugin_index
def plugin_index(self, request: HttpRequest, rid, repo_slug, state_slug=None):
# noinspection PyUnusedLocal
repo_slug = repo_slug
repo = get_object_or_404(Repository.reader_queryset(request), id=rid, archive_type=self.archive_type)
base_query = Element.objects.filter(repository=repo)
if state_slug:
state = get_object_or_404(ArchiveState, repository=repo, name=state_slug)
base_query = base_query.filter(states=state)
return TemplateResponse(request, 'repositories/jetbrains/updatePlugins.xml', {'elements': base_query},
content_type='application/xml')
示例9: index
def index(self, request, rid):
repo = get_object_or_404(Repository.reader_queryset(request), id=rid, archive_type=self.archive_type)
states = [state for state in ArchiveState.objects.filter(repository=repo).order_by('name')]
tab_infos = [(states, ArchiveState(name=_('All states'), slug='all-states')), ]
tab_infos += [([state], state) for state in states]
template_values = {'repo': repo, 'states': states, 'upload_allowed': repo.upload_allowed(request),
'index_url': reverse(moneta_url(repo, 'index'), kwargs={'rid': repo.id, }),
'tab_infos': tab_infos, 'admin_allowed': repo.admin_allowed(request), }
return TemplateResponse(request, self.index_html, template_values)
示例10: specs
def specs(self, request, rid, repo_slug, state_slug=None, filename='specs.4.8.gz'):
# noinspection PyUnusedLocal
repo_slug = repo_slug
repo = get_object_or_404(Repository.reader_queryset(request), id=rid, archive_type=self.archive_type)
if state_slug:
filename = 'specs/%(slug)s/%(filename)s' % {'slug': state_slug, 'filename': filename, }
else:
filename = 'specs/%(filename)s' % {'filename': filename, }
uid = self.storage_uid % repo.pk
key = storage(settings.STORAGE_CACHE).uid_to_key(uid)
return sendpath(settings.STORAGE_CACHE, key, filename, 'application/gzip')
示例11: download
def download(self, request, rid, repo_slug, state_slug=None, filename=None):
# noinspection PyUnusedLocal
repo_slug = repo_slug
repo = get_object_or_404(Repository.reader_queryset(request), id=rid, archive_type=self.archive_type)
base_query = Element.objects.filter(repository=repo)
if state_slug:
state = get_object_or_404(ArchiveState, repository=repo, name=state_slug)
base_query = base_query.filter(states=state)
element = get_object_or_404(base_query, filename=filename)
from moneta.views import get_file
return get_file(request, element.pk)
示例12: xr_package_releases
def xr_package_releases(request, rpc_args, self, rid, repo_slug, state_slug=None):
if len(rpc_args) == 0:
raise PermissionDenied
repo = get_object_or_404(Repository.reader_queryset(request), id=rid, archive_type=self.model)
if state_slug:
state = get_object_or_404(ArchiveState, repository=repo, name=state_slug)
query = Element.objects.filter(repository=repo, states=state, archive=rpc_args[0])
else:
query = Element.objects.filter(repository=repo, archive=rpc_args[0])
versions = [LooseVersion(x.version) for x in query]
versions.sort()
return [str(x) for x in versions]
示例13: index
def index(request: HttpRequest):
repositories = Repository.index_queryset(request).annotate(package_count=Count('element'))
if not request.user.has_perm('repository.add_repository'):
form = None
elif request.method == 'POST':
form = get_repository_form()(request.POST)
if form.is_valid():
author = None if request.user.is_anonymous() else request.user
repo = Repository(author=author, name=form.cleaned_data['name'], on_index=form.cleaned_data['on_index'],
archive_type=form.cleaned_data['archive_type'],
is_private=form.cleaned_data['is_private'])
repo.save()
for group in form.cleaned_data['admin_group']:
repo.admin_group.add(group)
for state in set(form.cleaned_data['states'].split()):
ArchiveState(repository=repo, name=state, author=author).save()
messages.info(request, _('Your new repository has been created.'))
return HttpResponseRedirect(reverse('moneta:index'))
else:
form = get_repository_form()()
# compute repos with admin rights
upload_ids = {x.id for x in Repository.upload_queryset(request)}
admin_ids = {x.id for x in Repository.admin_queryset(request)}
template_values = {'repositories': repositories, 'form': form, 'request': request,
'upload_ids': upload_ids, 'admin_ids': admin_ids, }
return render_to_response('moneta/index.html', template_values, RequestContext(request))
示例14: gem_specs
def gem_specs(self, request, rid, repo_slug, state_slug=None, filename=None):
name, sep, version = filename.rpartition('-')
if sep != '-':
raise Http404
# noinspection PyUnusedLocal
repo_slug = repo_slug
repo = get_object_or_404(Repository.reader_queryset(request), id=rid, archive_type=self.archive_type)
base_query = Element.objects.filter(repository=repo)
if state_slug:
state = get_object_or_404(ArchiveState, repository=repo, name=state_slug)
base_query = base_query.filter(states=state)
element = get_object_or_404(base_query, name=name, version=version)
return HttpResponse(self.yaml_data(element), content_type='text/yaml')
示例15: repodata_file
def repodata_file(self, request, rid, repo_slug, state_slug, arch, filename, compression):
if filename not in ('comps.xml', 'primary.xml', 'other.xml', 'filelists.xml', 'repomd.xml', ):
return HttpResponse(_('File not found'), status=404)
if compression and filename == 'repomd.xml':
return HttpResponse(_('File not found'), status=404)
# noinspection PyUnusedLocal
repo_slug = repo_slug
filename = self.index_filename(state_slug, arch, filename + compression)
mimetype = 'text/xml'
repo = get_object_or_404(Repository.reader_queryset(request), id=rid, archive_type=self.archive_type)
uid = self.storage_uid % repo.id
key = storage(settings.STORAGE_CACHE).uid_to_key(uid)
return sendpath(settings.STORAGE_CACHE, key, filename, mimetype)