outscale.ApiAccessRule
Explore with Pulumi AI
Manages an API access rule.
For more information on this resource, see the User Guide.
For more information on this resource actions, see the API documentation.
Example Usage
Create an API access rule based on IPs
import * as pulumi from "@pulumi/pulumi";
import * as outscale from "@pulumi/outscale";
const apiAccessRule01 = new outscale.ApiAccessRule("apiAccessRule01", {
description: "Basic API Access Rule from Terraform",
ipRanges: [
"192.0.2.0",
"192.0.2.0/16",
],
});
import pulumi
import pulumi_outscale as outscale
api_access_rule01 = outscale.ApiAccessRule("apiAccessRule01",
description="Basic API Access Rule from Terraform",
ip_ranges=[
"192.0.2.0",
"192.0.2.0/16",
])
package main
import (
"github.com/pulumi/pulumi-terraform-provider/sdks/go/outscale/outscale"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
_, err := outscale.NewApiAccessRule(ctx, "apiAccessRule01", &outscale.ApiAccessRuleArgs{
Description: pulumi.String("Basic API Access Rule from Terraform"),
IpRanges: pulumi.StringArray{
pulumi.String("192.0.2.0"),
pulumi.String("192.0.2.0/16"),
},
})
if err != nil {
return err
}
return nil
})
}
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Outscale = Pulumi.Outscale;
return await Deployment.RunAsync(() =>
{
var apiAccessRule01 = new Outscale.ApiAccessRule("apiAccessRule01", new()
{
Description = "Basic API Access Rule from Terraform",
IpRanges = new[]
{
"192.0.2.0",
"192.0.2.0/16",
},
});
});
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.outscale.ApiAccessRule;
import com.pulumi.outscale.ApiAccessRuleArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
var apiAccessRule01 = new ApiAccessRule("apiAccessRule01", ApiAccessRuleArgs.builder()
.description("Basic API Access Rule from Terraform")
.ipRanges(
"192.0.2.0",
"192.0.2.0/16")
.build());
}
}
resources:
apiAccessRule01:
type: outscale:ApiAccessRule
properties:
description: Basic API Access Rule from Terraform
ipRanges:
- 192.0.2.0
- 192.0.2.0/16
Create an API access rule based on IPs and Certificate Authority (CA)
import * as pulumi from "@pulumi/pulumi";
import * as fs from "fs";
import * as outscale from "@pulumi/outscale";
const ca01 = new outscale.Ca("ca01", {
caPem: fs.readFileSync("<PATH>", "utf8"),
description: "Terraform CA",
});
const apiAccessRule02 = new outscale.ApiAccessRule("apiAccessRule02", {
ipRanges: [
"192.0.2.0",
"192.0.2.0/16",
],
caIds: [ca01.caId],
description: "API Access Rule with CA from Terraform",
});
import pulumi
import pulumi_outscale as outscale
ca01 = outscale.Ca("ca01",
ca_pem=(lambda path: open(path).read())("<PATH>"),
description="Terraform CA")
api_access_rule02 = outscale.ApiAccessRule("apiAccessRule02",
ip_ranges=[
"192.0.2.0",
"192.0.2.0/16",
],
ca_ids=[ca01.ca_id],
description="API Access Rule with CA from Terraform")
package main
import (
"os"
"github.com/pulumi/pulumi-terraform-provider/sdks/go/outscale/outscale"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func readFileOrPanic(path string) pulumi.StringPtrInput {
data, err := os.ReadFile(path)
if err != nil {
panic(err.Error())
}
return pulumi.String(string(data))
}
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
ca01, err := outscale.NewCa(ctx, "ca01", &outscale.CaArgs{
CaPem: pulumi.String(readFileOrPanic("<PATH>")),
Description: pulumi.String("Terraform CA"),
})
if err != nil {
return err
}
_, err = outscale.NewApiAccessRule(ctx, "apiAccessRule02", &outscale.ApiAccessRuleArgs{
IpRanges: pulumi.StringArray{
pulumi.String("192.0.2.0"),
pulumi.String("192.0.2.0/16"),
},
CaIds: pulumi.StringArray{
ca01.CaId,
},
Description: pulumi.String("API Access Rule with CA from Terraform"),
})
if err != nil {
return err
}
return nil
})
}
using System.Collections.Generic;
using System.IO;
using System.Linq;
using Pulumi;
using Outscale = Pulumi.Outscale;
return await Deployment.RunAsync(() =>
{
var ca01 = new Outscale.Ca("ca01", new()
{
CaPem = File.ReadAllText("<PATH>"),
Description = "Terraform CA",
});
var apiAccessRule02 = new Outscale.ApiAccessRule("apiAccessRule02", new()
{
IpRanges = new[]
{
"192.0.2.0",
"192.0.2.0/16",
},
CaIds = new[]
{
ca01.CaId,
},
Description = "API Access Rule with CA from Terraform",
});
});
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.outscale.Ca;
import com.pulumi.outscale.CaArgs;
import com.pulumi.outscale.ApiAccessRule;
import com.pulumi.outscale.ApiAccessRuleArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
var ca01 = new Ca("ca01", CaArgs.builder()
.caPem(Files.readString(Paths.get("<PATH>")))
.description("Terraform CA")
.build());
var apiAccessRule02 = new ApiAccessRule("apiAccessRule02", ApiAccessRuleArgs.builder()
.ipRanges(
"192.0.2.0",
"192.0.2.0/16")
.caIds(ca01.caId())
.description("API Access Rule with CA from Terraform")
.build());
}
}
resources:
ca01:
type: outscale:Ca
properties:
caPem:
fn::readFile: <PATH>
description: Terraform CA
apiAccessRule02:
type: outscale:ApiAccessRule
properties:
ipRanges:
- 192.0.2.0
- 192.0.2.0/16
caIds:
- ${ca01.caId}
description: API Access Rule with CA from Terraform
Create ApiAccessRule Resource
Resources are created with functions called constructors. To learn more about declaring and configuring resources, see Resources.
Constructor syntax
new ApiAccessRule(name: string, args?: ApiAccessRuleArgs, opts?: CustomResourceOptions);
@overload
def ApiAccessRule(resource_name: str,
args: Optional[ApiAccessRuleArgs] = None,
opts: Optional[ResourceOptions] = None)
@overload
def ApiAccessRule(resource_name: str,
opts: Optional[ResourceOptions] = None,
ca_ids: Optional[Sequence[str]] = None,
cns: Optional[Sequence[str]] = None,
description: Optional[str] = None,
ip_ranges: Optional[Sequence[str]] = None,
outscale_api_access_rule_id: Optional[str] = None)
func NewApiAccessRule(ctx *Context, name string, args *ApiAccessRuleArgs, opts ...ResourceOption) (*ApiAccessRule, error)
public ApiAccessRule(string name, ApiAccessRuleArgs? args = null, CustomResourceOptions? opts = null)
public ApiAccessRule(String name, ApiAccessRuleArgs args)
public ApiAccessRule(String name, ApiAccessRuleArgs args, CustomResourceOptions options)
type: outscale:ApiAccessRule
properties: # The arguments to resource properties.
options: # Bag of options to control resource's behavior.
Parameters
- name string
- The unique name of the resource.
- args ApiAccessRuleArgs
- The arguments to resource properties.
- opts CustomResourceOptions
- Bag of options to control resource's behavior.
- resource_name str
- The unique name of the resource.
- args ApiAccessRuleArgs
- The arguments to resource properties.
- opts ResourceOptions
- Bag of options to control resource's behavior.
- ctx Context
- Context object for the current deployment.
- name string
- The unique name of the resource.
- args ApiAccessRuleArgs
- The arguments to resource properties.
- opts ResourceOption
- Bag of options to control resource's behavior.
- name string
- The unique name of the resource.
- args ApiAccessRuleArgs
- The arguments to resource properties.
- opts CustomResourceOptions
- Bag of options to control resource's behavior.
- name String
- The unique name of the resource.
- args ApiAccessRuleArgs
- The arguments to resource properties.
- options CustomResourceOptions
- Bag of options to control resource's behavior.
Constructor example
The following reference example uses placeholder values for all input properties.
var apiAccessRuleResource = new Outscale.ApiAccessRule("apiAccessRuleResource", new()
{
CaIds = new[]
{
"string",
},
Cns = new[]
{
"string",
},
Description = "string",
IpRanges = new[]
{
"string",
},
OutscaleApiAccessRuleId = "string",
});
example, err := outscale.NewApiAccessRule(ctx, "apiAccessRuleResource", &outscale.ApiAccessRuleArgs{
CaIds: pulumi.StringArray{
pulumi.String("string"),
},
Cns: pulumi.StringArray{
pulumi.String("string"),
},
Description: pulumi.String("string"),
IpRanges: pulumi.StringArray{
pulumi.String("string"),
},
OutscaleApiAccessRuleId: pulumi.String("string"),
})
var apiAccessRuleResource = new ApiAccessRule("apiAccessRuleResource", ApiAccessRuleArgs.builder()
.caIds("string")
.cns("string")
.description("string")
.ipRanges("string")
.outscaleApiAccessRuleId("string")
.build());
api_access_rule_resource = outscale.ApiAccessRule("apiAccessRuleResource",
ca_ids=["string"],
cns=["string"],
description="string",
ip_ranges=["string"],
outscale_api_access_rule_id="string")
const apiAccessRuleResource = new outscale.ApiAccessRule("apiAccessRuleResource", {
caIds: ["string"],
cns: ["string"],
description: "string",
ipRanges: ["string"],
outscaleApiAccessRuleId: "string",
});
type: outscale:ApiAccessRule
properties:
caIds:
- string
cns:
- string
description: string
ipRanges:
- string
outscaleApiAccessRuleId: string
ApiAccessRule Resource Properties
To learn more about resource properties and how to use them, see Inputs and Outputs in the Architecture and Concepts docs.
Inputs
In Python, inputs that are objects can be passed either as argument classes or as dictionary literals.
The ApiAccessRule resource accepts the following input properties:
- Ca
Ids List<string> - One or more IDs of Client Certificate Authorities (CAs).
- Cns List<string>
- One or more Client Certificate Common Names (CNs). If this parameter is specified, you must also specify the
ca_ids
parameter. - Description string
- A description for the API access rule.
- Ip
Ranges List<string> - One or more IPs or CIDR blocks (for example,
192.0.2.0/16
). - Outscale
Api stringAccess Rule Id
- Ca
Ids []string - One or more IDs of Client Certificate Authorities (CAs).
- Cns []string
- One or more Client Certificate Common Names (CNs). If this parameter is specified, you must also specify the
ca_ids
parameter. - Description string
- A description for the API access rule.
- Ip
Ranges []string - One or more IPs or CIDR blocks (for example,
192.0.2.0/16
). - Outscale
Api stringAccess Rule Id
- ca
Ids List<String> - One or more IDs of Client Certificate Authorities (CAs).
- cns List<String>
- One or more Client Certificate Common Names (CNs). If this parameter is specified, you must also specify the
ca_ids
parameter. - description String
- A description for the API access rule.
- ip
Ranges List<String> - One or more IPs or CIDR blocks (for example,
192.0.2.0/16
). - outscale
Api StringAccess Rule Id
- ca
Ids string[] - One or more IDs of Client Certificate Authorities (CAs).
- cns string[]
- One or more Client Certificate Common Names (CNs). If this parameter is specified, you must also specify the
ca_ids
parameter. - description string
- A description for the API access rule.
- ip
Ranges string[] - One or more IPs or CIDR blocks (for example,
192.0.2.0/16
). - outscale
Api stringAccess Rule Id
- ca_
ids Sequence[str] - One or more IDs of Client Certificate Authorities (CAs).
- cns Sequence[str]
- One or more Client Certificate Common Names (CNs). If this parameter is specified, you must also specify the
ca_ids
parameter. - description str
- A description for the API access rule.
- ip_
ranges Sequence[str] - One or more IPs or CIDR blocks (for example,
192.0.2.0/16
). - outscale_
api_ straccess_ rule_ id
- ca
Ids List<String> - One or more IDs of Client Certificate Authorities (CAs).
- cns List<String>
- One or more Client Certificate Common Names (CNs). If this parameter is specified, you must also specify the
ca_ids
parameter. - description String
- A description for the API access rule.
- ip
Ranges List<String> - One or more IPs or CIDR blocks (for example,
192.0.2.0/16
). - outscale
Api StringAccess Rule Id
Outputs
All input properties are implicitly available as output properties. Additionally, the ApiAccessRule resource produces the following output properties:
- Api
Access stringRule Id - The ID of the API access rule.
- Id string
- The provider-assigned unique ID for this managed resource.
- Request
Id string
- Api
Access stringRule Id - The ID of the API access rule.
- Id string
- The provider-assigned unique ID for this managed resource.
- Request
Id string
- api
Access StringRule Id - The ID of the API access rule.
- id String
- The provider-assigned unique ID for this managed resource.
- request
Id String
- api
Access stringRule Id - The ID of the API access rule.
- id string
- The provider-assigned unique ID for this managed resource.
- request
Id string
- api_
access_ strrule_ id - The ID of the API access rule.
- id str
- The provider-assigned unique ID for this managed resource.
- request_
id str
- api
Access StringRule Id - The ID of the API access rule.
- id String
- The provider-assigned unique ID for this managed resource.
- request
Id String
Look up Existing ApiAccessRule Resource
Get an existing ApiAccessRule resource’s state with the given name, ID, and optional extra properties used to qualify the lookup.
public static get(name: string, id: Input<ID>, state?: ApiAccessRuleState, opts?: CustomResourceOptions): ApiAccessRule
@staticmethod
def get(resource_name: str,
id: str,
opts: Optional[ResourceOptions] = None,
api_access_rule_id: Optional[str] = None,
ca_ids: Optional[Sequence[str]] = None,
cns: Optional[Sequence[str]] = None,
description: Optional[str] = None,
ip_ranges: Optional[Sequence[str]] = None,
outscale_api_access_rule_id: Optional[str] = None,
request_id: Optional[str] = None) -> ApiAccessRule
func GetApiAccessRule(ctx *Context, name string, id IDInput, state *ApiAccessRuleState, opts ...ResourceOption) (*ApiAccessRule, error)
public static ApiAccessRule Get(string name, Input<string> id, ApiAccessRuleState? state, CustomResourceOptions? opts = null)
public static ApiAccessRule get(String name, Output<String> id, ApiAccessRuleState state, CustomResourceOptions options)
resources: _: type: outscale:ApiAccessRule get: id: ${id}
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- resource_name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- name
- The unique name of the resulting resource.
- id
- The unique provider ID of the resource to lookup.
- state
- Any extra arguments used during the lookup.
- opts
- A bag of options that control this resource's behavior.
- Api
Access stringRule Id - The ID of the API access rule.
- Ca
Ids List<string> - One or more IDs of Client Certificate Authorities (CAs).
- Cns List<string>
- One or more Client Certificate Common Names (CNs). If this parameter is specified, you must also specify the
ca_ids
parameter. - Description string
- A description for the API access rule.
- Ip
Ranges List<string> - One or more IPs or CIDR blocks (for example,
192.0.2.0/16
). - Outscale
Api stringAccess Rule Id - Request
Id string
- Api
Access stringRule Id - The ID of the API access rule.
- Ca
Ids []string - One or more IDs of Client Certificate Authorities (CAs).
- Cns []string
- One or more Client Certificate Common Names (CNs). If this parameter is specified, you must also specify the
ca_ids
parameter. - Description string
- A description for the API access rule.
- Ip
Ranges []string - One or more IPs or CIDR blocks (for example,
192.0.2.0/16
). - Outscale
Api stringAccess Rule Id - Request
Id string
- api
Access StringRule Id - The ID of the API access rule.
- ca
Ids List<String> - One or more IDs of Client Certificate Authorities (CAs).
- cns List<String>
- One or more Client Certificate Common Names (CNs). If this parameter is specified, you must also specify the
ca_ids
parameter. - description String
- A description for the API access rule.
- ip
Ranges List<String> - One or more IPs or CIDR blocks (for example,
192.0.2.0/16
). - outscale
Api StringAccess Rule Id - request
Id String
- api
Access stringRule Id - The ID of the API access rule.
- ca
Ids string[] - One or more IDs of Client Certificate Authorities (CAs).
- cns string[]
- One or more Client Certificate Common Names (CNs). If this parameter is specified, you must also specify the
ca_ids
parameter. - description string
- A description for the API access rule.
- ip
Ranges string[] - One or more IPs or CIDR blocks (for example,
192.0.2.0/16
). - outscale
Api stringAccess Rule Id - request
Id string
- api_
access_ strrule_ id - The ID of the API access rule.
- ca_
ids Sequence[str] - One or more IDs of Client Certificate Authorities (CAs).
- cns Sequence[str]
- One or more Client Certificate Common Names (CNs). If this parameter is specified, you must also specify the
ca_ids
parameter. - description str
- A description for the API access rule.
- ip_
ranges Sequence[str] - One or more IPs or CIDR blocks (for example,
192.0.2.0/16
). - outscale_
api_ straccess_ rule_ id - request_
id str
- api
Access StringRule Id - The ID of the API access rule.
- ca
Ids List<String> - One or more IDs of Client Certificate Authorities (CAs).
- cns List<String>
- One or more Client Certificate Common Names (CNs). If this parameter is specified, you must also specify the
ca_ids
parameter. - description String
- A description for the API access rule.
- ip
Ranges List<String> - One or more IPs or CIDR blocks (for example,
192.0.2.0/16
). - outscale
Api StringAccess Rule Id - request
Id String
Import
An API access rule can be imported using its ID. For example:
console
$ pulumi import outscale:index/apiAccessRule:ApiAccessRule ImportedAPIAccessRule "aar-12345678"
To learn more about importing existing cloud resources, see Importing resources.
Package Details
- Repository
- outscale outscale/terraform-provider-outscale
- License
- Notes
- This Pulumi package is based on the
outscale
Terraform Provider.