2022-08-27 11:52:29 +05:30
---
stage: Package
2023-01-13 00:05:48 +05:30
group: Package Registry
2022-11-25 23:54:43 +05:30
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/product/ux/technical-writing/#assignments
2022-08-27 11:52:29 +05:30
---
# Terraform Registry API **(FREE)**
This is the API documentation for [Terraform Modules ](../../user/packages/terraform_module_registry/index.md ).
WARNING:
2023-03-04 22:38:38 +05:30
This API is used by the [Terraform CLI ](https://www.terraform.io/ )
2022-08-27 11:52:29 +05:30
and is generally not meant for manual consumption.
2022-10-11 01:57:18 +05:30
For instructions on how to upload and install Terraform modules from the GitLab
infrastructure registry, see the [Terraform modules registry documentation ](../../user/packages/terraform_module_registry/index.md ).
2022-08-27 11:52:29 +05:30
## List available versions for a specific module
Get a list of available versions for a specific module.
```plaintext
GET packages/terraform/modules/v1/:module_namespace/:module_name/:module_system/versions
```
| Attribute | Type | Required | Description |
| --------- | ---- | -------- | ----------- |
2022-11-25 23:54:43 +05:30
| `module_namespace` | string | yes | The top-level group (namespace) to which Terraform module's project or subgroup belongs.|
2022-08-27 11:52:29 +05:30
| `module_name` | string | yes | The module name. |
| `module_system` | string | yes | The name of the module system or [provider ](https://www.terraform.io/registry/providers ). |
```shell
2022-11-25 23:54:43 +05:30
curl --header "Authorization: Bearer < personal_access_token > " "https://gitlab.example.com/api/v4/packages/terraform/modules/v1/group/hello-world/local/versions"
2022-08-27 11:52:29 +05:30
```
Example response:
```shell
{
"modules": [
{
"versions": [
{
"version": "1.0.0",
"submodules": [],
"root": {
"dependencies": [],
"providers": [
{
"name": "local",
"version":""
}
]
}
},
{
"version": "0.9.3",
"submodules": [],
"root": {
"dependencies": [],
"providers": [
{
"name": "local",
"version":""
}
]
}
}
],
"source": "https://gitlab.example.com/group/hello-world"
}
]
}
```
## Latest version for a specific module
Get information about the latest version for a given module.
```plaintext
GET packages/terraform/modules/v1/:module_namespace/:module_name/:module_system
```
| Attribute | Type | Required | Description |
| --------- | ---- | -------- | ----------- |
| `module_namespace` | string | yes | The group to which Terraform module's project belongs. |
| `module_name` | string | yes | The module name. |
| `module_system` | string | yes | The name of the module system or [provider ](https://www.terraform.io/registry/providers ). |
```shell
2022-11-25 23:54:43 +05:30
curl --header "Authorization: Bearer < personal_access_token > " "https://gitlab.example.com/api/v4/packages/terraform/modules/v1/group/hello-world/local"
2022-08-27 11:52:29 +05:30
```
Example response:
```shell
{
"name": "hellow-world/local",
"provider": "local",
"providers": [
"local"
],
"root": {
"dependencies": []
},
"source": "https://gitlab.example.com/group/hello-world",
"submodules": [],
"version": "1.0.0",
"versions": [
"1.0.0"
]
}
```
## Get specific version for a specific module
2022-10-11 01:57:18 +05:30
Get information about a specific version for a given module.
2022-08-27 11:52:29 +05:30
```plaintext
GET packages/terraform/modules/v1/:module_namespace/:module_name/:module_system/1.0.0
```
| Attribute | Type | Required | Description |
| --------- | ---- | -------- | ----------- |
| `module_namespace` | string | yes | The group to which Terraform module's project belongs. |
| `module_name` | string | yes | The module name. |
| `module_system` | string | yes | The name of the module system or [provider ](https://www.terraform.io/registry/providers ). |
```shell
2022-11-25 23:54:43 +05:30
curl --header "Authorization: Bearer < personal_access_token > " "https://gitlab.example.com/api/v4/packages/terraform/modules/v1/group/hello-world/local/1.0.0"
2022-08-27 11:52:29 +05:30
```
Example response:
```shell
{
"name": "hellow-world/local",
"provider": "local",
"providers": [
"local"
],
"root": {
"dependencies": []
},
"source": "https://gitlab.example.com/group/hello-world",
"submodules": [],
"version": "1.0.0",
"versions": [
"1.0.0"
]
}
```
## Get URL for downloading latest module version
Get the download URL for latest module version in `X-Terraform-Get` header
```plaintext
GET packages/terraform/modules/v1/:module_namespace/:module_name/:module_system/download
```
| Attribute | Type | Required | Description |
| --------- | ---- | -------- | ----------- |
| `module_namespace` | string | yes | The group to which Terraform module's project belongs. |
| `module_name` | string | yes | The module name. |
| `module_system` | string | yes | The name of the module system or [provider ](https://www.terraform.io/registry/providers ). |
```shell
2022-11-25 23:54:43 +05:30
curl --header "Authorization: Bearer < personal_access_token > " "https://gitlab.example.com/api/v4/packages/terraform/modules/v1/group/hello-world/local/download"
2022-08-27 11:52:29 +05:30
```
Example response:
```shell
HTTP/1.1 204 No Content
Content-Length: 0
X-Terraform-Get: /api/v4/packages/terraform/modules/v1/group/hello-world/local/1.0.0/file?token=& archive=tgz
```
Under the hood, this API endpoint redirects to `packages/terraform/modules/v1/:module_namespace/:module_name/:module_system/:module_version/download`
## Get URL for downloading specific module version
Get the download URL for a specific module version in `X-Terraform-Get` header
```plaintext
GET packages/terraform/modules/v1/:module_namespace/:module_name/:module_system/:module_version/download
```
| Attribute | Type | Required | Description |
| --------- | ---- | -------- | ----------- |
| `module_namespace` | string | yes | The group to which Terraform module's project belongs. |
| `module_name` | string | yes | The module name. |
| `module_system` | string | yes | The name of the module system or [provider ](https://www.terraform.io/registry/providers ). |
| `module_version` | string | yes | Specific module version to download. |
```shell
2022-11-25 23:54:43 +05:30
curl --header "Authorization: Bearer < personal_access_token > " "https://gitlab.example.com/api/v4/packages/terraform/modules/v1/group/hello-world/local/1.0.0/download"
2022-08-27 11:52:29 +05:30
```
Example response:
```shell
HTTP/1.1 204 No Content
Content-Length: 0
X-Terraform-Get: /api/v4/packages/terraform/modules/v1/group/hello-world/local/1.0.0/file?token=& archive=tgz
```
## Download module
```plaintext
GET packages/terraform/modules/v1/:module_namespace/:module_name/:module_system/:module_version/file
```
| Attribute | Type | Required | Description |
| --------- | ---- | -------- | ----------- |
| `module_namespace` | string | yes | The group to which Terraform module's project belongs. |
| `module_name` | string | yes | The module name. |
| `module_system` | string | yes | The name of the module system or [provider ](https://www.terraform.io/registry/providers ). |
| `module_version` | string | yes | Specific module version to download. |
```shell
2022-11-25 23:54:43 +05:30
curl --header "Authorization: Bearer < personal_access_token > " "https://gitlab.example.com/api/v4/packages/terraform/modules/v1/group/hello-world/local/1.0.0/file"
2022-08-27 11:52:29 +05:30
```
To write the output to file:
```shell
2022-11-25 23:54:43 +05:30
curl --header "Authorization: Bearer < personal_access_token > " "https://gitlab.example.com/api/v4/packages/terraform/modules/v1/group/hello-world/local/1.0.0/file" --output hello-world-local.tgz
2022-08-27 11:52:29 +05:30
```