Skip to content
Toggle navigation
P
Projects
G
Groups
S
Snippets
Help
RECIRCLE
/
portal
This project
Loading...
Sign in
Toggle navigation
Go to a project
Project
Repository
Issues
11
Merge Requests
0
Pipelines
Wiki
Snippets
Members
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Commit
46d067b1
authored
Aug 15, 2019
by
Bodor Máté
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Refactor template models, urls and views
parent
3a808815
Pipeline
#829
passed with stage
in 2 minutes 6 seconds
Changes
3
Pipelines
1
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
29 additions
and
57 deletions
+29
-57
recircle/template/models.py
+27
-56
recircle/template/urls.py
+1
-0
recircle/template/views.py
+1
-1
No files found.
recircle/template/models.py
View file @
46d067b1
...
@@ -8,71 +8,53 @@ from interface_openstack.implementation.storage.openstack_snapshot_manager impor
...
@@ -8,71 +8,53 @@ from interface_openstack.implementation.storage.openstack_snapshot_manager impor
class
BaseTemplate
(
models
.
Model
):
class
BaseTemplate
(
models
.
Model
):
"""Virtual machine template.
"""Virtual machine template.
"""
"""
name
=
models
.
CharField
(
name
=
models
.
CharField
(
max_length
=
100
,
max_length
=
100
,
verbose_name
=
"name"
,
verbose_name
=
"name"
,
help_text
=
"Human readable name of template."
help_text
=
"Human readable name of template."
)
)
description
=
models
.
TextField
(
verbose_name
=
"description"
,
description
=
models
.
TextField
(
verbose_name
=
"description"
,
blank
=
True
,
blank
=
True
,
help_text
=
"Description of the template."
help_text
=
"Description of the template."
)
)
created_at
=
models
.
DateTimeField
(
auto_now_add
=
True
,
# remote_id = models.CharField(
# max_length=40,
# unique=True,
# verbose_name="remote_ID",
# help_text="ID, which helps access the template."
# )
created_at
=
models
.
DateTimeField
(
auto_now_add
=
True
,
editable
=
False
,
editable
=
False
,
help_text
=
"Date, when the template created."
help_text
=
"Date, when the template created."
)
)
created_by
=
models
.
ForeignKey
(
User
,
created_by
=
models
.
ForeignKey
(
User
,
on_delete
=
models
.
DO_NOTHING
,
on_delete
=
models
.
DO_NOTHING
,
related_name
=
"created_templates"
,
related_name
=
"created_templates"
,
help_text
=
"The user, who create the template"
help_text
=
"The user, who create the template"
)
)
flavor
=
models
.
ForeignKey
(
Flavor
,
flavor
=
models
.
ForeignKey
(
Flavor
,
help_text
=
"Reasources given to the vm"
,
help_text
=
"Resources given to the vm"
,
verbose_name
=
"flavor"
,
on_delete
=
"CASCADE"
,
verbose_name
=
"flavor"
,
on_delete
=
"CASCADE"
,
related_name
=
'templates'
)
related_name
=
'templates'
)
lease
=
models
.
ForeignKey
(
Lease
,
on_delete
=
"CASCADE"
,
lease
=
models
.
ForeignKey
(
Lease
,
on_delete
=
"CASCADE"
,
related_name
=
'templates'
)
related_name
=
'templates'
)
network_id
=
models
.
CharField
(
network_id
=
models
.
CharField
(
max_length
=
100
,
max_length
=
100
,
verbose_name
=
"network_id"
,
verbose_name
=
"network_id"
,
help_text
=
"The new instance will be in this network."
,
help_text
=
"The new instance will be in this network."
,
null
=
True
,
null
=
True
,
blank
=
True
blank
=
True
)
)
class
DiskTemplate
(
BaseTemplate
):
class
DiskTemplate
(
BaseTemplate
):
disk
=
models
.
ForeignKey
(
disk
=
models
.
ForeignKey
(
Disk
,
Disk
,
related_name
=
"templates"
,
related_name
=
"templates"
,
on_delete
=
models
.
CASCADE
,
on_delete
=
models
.
CASCADE
,
help_text
=
"The disk where the template is located."
help_text
=
"The disk where the template is located."
)
)
@classmethod
@classmethod
def
create_from_volume
(
cls
,
name
,
description
,
disk
,
user
):
def
create_from_volume
(
cls
,
name
,
description
,
disk
,
user
):
interface
=
SnapshotManager
(
settings
.
CONNECTION
)
interface
=
SnapshotManager
(
settings
.
CONNECTION
)
remote_template
=
interface
.
create_from_volume
(
disk
.
remote_id
)
remote_template
=
interface
.
create_from_volume
(
disk
.
remote_id
)
remote_id
=
remote_template
.
id
remote_id
=
remote_template
.
id
new_template
=
cls
.
create
(
new_template
=
DiskTemplate
.
objects
.
create
(
name
=
name
,
name
=
name
,
description
=
description
,
description
=
description
,
disk
=
disk
,
disk
=
disk
,
remote_id
=
remote_id
,
remote_id
=
remote_id
,
created_by
=
user
created_by
=
user
)
)
return
new_template
return
new_template
...
@@ -82,33 +64,22 @@ class ImageTemplate(BaseTemplate):
...
@@ -82,33 +64,22 @@ class ImageTemplate(BaseTemplate):
(
'I'
,
'Template created from instance'
),
(
'I'
,
'Template created from instance'
),
(
'P'
,
'"Pure" template'
),
(
'P'
,
'"Pure" template'
),
)
)
image
=
models
.
ForeignKey
(
Image
,
image
=
models
.
ForeignKey
(
Image
,
related_name
=
"templates"
,
related_name
=
"templates"
,
on_delete
=
models
.
CASCADE
,
on_delete
=
models
.
CASCADE
,
help_text
=
""
help_text
=
""
)
)
type
=
models
.
CharField
(
max_length
=
10
,
type
=
models
.
CharField
(
max_length
=
10
,
choices
=
TYPES
,
default
=
"U"
)
choices
=
TYPES
,
default
=
"U"
)
@classmethod
def
create
(
cls
,
name
,
description
,
image
,
lease
,
flavor
,
created_by
,
type
=
'U'
):
inst
=
cls
(
name
=
name
,
description
=
description
,
image
=
image
,
lease
=
lease
,
flavor
=
flavor
,
created_by
=
created_by
,
type
=
type
)
inst
.
full_clean
()
inst
.
save
()
return
inst
@classmethod
@classmethod
def
create_from_instance
(
cls
,
name
,
description
,
instance
,
user
):
def
create_from_instance
(
cls
,
name
,
description
,
instance
,
user
):
image
=
Image
.
create_from_instance
(
user
,
instance
,
description
)
image
=
Image
.
create_from_instance
(
user
,
instance
,
description
)
new_template
=
cls
.
create
(
new_template
=
ImageTemplate
.
objects
.
create
(
name
=
name
,
name
=
name
,
description
=
description
,
description
=
description
,
created_by
=
user
,
created_by
=
user
,
image
=
image
,
image
=
image
,
lease
=
instance
.
lease
,
lease
=
instance
.
lease
,
flavor
=
instance
.
flavor
,
flavor
=
instance
.
flavor
,
type
=
"I"
type
=
"I"
)
)
return
new_template
return
new_template
recircle/template/urls.py
View file @
46d067b1
from
rest_framework
import
routers
from
rest_framework
import
routers
from
template
import
views
from
template
import
views
router
=
routers
.
DefaultRouter
()
router
=
routers
.
DefaultRouter
()
...
...
recircle/template/views.py
View file @
46d067b1
# from django.shortcuts import render
from
rest_framework.response
import
Response
from
rest_framework.response
import
Response
from
rest_framework.viewsets
import
ModelViewSet
from
rest_framework.viewsets
import
ModelViewSet
from
template.serializers
import
ImageTemplateModelSerializer
from
template.serializers
import
ImageTemplateModelSerializer
from
template.models
import
ImageTemplate
from
template.models
import
ImageTemplate
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment