diff --git a/docs/dev/api-reference/feeds.rst b/docs/dev/api-reference/feeds.rst
index 2f17102971b3..cd9e398d6d0a 100644
--- a/docs/dev/api-reference/feeds.rst
+++ b/docs/dev/api-reference/feeds.rst
@@ -1,69 +1,9 @@
Feeds
=====
-PyPI offers three RSS feeds, the `Newest Packages Feed`_, the `Latest Updates
-Feed`_, and the `Project Releases Feed`_. You can also call its APIs to get
-more details on project activity.
+.. important::
+ This API documentation has been migrated to a new page in
+ the `user documentation `_:
-Newest Packages Feed
---------------------
-
-Available at https://pypi.org/rss/packages.xml, this feed provides the latest
-newly created projects on PyPI, including the package name, description and a
-link to the project page.
-
-
-Latest Updates Feed
--------------------
-
-Available at https://pypi.org/rss/updates.xml, this feed provides the latest
-newly created releases for individual projects on PyPI, including the project
-name and description, release version, and a link to the release page.
-
-
-Project Releases Feed
----------------------
-
-Available at ``https://pypi.org/rss/project//releases.xml`` for each
-project, this feed provides the latest releases for the given project on
-PyPI, including the package name and description, release version, and a link
-to the release page.
-
-
-Project and release activity details
-------------------------------------
-
-PyPI publishes a "journal" of all project, package, and release
-activity (including Owner and Maintainer additions and removals, and
-source file and release additions and removals). You can query it with
-a mix of :ref:`changelog-since` and the
-`index API `_. Call
-``changelog_last_serial()`` (in :doc:`xml-rpc`) to get the current
-revision of the journal (the last event's serial ID), then look at
-``/simple/`` to get a list of all packages that currently
-exist. Subsequently, you can call
-``changelog_since_serial(since_serial)`` with the serial ID you
-retrieved, and get the list of all actions that have occurred since
-then.
-
-Example usage::
-
- >>> import time
- >>> import xmlrpc.client
- >>> client = xmlrpc.client.ServerProxy("https://test.pypi.org/pypi")
- >>> serial = client.changelog_last_serial()
- >>> serial
- 4601224
- >>> while serial == client.changelog_last_serial():
- ... time.sleep(5)
- >>> recentchanges = client.changelog_since_serial(serial)
- >>> for entry in recentchanges:
- ... print(entry)
- ['openllm', '0.4.33.dev3', 1701280908, 'new release', 4601225]
- ['openllm', '0.4.33.dev3', 1701280908, 'add py3 file openllm-0.4.33.dev3-py3-none-any.whl', 4601226]
-
-You could also request ``GET /simple/``, and record the ``ETag``, and
-then periodically do a conditional HTTP GET to ``/simple/`` with that
-ETag included. A 200 OK response indicates something has been added or
-removed; if you get a 304 Not Modified, then nothing has changed.
+ * `RSS Feeds `_
diff --git a/docs/dev/api-reference/xml-rpc.rst b/docs/dev/api-reference/xml-rpc.rst
index 896bb448bf20..095900c1e3f4 100644
--- a/docs/dev/api-reference/xml-rpc.rst
+++ b/docs/dev/api-reference/xml-rpc.rst
@@ -35,6 +35,43 @@ Example usage (Python 3)::
'0.618': 14863648,
...
+Project and release activity details
+------------------------------------
+
+PyPI publishes a "journal" of all project, package, and release
+activity (including Owner and Maintainer additions and removals, and
+source file and release additions and removals). You can query it with
+a mix of :ref:`changelog-since` and the
+`index API `_. Call
+``changelog_last_serial()`` to get the current
+revision of the journal (the last event's serial ID), then look at
+``/simple/`` to get a list of all packages that currently
+exist. Subsequently, you can call
+``changelog_since_serial(since_serial)`` with the serial ID you
+retrieved, and get the list of all actions that have occurred since
+then.
+
+Example usage::
+
+ >>> import time
+ >>> import xmlrpc.client
+ >>> client = xmlrpc.client.ServerProxy("https://test.pypi.org/pypi")
+ >>> serial = client.changelog_last_serial()
+ >>> serial
+ 4601224
+ >>> while serial == client.changelog_last_serial():
+ ... time.sleep(5)
+ >>> recentchanges = client.changelog_since_serial(serial)
+ >>> for entry in recentchanges:
+ ... print(entry)
+ ['openllm', '0.4.33.dev3', 1701280908, 'new release', 4601225]
+ ['openllm', '0.4.33.dev3', 1701280908, 'add py3 file openllm-0.4.33.dev3-py3-none-any.whl', 4601226]
+
+You could also request ``GET /simple/``, and record the ``ETag``, and
+then periodically do a conditional HTTP GET to ``/simple/`` with that
+ETag included. A 200 OK response indicates something has been added or
+removed; if you get a 304 Not Modified, then nothing has changed.
+
.. _changes-to-legacy-api:
Changes to XMLRPC API
diff --git a/docs/mkdocs-user-docs.yml b/docs/mkdocs-user-docs.yml
index bb8259f64e5a..bd4e3d6e7a46 100644
--- a/docs/mkdocs-user-docs.yml
+++ b/docs/mkdocs-user-docs.yml
@@ -93,3 +93,4 @@ nav:
- "api/integrity.md"
- "api/stats.md"
- "api/bigquery.md"
+ - "api/feeds.md"
diff --git a/docs/user/api/feeds.md b/docs/user/api/feeds.md
new file mode 100644
index 000000000000..bb3bbfa9de16
--- /dev/null
+++ b/docs/user/api/feeds.md
@@ -0,0 +1,27 @@
+# RSS Feeds
+
+PyPI offers three RSS feeds: the Newest Packages Feed, the Latest Updates
+Feed, and the Project Releases Feed.
+
+## Newest Packages Feed
+
+*Feed URL:*
+
+This feed provides the latest newly created projects on PyPI, including the
+package name, description and a link to the project page.
+
+## Latest Updates Feed
+
+*Feed URL:*
+
+This feed provides the latest newly created releases for individual projects on
+PyPI, including the project name and description, release version, and a link
+to the release page.
+
+## Project Releases Feed
+
+*Feed URL:* `https://pypi.org/rss/project//releases.xml`
+
+Available for each project, this feed provides the latest releases for the
+given project on PyPI, including the package name and description, release
+version, and a link to the release page.