forked from polycube-network/polycube
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge remote-tracking branch 'upstream/master'
- Loading branch information
Showing
103 changed files
with
3,390 additions
and
1,382 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,145 @@ | ||
Hateoas | ||
======= | ||
|
||
Polycube supports the Hateoas standard. | ||
Thanks to this feature the daemon (:doc:`polycubed<../polycubed/polycubed>`) is able to provide the list | ||
of valid endpoints to the client that can be used to make requests to the server. | ||
The endpoints provided are those of the level just after the one requested. | ||
From the :doc:`polycubed<../polycubed/polycubed>` root you can explore the service through the Hateoas standard. | ||
|
||
|
||
What can Hateoas be used for? | ||
----------------------------- | ||
|
||
The Hateoas standard can be used to explore endpoints that can be used in Polycube. | ||
In this way a client will be able to access Polycube resources and thus cubes independently. | ||
This feature can also be useful in case you want to implement an alternative client to :doc:`polycubectl<../polycubectl/polycubectl>`. | ||
|
||
|
||
How to use Hateoas | ||
------------------ | ||
This feature can be used by observing the json of :doc:`polycubed<../polycubed/polycubed>` responses. | ||
You can use an http client (e.g. Postman) to execute requests to the Polycube daemon. | ||
|
||
|
||
|
||
Example | ||
------- | ||
|
||
In this example if the client request is | ||
|
||
:: | ||
|
||
GET -> localhost:9000/polycube/v1/simplebridge/sb1/ | ||
|
||
then the server response will include all endpoints a of the level just after the simplebridge name (sb1). | ||
|
||
:: | ||
|
||
{ | ||
"name": "sb1", | ||
"uuid": "d138da68-f6f4-4ee9-8238-34e9ab1df156", | ||
"service-name": "simplebridge", | ||
"type": "TC", | ||
"loglevel": "INFO", | ||
"ports": [ | ||
{ | ||
"name": "tovethe1", | ||
"uuid": "b2d6ebcb-163c-4ee8-a943-ba46b5fa4bda", | ||
"status": "UP", | ||
"peer": "veth1" | ||
}, | ||
{ | ||
"name": "tovethe2", | ||
"uuid": "e760a44d-5e9f-47e9-85d9-38e144400e83", | ||
"status": "UP", | ||
"peer": "veth2" | ||
} | ||
], | ||
"shadow": false, | ||
"span": false, | ||
"fdb": { | ||
"aging-time": 300, | ||
"entry": [ | ||
{ | ||
"address": "da:55:44:5a:b1:b1", | ||
"port": "tovethe1", | ||
"age": 29 | ||
}, | ||
{ | ||
"address": "11:ff:fe:80:00:00", | ||
"port": "tovethe2", | ||
"age": 26 | ||
}, | ||
{ | ||
"address": "ee:c9:0e:19:c7:2a", | ||
"port": "tovethe2", | ||
"age": 1 | ||
} | ||
] | ||
}, | ||
"_links": [ | ||
{ | ||
"rel": "self", | ||
"href": "//127.0.0.1:9000/polycube/v1/simplebridge/sb1/" | ||
}, | ||
{ | ||
"rel": "uuid", | ||
"href": "//127.0.0.1:9000/polycube/v1/simplebridge/sb1/uuid/" | ||
}, | ||
{ | ||
"rel": "type", | ||
"href": "//127.0.0.1:9000/polycube/v1/simplebridge/sb1/type/" | ||
}, | ||
{ | ||
"rel": "service-name", | ||
"href": "//127.0.0.1:9000/polycube/v1/simplebridge/sb1/service-name/" | ||
}, | ||
{ | ||
"rel": "loglevel", | ||
"href": "//127.0.0.1:9000/polycube/v1/simplebridge/sb1/loglevel/" | ||
}, | ||
{ | ||
"rel": "ports", | ||
"href": "//127.0.0.1:9000/polycube/v1/simplebridge/sb1/ports/" | ||
}, | ||
{ | ||
"rel": "shadow", | ||
"href": "//127.0.0.1:9000/polycube/v1/simplebridge/sb1/shadow/" | ||
}, | ||
{ | ||
"rel": "span", | ||
"href": "//127.0.0.1:9000/polycube/v1/simplebridge/sb1/span/" | ||
}, | ||
{ | ||
"rel": "fdb", | ||
"href": "//127.0.0.1:9000/polycube/v1/simplebridge/sb1/fdb/" | ||
} | ||
] | ||
|
||
} | ||
|
||
As we can see from this answer json, the "_links" section contains all the endpoints | ||
that the client can use to contact :doc:`polycubed<../polycubed/polycubed>` starting from the service name (sb1). | ||
|
||
In this way a client can explore the service level by level. | ||
|
||
|
||
|
||
How to know endpoints without hateoas? | ||
-------------------------------------- | ||
Well, there is an alternative (harder) way to know the endpoints of a cube that can be used in a Polycube. | ||
The swaggerfile must be produced from the yang datamodel of a service (option **-s** in swagger-codegen_). | ||
|
||
To do this you have to provide the datamodel of a service as input to the swagger codegen (**-i** option). | ||
The swaggerfile is a large and not very understandable json. | ||
How can we study it in order to know APIs? | ||
We have to use the swagger-editor_ that can accept the swaggerfile generated and | ||
provides a more user friendly way to observe api's of a service. | ||
Swagger editor allows you to view endpoints and verbs that can be used to interact with a Polycube. | ||
|
||
Note: using this method you will only know the endpoints of a cube and not all the endpoints offered by :doc:`polycubed<../polycubed/polycubed>`. | ||
|
||
|
||
.. _swagger-codegen: https://github.com/polycube-network/polycube-codegen#full-installation-from-sources | ||
.. _swagger-editor: https://editor.swagger.io/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.