Skip to content

Conversation

@miguelgrinberg
Copy link
Contributor

@miguelgrinberg miguelgrinberg commented Jan 29, 2025

Reorganization of the Sphinx docs to only include reference pages.

@github-actions
Copy link

A documentation preview will be available soon.

Request a new doc build by commenting
  • Rebuild this PR: run docs-build
  • Rebuild this PR and all Elastic docs: run docs-build rebuild

run docs-build is much faster than run docs-build rebuild. A rebuild should only be needed in rare situations.

If your PR continues to fail for an unknown reason, the doc build pipeline may be broken. Elastic employees can check the pipeline status here.

@miguelgrinberg miguelgrinberg marked this pull request as ready for review January 30, 2025 20:27
Copy link
Member

@pquentin pquentin left a comment

Choose a reason for hiding this comment

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

LGTM, but we should wait for HTTP redirects to be in place before merging IMO.

Including a redirect from /api.html to /index.html.

@miguelgrinberg
Copy link
Contributor Author

miguelgrinberg commented Jan 31, 2025

@pquentin Redirect table proposal:

source 8.18 9.0+
/en/latest/ No change No change
/en/latest/quickstart.html https://www.elastic.co/guide/en/elasticsearch/client/python-api/8.18/getting-started-python.html https://www.elastic.co/docs/reference/elasticsearch-py/getting-started
/en/latest/interactive.html https://www.elastic.co/guide/en/elasticsearch/client/python-api/8.18/examples.html https://www.elastic.co/docs/reference/elasticsearch-py/examples
/en/latest/api.html /en/latest/index.html /en/latest/index.html
/en/latest/exceptions.html No change No change
/en/latest/async.html https://www.elastic.co/guide/en/elasticsearch/client/python-api/8.18/async.html https://www.elastic.co/docs/reference/elasticsearch-py/async
/en/latest/helpers.html https://www.elastic.co/guide/en/elasticsearch/client/python-api/8.18/client-helpers.html https://www.elastic.co/docs/reference/elasticsearch-py/client-helpers

The api.html, async.html and helpers.html exist in both old and new designs. Would it make sense rename these pages in the redesigned docs, so that we can add the redirects above and also have pages we can link from now on?

And aside from this, it is unfortunate but I think we are going to have to create redirects for each version that we publish, until we decide this isn't necessary anymore, because we want the <= 8.17 docs to be redirect free, meaning that we cannot do generic redirects across all versions.

@pquentin
Copy link
Member

The api.html, async.html and helpers.html exist in both old and new designs. Would it make sense rename these pages in the redesigned docs, so that we can add the redirects above and also have pages we can link from now on?

Yes, good point.

And aside from this, it is unfortunate but I think we are going to have to create redirects for each version that we publish, until we decide this isn't necessary anymore, because we want the <= 8.17 docs to be redirect free, meaning that we cannot do generic redirects across all versions.

That makes sense. The free plan we're using allows for 100 redirects, but I'm assuming we will only need redirects for latest, stable, 8.18, 8.19, 9.0 and 9.1, not much more than that?

@miguelgrinberg
Copy link
Contributor Author

miguelgrinberg commented Jan 31, 2025

All pages renamed so that there are no collisions with the redirects. I guess we can wait until the new docs system is in place to see if the redirects above need to be adjusted, and only merge this PR after we put those in.

@miguelgrinberg miguelgrinberg changed the title add DSL module reference documentation to sphinx docs Reorganization of the Sphinx docs to only include reference pages Jan 31, 2025
@miguelgrinberg
Copy link
Contributor Author

Rebased to incorporate minor changes made during the docs migration to markdown.

Copy link
Member

Choose a reason for hiding this comment

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

Why was this renamed? This is going to break existing links, I believe

Copy link
Contributor Author

@miguelgrinberg miguelgrinberg Mar 4, 2025

Choose a reason for hiding this comment

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

This is to avoid collisions when we add the redirects. Look at the table above. Requests to /en/latest/api.html will be redirected to /en/latest/index.html, since now the whole site is reference documentation. This page is renamed because if not there would be no way to create a direct link to it, given that it collides with the redirect.

Side note, the URLs under the new doc system are different, so the second column of the redirect table above needs to be updated to match the markdown doc URLs (and hopefully the docs team have added their own redirects from the old URLs to the new.)

Comment on lines 1 to 3
Python Elasticsearch Client
===========================

Copy link
Member

Choose a reason for hiding this comment

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

Should we link to the main docs?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Yes, we should add links to the guide in all the reference pages where there is a reasonable page to link to. I'm looking into this.

@miguelgrinberg
Copy link
Contributor Author

@pquentin I have updated the redirect table. It now has redirects for 8.18 and 9.0+ separately. I need to confirm that I've got the 9.0 links right, since these are not deployed yet and I'm building them based on previews and descriptions of what the URL system is going to be.

Can you confirm that this looks good?
There was an outstanding question you had regarding the rename of api.html to es-api.html. Do you now understand why I did this, or do we need to discuss this more?

@pquentin
Copy link
Member

pquentin commented Mar 20, 2025

Sounds good! We can set up the 9.0 redirects when the docs are live. Yes, es-api.html, makes sense.

Thank you for this work

@miguelgrinberg
Copy link
Contributor Author

miguelgrinberg commented Apr 15, 2025

Updated table of redirects:

source destination
/en/{latest,stable}/ No change
/en/{latest,stable}/quickstart.html https://www.elastic.co/docs/reference/elasticsearch/clients/python/getting-started
/en/{latest,stable}/interactive.html https://www.elastic.co/docs/reference/elasticsearch/clients/python/examples
/en/{latest,stable}/api.html /en/latest/index.html
/en/{latest,stable}/exceptions.html No change
/en/{latest,stable}/async.html https://www.elastic.co/docs/reference/elasticsearch/clients/python/async
/en/{latest,stable}/helpers.html https://www.elastic.co/docs/reference/elasticsearch/clients/python/client-helpers

@miguelgrinberg miguelgrinberg merged commit a1b458e into elastic:main Apr 15, 2025
13 checks passed
@miguelgrinberg miguelgrinberg deleted the dsl-reference-docs branch April 15, 2025 16:08
@github-actions
Copy link

The backport to 8.x failed:

The process '/usr/bin/git' failed with exit code 1

To backport manually, run these commands in your terminal:

# Fetch latest updates from GitHub
git fetch
# Create a new working tree
git worktree add .worktrees/backport-8.x 8.x
# Navigate to the new working tree
cd .worktrees/backport-8.x
# Create a new branch
git switch --create backport-2776-to-8.x
# Cherry-pick the merged commit of this pull request and resolve the conflicts
git cherry-pick -x --mainline 1 a1b458e37e62f1abe0582b4c28d838dfe1e364e8
# Push it to GitHub
git push --set-upstream origin backport-2776-to-8.x
# Go back to the original working tree
cd ../..
# Delete the working tree
git worktree remove .worktrees/backport-8.x

Then, create a pull request where the base branch is 8.x and the compare/head branch is backport-2776-to-8.x.

@github-actions
Copy link

The backport to 8.18 failed:

The process '/usr/bin/git' failed with exit code 1

To backport manually, run these commands in your terminal:

# Fetch latest updates from GitHub
git fetch
# Create a new working tree
git worktree add .worktrees/backport-8.18 8.18
# Navigate to the new working tree
cd .worktrees/backport-8.18
# Create a new branch
git switch --create backport-2776-to-8.18
# Cherry-pick the merged commit of this pull request and resolve the conflicts
git cherry-pick -x --mainline 1 a1b458e37e62f1abe0582b4c28d838dfe1e364e8
# Push it to GitHub
git push --set-upstream origin backport-2776-to-8.18
# Go back to the original working tree
cd ../..
# Delete the working tree
git worktree remove .worktrees/backport-8.18

Then, create a pull request where the base branch is 8.18 and the compare/head branch is backport-2776-to-8.18.

github-actions bot pushed a commit that referenced this pull request Apr 15, 2025
)

* add DSL module reference documentation to sphinx docs

* only reference docs

* renamed pages to avoid collisions with redirects

(cherry picked from commit a1b458e)
miguelgrinberg added a commit that referenced this pull request Apr 15, 2025
) (#2924)

* add DSL module reference documentation to sphinx docs

* only reference docs

* renamed pages to avoid collisions with redirects

(cherry picked from commit a1b458e)

Co-authored-by: Miguel Grinberg <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants