Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Move doc files from main repo into docs repo #426

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion docs/developer/rest_api_doc.md
Original file line number Diff line number Diff line change
@@ -69,7 +69,7 @@ filtered and produces an error, if found.
suite. To manually check the generated spec file, run

```bash
rucio/tools/test/check_rest_api_documentation.sh FILE
rucio_documentation/tools/check_rest_api_documentation.sh FILE
Copy link
Contributor

@rdimaio rdimaio Dec 18, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe we should say this to be explicit

Suggested change
rucio_documentation/tools/check_rest_api_documentation.sh FILE
[rucio documentation folder]/tools/check_rest_api_documentation.sh FILE

rucio_documentation is clear enough imo, but it might be interpreted as if we have an actual folder named rucio_documentation, whereas [rucio documentation folder] might be more easily interpreted as 'top-level Rucio documentation folder'

Copy link
Contributor Author

@voetberg voetberg Dec 18, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If we're linking directly to the file anyways, is there any harm in going Full explicit and doing

Suggested change
rucio_documentation/tools/check_rest_api_documentation.sh FILE
[rucio/documentation](https://github.com/rucio/documentation)/tools/check_rest_api_documentation.sh FILE

?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I like the idea, but I feel that the / in rucio/documentation could be interpreted as being part of the path, so it might be confusing

```

## Tips
39 changes: 39 additions & 0 deletions tools/check_rest_api_documentation.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
#!/bin/bash
# -*- coding: utf-8 -*-
# Copyright European Organization for Nuclear Research (CERN) since 2012
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

set -eo pipefail

SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )


command_exists() {
# check if command exists and fail otherwise
command -v "$1" >/dev/null 2>&1 || {
echo "$1 is required, but it's not installed. Abort."
exit 1
}
}


if [ "$#" -ne 1 ]; then
echo "Usage: check_rest_api_documentation.sh FILE"
exit 1
fi

command_exists "node"
command_exists "npx"

npx @redocly/cli lint --config "$SCRIPT_DIR/redocly.yaml" "$1"
126 changes: 126 additions & 0 deletions tools/run_in_docker/generate_rest_api_docs.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,126 @@
#!/usr/bin/env python3
# Copyright European Organization for Nuclear Research (CERN) since 2012
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from apispec import APISpec # type: ignore
from apispec_webframeworks.flask import FlaskPlugin # type: ignore
from rucio.vcsversion import VERSION_INFO # type: ignore
from rucio.web.rest.flaskapi.v1.main import application # type: ignore
Comment on lines +16 to +19
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

what are the # type: ignore comments for?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The python script checking action claims these packages don't exist and fails the build 😔

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe we could add them to the requirements instead - I guess they can be seen as part of the requirements for building the docs, so it makes sense that they'd need to be part of the requirements.txt file

  check_python_scripts:
    name: Check Python Scripts
    runs-on: ubuntu-latest
    steps:
      - name: Checkout repository
        uses: actions/checkout@v4
      - name: Install dependencies
        run: |
          pip install -r tools/requirements.txt
      - name: Run black
        run: |
          black --check .
      - name: Run isort
        run: |
          isort --profile black --filter-files --check .
      - name: Run flake8
        run: |
          flake8 --config tools/.flake8
      - name: MyPy
        run: |
          mypy --ignore-missing-imports .


description_text = """Each resource can be accessed or modified using specially
formed URLs and the standard HTTP methods:

- GET to read

- POST to create

- PUT to update

- DELETE to remove

We require that all requests are done over SSL. The API supports JSON
formats. Rucio uses [OAuth](http://oauth.net/) to authenticate all API
requests. The method is to get an authentication token, and use it for the rest
of the requests. Descriptions of the actions you may perform on each resource
can be found below.

### Date format

All dates returned are in UTC and are strings in the following format
(RFC 1123, ex RFC 822):

```
Mon, 13 May 2013 10:23:03 UTC
```

In code format, which can be used in all programming languages that support
strftime or strptime:

```
%a, %d %b %Y %H:%M:%S UTC
```

### SSL only

We require that all requests(except for the ping) are done over SSL.

### Response formats

The currently-available response format for all REST endpoints is the
string-based format JavaScript Object
Notation([JSON](http://www.json.org/)). The server answer can be one of the
following content-type in the http Header:

```text
Content-type: application/json
Content-Type: application/x-json-stream
```

In the last case, it corresponds to JSON objects delimited by newlines
(streaming JSON for large answer), e.g.:

```
{ "id": 1, "foo": "bar" } { "id": 2, "foo": "baz" } ...
```

### Error handling

Errors are returned using standard HTTP error code syntax. Any additional info
is included in the header of the return call, JSON-formatted with the
parameters:

```
ExceptionClass ExceptionMessage
```

Where ExceptionClass refers to [`Rucio
Exceptions`](https://github.com/rucio/rucio/blob/58efd21b5e21182df80bef3dbe8befa636e440b8/lib/rucio/common/exception.py).
"""


spec = APISpec(
title="Rucio",
version=VERSION_INFO["version"],
openapi_version="3.0.2",
plugins=[FlaskPlugin()],
info={
"description": description_text,
"license": {
"name": "Apache 2.0",
"url": "https://www.apache.org/licenses/LICENSE-2.0.html",
},
"x-logo": {
"url": "http://rucio.cern.ch/documentation/img/rucio_horizontaled_black_cropped.svg", # noqa: E501
"backgroundColor": "#FFFFFF",
"altText": "Rucio logo",
},
},
# See: https://swagger.io/docs/specification/authentication/api-keys/
components={
"securitySchemes": {
"AuthToken": {
"type": "apiKey",
"in": "header",
"name": "X-Rucio-Auth-Token",
"description": "The Rucio Token obtained by one of the /auth endpoints.", # noqa: E501
},
},
},
security=[{"AuthToken": []}],
)

with application.test_request_context():
for view_func in application.view_functions.values():
spec.path(view=view_func)
print(spec.to_yaml())
2 changes: 1 addition & 1 deletion tools/run_in_docker/generate_rest_api_docs.sh
Original file line number Diff line number Diff line change
@@ -3,4 +3,4 @@
set -e

echo "Generating the Rest Api Docs..."
rucio/tools/generate_rest_api_doc.py > /auto_generated/rest_api_doc_spec.yaml
/usr/bin/env python3 generate_rest_api_docs.py > /auto_generated/rest_api_doc_spec.yaml
Loading