Compare commits
10 Commits
74bfaed558
...
v25.1.14
Author | SHA1 | Date | |
---|---|---|---|
7accacd5fd | |||
10fecc63e9
|
|||
368e248efc | |||
a71b1f783e
|
|||
77531b1948
|
|||
![]() |
2bf2fa235f | ||
![]() |
87a0d37953 | ||
![]() |
4210a46f9a | ||
![]() |
bd4d50b84e | ||
![]() |
fcd473608c |
@@ -42,4 +42,4 @@ services:
|
|||||||
ports:
|
ports:
|
||||||
- "8080:80"
|
- "8080:80"
|
||||||
volumes:
|
volumes:
|
||||||
- ./nginx.conf:/config/nginx/site-confs/default.conf:ro
|
- ./nginx.conf:/config/nginx/site-confs/default.conf
|
@@ -8,7 +8,7 @@ fi
|
|||||||
|
|
||||||
printf "downloadpackages.sh\nusing %s/\$repo/os/\$arch for mirror.\n" "$mirror"
|
printf "downloadpackages.sh\nusing %s/\$repo/os/\$arch for mirror.\n" "$mirror"
|
||||||
|
|
||||||
repos="system world galaxy lib32 system-gremlins world-gremlins galaxy-gremlins lib32-gremlins"
|
repos="system world galaxy lib32 system-gremlins world-gremlins galaxy-gremlins lib32-gremlins system-goblins world-goblins galaxy-goblins lib32-goblins"
|
||||||
|
|
||||||
mkdir -p ./archives
|
mkdir -p ./archives
|
||||||
|
|
||||||
|
@@ -11,6 +11,18 @@
|
|||||||
"testing": true
|
"testing": true
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"pk": 15,
|
||||||
|
"model": "main.repo",
|
||||||
|
"fields": {
|
||||||
|
"bugs_category": 33,
|
||||||
|
"staging": true,
|
||||||
|
"name": "Extra-Staging",
|
||||||
|
"bugs_project": 5,
|
||||||
|
"svn_root": "packages",
|
||||||
|
"testing": false
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"pk": 1,
|
"pk": 1,
|
||||||
"model": "main.repo",
|
"model": "main.repo",
|
||||||
@@ -118,5 +130,17 @@
|
|||||||
"svn_root": "packages",
|
"svn_root": "packages",
|
||||||
"testing": true
|
"testing": true
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pk": 16,
|
||||||
|
"model": "main.repo",
|
||||||
|
"fields": {
|
||||||
|
"bugs_category": 10,
|
||||||
|
"staging": true,
|
||||||
|
"name": "Core-Staging",
|
||||||
|
"bugs_project": 1,
|
||||||
|
"svn_root": "packages",
|
||||||
|
"testing": false
|
||||||
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
"fields": {
|
"fields": {
|
||||||
"bugs_category": 0,
|
"bugs_category": 0,
|
||||||
"staging": false,
|
"staging": false,
|
||||||
"name": "World-Gremlins",
|
"name": "world-gremlins",
|
||||||
"bugs_project": 0,
|
"bugs_project": 0,
|
||||||
"svn_root": "packages",
|
"svn_root": "packages",
|
||||||
"testing": true
|
"testing": true
|
||||||
@@ -17,7 +17,7 @@
|
|||||||
"fields": {
|
"fields": {
|
||||||
"bugs_category": 0,
|
"bugs_category": 0,
|
||||||
"staging": false,
|
"staging": false,
|
||||||
"name": "Galaxy-Gremlins",
|
"name": "galaxy-gremlins",
|
||||||
"bugs_project": 0,
|
"bugs_project": 0,
|
||||||
"svn_root": "packages",
|
"svn_root": "packages",
|
||||||
"testing": true
|
"testing": true
|
||||||
@@ -29,7 +29,7 @@
|
|||||||
"fields": {
|
"fields": {
|
||||||
"bugs_category": 0,
|
"bugs_category": 0,
|
||||||
"staging": false,
|
"staging": false,
|
||||||
"name": "System",
|
"name": "system",
|
||||||
"bugs_project": 0,
|
"bugs_project": 0,
|
||||||
"svn_root": "packages",
|
"svn_root": "packages",
|
||||||
"testing": false
|
"testing": false
|
||||||
@@ -41,7 +41,7 @@
|
|||||||
"fields": {
|
"fields": {
|
||||||
"bugs_category": 0,
|
"bugs_category": 0,
|
||||||
"staging": false,
|
"staging": false,
|
||||||
"name": "World",
|
"name": "world",
|
||||||
"bugs_project": 0,
|
"bugs_project": 0,
|
||||||
"svn_root": "packages",
|
"svn_root": "packages",
|
||||||
"testing": false
|
"testing": false
|
||||||
@@ -53,7 +53,7 @@
|
|||||||
"fields": {
|
"fields": {
|
||||||
"bugs_category": 0,
|
"bugs_category": 0,
|
||||||
"staging": false,
|
"staging": false,
|
||||||
"name": "Galaxy",
|
"name": "galaxy",
|
||||||
"bugs_project": 0,
|
"bugs_project": 0,
|
||||||
"svn_root": "packages",
|
"svn_root": "packages",
|
||||||
"testing": false
|
"testing": false
|
||||||
@@ -65,7 +65,7 @@
|
|||||||
"fields": {
|
"fields": {
|
||||||
"bugs_category": 0,
|
"bugs_category": 0,
|
||||||
"staging": false,
|
"staging": false,
|
||||||
"name": "Lib32",
|
"name": "lib32",
|
||||||
"bugs_project": 0,
|
"bugs_project": 0,
|
||||||
"svn_root": "packages",
|
"svn_root": "packages",
|
||||||
"testing": false
|
"testing": false
|
||||||
@@ -77,7 +77,7 @@
|
|||||||
"fields": {
|
"fields": {
|
||||||
"bugs_category": 0,
|
"bugs_category": 0,
|
||||||
"staging": false,
|
"staging": false,
|
||||||
"name": "Lib32-Gremlins",
|
"name": "lib32-gremlins",
|
||||||
"bugs_project": 0,
|
"bugs_project": 0,
|
||||||
"svn_root": "packages",
|
"svn_root": "packages",
|
||||||
"testing": true
|
"testing": true
|
||||||
@@ -89,10 +89,58 @@
|
|||||||
"fields": {
|
"fields": {
|
||||||
"bugs_category": 0,
|
"bugs_category": 0,
|
||||||
"staging": false,
|
"staging": false,
|
||||||
"name": "System-Gremlins",
|
"name": "system-gremlins",
|
||||||
"bugs_project": 0,
|
"bugs_project": 0,
|
||||||
"svn_root": "packages",
|
"svn_root": "packages",
|
||||||
"testing": true
|
"testing": true
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pk": 9,
|
||||||
|
"model": "main.repo",
|
||||||
|
"fields": {
|
||||||
|
"bugs_category": 0,
|
||||||
|
"staging": true,
|
||||||
|
"name": "system-goblins",
|
||||||
|
"bugs_project": 0,
|
||||||
|
"svn_root": "packages",
|
||||||
|
"testing": false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pk": 10,
|
||||||
|
"model": "main.repo",
|
||||||
|
"fields": {
|
||||||
|
"bugs_category": 0,
|
||||||
|
"staging": true,
|
||||||
|
"name": "world-goblins",
|
||||||
|
"bugs_project": 0,
|
||||||
|
"svn_root": "packages",
|
||||||
|
"testing": false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pk": 11,
|
||||||
|
"model": "main.repo",
|
||||||
|
"fields": {
|
||||||
|
"bugs_category": 0,
|
||||||
|
"staging": true,
|
||||||
|
"name": "galaxy-goblins",
|
||||||
|
"bugs_project": 0,
|
||||||
|
"svn_root": "packages",
|
||||||
|
"testing": false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"pk": 12,
|
||||||
|
"model": "main.repo",
|
||||||
|
"fields": {
|
||||||
|
"bugs_category": 0,
|
||||||
|
"staging": true,
|
||||||
|
"name": "lib32-goblins",
|
||||||
|
"bugs_project": 0,
|
||||||
|
"svn_root": "packages",
|
||||||
|
"testing": false
|
||||||
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
@@ -52,7 +52,7 @@ def create_specification(package, log, finder):
|
|||||||
return spec
|
return spec
|
||||||
|
|
||||||
|
|
||||||
def get_last_log(repo, pkgbase):
|
def get_tag_info(repo, pkgbase, version):
|
||||||
# Gitlab requires the path to the gitlab repo to be html encoded and project name encoded in a different special way
|
# Gitlab requires the path to the gitlab repo to be html encoded and project name encoded in a different special way
|
||||||
pkgrepo = urllib.parse.quote_plus(f'{settings.GITLAB_PACKAGE_REPO}/') + gitlab_project_name_to_path(pkgbase)
|
pkgrepo = urllib.parse.quote_plus(f'{settings.GITLAB_PACKAGE_REPO}/') + gitlab_project_name_to_path(pkgbase)
|
||||||
url = f'https://{settings.GITLAB_INSTANCE}/api/v4/projects/{pkgrepo}/repository/tags'
|
url = f'https://{settings.GITLAB_INSTANCE}/api/v4/projects/{pkgrepo}/repository/tags'
|
||||||
@@ -65,8 +65,12 @@ def get_last_log(repo, pkgbase):
|
|||||||
return None
|
return None
|
||||||
|
|
||||||
tags = r.json()
|
tags = r.json()
|
||||||
|
|
||||||
|
# filter out unrelated tags
|
||||||
|
tags = [tag for tag in tags if tag["name"] == version]
|
||||||
|
|
||||||
if len(tags) == 0:
|
if len(tags) == 0:
|
||||||
logger.error("No tags found for pkgbase %s (%s)", pkgbase, repo)
|
logger.error("No tags found for pkgbase %s (%s) version %s", pkgbase, repo, version)
|
||||||
return None
|
return None
|
||||||
|
|
||||||
tag = tags[0]
|
tag = tags[0]
|
||||||
@@ -89,7 +93,7 @@ def add_signoff_comments():
|
|||||||
if not group.default_spec:
|
if not group.default_spec:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
log = get_last_log(group.repo, group.pkgbase)
|
log = get_tag_info(group.repo, group.pkgbase, group.version)
|
||||||
if log is None:
|
if log is None:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
|
@@ -26,9 +26,9 @@ class RematchDeveloperTest(TransactionTestCase):
|
|||||||
self.package.delete()
|
self.package.delete()
|
||||||
|
|
||||||
def test_basic(self):
|
def test_basic(self):
|
||||||
with mock.patch('packages.management.commands.populate_signoffs.get_last_log') as get_last_log:
|
with mock.patch('packages.management.commands.populate_signoffs.get_tag_info') as get_tag_info:
|
||||||
comment = 'upgpkg: 0.1-1: rebuild'
|
comment = 'upgpkg: 0.1-1: rebuild'
|
||||||
get_last_log.return_value = {'message': f'{comment}\n', 'author': 'foo@archlinux.org'}
|
get_tag_info.return_value = {'message': f'{comment}\n', 'author': 'foo@archlinux.org'}
|
||||||
call_command('populate_signoffs')
|
call_command('populate_signoffs')
|
||||||
|
|
||||||
signoff_spec = SignoffSpecification.objects.first()
|
signoff_spec = SignoffSpecification.objects.first()
|
||||||
@@ -36,8 +36,8 @@ class RematchDeveloperTest(TransactionTestCase):
|
|||||||
assert signoff_spec.pkgbase == self.package.pkgbase
|
assert signoff_spec.pkgbase == self.package.pkgbase
|
||||||
|
|
||||||
def test_invalid(self):
|
def test_invalid(self):
|
||||||
with mock.patch('packages.management.commands.populate_signoffs.get_last_log') as get_last_log:
|
with mock.patch('packages.management.commands.populate_signoffs.get_tag_info') as get_tag_info:
|
||||||
get_last_log.return_value = None
|
get_tag_info.return_value = None
|
||||||
call_command('populate_signoffs')
|
call_command('populate_signoffs')
|
||||||
|
|
||||||
assert SignoffSpecification.objects.count() == 0
|
assert SignoffSpecification.objects.count() == 0
|
||||||
|
@@ -8,7 +8,7 @@ fi
|
|||||||
|
|
||||||
printf "populatepackages.sh\nretrieving package files from %s\n" "$path"
|
printf "populatepackages.sh\nretrieving package files from %s\n" "$path"
|
||||||
|
|
||||||
repos="system world galaxy lib32 system-gremlins world-gremlins galaxy-gremlins lib32-gremlins"
|
repos="system world galaxy lib32 system-gremlins world-gremlins galaxy-gremlins lib32-gremlins system-goblins world-goblins galaxy-goblins lib32-goblins"
|
||||||
|
|
||||||
for repo in $repos
|
for repo in $repos
|
||||||
do
|
do
|
||||||
|
@@ -7,14 +7,14 @@ django-countries==7.6.1
|
|||||||
django-extensions==3.2.3
|
django-extensions==3.2.3
|
||||||
jsmin==3.0.1
|
jsmin==3.0.1
|
||||||
pgpdump==1.5
|
pgpdump==1.5
|
||||||
parse==1.19.0
|
parse==1.20.2
|
||||||
sqlparse==0.5.0
|
sqlparse==0.5.0
|
||||||
django-csp==3.7
|
django-csp==3.8
|
||||||
ptpython==2.0.4
|
ptpython==2.0.4
|
||||||
feedparser==6.0.10
|
feedparser==6.0.11
|
||||||
bleach==6.0.0
|
bleach==6.0.0
|
||||||
requests==2.32.0
|
requests==2.32.3
|
||||||
xtarfile==0.1.0
|
xtarfile==0.2.1
|
||||||
zstandard==0.17.0
|
zstandard==0.23.0
|
||||||
whitenoise==6.7.0
|
whitenoise==6.8.2
|
||||||
django-prometheus==2.3.1
|
django-prometheus==2.3.1
|
||||||
|
@@ -754,6 +754,10 @@ table.results {
|
|||||||
text-align: center;
|
text-align: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.results [hidden] {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
/* pkglist: layout */
|
/* pkglist: layout */
|
||||||
#pkglist-about {
|
#pkglist-about {
|
||||||
margin-top: 1.5em;
|
margin-top: 1.5em;
|
||||||
@@ -1056,12 +1060,12 @@ table td.country {
|
|||||||
background: #ffd;
|
background: #ffd;
|
||||||
}
|
}
|
||||||
|
|
||||||
.results tr:nth-child(even),
|
.results tr:nth-child(even of :not([hidden])),
|
||||||
#article-list tr:nth-child(even) {
|
#article-list tr:nth-child(even) {
|
||||||
background: #e4eeff;
|
background: #e4eeff;
|
||||||
}
|
}
|
||||||
|
|
||||||
.results tr:nth-child(odd),
|
.results tr:nth-child(odd of :not([hidden])),
|
||||||
#article-list tr:nth-child(odd) {
|
#article-list tr:nth-child(odd) {
|
||||||
background: #fff;
|
background: #fff;
|
||||||
}
|
}
|
||||||
|
@@ -212,8 +212,14 @@ function filter_pkgs_list(filter_ele, tbody_ele) {
|
|||||||
rows = rows.has('.incomplete');
|
rows = rows.has('.incomplete');
|
||||||
}
|
}
|
||||||
/* hide all rows, then show the set we care about */
|
/* hide all rows, then show the set we care about */
|
||||||
all_rows.hide();
|
// note that we don't use .hide() from jQuery because it adds display:none
|
||||||
rows.show();
|
// which is very expensive to query in CSS ([style*="display: none"])
|
||||||
|
all_rows.each(function() {
|
||||||
|
$(this).attr('hidden', true);
|
||||||
|
});
|
||||||
|
rows.each(function() {
|
||||||
|
$(this).removeAttr('hidden');
|
||||||
|
});
|
||||||
$('#filter-count').text(rows.length);
|
$('#filter-count').text(rows.length);
|
||||||
/* make sure we update the odd/even styling from sorting */
|
/* make sure we update the odd/even styling from sorting */
|
||||||
$('.results').trigger('applyWidgets', [false]);
|
$('.results').trigger('applyWidgets', [false]);
|
||||||
@@ -330,8 +336,14 @@ function filter_signoffs() {
|
|||||||
rows = rows.has('td.signoff-no');
|
rows = rows.has('td.signoff-no');
|
||||||
}
|
}
|
||||||
/* hide all rows, then show the set we care about */
|
/* hide all rows, then show the set we care about */
|
||||||
all_rows.hide();
|
// note that we don't use .hide() from jQuery because it adds display:none
|
||||||
rows.show();
|
// which is very expensive to query in CSS ([style*="display: none"])
|
||||||
|
all_rows.each(function() {
|
||||||
|
$(this).attr('hidden', true);
|
||||||
|
});
|
||||||
|
rows.each(function() {
|
||||||
|
$(this).removeAttr('hidden');
|
||||||
|
});
|
||||||
$('#filter-count').text(rows.length);
|
$('#filter-count').text(rows.length);
|
||||||
/* make sure we update the odd/even styling from sorting */
|
/* make sure we update the odd/even styling from sorting */
|
||||||
$('.results').trigger('applyWidgets', [false]);
|
$('.results').trigger('applyWidgets', [false]);
|
||||||
|
@@ -36,8 +36,8 @@
|
|||||||
{% endif %}{% endwith %}</td>
|
{% endif %}{% endwith %}</td>
|
||||||
<td>{{ pkg.repo.name }}</td>
|
<td>{{ pkg.repo.name }}</td>
|
||||||
<td>{{ pkg.arch.name }}</td>
|
<td>{{ pkg.arch.name }}</td>
|
||||||
<td>{{ pkg.flag_date|date }}</td>
|
<td>{{ pkg.flag_date|date:"Y-m-d" }}</td>
|
||||||
<td>{{ pkg.last_update|date }}</td>
|
<td>{{ pkg.last_update|date:"Y-m-d" }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
{% empty %}
|
{% empty %}
|
||||||
<tr class="empty"><td colspan="7"><em>No flagged packages to display</em></td></tr>
|
<tr class="empty"><td colspan="7"><em>No flagged packages to display</em></td></tr>
|
||||||
@@ -68,7 +68,7 @@
|
|||||||
<td>{{ group.version }}</td>
|
<td>{{ group.version }}</td>
|
||||||
<td>{{ group.arch.name }}</td>
|
<td>{{ group.arch.name }}</td>
|
||||||
<td>{{ group.target_repo }}</td>
|
<td>{{ group.target_repo }}</td>
|
||||||
<td>{{ group.last_update|date }}</td>
|
<td>{{ group.last_update|date:"Y-m-d" }}</td>
|
||||||
{% if group.specification.known_bad %}
|
{% if group.specification.known_bad %}
|
||||||
<td class="approval signoff-bad">Bad</td>
|
<td class="approval signoff-bad">Bad</td>
|
||||||
{% else %}
|
{% else %}
|
||||||
@@ -138,7 +138,7 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td class="wrap"><a href="{{ todo.get_absolute_url }}"
|
<td class="wrap"><a href="{{ todo.get_absolute_url }}"
|
||||||
title="View todo list: {{ todo.name }}">{{ todo.name }}</a></td>
|
title="View todo list: {{ todo.name }}">{{ todo.name }}</a></td>
|
||||||
<td>{{ todo.created|date }}</td>
|
<td>{{ todo.created|date:"Y-m-d" }}</td>
|
||||||
<td>{{ todo.creator.get_full_name }}</td>
|
<td>{{ todo.creator.get_full_name }}</td>
|
||||||
<td>{{ todo.pkg_count }}</td>
|
<td>{{ todo.pkg_count }}</td>
|
||||||
<td>{{ todo.incomplete_count }}</td>
|
<td>{{ todo.incomplete_count }}</td>
|
||||||
|
@@ -60,9 +60,9 @@
|
|||||||
{% else %}
|
{% else %}
|
||||||
<td>{{ pkg.full_version }}</td>
|
<td>{{ pkg.full_version }}</td>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<td>{{ pkg.last_update|date }}</td>
|
<td>{{ pkg.last_update|date:"Y-m-d" }}</td>
|
||||||
<td>{{ pkg.build_date|date }}</td>
|
<td>{{ pkg.build_date|date:"Y-m-d" }}</td>
|
||||||
<td>{{ pkg.flag_date|date }}</td>
|
<td>{{ pkg.flag_date|date:"Y-m-d" }}</td>
|
||||||
{% for attr in column_attrs %}
|
{% for attr in column_attrs %}
|
||||||
<td>{{ pkg|attribute:attr }}</td>
|
<td>{{ pkg|attribute:attr }}</td>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
@@ -33,7 +33,7 @@
|
|||||||
<tbody>
|
<tbody>
|
||||||
{% for item in news_list %}
|
{% for item in news_list %}
|
||||||
<tr>
|
<tr>
|
||||||
<td>{{ item.postdate|date }}</td>
|
<td>{{ item.postdate|date:"Y-m-d" }}</td>
|
||||||
<td class="wrap"><a href="{{ item.get_absolute_url }}"
|
<td class="wrap"><a href="{{ item.get_absolute_url }}"
|
||||||
title="View: {{ item.title }}">{{ item.title }}</a></td>
|
title="View: {{ item.title }}">{{ item.title }}</a></td>
|
||||||
<td>{{ item.author.get_full_name }}</td>
|
<td>{{ item.author.get_full_name }}</td>
|
||||||
|
@@ -25,7 +25,7 @@
|
|||||||
</ul>
|
</ul>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
<p class="article-info">{{ news.postdate|date }} - {{ news.author.get_full_name }}</p>
|
<p class="article-info">{{ news.postdate|date:"Y-m-d" }} - {{ news.author.get_full_name }}</p>
|
||||||
|
|
||||||
<div class="article-content" itemprop="articleBody">{{ news.html }}</div>
|
<div class="article-content" itemprop="articleBody">{{ news.html }}</div>
|
||||||
</div>
|
</div>
|
||||||
|
@@ -29,8 +29,8 @@
|
|||||||
<td><span{% if pkg2.flag_date %} class="flagged"{% endif %}>{{ pkg2.full_version }}</span></td>
|
<td><span{% if pkg2.flag_date %} class="flagged"{% endif %}>{{ pkg2.full_version }}</span></td>
|
||||||
<td>{% pkg_details_link pkg2 %}</td>
|
<td>{% pkg_details_link pkg2 %}</td>
|
||||||
<td>{{ pkg2.repo }}</td>
|
<td>{{ pkg2.repo }}</td>
|
||||||
<td>{{ pkg1.last_update|date }}</td>
|
<td>{{ pkg1.last_update|date:"Y-m-d" }}</td>
|
||||||
<td>{{ pkg2.last_update|date }}</td>
|
<td>{{ pkg2.last_update|date:"Y-m-d" }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</tbody>
|
</tbody>
|
||||||
|
@@ -23,7 +23,7 @@
|
|||||||
<td><a href="/groups/{{ grp.arch }}/{{ grp.name }}/"
|
<td><a href="/groups/{{ grp.arch }}/{{ grp.name }}/"
|
||||||
title="Group details for {{ grp.name }}">{{ grp.name }}</a></td>
|
title="Group details for {{ grp.name }}">{{ grp.name }}</a></td>
|
||||||
<td>{{ grp.count }}</td>
|
<td>{{ grp.count }}</td>
|
||||||
<td>{{ grp.last_update|date }}</td>
|
<td>{{ grp.last_update|date:"Y-m-d" }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</tbody>
|
</tbody>
|
||||||
|
@@ -30,7 +30,7 @@
|
|||||||
</li>
|
</li>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if pkg.flag_date %}
|
{% if pkg.flag_date %}
|
||||||
<li><span class="flagged">Flagged out-of-date on {{ pkg.flag_date|date }}</span></li>
|
<li><span class="flagged">Flagged out-of-date on {{ pkg.flag_date|date:"Y-m-d" }}</span></li>
|
||||||
{% with tp=pkg.in_testing %}{% if tp %}
|
{% with tp=pkg.in_testing %}{% if tp %}
|
||||||
<li><span class="flagged">Version
|
<li><span class="flagged">Version
|
||||||
<a href="{{ tp.get_absolute_url }}"
|
<a href="{{ tp.get_absolute_url }}"
|
||||||
@@ -98,8 +98,8 @@
|
|||||||
title="Browse packages for {{ pkg.arch.name }} architecture">{{ pkg.arch.name }}</a></td>
|
title="Browse packages for {{ pkg.arch.name }} architecture">{{ pkg.arch.name }}</a></td>
|
||||||
</tr><tr>
|
</tr><tr>
|
||||||
<th>Repository:</th>
|
<th>Repository:</th>
|
||||||
<td><a href="/packages/?repo={{ pkg.repo.name|capfirst }}"
|
<td><a href="/packages/?repo={{ pkg.repo.name }}"
|
||||||
title="Browse the {{ pkg.repo.name|capfirst }} repository">{{ pkg.repo.name|capfirst }}</a></td>
|
title="Browse the {{ pkg.repo.name }} repository">{{ pkg.repo.name }}</a></td>
|
||||||
</tr>
|
</tr>
|
||||||
{% if pkg.pkgname == pkg.pkgbase %}
|
{% if pkg.pkgname == pkg.pkgbase %}
|
||||||
{% with splits=pkg.split_packages %}{% if splits %}
|
{% with splits=pkg.split_packages %}{% if splits %}
|
||||||
@@ -213,7 +213,7 @@
|
|||||||
{% endif %}
|
{% endif %}
|
||||||
{% if user.is_authenticated %}{% with flag_request=pkg.flag_request %}{% if flag_request %}<tr>
|
{% if user.is_authenticated %}{% with flag_request=pkg.flag_request %}{% if flag_request %}<tr>
|
||||||
<th>Last Flag Request:</th>
|
<th>Last Flag Request:</th>
|
||||||
<td class="wrap">From {{ flag_request.who }} on {{ flag_request.created|date }}:<br/>
|
<td class="wrap">From {{ flag_request.who }} on {{ flag_request.created|date:"Y-m-d" }}:<br/>
|
||||||
<div class="userdata">{{ flag_request.message|linebreaksbr|default:"{no message}" }}</div></td>
|
<div class="userdata">{{ flag_request.message|linebreaksbr|default:"{no message}" }}</div></td>
|
||||||
</tr>{% endif %}{% endwith %}{% endif %}
|
</tr>{% endif %}{% endwith %}{% endif %}
|
||||||
</table>
|
</table>
|
||||||
|
@@ -33,8 +33,8 @@
|
|||||||
<td>{{ pkg.full_version }}</td>
|
<td>{{ pkg.full_version }}</td>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<td class="wrap">{{ pkg.pkgdesc }}</td>
|
<td class="wrap">{{ pkg.pkgdesc }}</td>
|
||||||
<td>{{ pkg.last_update|date }}</td>
|
<td>{{ pkg.last_update|date:"Y-m-d" }}</td>
|
||||||
<td>{{ pkg.flag_date|date }}</td>
|
<td>{{ pkg.flag_date|date:"Y-m-d" }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</tbody>
|
</tbody>
|
||||||
|
@@ -62,7 +62,7 @@
|
|||||||
{% for pkg in exact_matches %}
|
{% for pkg in exact_matches %}
|
||||||
<tr>
|
<tr>
|
||||||
<td>{{ pkg.arch.name }}</td>
|
<td>{{ pkg.arch.name }}</td>
|
||||||
<td>{{ pkg.repo.name|capfirst }}</td>
|
<td>{{ pkg.repo.name }}</td>
|
||||||
<td>{% pkg_details_link pkg %}</td>
|
<td>{% pkg_details_link pkg %}</td>
|
||||||
{% if pkg.flag_date %}
|
{% if pkg.flag_date %}
|
||||||
<td><span class="flagged" title="Flagged out-of-date">{{ pkg.full_version }}</span></td>
|
<td><span class="flagged" title="Flagged out-of-date">{{ pkg.full_version }}</span></td>
|
||||||
@@ -70,8 +70,8 @@
|
|||||||
<td>{{ pkg.full_version }}</td>
|
<td>{{ pkg.full_version }}</td>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<td class="wrap">{{ pkg.pkgdesc }}</td>
|
<td class="wrap">{{ pkg.pkgdesc }}</td>
|
||||||
<td>{{ pkg.last_update|date }}</td>
|
<td>{{ pkg.last_update|date:"Y-m-d" }}</td>
|
||||||
<td>{{ pkg.flag_date|date }}</td>
|
<td>{{ pkg.flag_date|date:"Y-m-d" }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</tbody>
|
</tbody>
|
||||||
@@ -109,7 +109,7 @@
|
|||||||
<td><input type="checkbox" name="pkgid" value="{{ pkg.id }}" /></td>
|
<td><input type="checkbox" name="pkgid" value="{{ pkg.id }}" /></td>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<td>{{ pkg.arch.name }}</td>
|
<td>{{ pkg.arch.name }}</td>
|
||||||
<td>{{ pkg.repo.name|capfirst }}</td>
|
<td>{{ pkg.repo.name }}</td>
|
||||||
<td>{% pkg_details_link pkg %}</td>
|
<td>{% pkg_details_link pkg %}</td>
|
||||||
{% if pkg.flag_date %}
|
{% if pkg.flag_date %}
|
||||||
<td><span class="flagged" title="Flagged out-of-date">{{ pkg.full_version }}</span></td>
|
<td><span class="flagged" title="Flagged out-of-date">{{ pkg.full_version }}</span></td>
|
||||||
@@ -117,8 +117,8 @@
|
|||||||
<td>{{ pkg.full_version }}</td>
|
<td>{{ pkg.full_version }}</td>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<td class="wrap">{{ pkg.pkgdesc }}</td>
|
<td class="wrap">{{ pkg.pkgdesc }}</td>
|
||||||
<td>{{ pkg.last_update|date }}</td>
|
<td>{{ pkg.last_update|date:"Y-m-d" }}</td>
|
||||||
<td>{{ pkg.flag_date|date }}</td>
|
<td>{{ pkg.flag_date|date:"Y-m-d" }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
{% empty %}
|
{% empty %}
|
||||||
<tr class="empty"><td colspan="{% if perms.main.change_package %}8{% else %}7{% endif %}"><em>No matching packages found</em></td></tr>
|
<tr class="empty"><td colspan="{% if perms.main.change_package %}8{% else %}7{% endif %}"><em>No matching packages found</em></td></tr>
|
||||||
|
@@ -56,7 +56,7 @@
|
|||||||
<td>{{ group.target_repo }}</td>
|
<td>{{ group.target_repo }}</td>
|
||||||
<td>{{ group.packager|default:"Unknown" }}</td>
|
<td>{{ group.packager|default:"Unknown" }}</td>
|
||||||
<td>{{ group.packages|length }}</td>
|
<td>{{ group.packages|length }}</td>
|
||||||
<td class="epoch-{{ group.last_update|date:'U' }}">{{ group.last_update|date }}</td>
|
<td class="epoch-{{ group.last_update|date:'U' }}">{{ group.last_update|date:"Y-m-d" }}</td>
|
||||||
{% if group.specification.known_bad %}
|
{% if group.specification.known_bad %}
|
||||||
<td class="approval signoff-bad">Bad</td>
|
<td class="approval signoff-bad">Bad</td>
|
||||||
{% else %}
|
{% else %}
|
||||||
|
@@ -24,7 +24,7 @@
|
|||||||
<a href="{{ entry.url }}"
|
<a href="{{ entry.url }}"
|
||||||
title="View full article: {{ entry.title }}">{{ entry.title }}</a>
|
title="View full article: {{ entry.title }}">{{ entry.title }}</a>
|
||||||
</h4>
|
</h4>
|
||||||
<p class="timestamp">{{ entry.publishdate|date }}</p>
|
<p class="timestamp">{{ entry.publishdate|date:"Y-m-d" }}</p>
|
||||||
<div class="article-content">
|
<div class="article-content">
|
||||||
{{ entry.summary |safe }}
|
{{ entry.summary |safe }}
|
||||||
</div>
|
</div>
|
||||||
|
@@ -50,7 +50,7 @@
|
|||||||
<a href="{{ news.get_absolute_url }}"
|
<a href="{{ news.get_absolute_url }}"
|
||||||
title="View full article: {{ news.title }}">{{ news.title }}</a>
|
title="View full article: {{ news.title }}">{{ news.title }}</a>
|
||||||
</h4>
|
</h4>
|
||||||
<p class="timestamp">{{ news.postdate|date }}</p>
|
<p class="timestamp">{{ news.postdate|date:"Y-m-d" }}</p>
|
||||||
<div class="article-content">
|
<div class="article-content">
|
||||||
{% if forloop.counter0 == 0 %}{{ news.html|truncatewords_html:300 }}
|
{% if forloop.counter0 == 0 %}{{ news.html|truncatewords_html:300 }}
|
||||||
{% else %}{{ news.html|truncatewords_html:100 }}{% endif %}
|
{% else %}{{ news.html|truncatewords_html:100 }}{% endif %}
|
||||||
@@ -63,7 +63,7 @@
|
|||||||
</h3>
|
</h3>
|
||||||
<dl class="newslist">
|
<dl class="newslist">
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<dt>{{ news.postdate|date }}</dt>
|
<dt>{{ news.postdate|date:"Y-m-d" }}</dt>
|
||||||
<dd>
|
<dd>
|
||||||
<a href="{{ news.get_absolute_url }}"
|
<a href="{{ news.get_absolute_url }}"
|
||||||
title="View full article: {{ news.title }}">{{ news.title }}</a>
|
title="View full article: {{ news.title }}">{{ news.title }}</a>
|
||||||
|
@@ -9,7 +9,7 @@
|
|||||||
<h2>{{ release.version }}</h2>
|
<h2>{{ release.version }}</h2>
|
||||||
|
|
||||||
<ul>
|
<ul>
|
||||||
<li><strong>Release Date:</strong> {{ release.release_date|date }}</li>
|
<li><strong>Release Date:</strong> {{ release.release_date|date:"Y-m-d" }}</li>
|
||||||
{% if release.kernel_version %}<li><strong>Kernel Version:</strong> {{ release.kernel_version }}</li>{% endif %}
|
{% if release.kernel_version %}<li><strong>Kernel Version:</strong> {{ release.kernel_version }}</li>{% endif %}
|
||||||
<li><strong>Available:</strong> {{ release.available|yesno|capfirst }}</li>
|
<li><strong>Available:</strong> {{ release.available|yesno|capfirst }}</li>
|
||||||
{% if release.torrent_data %}
|
{% if release.torrent_data %}
|
||||||
|
@@ -42,7 +42,7 @@
|
|||||||
<a href="{{ item.magnet_uri }}"
|
<a href="{{ item.magnet_uri }}"
|
||||||
title="Get magnet link for {{ item.version }}"><img width="12" height="12" src="{% static "magnet.png" %}" alt="Magnet"/></a>
|
title="Get magnet link for {{ item.version }}"><img width="12" height="12" src="{% static "magnet.png" %}" alt="Magnet"/></a>
|
||||||
{% endif %}</td>
|
{% endif %}</td>
|
||||||
<td>{{ item.release_date|date }}</td>
|
<td>{{ item.release_date|date:"Y-m-d" }}</td>
|
||||||
<td><a href="{{ item.get_absolute_url }}" title="Release details for {{ item.version }}">{{ item.version }}</a></td>
|
<td><a href="{{ item.get_absolute_url }}" title="Release details for {{ item.version }}">{{ item.version }}</a></td>
|
||||||
<td>{{ item.kernel_version|default:"" }}</td>
|
<td>{{ item.kernel_version|default:"" }}</td>
|
||||||
<td class="available-{{ item.available|yesno }}">{{ item.available|yesno|capfirst }}</td>
|
<td class="available-{{ item.available|yesno }}">{{ item.available|yesno|capfirst }}</td>
|
||||||
|
@@ -37,7 +37,7 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td class="wrap"><a href="{{ list.get_absolute_url }}"
|
<td class="wrap"><a href="{{ list.get_absolute_url }}"
|
||||||
title="View todo list: {{ list.name }}">{{ list.name }}</a></td>
|
title="View todo list: {{ list.name }}">{{ list.name }}</a></td>
|
||||||
<td>{{ list.created|date }}</td>
|
<td>{{ list.created|date:"Y-m-d" }}</td>
|
||||||
<td>{{ list.creator.get_full_name }}</td>
|
<td>{{ list.creator.get_full_name }}</td>
|
||||||
<td>{{ list.pkg_count }}</td>
|
<td>{{ list.pkg_count }}</td>
|
||||||
<td>{{ list.incomplete_count }}</td>
|
<td>{{ list.incomplete_count }}</td>
|
||||||
|
@@ -23,7 +23,7 @@
|
|||||||
{% endif %}
|
{% endif %}
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div class="todo-info">{{ list.created|date }} - {{ list.creator.get_full_name }}</div>
|
<div class="todo-info">{{ list.created|date:"Y-m-d" }} - {{ list.creator.get_full_name }}</div>
|
||||||
|
|
||||||
<div class="todo-description">
|
<div class="todo-description">
|
||||||
{{list.stripped_description|default:'(no description)'|urlize|linebreaks}}
|
{{list.stripped_description|default:'(no description)'|urlize|linebreaks}}
|
||||||
|
Reference in New Issue
Block a user