Skip to content

red5pro/terraform-digitalocean-red5pro

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

48 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Digital Ocean Red5 Pro Terraform module

Red5 Pro is a real-time video streaming server plaform known for its low-latency streaming capabilities, making it ideal for interactive applications like online gaming, streaming events and video conferencing etc.

This a reusable Terraform installer module for Red5 Pro that provisions infrastucture over Digital Ocean(DO).

This module has 3 variants of Red5 Pro deployments

  • single - Single droplet with installed and configured Red5 Pro server
  • cluster - Stream Manager cluster (MySQL DB + Stream Manager droplet + Autoscaling Node group with Origin, Edge, Transcoder, Relay droplets)
  • autoscaling - Autoscaling Stream Managers (MySQL DB + Load Balancer + Autoscaling Stream Managers + Autoscaling Node group with Origin, Edge, Transcoder, Relay droplets)

Preparation

  • Install terraform https://developer.hashicorp.com/terraform/downloads

    • Open your web browser and visit the Terraform download page, ensuring you get version 1.0.0 or higher.
    • Download the suitable version for your operating system,
    • Extract the compressed file, and then copy the Terraform binary to a location within your system's path
      • Configure path on Linux/macOS
        • Open a terminal and type the following:

          $ sudo mv /path/to/terraform /usr/local/bin

      • Configure path on Windows OS
        • Click 'Start', search for 'Control Panel', and open it.
        • Navigate to System > Advanced System Settings > Environment Variables.
        • Under System variables, find 'PATH' and click 'Edit'.
        • Click 'New' and paste the directory location where you extracted the terraform.exe file.
        • Confirm changes by clicking 'OK' and close all open windows.
        • Open a new terminal and verify that Terraform has been successfully installed.
  • Install Digital Ocean CLI https://docs.digitalocean.com/reference/doctl/how-to/install/

  • Install jq Linux or Mac OS only - apt install jq or brew install jq (It is using in bash scripts to create/delete Stream Manager node group using API)

  • Download Red5 Pro server build: (Example: red5pro-server-0.0.0.b0-release.zip) https://account.red5pro.com/downloads

  • Download Red5 Pro Terraform controller for Digital Ocean: (Example: terraform-cloud-controller-0.0.0.jar) https://account.red5pro.com/downloads

  • Download Red5 Pro Terraform Service : (Example: terraform-service-0.0.0.zip) https://account.red5pro.com/downloads

  • Get Red5 Pro License key: (Example: 1111-2222-3333-4444) https://account.red5pro.com

  • Get Digital Ocean API key or use existing (To access Digital Ocean Cloud)

  • Copy Red5 Pro server build, Terraform service and Terraform controller to the root folder of your project

Example:

cp ~/Downloads/red5pro-server-0.0.0.b0-release.zip ./
cp ~/Downloads/terraform-cloud-controller-0.0.0.jar ./
cp ~/Downloads/terraform-service-0.0.0.zip ./

Single Red5 Pro server deployment (single) - Example

  • VPC - This Terrform module can either create a new or use your existing VPC. If you wish to create a new VPC, set vpc_create to true, and the script will ignore the other VPC configurations. To use your existing VPC, set vpc_create to false and include your existing vpc name.
  • Firewall - This Terrform module create a new Firewall in Digital Ocean.
  • Droplet Size - Select the appropriate droplet size based on the usecase from Digital Ocean.
  • SSL Certificates - User can install Let's encrypt SSL certificates or use Red5Pro server without SSL certificate (HTTP only).

Usage (single)

provider "digitalocean" {
  token                     = "dop_v1_example"                                               # Digital Ocean token (https://cloud.digitalocean.com/account/api/tokens)
}

module "red5pro" {
  source                     = "red5pro/red5pro/digitalocean"
  digital_ocean_region       = "nyc1"                                                        # Digital Ocean region where resources will create
  ubuntu_version             = "22.04"                                                       # The version of ubuntu which is used to create droplet, it can either be 20.04 or 22.04
  type                       = "single"                                                      # Deployment type: single, cluster, autoscaling
  name                       = "red5pro-single"                                              # Name to be used on all the resources as identifier
  
  # Red5 Pro artifacts configuration
  path_to_red5pro_build       = "./red5pro-server-0.0.0.0-release.zip"                       # Absolute path or relative path to Red5 Pro server ZIP file
  
  # SSH key configuration
  ssh_key_create              = true                                                         # true - create new SSH key, false - use existing SSH key
  ssh_key_name                = "example_key_name"                                           # Name for new SSH key or for existing SSH key
  ssh_private_key_path        = "./example_key.pem"                                          # Path to existing SSH private key

  # Digital Ocean project configuration
  project_create              = true                                                         # true - create a new project, false - use existing project
  project_name                = "Exaple-Project-Name"                                        # New or existing Project name in digital Ocean

  # Digital Ocean VPC configuration
  vpc_create                  = true                                                         # true - create new VPC, false - use existing VPC
  vpc_cidr_block              = "10.5.0.0/16"                                                # VPC CIDR value for Digital Ocean
  vpc_name_existing           = "example-vpc"                                                # VPC name of existing VPC if vpc_create is false
  
  # Single Red5 Pro server HTTPS/SSL certificate configuration
  https_letsencrypt_enable                   = false                                         # true - create new Let's Encrypt HTTPS/SSL certificate, false - use Red5 Pro server without HTTPS/SSL certificate
  https_letsencrypt_certificate_domain_name  = "red5pro.example.com"                         # Domain name for Let's Encrypt SSL certificate
  https_letsencrypt_certificate_email        = "email@example.com"                           # Email for Let's Encrypt SSL certificate
  https_letsencrypt_certificate_password     = "examplepass"                                 # Password for Let's Encrypt SSL certificate

  # Single Red5 Pro server Droplet configuration
  single_droplet_size                        = "c-2"                                         # Droplet size for Red5 Pro server in Digital Ocean
  create_reserved_ip_single_server           = true                                          # True - Create the reserved IP for Single server, False - Use existing reserved IP for Single server
  existing_reserved_ip_address_single_server = "1.2.3.4"                                     # Already created reserved IP address for Single server
  
  # Red5Pro server configuration
  red5pro_license_key                           = "1111-2222-3333-4444"                      # Red5 Pro license key (https://account.red5pro.com/login)
  red5pro_api_enable                            = true                                       # true - enable Red5 Pro server API, false - disable Red5 Pro server API (https://www.red5pro.com/docs/development/api/overview/)
  red5pro_api_key                               = "examplekey"                               # Red5 Pro server API key (https://www.red5pro.com/docs/development/api/overview/)
  red5pro_inspector_enable                      = false                                      # true - enable Red5 Pro server inspector, false - disable Red5 Pro server inspector (https://www.red5pro.com/docs/troubleshooting/inspector/overview/)
  red5pro_restreamer_enable                     = false                                      # true - enable Red5 Pro server restreamer, false - disable Red5 Pro server restreamer (https://www.red5pro.com/docs/special/restreamer/overview/)
  red5pro_socialpusher_enable                   = false                                      # true - enable Red5 Pro server socialpusher, false - disable Red5 Pro server socialpusher (https://www.red5pro.com/docs/special/social-media-plugin/overview/)
  red5pro_suppressor_enable                     = false                                      # true - enable Red5 Pro server suppressor, false - disable Red5 Pro server suppressor
  red5pro_hls_enable                            = false                                      # true - enable Red5 Pro server HLS, false - disable Red5 Pro server HLS (https://www.red5pro.com/docs/protocols/hls-plugin/hls-vod/)
  red5pro_round_trip_auth_enable                = false                                      # true - enable Red5 Pro server round trip authentication, false - disable Red5 Pro server round trip authentication (https://www.red5pro.com/docs/special/round-trip-auth/overview/)
  red5pro_round_trip_auth_host                  = "round-trip-auth.example.com"              # Round trip authentication server host
  red5pro_round_trip_auth_port                  = 3000                                       # Round trip authentication server port
  red5pro_round_trip_auth_protocol              = "http"                                     # Round trip authentication server protocol
  red5pro_round_trip_auth_endpoint_validate     = "/validateCredentials"                     # Round trip authentication server endpoint for validate
  red5pro_round_trip_auth_endpoint_invalidate   = "/invalidateCredentials"                   # Round trip authentication server endpoint for invalidate
    
  # Video on demand via Cloud Storage
  red5pro_cloudstorage_enable                             = false                            # Red5 Pro server cloud storage enable/disable (https://www.red5.net/docs/special/cloudstorage-plugin/digital-ocean-storage/)
  red5pro_cloudstorage_digitalocean_spaces_access_key     = ""                               # Red5 Pro server cloud storage - Digital Ocean space access key (DO Spaces)
  red5pro_cloudstorage_digitalocean_spaces_secret_key     = ""                               # Red5 Pro server cloud storage - Digital Ocean space secret key (DO Spaces)
  red5pro_cloudstorage_digitalocean_spaces_name           = "bucket-example-name"            # Red5 Pro server cloud storage - Digital Ocean space name (DO Spaces)
  red5pro_cloudstorage_digitalocean_spaces_region         = "nyc1"                           # Red5 Pro server cloud storage - Digital Ocean space region (DO Spaces) (Valid locations are: ams3, fra1, nyc1, nyc3, sfo3, sgp1)
  red5pro_cloudstorage_postprocessor_enable               = false                            # Red5 Pro server cloud storage - enable/disable Red5 Pro server postprocessor (https://www.red5.net/docs/special/cloudstorage-plugin/server-configuration/)
  red5pro_cloudstorage_spaces_file_access                 = true                             # true - Cloud storage files private access only   false - Cloud storage files public access
  red5pro_cloudstorage_postprocessor_mp4_enable           = true                             # Red5 Pro server cloud storage - enable/disable Red5 Pro server postprocessor to convert flv to MP4 (https://www.red5.net/docs/protocols/converting/overview/)
}

output "module_output" {
  sensitive = true
  value     = module.red5pro
}

Red5 Pro Stream Manager cluster deployment (cluster) - Example

  • VPC - This Terrform module can either create a new or use your existing VPC. If you wish to create a new VPC, set vpc_create to true, and the script will ignore the other VPC configurations. To use your existing VPC, set vpc_create to false and include your existing vpc name.
  • Firewall - This Terrform module create a new Firewall in Digital Ocean.
  • Droplet Size - Select the appropriate droplet size based on the usecase from Digital Ocean.
  • SSL Certificates - User can install Let's encrypt SSL certificates or use Red5Pro server without SSL certificate (HTTP only).
  • MySQL Database - Users have flexibility to create a MySQL databse server in Digital Ocean or install it locally on the Stream Manager
  • Terraform Server - Uesrs can choose to create a dedicated droplet for Terraform Server or install it locally on the Stream Manager
  • Stream Manager - Droplet will be created automatically for Stream Manager
  • Origin Node Image - To create Digital Ocean(DO) custom image for Orgin Node type for Stream Manager node group
  • Edge Node Image - To create Digital Ocean(DO) custom image for Edge Node type for Stream Manager node group (optional)
  • Transcoder Node Image - To create Digital Ocean(DO) custom image for Transcoder Node type for Stream Manager node group (optional)
  • Relay Node Image - To create Digital Ocean(DO) custom image for Relay Node type for Stream Manager node group (optional)

Usage (cluster)

provider "digitalocean" {
  token                     = "dop_v1_example"                                               # Digital Ocean token (https://cloud.digitalocean.com/account/api/tokens)
}

module "red5pro" {
  source                     = "red5pro/red5pro/digitalocean"
  digital_ocean_region       = "nyc1"                                                        # Digital Ocean region where resources will create
  ubuntu_version             = "22.04"                                                       # The version of ubuntu which is used to create droplet, it can either be 20.04 or 22.04
  type                       = "cluster"                                                     # Deployment type: single, cluster, autoscaling
  name                       = "red5pro-cluster"                                             # Name to be used on all the resources as identifier
  digital_ocean_access_token = "dop_v1_example"                                              # Digital Ocean access token (https://cloud.digitalocean.com/account/api/tokens)
  
  # Red5 Pro artifacts configuration
  path_to_red5pro_build              = "./red5pro-server-0.0.0.0-release.zip"                # Absolute path or relative path to Red5 Pro server ZIP file
  path_to_terraform_cloud_controller = "./terraform-cloud-controller-0.0.0.jar"              # Absolute path or relative path to terraform cloud controller jar file
  path_to_terraform_service_build    = "./terraform-service-0.0.0.zip"                       # Absolute path or relative path to terraform service ZIP file
  
  # SSH key configuration
  ssh_key_create              = true                                                         # true - create new SSH key, false - use existing SSH key
  ssh_key_name                = "example_key_name"                                           # Name for new SSH key or for existing SSH key
  ssh_private_key_path        = "./example_key.pem"                                          # Path to existing SSH private key

  # Digital Ocean project configuration
  project_create              = true                                                         # true - create a new project, false - use existing project
  project_name                = "Exaple-Project-Name"                                        # New or existing Project name in digital Ocean

  # Digital Ocean VPC configuration
  vpc_create                  = true                                                         # true - create new VPC, false - use existing VPC
  vpc_cidr_block              = "10.5.0.0/16"                                                # VPC CIDR value for Digital Ocean
  vpc_name_existing           = "example-vpc"                                                # VPC name of existing VPC if vpc_create is false
  
  # Digital Ocean Database Configuration
  mysql_database_create       = true                                                         # true - create a new database false- Install locally
  mysql_database_size         = "db-s-1vcpu-2gb"                                             # New MysQL database size
  mysql_username              = "example-user"                                               # Username for locally install databse
  mysql_password              = "example-password"                                           # Password for locally install databse
  mysql_port                  = "3306"                                                       # Port for locally install databse

  # Stream Manager Configuration
  create_reserved_ip_stream_manager = true                                                   # True - Create a reserved IP for Stream Manager, False - Use existing reserved IP for stream manager
  existing_reserved_ip_address_stream_manager = "1.2.3.4"                                    # Existing reserved IP for stream manager
  stream_manager_droplet_size = "c-4"                                                        # Stream Manager droplet size
  stream_manager_api_key      = "examplekey"                                                 # Stream Manager api key

  # Terraform Service configuration
  terraform_service_instance_create = true                                                   # true - Create a dedicate terraform service droplet, false - install terraform service locally on the stream manager
  terraform_service_api_key         = "examplekey"                                           # Terraform service api key
  terraform_service_parallelism     = "20"                                                   # Terraform service parallelism
  terraform_service_droplet_size    = "c-4"                                                  # Terraform service droplet size

  # Red5 Pro general configuration
  red5pro_license_key         = "1111-2222-3333-4444"                                        # Red5 Pro license key (https://account.red5pro.com/login)
  red5pro_cluster_key         = "examplekey"                                                 # Red5 Pro cluster key
  red5pro_api_enable          = true                                                         # true - enable Red5 Pro server API, false - disable Red5 Pro server API (https://www.red5pro.com/docs/development/api/overview/)
  red5pro_api_key             = "examplekey"                                                 # Red5 Pro server API key (https://www.red5pro.com/docs/development/api/overview/)

  # Stream Manager HTTPS/SSL certificate configuration
  https_letsencrypt_enable                   = false                                         # true - create new Let's Encrypt HTTPS/SSL certificate, false - use Stream Manager server without HTTPS/SSL certificate
  https_letsencrypt_certificate_domain_name  = "red5pro.example.com"                         # Domain name for Let's Encrypt SSL certificate
  https_letsencrypt_certificate_email        = "email@example.com"                           # Email for Let's Encrypt SSL certificate
  https_letsencrypt_certificate_password     = "examplepass"                                 # Password for Let's Encrypt SSL certificate

  # Red5 Pro autoscaling Origin node image configuration
  origin_image_create                                      = true                            # Default: true for Autoscaling and Cluster, true - create new Origin node image, false - not create new Origin node image
  origin_image_droplet_size                                = "c-2"                           # droplet type for Origin node image
  origin_image_red5pro_inspector_enable                    = false                           # true - enable Red5 Pro server inspector, false - disable Red5 Pro server inspector (https://www.red5pro.com/docs/troubleshooting/inspector/overview/)
  origin_image_red5pro_restreamer_enable                   = false                           # true - enable Red5 Pro server restreamer, false - disable Red5 Pro server restreamer (https://www.red5pro.com/docs/special/restreamer/overview/)
  origin_image_red5pro_socialpusher_enable                 = false                           # true - enable Red5 Pro server socialpusher, false - disable Red5 Pro server socialpusher (https://www.red5pro.com/docs/special/social-media-plugin/overview/)
  origin_image_red5pro_suppressor_enable                   = false                           # true - enable Red5 Pro server suppressor, false - disable Red5 Pro server suppressor
  origin_image_red5pro_hls_enable                          = false                           # true - enable Red5 Pro server HLS, false - disable Red5 Pro server HLS (https://www.red5pro.com/docs/protocols/hls-plugin/hls-vod/)
  origin_image_red5pro_round_trip_auth_enable              = false                           # true - enable Red5 Pro server round trip authentication, false - disable Red5 Pro server round trip authentication (https://www.red5pro.com/docs/special/round-trip-auth/overview/)
  origin_image_red5pro_round_trip_auth_host                = "round-trip-auth.example.com"   # Round trip authentication server host
  origin_image_red5pro_round_trip_auth_port                = 3000                            # Round trip authentication server port
  origin_image_red5pro_round_trip_auth_protocol            = "http"                          # Round trip authentication server protocol
  origin_image_red5pro_round_trip_auth_endpoint_validate   = "/validateCredentials"          # Round trip authentication server endpoint for validate
  origin_image_red5pro_round_trip_auth_endpoint_invalidate = "/invalidateCredentials"        # Round trip authentication server endpoint for invalidate
  # Video on demand via Cloud Storage
  origin_red5pro_cloudstorage_enable                             = false                     # Red5 Pro server cloud storage enable/disable (https://www.red5.net/docs/special/cloudstorage-plugin/digital-ocean-storage/)
  origin_red5pro_cloudstorage_digitalocean_spaces_access_key     = ""                        # Red5 Pro server cloud storage - Digital Ocean space access key (DO Spaces)
  origin_red5pro_cloudstorage_digitalocean_spaces_secret_key     = ""                        # Red5 Pro server cloud storage - Digital Ocean space secret key (DO Spaces)
  origin_red5pro_cloudstorage_digitalocean_spaces_name           = "bucket-example-name"     # Red5 Pro server cloud storage - Digital Ocean space name (DO Spaces)
  origin_red5pro_cloudstorage_digitalocean_spaces_region         = "nyc1"                    # Red5 Pro server cloud storage - Digital Ocean space region (DO Spaces) (Valid locations are: ams3, fra1, nyc1, nyc3, sfo3, sgp1)
  origin_red5pro_cloudstorage_postprocessor_enable               = false                     # Red5 Pro server cloud storage - enable/disable Red5 Pro server postprocessor (https://www.red5.net/docs/special/cloudstorage-plugin/server-configuration/)
  origin_red5pro_cloudstorage_spaces_file_access                 = true                      # true - Cloud storage files private access only   false - Cloud storage files public access
  origin_red5pro_cloudstorage_postprocessor_mp4_enable           = true                      # Red5 Pro server cloud storage - enable/disable Red5 Pro server postprocessor to convert flv to MP4 (https://www.red5.net/docs/protocols/converting/overview/)
 
  # Red5 Pro autoscaling Node group - (Optional)
  node_group_create                    = true                       # Linux or Mac OS only. true - create new Stream Manager Node group, false - not create new Stream Manager Node group
  node_group_name                      = "example-node-group"       # Node group name
  # Origin node configuration
  node_group_origins_min               = 1                          # Number of minimum Origins
  node_group_origins_max               = 20                         # Number of maximum Origins
  node_group_origins_droplet_type      = "c-2"                      # Origins DO droplet 
  node_group_origins_capacity          = 20                         # Connections capacity for Origins
  # Edge node configuration
  node_group_edges_min                 = 1                          # Number of minimum Edges
  node_group_edges_max                 = 40                         # Number of maximum Edges
  node_group_edges_droplet_type        = "c-2"                      # Edges DO droplet 
  node_group_edges_capacity            = 200                        # Connections capacity for Edges
  # Transcoder node configuration
  node_group_transcoders_min           = 0                          # Number of minimum Transcoders
  node_group_transcoders_max           = 20                         # Number of maximum Transcoders
  node_group_transcoders_droplet_type  = "c-2"                      # Transcoders DO droplet 
  node_group_transcoders_capacity      = 20                         # Connections capacity for Transcoders
  # Relay node configuration
  node_group_relays_min                = 0                          # Number of minimum Relays
  node_group_relays_max                = 20                         # Number of maximum Relays
  node_group_relays_droplet_type       = "c-2"                      # Relays DO droplet 
  node_group_relays_capacity           = 20                         # Connections capacity for Relays

# Red5 Pro TrueTime Webinar Deployments - (Optional)                https://www.red5.net/truetime/studio-for-webinars/
  red5pro_truetime_studio_webinar_enable                         = false                     # True - Enable wantch party configuration (https://www.red5.net/truetime/studio-for-webinars/) 
  red5pro_truetime_studio_webinar_smtp_host                      = "smtp.example.com"        # SMTP host address
  red5pro_truetime_studio_webinar_smtp_port                      = "587"                     # SMTP port
  red5pro_truetime_studio_webinar_smtp_username                  = ""                        # SMTP Username
  red5pro_truetime_studio_webinar_smtp_password                  = ""                        # SMTP Password
  red5pro_truetime_studio_webinar_smtp_email_address             = "example@example.com"     # EMail address for sending email using SMTP server
}

output "module_output" {
  sensitive = true
  value     = module.red5pro
}

Red5 Pro Stream Manager cluster with Load Balancer Stream Managers (autoscaling) - Example

  • VPC - This Terrform module can either create a new or use your existing VPC. If you wish to create a new VPC, set vpc_create to true, and the script will ignore the other VPC configurations. To use your existing VPC, set vpc_create to false and include your existing vpc name.
  • Firewall - This Terrform module create a new Firewall in Digital Ocean.
  • Droplet Size - Select the appropriate droplet size based on the usecase from Digital Ocean.
  • Load Balancer - Digital Ocean load balancer for Stream Managers will be created automatically
  • SSL Certificates - User can install Let's encrypt SSL certificates or use Red5Pro server without SSL certificate (HTTP only).
  • MySQL Database - Users have flexibility to create a MySQL databse server in Digital Ocean or install it locally on the Stream Manager
  • Terraform Server - Uesrs can choose to create a dedicated droplet for Terraform Server or install it locally on the Stream Manager
  • Stream Manager - Droplet will be created automatically for Stream Manager
  • Origin Node Image - To create Digital Ocean(DO) custom image for Orgin Node type for Stream Manager node group
  • Edge Node Image - To create Digital Ocean(DO) custom image for Edge Node type for Stream Manager node group (optional)
  • Transcoder Node Image - To create Digital Ocean(DO) custom image for Transcoder Node type for Stream Manager node group (optional)
  • Relay Node Image - To create Digital Ocean(DO) custom image for Relay Node type for Stream Manager node group (optional)

Usage (autoscaling)

provider "digitalocean" {
  token                     = "dop_v1_example"                                               # Digital Ocean token (https://cloud.digitalocean.com/account/api/tokens)
}

module "red5pro" {
  source                     = "red5pro/red5pro/digitalocean"
  digital_ocean_region       = "nyc1"                                                        # Digital Ocean region where resources will create
  ubuntu_version             = "22.04"                                                       # The version of ubuntu which is used to create droplet, it can either be 20.04 or 22.04
  type                       = "autoscaling"                                                 # Deployment type: single, cluster, autoscaling
  name                       = "red5pro-auto"                                                # Name to be used on all the resources as identifier
  digital_ocean_access_token = "dop_v1_example"                                              # Digital Ocean access token (https://cloud.digitalocean.com/account/api/tokens)
  
  # Red5 Pro artifacts configuration
  path_to_red5pro_build              = "./red5pro-server-0.0.0.0-release.zip"                # Absolute path or relative path to Red5 Pro server ZIP file
  path_to_terraform_cloud_controller = "./terraform-cloud-controller-0.0.0.jar"              # Absolute path or relative path to terraform cloud controller jar file
  path_to_terraform_service_build    = "./terraform-service-0.0.0.zip"                       # Absolute path or relative path to terraform service ZIP file
  
  # SSH key configuration
  ssh_key_create              = true                                                         # true - create new SSH key, false - use existing SSH key
  ssh_key_name                = "example_key_name"                                           # Name for new SSH key or for existing SSH key
  ssh_private_key_path        = "./example_key.pem"                                          # Path to existing SSH private key

  # Digital Ocean project configuration
  project_create              = true                                                         # true - create a new project, false - use existing project
  project_name                = "Exaple-Project-Name"                                        # New or existing Project name in digital Ocean

  # Digital Ocean VPC configuration
  vpc_create                  = true                                                         # true - create new VPC, false - use existing VPC
  vpc_cidr_block              = "10.5.0.0/16"                                                # VPC CIDR value for Digital Ocean
  vpc_name_existing           = "example-vpc"                                                # VPC name of existing VPC if vpc_create is false
  
  # Digital Ocean Database Configuration
  mysql_database_size         = "db-s-1vcpu-2gb"                                             # New MysQL database size

  # Stream Manager Configuration
  stream_managers_amount      = 2                                                            # Total number stream manager required to setup in autoscale.
  stream_manager_droplet_size = "c-2"                                                        # Stream Manager droplet size
  stream_manager_api_key      = "examplekey"                                                 # Stream Manager api key

  # Terraform Service configuration
  terraform_service_api_key      = "examplekey"                                              # Terraform service api key
  terraform_service_parallelism  = "20"                                                      # Terraform service parallelism
  terraform_service_droplet_size = "c-2"                                                     # Terraform service droplet size

  # Load Balancer configuration for Stream Manager
  lb_size                     = "lb-small"                                                   # The size of the Load Balancer. It must be either lb-small, lb-medium, or lb-large  
  lb_ssl_create               = false                                                        # Create a new SSL certificate for Load Balancer (autoscaling)
  cert_fullchain              = "./fullchain.pem"                                            # Only If 'lb_ssl_create' = true  File path for SSL/TLS CA Certificate Fullchain (autoscaling)
  cert_private_key            = "./privkey.pem"                                              # Only If 'lb_ssl_create' = true  File path for SSL/TLS Certificate Private Key (autoscaling)
  leaf_public_cert            = "./cert.pem"                                                 # Only If 'lb_ssl_create' = true  File path for SSL/TLS Certificate Public Cert (autoscaling)

  # Red5 Pro general configuration
  red5pro_license_key         = "1111-2222-3333-4444"                                        # Red5 Pro license key (https://account.red5pro.com/login)
  red5pro_cluster_key         = "examplekey"                                                 # Red5 Pro cluster key
  red5pro_api_enable          = true                                                         # true - enable Red5 Pro server API, false - disable Red5 Pro server API (https://www.red5pro.com/docs/development/api/overview/)
  red5pro_api_key             = "examplekey"                                                 # Red5 Pro server API key (https://www.red5pro.com/docs/development/api/overview/)

  # Red5 Pro autoscaling Origin node image configuration
  origin_image_create                                      = true                            # Default: true for Autoscaling and Cluster, true - create new Origin node image, false - not create new Origin node image
  origin_image_droplet_size                                = "c-2"                           # droplet type for Origin node image
  origin_image_red5pro_inspector_enable                    = false                           # true - enable Red5 Pro server inspector, false - disable Red5 Pro server inspector (https://www.red5pro.com/docs/troubleshooting/inspector/overview/)
  origin_image_red5pro_restreamer_enable                   = false                           # true - enable Red5 Pro server restreamer, false - disable Red5 Pro server restreamer (https://www.red5pro.com/docs/special/restreamer/overview/)
  origin_image_red5pro_socialpusher_enable                 = false                           # true - enable Red5 Pro server socialpusher, false - disable Red5 Pro server socialpusher (https://www.red5pro.com/docs/special/social-media-plugin/overview/)
  origin_image_red5pro_suppressor_enable                   = false                           # true - enable Red5 Pro server suppressor, false - disable Red5 Pro server suppressor
  origin_image_red5pro_hls_enable                          = false                           # true - enable Red5 Pro server HLS, false - disable Red5 Pro server HLS (https://www.red5pro.com/docs/protocols/hls-plugin/hls-vod/)
  origin_image_red5pro_round_trip_auth_enable              = false                           # true - enable Red5 Pro server round trip authentication, false - disable Red5 Pro server round trip authentication (https://www.red5pro.com/docs/special/round-trip-auth/overview/)
  origin_image_red5pro_round_trip_auth_host                = "round-trip-auth.example.com"   # Round trip authentication server host
  origin_image_red5pro_round_trip_auth_port                = 3000                            # Round trip authentication server port
  origin_image_red5pro_round_trip_auth_protocol            = "http"                          # Round trip authentication server protocol
  origin_image_red5pro_round_trip_auth_endpoint_validate   = "/validateCredentials"          # Round trip authentication server endpoint for validate
  origin_image_red5pro_round_trip_auth_endpoint_invalidate = "/invalidateCredentials"        # Round trip authentication server endpoint for invalidate
  # Video on demand via Cloud Storage
  origin_red5pro_cloudstorage_enable                             = false                     # Red5 Pro server cloud storage enable/disable (https://www.red5.net/docs/special/cloudstorage-plugin/digital-ocean-storage/)
  origin_red5pro_cloudstorage_digitalocean_spaces_access_key     = ""                        # Red5 Pro server cloud storage - Digital Ocean space access key (DO Spaces)
  origin_red5pro_cloudstorage_digitalocean_spaces_secret_key     = ""                        # Red5 Pro server cloud storage - Digital Ocean space secret key (DO Spaces)
  origin_red5pro_cloudstorage_digitalocean_spaces_name           = "bucket-example-name"     # Red5 Pro server cloud storage - Digital Ocean space name (DO Spaces)
  origin_red5pro_cloudstorage_digitalocean_spaces_region         = "nyc1"                    # Red5 Pro server cloud storage - Digital Ocean space region (DO Spaces) (Valid locations are: ams3, fra1, nyc1, nyc3, sfo3, sgp1)
  origin_red5pro_cloudstorage_postprocessor_enable               = false                     # Red5 Pro server cloud storage - enable/disable Red5 Pro server postprocessor (https://www.red5.net/docs/special/cloudstorage-plugin/server-configuration/)
  origin_red5pro_cloudstorage_spaces_file_access                 = true                      # true - Cloud storage files private access only   false - Cloud storage files public access
  origin_red5pro_cloudstorage_postprocessor_mp4_enable           = true                      # Red5 Pro server cloud storage - enable/disable Red5 Pro server postprocessor to convert flv to MP4 (https://www.red5.net/docs/protocols/converting/overview/)

# Red5 Pro autoscaling Node group - (Optional)
  node_group_create                    = true                       # Linux or Mac OS only. true - create new Stream Manager Node group, false - not create new Stream Manager Node group
  node_group_name                      = "example-node-group"       # Node group name
  # Origin node configuration
  node_group_origins_min               = 1                          # Number of minimum Origins
  node_group_origins_max               = 20                         # Number of maximum Origins
  node_group_origins_droplet_type      = "c-2"                      # Origins DO droplet 
  node_group_origins_capacity          = 20                         # Connections capacity for Origins
  # Edge node configuration
  node_group_edges_min                 = 1                          # Number of minimum Edges
  node_group_edges_max                 = 40                         # Number of maximum Edges
  node_group_edges_droplet_type        = "c-2"                      # Edges DO droplet 
  node_group_edges_capacity            = 200                        # Connections capacity for Edges
  # Transcoder node configuration
  node_group_transcoders_min           = 0                          # Number of minimum Transcoders
  node_group_transcoders_max           = 20                         # Number of maximum Transcoders
  node_group_transcoders_droplet_type  = "c-2"                      # Transcoders DO droplet 
  node_group_transcoders_capacity      = 20                         # Connections capacity for Transcoders
  # Relay node configuration
  node_group_relays_min                = 0                          # Number of minimum Relays
  node_group_relays_max                = 20                         # Number of maximum Relays
  node_group_relays_droplet_type       = "c-2"                      # Relays DO droplet 
  node_group_relays_capacity           = 20                         # Connections capacity for Relays
}

output "module_output" {
  sensitive = true
  value     = module.red5pro
}

NOTES

  • To activate HTTPS/SSL you need to add DNS A record for Elastic IP (single/cluster) or CNAME record for Load Balancer DNS name (autoscaling)