Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docs(vpcgw): add v2 migration guide #2991

Merged
merged 23 commits into from
Mar 25, 2025
Merged
Changes from all commits
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
177 changes: 177 additions & 0 deletions docs/guides/migration_guide_vpcgw_v2.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,177 @@
---
page_title: "Moving a Public Gateway from Legacy mode to IPAM mode, for v2 compatibility"
---

# Moving a Public Gateway from Legacy mode to IPAM mode

This guide explains how to move a Public Gateway from [Legacy mode](https://www.scaleway.com/en/docs/public-gateways/concepts/#ipam) to IPAM mode. Only gateways in IPAM mode will be compatible with the new v2 of the Public Gateways API. v1 of the API is deprecated, and will be removed before the end of 2025.
In the legacy setup, DHCP and DHCP reservations are managed with dedicated resources and referenced in the gateway network.
In IPAM mode, these functionalities are managed by Scaleway IPAM.
In 2023, DHCP functionality was moved from Public Gateways to Private Networks, DHCP resources are now no longer needed on the Public Gateway itself.

You can find out more about the deprecation of v1 of the Public Gateways API, and the obligatory move to IPAM mode, in the [main Public Gateways documentation](https://www.scaleway.com/en/docs/public-gateways/).

Note:
Trigger the move from Legacy mode to IPAM mode by setting the `move_to_ipam` flag on your Public Gateway resource.
You can do this via the Terraform configuration or by using the Scaleway CLI/Console.

Using the CLI:
Ensure you have at least version v2.38.0 of the Scaleway CLI installed. Then run:

```bash
scw vpc-gw gateway move-to-ipam 'id-of-the-public-gateway'
```


## Prerequisites

### Ensure the Latest Provider Version

Ensure your Scaleway Terraform provider is updated to at least version `2.52.0`.

```hcl
terraform {
required_providers {
scaleway = {
source = "scaleway/scaleway"
version = "~> v2.52.0"
}
}
}
```

## Steps to Move to IPAM Mode

### Legacy Configuration

A typical legacy configuration might look like this:

```hcl
resource "scaleway_vpc" "main" {
name = "foo"
}

resource "scaleway_vpc_private_network" "main" {
name = "bar"
vpc_id = scaleway_vpc.main.id
}

resource "scaleway_vpc_public_gateway_ip" "main" {
}

resource "scaleway_vpc_public_gateway" "main" {
name = "foobar"
type = "VPC-GW-S"
ip_id = scaleway_vpc_public_gateway_ip.main.id
}

resource "scaleway_vpc_public_gateway_dhcp" "main" {
subnet = "192.168.1.0/24"
}

resource "scaleway_instance_server" "main" {
image = "ubuntu_focal"
type = "DEV1-S"
}

resource "scaleway_instance_private_nic" "main" {
server_id = scaleway_instance_server.main.id
private_network_id = scaleway_vpc_private_network.main.id
}

resource "scaleway_vpc_gateway_network" "main" {
gateway_id = scaleway_vpc_public_gateway.main.id
private_network_id = scaleway_vpc_private_network.main.id
dhcp_id = scaleway_vpc_public_gateway_dhcp.main.id
cleanup_dhcp = true
enable_masquerade = true
}

resource "scaleway_vpc_public_gateway_dhcp_reservation" "main" {
gateway_network_id = scaleway_vpc_gateway_network.main.id
mac_address = scaleway_instance_private_nic.main.mac_address
ip_address = "192.168.1.1"
}
```

### Triggering the move to IPAM-mode

Before updating your configuration, you must trigger the move to IPAM-mode on the Public Gateway resource. For example, add the `move_to_ipam` flag:

```hcl
resource "scaleway_vpc_public_gateway" "main" {
name = "foobar"
type = "VPC-GW-S"
ip_id = scaleway_vpc_public_gateway_ip.main.id
move_to_ipam = true
}
```

This call puts the gateway into IPAM mode and means it will now be managed by v2 of the API instead of v1. The DHCP configuration and reservations remain intact, but the underlying resource is now managed using v2.

### Updated Configuration

After triggering the move, update your Terraform configuration as follows:

1. **Remove the DHCP and DHCP Reservation Resources**

Since DHCP functionality is built directly into Private Networks, you no longer need the DHCP configuration resources. Delete the following from your config:

`scaleway_vpc_public_gateway_dhcp`
`scaleway_vpc_public_gateway_dhcp_reservation`

2. **Update the Gateway Network**

Replace the DHCP related attributes with an `ipam_config` block. For example

```hcl
resource "scaleway_vpc_gateway_network" "main" {
gateway_id = scaleway_vpc_public_gateway.main.id
private_network_id = scaleway_vpc_private_network.main.id
enable_masquerade = true
ipam_config {
push_default_route = false
}
}
```

### Using the IPAM Datasource and Resource for Reservations

After putting your Public Gateway in IPAM mode, you no longer manage DHCP reservations with dedicated resources.
Instead, you remove the legacy DHCP reservation resource and switch to using IPAM to manage your IPs.

1. **Retrieve an Existing IP with the IPAM Datasource**
If you have already reserved an IP (for example, via your legacy configuration), even after deleting the DHCP reservation resource the IP is still available. You can retrieve it using the `scaleway_ipam_ip` datasource. For instance:

```hcl
data "scaleway_ipam_ip" "existing" {
mac_address = scaleway_instance_private_nic.main.mac_address
type = "ipv4"
}
```

You can now use `data.scaleway_ipam_ip.existing.id` in your configuration to reference the reserved IP.

2. **Book New IPs Using the IPAM IP Resource**
If you need to reserve new IPs, use the `scaleway_ipam_ip` resource. This resource allows you to explicitly book an IP from your private network. For example:

```hcl
resource "scaleway_ipam_ip" "new_ip" {
address = "192.168.1.1"
source {
private_network_id = scaleway_vpc_private_network.main.id
}
}
```

3. **Attach the Reserved IP to Your Resources**

Once you have your IP—whether retrieved via the datasource or booked as a new resource—you can attach it to your server’s private NIC:

```hcl
resource "scaleway_instance_private_nic" "pnic01" {
private_network_id = scaleway_vpc_private_network.main.id
server_id = scaleway_instance_server.main.id
ipam_ip_ids = [scaleway_ipam_ip.new_ip.id]
}
```
Loading