You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
terraform-provider-decort/README.md

166 lines
5.7 KiB

5 years ago
# terraform-provider-decort
3 years ago
Terraform provider для платформы Digital Energy Cloud Orchestration Technology (DECORT)
3 years ago
Внимание: провайдер версии 3.x разработан для DECORT API 3.8.x.
Для более старых версий можно использовать:
3 years ago
3 years ago
- DECORT API 3.7.x - версия провайдера rc-1.25
- DECORT API 3.6.x - версия провайдера rc-1.10
- DECORT API до 3.6.0 - terraform DECS provider (https://github.com/rudecs/terraform-provider-decs)
3 years ago
## Режимы работы
3 years ago
3 years ago
Провайдер позволяет работать в двух режимах:
3 years ago
3 years ago
- Режим пользователя,
- Режим администратора.
3 years ago
Для переключения между режимами используйте флаг DECORT_ADMIN_MODE.
Вики проекта: https://github.com/rudecs/terraform-provider-decort/wiki
3 years ago
## Возможности провайдера
3 years ago
- Работа с Compute instances,
- Работа с disks,
- Работа с k8s,
- Работа с image,
- Работа с reource groups,
- Работа с VINS,
- Работа с pfw,
- Работа с accounts,
- Работа с snapshots,
- Работа с pcidevice,
- Работа с sep,
- Работа с vgpu,
4 years ago
- Работа с bservice,
3 years ago
- Работа с extnets,
3 years ago
- Работа с locations,
- Работа с load balancer.
Вики проекта: https://github.com/rudecs/terraform-provider-decort/wiki
## Начало
3 years ago
Старт возможен по двум путям:
1. Установка через собранные пакеты.
2. Ручная установка.
### Установка через собранные пакеты.
3 years ago
1. Скачайте и установите terraform по ссылке: https://learn.hashicorp.com/tutorials/terraform/install-cli?in=terraform/aws-get-started
2. Создайте файл `main.tf` и добавьте в него следующий блок.
3 years ago
```terraform
provider "decort" {
authenticator = "oauth2"
#controller_url = <DECORT_CONTROLLER_URL>
controller_url = "https://ds1.digitalenergy.online"
#oauth2_url = <DECORT_SSO_URL>
oauth2_url = "https://sso.digitalenergy.online"
allow_unverified_ssl = true
}
```
3 years ago
3. Выполните команду
3 years ago
```
terraform init
```
3 years ago
Провайдер автоматически будет установлен на ваш компьютер из terraform registry.
### Ручная установка
3 years ago
1. Скачайте и установите Go по ссылке: https://go.dev/dl/
2. Скачайте и установите terraform по ссылке: https://learn.hashicorp.com/tutorials/terraform/install-cli?in=terraform/aws-get-started
3. Склонируйте репозиторий с провайдером, выполнив команду:
3 years ago
```bash
git clone https://github.com/rudecs/terraform-provider-decort.git
```
3 years ago
4. Перейдите в скачанную папку с провайдером и выполните команду
3 years ago
```bash
go build -o terraform-provider-decort
```
3 years ago
Если вы знаете как устроен _makefile_, то можно изменить в файле `Makefile` параметры под вашу ОС и выполнить команду
3 years ago
```bash
make build
```
3 years ago
5. Полученный файл необходимо поместить:
3 years ago
Linux:
```bash
~/.terraform.d/plugins/${host_name}/${namespace}/${type}/${version}/${target}
```
3 years ago
Windows:
3 years ago
```powershell
%APPDATA%\terraform.d\plugins\${host_name}\${namespace}\${type}\${version}\${target}
```
3 years ago
ВНИМАНИЕ: для ОС Windows `%APP_DATA%` является каталогом, в котором будут помещены будущие файлы terraform.
Где:
3 years ago
- host_name - имя хоста, держателя провайдера, например, digitalenergy.online
3 years ago
- namespace - пространство имен хоста, например decort
- type - тип провайдера, может совпадать с пространством имен, например, decort
- version - версия провайдера, например 1.2
- target - версия ОС, например windows_amd64
3 years ago
6. После этого, создайте файл `main.tf`.
7. Добавьте в него следующий блок
3 years ago
```terraform
terraform {
required_providers {
decort = {
version = "1.2"
source = "digitalenergy.online/decort/decort"
}
}
}
```
3 years ago
В поле `version` указывается версия провайдера.
Обязательный параметр
Тип поля - строка
ВНИМАНИЕ: Версии в блоке и в репозитории, в который был помещен провайдер должны совпадать!
В поле `source` помещается путь до репозитория с версией вида:
3 years ago
```bash
${host_name}/${namespace}/${type}
```
3 years ago
ВНИМАНИЕ: все параметры должны совпадать с путем репозитория, в котором помещен провайдер.
8. В консоле выполнить команду
```bash
terraform init
```
3 years ago
9. Если все прошло хорошо - ошибок не будет.
Более подробно о сборке провайдера можно найти по ссылке: https://learn.hashicorp.com/tutorials/terraform/provider-use?in=terraform/providers
## Примеры работы
3 years ago
Примеры работы можно найти:
3 years ago
- На вики проекта: https://github.com/rudecs/terraform-provider-decort/wiki
3 years ago
- В папке `samples`
Схемы к terraform'у доступны:
3 years ago
- В папке `docs`
4 years ago
Хорошей работы!