Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
slapos.core
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Léo-Paul Géneau
slapos.core
Commits
cb0e49de
Commit
cb0e49de
authored
Dec 08, 2020
by
Jérome Perrin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
WIP: OpenAPI integration with flasgger
parent
dc4f7604
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
255 additions
and
0 deletions
+255
-0
setup.py
setup.py
+1
-0
slapos-api.yaml
slapos-api.yaml
+240
-0
slapos/proxy/views.py
slapos/proxy/views.py
+14
-0
No files found.
setup.py
View file @
cb0e49de
...
...
@@ -59,6 +59,7 @@ setup(name=name,
include_package_data
=
True
,
install_requires
=
[
'Flask'
,
# used by proxy
'flasgger'
,
'lxml'
,
# needed to play with XML trees
'netaddr>=0.7.5'
,
# to play safely with IPv6 prefixes
'netifaces'
,
# to fetch information about network devices
...
...
slapos-api.yaml
0 → 100644
View file @
cb0e49de
openapi
:
3.0.0
info
:
title
:
SlapOS
version
:
0.1.0
tags
:
-
name
:
Request
description
:
API used by users to request partitions or manage computers
-
name
:
Node
description
:
API used by SlapOS nodes
paths
:
/getFullComputerInformation
:
get
:
tags
:
-
Request
operationId
:
getFullComputerInformation
summary
:
Retrieve information about a computer
parameters
:
-
in
:
query
name
:
computer_id
schema
:
type
:
string
required
:
true
examples
:
local
:
value
:
"
local"
summary
:
Local computer
comp-1234
:
summary
:
Computer COMP-1234
value
:
"
COMP-1234"
responses
:
'
200'
:
description
:
Information about the computer
content
:
application/json
:
schema
:
$ref
:
'
#/components/schemas/Computer'
links
:
supplySupply
:
$ref
:
'
#/components/links/supplySupply'
/supplySupply
:
post
:
tags
:
-
Request
operationId
:
supplySupply
summary
:
Install software on a computer
requestBody
:
description
:
Request
required
:
true
content
:
application/json
:
schema
:
$ref
:
'
#/components/schemas/SupplyRequestBody'
responses
:
'
200'
:
description
:
Software was supplied
content
:
application/json
:
schema
:
$ref
:
'
#/components/schemas/ComputerPartition'
links
:
getComputerPartitionStatus
:
$ref
:
'
#/components/links/getComputerPartitionStatus'
destroyedComputerPartition
:
$ref
:
'
#/components/links/destroyedComputerPartition'
/requestComputerPartition
:
post
:
tags
:
-
Request
operationId
:
requestComputerPartition
summary
:
Request a service
requestBody
:
description
:
Request
required
:
true
content
:
application/json
:
schema
:
$ref
:
'
#/components/schemas/ComputerPartitionRequestBody'
examples
:
KVM
:
description
:
Request a KVM
value
:
reference
:
kvm
software_release_url
:
https://lab.nexedi.com/nexedi/slapos/raw/1.0/software/kvm/software.cfg
parameter_kw
:
memory
:
40Go
cpu_count
:
12
ERP5
:
description
:
Request an ERP5
value
:
reference
:
erp5
software_release_url
:
https://lab.nexedi.com/nexedi/slapos/raw/1.0/software/erp5/software.cfg
parameter_kw
:
responses
:
'
200'
:
description
:
Partition was created
content
:
application/json
:
schema
:
$ref
:
'
#/components/schemas/ComputerPartition'
links
:
getComputerPartitionStatus
:
$ref
:
'
#/components/links/getComputerPartitionStatus'
destroyedComputerPartition
:
$ref
:
'
#/components/links/destroyedComputerPartition'
/destroyedComputerPartition
:
post
:
tags
:
-
Node
operationId
:
destroyedComputerPartition
description
:
Called by SlapOS Node when partition is destroyed
requestBody
:
description
:
Request
required
:
true
content
:
application/json
:
schema
:
$ref
:
'
#/components/schemas/ComputerPartitionDestroyRequestBody'
responses
:
'
200'
:
description
:
Partition was created
content
:
application/json
:
schema
:
$ref
:
'
#/components/schemas/ComputerPartition'
links
:
getComputerPartitionStatus
:
$ref
:
'
#/components/links/getComputerPartitionStatus'
destroyedComputerPartition
:
$ref
:
'
#/components/links/destroyedComputerPartition'
components
:
links
:
getComputerPartitionStatus
:
operationId
:
getComputerPartitionStatus
destroyedComputerPartition
:
operationId
:
destroyedComputerPartition
supplySupply
:
operationId
:
supplySupply
parameters
:
computer_id
:
computer_id
schemas
:
ComputerPartition
:
type
:
object
properties
:
reference
:
type
:
string
title
:
type
:
string
software_release
:
$ref
:
'
#/components/schemas/SoftwareRelease'
SoftwareRelease
:
type
:
object
properties
:
url
:
type
:
string
Computer
:
type
:
object
properties
:
id
:
type
:
string
title
:
type
:
string
partitions
:
type
:
array
items
:
$ref
:
'
#/components/schemas/ComputerPartition'
ip_addresses
:
type
:
array
items
:
$ref
:
'
#/components/schemas/IPAddress'
IPAddress
:
type
:
object
properties
:
ip
:
type
:
string
netmask
:
type
:
string
ComputerPartitionRequestBody
:
type
:
object
properties
:
reference
:
description
:
Name of the computer partition
type
:
string
example
:
erp5
software_release_url
:
description
:
URL of the Software Release
type
:
string
example
:
"
https://lab.nexedi.com/nexedi/slapos/raw/1.0.170/software/erp5/software.cfg"
parameter_kw
:
description
:
Parameters for the instance
type
:
object
filter_kw
:
description
:
Parameters about where request the instance
type
:
object
example
:
computer_guid
:
COMP-1234
requested_state
:
type
:
string
enum
:
-
started
-
destroyed
default
:
started
SupplyRequestBody
:
type
:
object
properties
:
computer_id
:
description
:
Reference of the computer
type
:
string
example
:
COMP-1234
url
:
description
:
URL of the Software Release
type
:
string
example
:
"
https://lab.nexedi.com/nexedi/slapos/raw/1.0.170/software/erp5/software.cfg"
state
:
description
:
state of the software
type
:
string
enum
:
-
available
-
destroyed
default
:
available
ComputerPartitionDestroyRequestBody
:
type
:
object
properties
:
computer_partition_id
:
type
:
string
example
:
slappart7
computer_id
:
type
:
string
example
:
COMP-1234
slapos/proxy/views.py
View file @
cb0e49de
...
...
@@ -47,6 +47,20 @@ from six.moves import range
from
six.moves.urllib.parse
import
urlparse
app
=
Flask
(
__name__
)
from
flasgger
import
Swagger
app
.
config
[
'SWAGGER'
]
=
{
'openapi'
:
'3.0.0'
}
swagger
=
Swagger
(
app
,
template_file
=
'/srv/slapgrid/slappart9/srv/project/slapos.core/slapos-api.yaml'
,
parse
=
True
,
# XXX "examples" with getFullComputerInformation causes validation errors
# is this bug ?
validation_function
=
lambda
*
args
:
True
)
EMPTY_DICT_XML
=
dumps
({})
...
...
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