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
61658071
authored
Apr 15, 2020
by
Chif Gergő
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
DELETE request only indicates, that the user wants delete, doesn't deletes the instance
parent
77caa3dd
Pipeline
#1064
failed with stage
in 1 minute 33 seconds
Changes
3
Pipelines
1
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
34 additions
and
8 deletions
+34
-8
recircle/instance/migrations/0003_auto_20200408_1503.py
+23
-0
recircle/instance/models.py
+5
-2
recircle/instance/views.py
+6
-6
No files found.
recircle/instance/migrations/0003_auto_20200408_1503.py
0 → 100644
View file @
61658071
# Generated by Django 3.0.4 on 2020-04-08 13:03
from
django.db
import
migrations
,
models
class
Migration
(
migrations
.
Migration
):
dependencies
=
[
(
'image'
,
'0001_initial'
),
(
'instance'
,
'0002_instance_template'
),
]
operations
=
[
migrations
.
RemoveField
(
model_name
=
'instance'
,
name
=
'owner'
,
),
migrations
.
AlterField
(
model_name
=
'instance'
,
name
=
'disks'
,
field
=
models
.
ManyToManyField
(
blank
=
True
,
help_text
=
'Disks attached to instance'
,
related_name
=
'instance'
,
to
=
'image.Disk'
,
verbose_name
=
'disks'
),
),
]
recircle/instance/models.py
View file @
61658071
...
@@ -171,11 +171,10 @@ class Instance(BaseMachineDescriptor):
...
@@ -171,11 +171,10 @@ class Instance(BaseMachineDescriptor):
on_delete
=
models
.
DO_NOTHING
)
on_delete
=
models
.
DO_NOTHING
)
disks
=
models
.
ManyToManyField
(
Disk
,
related_name
=
"instance"
,
disks
=
models
.
ManyToManyField
(
Disk
,
related_name
=
"instance"
,
blank
=
True
,
help_text
=
"Disks attached to instance"
,
help_text
=
"Disks attached to instance"
,
verbose_name
=
"disks"
)
verbose_name
=
"disks"
)
owner
=
models
.
ForeignKey
(
User
,
on_delete
=
models
.
CASCADE
,
null
=
True
)
@classmethod
@classmethod
def
create
(
cls
,
lease
,
owner
,
flavor
,
template
,
remote_id
,
params
):
def
create
(
cls
,
lease
,
owner
,
flavor
,
template
,
remote_id
,
params
):
params
[
"password"
]
=
cls
.
generate_password
()
params
[
"password"
]
=
cls
.
generate_password
()
...
@@ -272,3 +271,7 @@ class Instance(BaseMachineDescriptor):
...
@@ -272,3 +271,7 @@ class Instance(BaseMachineDescriptor):
def
change_description
(
self
,
new_description
):
def
change_description
(
self
,
new_description
):
self
.
description
=
new_description
self
.
description
=
new_description
self
.
save
()
self
.
save
()
def
destroy
(
self
):
self
.
deleted
=
True
self
.
save
()
recircle/instance/views.py
View file @
61658071
...
@@ -62,7 +62,8 @@ class InstanceViewSet(AuthorizationMixin, ViewSet):
...
@@ -62,7 +62,8 @@ class InstanceViewSet(AuthorizationMixin, ViewSet):
raise
Http404
raise
Http404
def
list
(
self
,
request
):
def
list
(
self
,
request
):
instances
=
self
.
get_objects_with_perms
(
request
.
user
,
"list"
,
Instance
)
# instances = self.get_objects_with_perms(request.user, "list", Instance)
instances
=
Instance
.
objects
.
filter
(
Q
(
created_by
=
request
.
user
)
&
Q
(
deleted
=
False
))
return
Response
(
InstanceListItemSerializer
(
instances
,
many
=
True
)
.
data
)
return
Response
(
InstanceListItemSerializer
(
instances
,
many
=
True
)
.
data
)
def
create
(
self
,
request
):
def
create
(
self
,
request
):
...
@@ -114,14 +115,11 @@ class InstanceViewSet(AuthorizationMixin, ViewSet):
...
@@ -114,14 +115,11 @@ class InstanceViewSet(AuthorizationMixin, ViewSet):
instance
.
change_description
(
request
.
data
[
"description"
])
instance
.
change_description
(
request
.
data
[
"description"
])
return
Response
(
InstanceSerializer
(
instance
)
.
data
)
return
Response
(
InstanceSerializer
(
instance
)
.
data
)
def
destroy
(
self
,
request
,
pk
,
format
=
None
):
def
destroy
(
self
,
request
,
pk
):
instance
=
self
.
get_object
(
pk
)
instance
=
self
.
get_object
(
pk
)
if
not
instance
:
if
not
instance
:
return
Response
(
status
=
status
.
HTTP_204_NO_CONTENT
)
return
Response
(
status
=
status
.
HTTP_204_NO_CONTENT
)
if
not
self
.
has_perms_for_object
(
request
.
user
,
'destroy'
,
instance
):
instance
.
destroy
()
return
Response
({
"error"
:
"No permission to destroy the Virtual Machine."
},
status
=
status
.
HTTP_401_UNAUTHORIZED
)
instance
.
delete
()
return
Response
(
status
=
status
.
HTTP_204_NO_CONTENT
)
return
Response
(
status
=
status
.
HTTP_204_NO_CONTENT
)
@action
(
detail
=
True
,
methods
=
[
"post"
])
@action
(
detail
=
True
,
methods
=
[
"post"
])
...
@@ -182,10 +180,12 @@ class InstanceViewSet(AuthorizationMixin, ViewSet):
...
@@ -182,10 +180,12 @@ class InstanceViewSet(AuthorizationMixin, ViewSet):
@action
(
detail
=
True
,
methods
=
[
"POST"
])
@action
(
detail
=
True
,
methods
=
[
"POST"
])
def
attach_disk
(
self
,
request
,
pk
):
def
attach_disk
(
self
,
request
,
pk
):
# TODO: attach not implemented in model
pass
pass
@action
(
detail
=
True
,
methods
=
[
"POST"
])
@action
(
detail
=
True
,
methods
=
[
"POST"
])
def
detach_disk
(
self
,
request
,
pk
):
def
detach_disk
(
self
,
request
,
pk
):
# TODO: attach not implemented in model
pass
pass
@action
(
detail
=
True
,
methods
=
[
"POST"
])
@action
(
detail
=
True
,
methods
=
[
"POST"
])
...
...
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