mirror of
https://github.com/dkmstr/openuds.git
synced 2025-01-10 01:17:59 +03:00
Added changelog for publications to dashboard
This commit is contained in:
parent
32a04edbf9
commit
b77fa7dfd6
@ -42,7 +42,7 @@ from uds.core.util import permissions
|
||||
from uds.REST.model import ModelHandler
|
||||
from uds.REST import RequestError, ResponseError
|
||||
from uds.core.ui.UserInterface import gui
|
||||
from .user_services import AssignedService, CachedService, Groups, Transports, Publications
|
||||
from .user_services import AssignedService, CachedService, Groups, Transports, Publications, Changelog
|
||||
from .services import Services
|
||||
|
||||
import logging
|
||||
@ -61,6 +61,7 @@ class ServicesPools(ModelHandler):
|
||||
'groups': Groups,
|
||||
'transports': Transports,
|
||||
'publications': Publications,
|
||||
'changelog': Changelog
|
||||
}
|
||||
|
||||
save_fields = ['name', 'comments', 'service_id', 'osmanager_id', 'image_id', 'initial_srvs', 'cache_l1_srvs', 'cache_l2_srvs', 'max_srvs', 'show_transports']
|
||||
|
@ -329,3 +329,25 @@ class Publications(DetailHandler):
|
||||
'field': 'state',
|
||||
'prefix': 'row-state-'
|
||||
}
|
||||
|
||||
|
||||
class Changelog(DetailHandler):
|
||||
'''
|
||||
Processes the transports detail requests of a Service Pool
|
||||
'''
|
||||
def getItems(self, parent, item):
|
||||
return [{
|
||||
'revision': i.revision,
|
||||
'stamp': i.stamp,
|
||||
'log': i.log,
|
||||
} for i in parent.changelog.all()]
|
||||
|
||||
def getTitle(self, parent):
|
||||
return _('Changelog')
|
||||
|
||||
def getFields(self, parent):
|
||||
return [
|
||||
{'revision': {'title': _('Revision'), 'type': 'numeric', 'width': '6em'}},
|
||||
{'stamp': {'title': _('Publish date'), 'type': 'datetime'}},
|
||||
{'log': {'title': _('State')}},
|
||||
]
|
||||
|
@ -209,7 +209,7 @@ class PublicationManager(object):
|
||||
dsp = None
|
||||
dsp = servicePool.publications.create(state=State.LAUNCHING, state_date=now, publish_date=now, revision=servicePool.current_pub_revision)
|
||||
if changeLog:
|
||||
servicePool.changelog.create(revision=servicePool.current_pub_revision, log=changeLog)
|
||||
servicePool.changelog.create(revision=servicePool.current_pub_revision, log=changeLog, stamp=now)
|
||||
DelayedTaskRunner.runner().insert(PublicationLauncher(dsp), 4, PUBTAG + str(dsp.id))
|
||||
except Exception as e:
|
||||
logger.debug('Caught exception at publish: {0}'.format(e))
|
||||
|
59
server/src/uds/migrations/0016_auto_20150617_0741.py
Normal file
59
server/src/uds/migrations/0016_auto_20150617_0741.py
Normal file
@ -0,0 +1,59 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
from __future__ import unicode_literals
|
||||
|
||||
from django.db import models, migrations
|
||||
import django.db.models.deletion
|
||||
import uds.models.Util
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('uds', '0015_ticketstore'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='DeployedServicePublicationChangelog',
|
||||
fields=[
|
||||
('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)),
|
||||
('stamp', models.DateTimeField()),
|
||||
('revision', models.PositiveIntegerField(default=1)),
|
||||
('log', models.TextField(default='')),
|
||||
],
|
||||
options={
|
||||
'abstract': False,
|
||||
'db_table': 'uds__deployed_service_pub_cl',
|
||||
},
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='group',
|
||||
name='created',
|
||||
field=models.DateTimeField(default=uds.models.Util.getSqlDatetime, blank=True),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='user',
|
||||
name='created',
|
||||
field=models.DateTimeField(default=uds.models.Util.getSqlDatetime, blank=True),
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name='deployedservice',
|
||||
name='image',
|
||||
field=models.ForeignKey(related_name='deployedServices', on_delete=django.db.models.deletion.SET_NULL, blank=True, to='uds.Image', null=True),
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name='group',
|
||||
name='manager',
|
||||
field=uds.models.Util.UnsavedForeignKey(related_name='groups', to='uds.Authenticator'),
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name='user',
|
||||
name='manager',
|
||||
field=uds.models.Util.UnsavedForeignKey(related_name='users', to='uds.Authenticator'),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='deployedservicepublicationchangelog',
|
||||
name='publication',
|
||||
field=models.ForeignKey(related_name='changelog', to='uds.DeployedService'),
|
||||
),
|
||||
]
|
@ -47,7 +47,7 @@ from uds.models.UUIDModel import UUIDModel
|
||||
|
||||
import logging
|
||||
|
||||
__updated__ = '2015-06-15'
|
||||
__updated__ = '2015-06-17'
|
||||
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
@ -56,6 +56,7 @@ logger = logging.getLogger(__name__)
|
||||
@python_2_unicode_compatible
|
||||
class DeployedServicePublicationChangelog(models.Model):
|
||||
publication = models.ForeignKey(DeployedService, on_delete=models.CASCADE, related_name='changelog')
|
||||
stamp = models.DateTimeField()
|
||||
revision = models.PositiveIntegerField(default=1)
|
||||
log = models.TextField(default='')
|
||||
|
||||
|
@ -98,6 +98,7 @@ gui.servicesPools.link = (event) ->
|
||||
groups: "groups-placeholder"
|
||||
transports: "transports-placeholder"
|
||||
publications: "publications-placeholder"
|
||||
changelog: "changelog-placeholder"
|
||||
logs: "logs-placeholder"
|
||||
)
|
||||
gui.setLinksEvents()
|
||||
@ -378,6 +379,8 @@ gui.servicesPools.link = (event) ->
|
||||
# * Publications part
|
||||
#
|
||||
publications = null
|
||||
changelog = null
|
||||
clTable = null
|
||||
if info.needs_publication
|
||||
$("#publications-placeholder_tab").removeClass "hidden"
|
||||
pubApi = api.servicesPools.detail(servPool.id, "publications")
|
||||
@ -437,20 +440,34 @@ gui.servicesPools.link = (event) ->
|
||||
)
|
||||
gui.tools.applyCustoms modalId
|
||||
$(modalId + " .button-accept").click ->
|
||||
changelog = encodeURIComponent($('#id_publish_log').val())
|
||||
chlog = encodeURIComponent($('#id_publish_log').val())
|
||||
$(modalId).modal "hide"
|
||||
pubApi.invoke "publish", (->
|
||||
refreshFnc()
|
||||
changelog.refresh()
|
||||
# Also changelog
|
||||
return
|
||||
),
|
||||
gui.failRequestModalFnc(gettext("Failed creating publication")),
|
||||
{ params: 'changelog=' + changelog }
|
||||
{ params: 'changelog=' + chlog }
|
||||
|
||||
return
|
||||
|
||||
return
|
||||
)
|
||||
prevTables.push publicationsTable
|
||||
|
||||
# changelog
|
||||
clApi = api.servicesPools.detail(servPool.id, "changelog")
|
||||
changelog = new GuiElement(clApi, "changelog", { permission: servPool.permission })
|
||||
clTable = changelog.table(
|
||||
icon: 'publications'
|
||||
container: "changelog-placeholder"
|
||||
rowSelect: "single"
|
||||
)
|
||||
clTables.push clTable
|
||||
|
||||
|
||||
else
|
||||
$("#publications-placeholder_tab").addClass "hidden"
|
||||
|
||||
|
@ -198,7 +198,7 @@
|
||||
# What execute on refresh button push
|
||||
onRefresh = tblParams.onRefresh or ->
|
||||
|
||||
refreshFnc = ->
|
||||
self.refresh = refreshFnc = ->
|
||||
# Refreshes table content
|
||||
tbl = $("#" + tableId).dataTable()
|
||||
|
||||
|
@ -31,7 +31,7 @@
|
||||
<li id="{{ cache }}_tab"><a href="#{{ cache }}" data-toggle="tab">{% endverbatim %}{% trans 'Cache' %}{% verbatim %}</a></li>
|
||||
<li id="{{ groups }}_tab"><a href="#{{ groups }}" data-toggle="tab">{% endverbatim %}{% trans 'Groups' %}{% verbatim %}</a></li>
|
||||
<li><a href="#{{ transports }}" data-toggle="tab">{% endverbatim %}{% trans 'Transports' %}{% verbatim %}</a></li>
|
||||
<li id="{{ publications }}_tab"><a href="#{{ publications }}" data-toggle="tab">{% endverbatim %}{% trans 'Publications' %}{% verbatim %}</a></li>
|
||||
<li id="{{ publications }}_tab"><a href="#{{ publications }}_pane" data-toggle="tab">{% endverbatim %}{% trans 'Publications' %}{% verbatim %}</a></li>
|
||||
<li><a href="#{{ logs }}" data-toggle="tab">{% endverbatim %}{% trans 'Logs' %}{% verbatim %}</a></li>
|
||||
</ul>
|
||||
<div class="tab-content">
|
||||
@ -57,7 +57,12 @@
|
||||
</div>
|
||||
<div class="tab-pane fade" id="{{ groups }}">...</div>
|
||||
<div class="tab-pane fade" id="{{ transports }}">...</div>
|
||||
<div class="tab-pane fade" id="{{ publications }}">...</div>
|
||||
<div class="tab-pane fade" id="{{ publications }}_pane">
|
||||
<div id="{{ publications }}">
|
||||
</div>
|
||||
<div id="{{ changelog }}">
|
||||
</div>
|
||||
</div>
|
||||
<div class="tab-pane fade" id="{{ logs }}">...</div>
|
||||
</div>
|
||||
</div>
|
||||
|
Loading…
Reference in New Issue
Block a user