From a0deea03b5a390eeea455b2c07e244d3363c44cc Mon Sep 17 00:00:00 2001 From: Nolwenn <28621493+NoB0@users.noreply.github.com> Date: Mon, 6 May 2024 10:58:14 +0200 Subject: [PATCH] Add documentation for PKG Client and server --- docs/source/pkg_client.rst | 30 ++++++++++++++++++++++++++++++ docs/source/pkg_server.rst | 29 +++++++++++++++++++++++++++++ 2 files changed, 59 insertions(+) create mode 100644 docs/source/pkg_client.rst create mode 100644 docs/source/pkg_server.rst diff --git a/docs/source/pkg_client.rst b/docs/source/pkg_client.rst new file mode 100644 index 0000000..896b4c7 --- /dev/null +++ b/docs/source/pkg_client.rst @@ -0,0 +1,30 @@ +PKG Client +========== + +PKG Client is a simple and user-friendly user interface, based on React, to manage a PKG. The management is done through requests sent to the server. + +Run PKG Client +-------------- + +Node.js and npm are required to run PKG Client, more information on how to install them can be found `here `. + +To start PKG Client, run the following commands in the directory `pkg_client`: + +.. code-block:: bash + + npm install + npm start + +Note that `npm install` only needs to be run once, unless the dependencies change. For more information on how to run the client, refer to the README in the `pkg_client` directory. + +In case the server is not running on the default port (i.e., 5000), `PKG_API_BASE_URL` in `pkg_client/public/config.json` must be updated accordingly. + +Features +-------- + +PKG Client provides the following features: + +* **Login/Registration**: To access their PKG, users must be logged in. If they do not have an account, they can register. +* **Home**: The home page provides a text input field where users can enter their management instructions (i.e., add, remove, and retrieve statements) in natural language. After being processed by the server, the outcome of the instructions is displayed. The home page also provides a button to visualize the PKG. +* **Populate PKG**: Users can populate their PKG by adding or removing statements via a form. This feature assumes that the user is familiar with the `PKG vocabulary `. +* **Explore PKG**: Users can visualize their PKG or a part of it as an RDF graph. The visualization is generated based on the results of a SPARQL query, hence, this feature is intended for advised users. \ No newline at end of file diff --git a/docs/source/pkg_server.rst b/docs/source/pkg_server.rst new file mode 100644 index 0000000..8249301 --- /dev/null +++ b/docs/source/pkg_server.rst @@ -0,0 +1,29 @@ +Server +====== + +The backend server is a `Flask ` server. It is responsible for connecting the users and service providers to PKGs. + +Run server +---------- + +Before starting the server, make sure that the `requirements ` are installed and that CORS is disabled in your web browser. + +To start the server, run the following command: + +.. code-block:: bash + + flask --app pkg_api/server run --debug + +Note the `--debug` flag is optional, but it is recommended to use it during development. + +By default, the server will run locally on port 5000. In case you want to run the server on a different port, you can specify the port using the `--port` flag. + +Routes +------ + +The server has four main routes that relate to the :doc:`features available ` in the PKG Client: + +* `/auth`: Handles the authentication of users and service providers. +* `/nl`: Handles natural language instructions. +* `/statements`: Manages the addition and deletion of statements via forms. +* `/explore`: Handles SPARQL queries for the visualization of the PKG.