diff options
author | Alexandru DAMIAN <alexandru.damian@intel.com> | 2014-08-12 10:56:42 +0100 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2014-08-29 13:56:49 +0100 |
commit | 565f69205f130644dee136c8296dd0dc979e492b (patch) | |
tree | 7b4588b88656c13401e8f0341e73fcb8e8045321 /bitbake/lib/toaster/toastergui/views.py | |
parent | 3a4356dbfea07088b38881abe2c2b5d6bb6c7cf7 (diff) | |
download | poky-565f69205f130644dee136c8296dd0dc979e492b.tar.gz |
bitbake: toaster: add all layers page
We add a page where the user can browse
and import layers from all the layers known
by Toaster.
[YOCTO #6590]
(Bitbake rev: 59f4a9750a6c4f5360a91e3a4d1c03ceb42da086)
Signed-off-by: Alexandru DAMIAN <alexandru.damian@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake/lib/toaster/toastergui/views.py')
-rwxr-xr-x | bitbake/lib/toaster/toastergui/views.py | 74 |
1 files changed, 73 insertions, 1 deletions
diff --git a/bitbake/lib/toaster/toastergui/views.py b/bitbake/lib/toaster/toastergui/views.py index cad23570f8..5b2336509a 100755 --- a/bitbake/lib/toaster/toastergui/views.py +++ b/bitbake/lib/toaster/toastergui/views.py | |||
@@ -1849,6 +1849,9 @@ if toastermain.settings.MANAGED: | |||
1849 | except User.DoesNotExist: | 1849 | except User.DoesNotExist: |
1850 | puser = None | 1850 | puser = None |
1851 | 1851 | ||
1852 | # we use implicit knowledge of the current user's project to filter layer information, e.g. | ||
1853 | request.session['project'] = prj | ||
1854 | |||
1852 | context = { | 1855 | context = { |
1853 | "project" : prj, | 1856 | "project" : prj, |
1854 | #"buildrequests" : prj.buildrequest_set.filter(state=BuildRequest.REQ_QUEUED), | 1857 | #"buildrequests" : prj.buildrequest_set.filter(state=BuildRequest.REQ_QUEUED), |
@@ -1926,7 +1929,76 @@ if toastermain.settings.MANAGED: | |||
1926 | raise Exception("TODO: implement page #6595") | 1929 | raise Exception("TODO: implement page #6595") |
1927 | 1930 | ||
1928 | def layers(request): | 1931 | def layers(request): |
1929 | raise Exception("TODO: implement page #6590") | 1932 | # "TODO: implement page #6590" |
1933 | template = "layers.html" | ||
1934 | # define here what parameters the view needs in the GET portion in order to | ||
1935 | # be able to display something. 'count' and 'page' are mandatory for all views | ||
1936 | # that use paginators. | ||
1937 | mandatory_parameters = { 'count': 10, 'page' : 1, 'orderby' : 'layer__name:-' }; | ||
1938 | retval = _verify_parameters( request.GET, mandatory_parameters ) | ||
1939 | if retval: | ||
1940 | return _redirect_parameters( 'layers', request.GET, mandatory_parameters) | ||
1941 | |||
1942 | # boilerplate code that takes a request for an object type and returns a queryset | ||
1943 | # for that object type. copypasta for all needed table searches | ||
1944 | (filter_string, search_term, ordering_string) = _search_tuple(request, Layer_Version) | ||
1945 | |||
1946 | queryset_all = Layer_Version.objects.all() | ||
1947 | if 'project' in request.session: | ||
1948 | queryset_all = queryset_all.filter(up_branch = request.session['project'].branch) | ||
1949 | |||
1950 | queryset_with_search = _get_queryset(Layer_Version, queryset_all, None, search_term, ordering_string, '-layer__name') | ||
1951 | queryset = _get_queryset(Layer_Version, queryset_all, filter_string, search_term, ordering_string, '-layer__name') | ||
1952 | |||
1953 | # retrieve the objects that will be displayed in the table; layers a paginator and gets a page range to display | ||
1954 | layer_info = _build_page_range(Paginator(queryset, request.GET.get('count', 10)),request.GET.get('page', 1)) | ||
1955 | |||
1956 | |||
1957 | context = { | ||
1958 | 'objects' : layer_info, | ||
1959 | 'objectname' : "layers", | ||
1960 | 'default_orderby' : 'completed_on:-', | ||
1961 | |||
1962 | 'tablecols' : [ | ||
1963 | { 'name': 'Layer', | ||
1964 | 'orderfield': _get_toggle_order(request, "layer__name"), | ||
1965 | 'ordericon' : _get_toggle_order_icon(request, "layer__name"), | ||
1966 | }, | ||
1967 | { 'name': 'Description', | ||
1968 | 'dclass': 'span4', | ||
1969 | }, | ||
1970 | { 'name': 'Layer source', | ||
1971 | 'qhelp': "Where the layer is coming from, for example, if it's part of the OpenEmbedded collection of layers or if it's a layer you have imported", | ||
1972 | 'orderfield': _get_toggle_order(request, "layer_source__name"), | ||
1973 | 'ordericon': _get_toggle_order_icon(request, "layer_source__name"), | ||
1974 | 'filter': { | ||
1975 | 'class': 'layer', | ||
1976 | 'label': 'Show:', | ||
1977 | 'options': map(lambda x: (x.name, 'layer_source__pk:' + str(x.id), queryset_with_search.filter(layer_source__pk = x.id).count() ), LayerSource.objects.all()), | ||
1978 | } | ||
1979 | }, | ||
1980 | { 'name': 'Git repository URL', | ||
1981 | 'dclass': 'span6', | ||
1982 | 'qhelp': "The Git repository for the layer source code", | ||
1983 | }, | ||
1984 | { 'name': 'Subdirectory', | ||
1985 | 'qhelp': "The layer directory within the Git repository", | ||
1986 | }, | ||
1987 | { 'name': 'Branch, tag o commit', | ||
1988 | 'qhelp': "The Git branch of the layer. For the layers from the OpenEmbedded source, the branch matches the Yocto Project version you selected for this project", | ||
1989 | }, | ||
1990 | { 'name': 'Dependencies', | ||
1991 | 'qhelp': "Other layers a layer depends upon", | ||
1992 | }, | ||
1993 | { 'name': 'Add | Delete', | ||
1994 | 'dclass': 'span2', | ||
1995 | 'qhelp': "Add or delete layers to / from your project ", | ||
1996 | }, | ||
1997 | |||
1998 | ] | ||
1999 | } | ||
2000 | |||
2001 | return render(request, template, context) | ||
1930 | 2002 | ||
1931 | def layerdetails(request, layerid): | 2003 | def layerdetails(request, layerid): |
1932 | raise Exception("TODO: implement page #6591") | 2004 | raise Exception("TODO: implement page #6591") |