============================
Transitioning to scoped URLs
============================

As part of implementing :ref:`permission checks <permission-management-blueprint>`,
debusine is moving towards scoped URLs, and it requires a transition plan.


Fallback scope introduced in migrations
=======================================

The database migration that introduces scopes for workspaces needs a fallback
scope to assign existing workspaces, and it was decided to use ``debusine``.

Existing instances of debusine that will undergo database migration will
therefore find everything under the ``debusine`` scope. This is unlikely to be
what users need, so there needs to be a way to rename a scope after the
migration.

.. todo::

   Implement a management command to rename a scope.

   This is likely to be a simple management command that changes
   ``Scope.name``, since only foreign keys to scope are used to refer to scope
   at the database level.

However, the parts of Debusine who are not yet scope aware are needing a name
to lookup a default scope, and this needs to be changed accordingly.

.. todo::

   Add a ``DEFAULT_SCOPE`` (or ``TRANSITIONAL_DEFAULT_SCOPE``) setting
   (defaulting to ``debusine``) to specify the name of the default scope to use
   during the transitioning period where not all of Debusine is yet
   scope-aware.

This is supposed to eventually disappear the moment a Debusine instance will be
able to host multiple scopes: at that point the idea of a fallback scope will
need to be removed, as it will become a cause of ambiguity.


Transitioning web URLs
======================

Most debusine URLs are going to require a scope. For example,
``https://debusine.debian.net/workspace/`` will become
``https://debusine.debian.net/debian/workspace/``

A change of a URL namespace may break existing URL references. We can decide
that it's not worth the effort of setting up redirect, or to set up redirect
views forwarding to the configured fallback scope.

.. todo::

   Design a way to set up a system of best-effort redirects.


Transitioning APIs
==================

``debusine-client`` is currently not scope-aware, and API calls are currently
unable to use a scope different from the fallback one.

We have many implementation options:

* Use the scope in the base URL (for example: use
  ``https://debusine.debian.net/debian/api`` instead of
  ``https://debusine.debian.net/api``)

  This seems straightforward: the scope middleware can match ``/api/*`` paths
  and instantiate an unscoped urlconf, while setting the fallback scope for the
  request.

  ``debusine-client`` would then need to change URL only if it needs to point
  to a different scope.

* Keep using ``/api`` and pass the scope in a header

  This also seems straightforward, and it would provide an easy compatibility
  option to use the fallback scope if one is not provided in a header.

  We would then need to add a new configuration (and possibly also command
  line) option for ``debusine-client`` to configure a default scope.

  An advantage of this over the previous option is that clients would not need
  to edit URLs adding the scope before ``/api`` when changing scope.

* Keep using /api and pass the scope in an argument to the API call

  This seems to introduce a lot of disruption for little gain.


.. todo::

   Document a header in API calls used to select scope.

   When the header is missing, use the fallback scope.

   Add a configuration option in ``debusine-client`` to select the default scope.

   Add a command line option in ``debusine-client`` to specify a different scope.

   Make sure we have a scope-aware client in testing and stable-backports
   before we drop support for unscoped API calls.
