(projects-work)= # How to work with different projects If you have more projects than just the `default` project, you must make sure to use or address the correct project when working with LXD. ```{note} If you have projects that are {ref}`confined to specific users `, only users with full access to LXD can see all projects. Users without full access can only see information for the projects to which they have access. ``` ## List projects `````{tabs} ````{group-tab} CLI To list all projects (that you have permission to see), enter the following command: lxc project list By default, the output is presented as a list: ```{terminal} :input: lxc project list :scroll: +----------------------+--------+----------+-----------------+-----------------+----------+---------------+---------------------+---------+ | NAME | IMAGES | PROFILES | STORAGE VOLUMES | STORAGE BUCKETS | NETWORKS | NETWORK ZONES | DESCRIPTION | USED BY | +----------------------+--------+----------+-----------------+-----------------+----------+---------------+---------------------+---------+ | default | YES | YES | YES | YES | YES | YES | Default LXD project | 19 | +----------------------+--------+----------+-----------------+-----------------+----------+---------------+---------------------+---------+ | my-project (current) | YES | NO | NO | NO | YES | YES | | 0 | +----------------------+--------+----------+-----------------+-----------------+----------+---------------+---------------------+---------+ ``` You can request a different output format by adding the `--format` flag. See [`lxc project list --help`](lxc_project_list.md) for more information. ```` ````{group-tab} API To list all projects (that you have permission to see), send the following request: lxc query --request GET /1.0/projects To display information about each project, use {ref}`rest-api-recursion`: lxc query --request GET /1.0/projects?recursion=1 See [`GET /1.0/projects`](swagger:/projects/projects_get) and [`GET /1.0/projects?recursion=1`](swagger:/projects/projects_get_recursion1) for more information. ```` ````{group-tab} UI To list all projects (that you have permission to see), expand the {guilabel}`Project` drop-down. ```` ````` (projects-switch)= ## Switch projects ````{tabs} ```{group-tab} CLI By default, all commands that you issue in LXD affect the project that you are currently using. To see which project you are in, use the [`lxc project list`](lxc_project_list.md) command. To switch to a different project, enter the following command: lxc project switch ``` ```{group-tab} API The API does not have the concept of switching projects. All requests target the default project unless a different project is specified (see {ref}`projects-target`). ``` ```{group-tab} UI To switch to another project, select a different project from the {guilabel}`Project` drop-down. ``` ```` (projects-target)= ## Target a project When using the CLI or the API, you can target a specific project when running a command. Many LXD commands support the `--project` flag or the `project` parameter to run an action in a different project. ```{note} You can target only projects that you have permission for. ``` An example for targeting another project instead of switching to it is listing the instances in a specific project: ````{tabs} ```{group-tab} CLI To list the instances in a specific project, add the `--project` flag to the [`lxc list`](lxc_list.md) command. For example: lxc list --project my-project ``` ```{group-tab} API To list the instances in a specific project, add the `project` parameter to the request. For example: lxc query --request GET /1.0/instances?project=my-project Or with {ref}`rest-api-recursion`: lxc query --request GET /1.0/instances?recursion=2\&project=my-project ``` ```{group-tab} UI The UI does not currently support targeting another project. Instead, {ref}`switch to the other project `. ``` ```` ## Move an instance to another project ````{tabs} ```{group-tab} CLI To move an instance from one project to another, enter the following command: lxc move --project --target-project You can keep the same instance name if no instance with that name exists in the target project. For example, to move the instance `my-instance` from the `default` project to `my-project` and keep the instance name, enter the following command: lxc move my-instance my-instance --project default --target-project my-project ``` ```{group-tab} API To move an instance from one project to another, send a POST request to the instance: lxc query --request POST /1.0/instances/?project= --data '{ "name": "", "project": "", "migration": true }' If no instance with that name exists in the target project, you can leave out the name for the new instance to keep the existing name. For example, to move the instance `my-instance` from the `default` project to `my-project` and keep the instance name, enter the following command: lxc query --request POST /1.0/instances/my-instance?project=default --data '{ "project": "my-project", "migration": true }' Depending on your projects, you might need to change other configuration options when moving the instance. For example, you might need to change the root disk device if one of the projects uses isolated storage volumes. See [`POST /1.0/instances/{name}`](swagger:/instances/instance_post) for more information. ``` ```{group-tab} UI The UI does not currently support moving instances between projects. ``` ```` ## Copy a profile to another project If you create a project with the default settings, profiles are isolated in the project ({config:option}`project-features:features.profiles` is set to `true`). Therefore, the project does not have access to the default profile (which is part of the `default` project), and you will see an error similar to the following when trying to create an instance: Error: Failed instance creation: Failed creating instance record: Failed initialising instance: Failed getting root disk: No root device could be found To fix this, you can copy the contents of the `default` project's default profile into the current project's default profile. To do so: ````{tabs} ```{group-tab} CLI Enter the following command: lxc profile show default --project default | lxc profile edit default ``` ```{group-tab} API Send the following request, replacing `` with the new project that has an empty default profile: lxc query --request PUT /1.0/profiles/default?projects= --data \ "$(lxc query --request GET /1.0/profiles/default)" ``` ```{group-tab} UI 1. Select the `default` project from the {guilabel}`Project` drop-down. 1. Go to {guilabel}`Profiles` and select the default profile. 1. In the profile view, switch to the {guilabel}`Configuration` tab. 1. Select {guilabel}`YAML configuration` and copy the YAML representation of the profile. 1. Select the project with the empty default profile from the {guilabel}`Project` drop-down. 1. Go to {guilabel}`Profiles` and select the empty default profile for the project. 1. In the profile view, switch to the {guilabel}`Configuration` tab. 1. Select {guilabel}`YAML configuration` and click {guilabel}`Edit profile`. 1. Paste the YAML representation that you copied and save the changes. ``` ````