nexus.RepositoryRubygemsGroup
Explore with Pulumi AI
Use this resource to create a group rubygems repository.
Example Usage
import * as pulumi from "@pulumi/pulumi";
import * as nexus from "@pulumi/nexus";
const internal = new nexus.RepositoryRubygemsHosted("internal", {
online: true,
storage: {
blobStoreName: "default",
strictContentTypeValidation: true,
writePolicy: "ALLOW",
},
});
const rubygemsOrg = new nexus.RepositoryRubygemsProxy("rubygemsOrg", {
online: true,
storage: {
blobStoreName: "default",
strictContentTypeValidation: true,
},
proxy: {
remoteUrl: "https://rubygems.org",
contentMaxAge: 1440,
metadataMaxAge: 1440,
},
negativeCache: {
enabled: true,
ttl: 1440,
},
httpClient: {
blocked: false,
autoBlock: true,
},
});
const group = new nexus.RepositoryRubygemsGroup("group", {
online: true,
group: {
memberNames: [
internal.name,
rubygemsOrg.name,
],
},
storage: {
blobStoreName: "default",
strictContentTypeValidation: true,
},
});
import pulumi
import pulumi_nexus as nexus
internal = nexus.RepositoryRubygemsHosted("internal",
online=True,
storage={
"blob_store_name": "default",
"strict_content_type_validation": True,
"write_policy": "ALLOW",
})
rubygems_org = nexus.RepositoryRubygemsProxy("rubygemsOrg",
online=True,
storage={
"blob_store_name": "default",
"strict_content_type_validation": True,
},
proxy={
"remote_url": "https://rubygems.org",
"content_max_age": 1440,
"metadata_max_age": 1440,
},
negative_cache={
"enabled": True,
"ttl": 1440,
},
http_client={
"blocked": False,
"auto_block": True,
})
group = nexus.RepositoryRubygemsGroup("group",
online=True,
group={
"member_names": [
internal.name,
rubygems_org.name,
],
},
storage={
"blob_store_name": "default",
"strict_content_type_validation": True,
})
package main
import (
"github.com/pulumi/pulumi-terraform-provider/sdks/go/nexus/v2/nexus"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
internal, err := nexus.NewRepositoryRubygemsHosted(ctx, "internal", &nexus.RepositoryRubygemsHostedArgs{
Online: pulumi.Bool(true),
Storage: &nexus.RepositoryRubygemsHostedStorageArgs{
BlobStoreName: pulumi.String("default"),
StrictContentTypeValidation: pulumi.Bool(true),
WritePolicy: pulumi.String("ALLOW"),
},
})
if err != nil {
return err
}
rubygemsOrg, err := nexus.NewRepositoryRubygemsProxy(ctx, "rubygemsOrg", &nexus.RepositoryRubygemsProxyArgs{
Online: pulumi.Bool(true),
Storage: &nexus.RepositoryRubygemsProxyStorageArgs{
BlobStoreName: pulumi.String("default"),
StrictContentTypeValidation: pulumi.Bool(true),
},
Proxy: &nexus.RepositoryRubygemsProxyProxyArgs{
RemoteUrl: pulumi.String("https://rubygems.org"),
ContentMaxAge: pulumi.Float64(1440),
MetadataMaxAge: pulumi.Float64(1440),
},
NegativeCache: &nexus.RepositoryRubygemsProxyNegativeCacheArgs{
Enabled: pulumi.Bool(true),
Ttl: pulumi.Float64(1440),
},
HttpClient: &nexus.RepositoryRubygemsProxyHttpClientArgs{
Blocked: pulumi.Bool(false),
AutoBlock: pulumi.Bool(true),
},
})
if err != nil {
return err
}
_, err = nexus.NewRepositoryRubygemsGroup(ctx, "group", &nexus.RepositoryRubygemsGroupArgs{
Online: pulumi.Bool(true),
Group: &nexus.RepositoryRubygemsGroupGroupArgs{
MemberNames: pulumi.StringArray{
internal.Name,
rubygemsOrg.Name,
},
},
Storage: &nexus.RepositoryRubygemsGroupStorageArgs{
BlobStoreName: pulumi.String("default"),
StrictContentTypeValidation: pulumi.Bool(true),
},
})
if err != nil {
return err
}
return nil
})
}
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Nexus = Pulumi.Nexus;
return await Deployment.RunAsync(() =>
{
var @internal = new Nexus.RepositoryRubygemsHosted("internal", new()
{
Online = true,
Storage = new Nexus.Inputs.RepositoryRubygemsHostedStorageArgs
{
BlobStoreName = "default",
StrictContentTypeValidation = true,
WritePolicy = "ALLOW",
},
});
var rubygemsOrg = new Nexus.RepositoryRubygemsProxy("rubygemsOrg", new()
{
Online = true,
Storage = new Nexus.Inputs.RepositoryRubygemsProxyStorageArgs
{
BlobStoreName = "default",
StrictContentTypeValidation = true,
},
Proxy = new Nexus.Inputs.RepositoryRubygemsProxyProxyArgs
{
RemoteUrl = "https://rubygems.org",
ContentMaxAge = 1440,
MetadataMaxAge = 1440,
},
NegativeCache = new Nexus.Inputs.RepositoryRubygemsProxyNegativeCacheArgs
{
Enabled = true,
Ttl = 1440,
},
HttpClient = new Nexus.Inputs.RepositoryRubygemsProxyHttpClientArgs
{
Blocked = false,
AutoBlock = true,
},
});
var @group = new Nexus.RepositoryRubygemsGroup("group", new()
{
Online = true,
Group = new Nexus.Inputs.RepositoryRubygemsGroupGroupArgs
{
MemberNames = new[]
{
@internal.Name,
rubygemsOrg.Name,
},
},
Storage = new Nexus.Inputs.RepositoryRubygemsGroupStorageArgs
{
BlobStoreName = "default",
StrictContentTypeValidation = true,
},
});
});
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.nexus.RepositoryRubygemsHosted;
import com.pulumi.nexus.RepositoryRubygemsHostedArgs;
import com.pulumi.nexus.inputs.RepositoryRubygemsHostedStorageArgs;
import com.pulumi.nexus.RepositoryRubygemsProxy;
import com.pulumi.nexus.RepositoryRubygemsProxyArgs;
import com.pulumi.nexus.inputs.RepositoryRubygemsProxyStorageArgs;
import com.pulumi.nexus.inputs.RepositoryRubygemsProxyProxyArgs;
import com.pulumi.nexus.inputs.RepositoryRubygemsProxyNegativeCacheArgs;
import com.pulumi.nexus.inputs.RepositoryRubygemsProxyHttpClientArgs;
import com.pulumi.nexus.RepositoryRubygemsGroup;
import com.pulumi.nexus.RepositoryRubygemsGroupArgs;
import com.pulumi.nexus.inputs.RepositoryRubygemsGroupGroupArgs;
import com.pulumi.nexus.inputs.RepositoryRubygemsGroupStorageArgs;
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 internal = new RepositoryRubygemsHosted("internal", RepositoryRubygemsHostedArgs.builder()
.online(true)
.storage(RepositoryRubygemsHostedStorageArgs.builder()
.blobStoreName("default")
.strictContentTypeValidation(true)
.writePolicy("ALLOW")
.build())
.build());
var rubygemsOrg = new RepositoryRubygemsProxy("rubygemsOrg", RepositoryRubygemsProxyArgs.builder()
.online(true)
.storage(RepositoryRubygemsProxyStorageArgs.builder()
.blobStoreName("default")
.strictContentTypeValidation(true)
.build())
.proxy(RepositoryRubygemsProxyProxyArgs.builder()
.remoteUrl("https://rubygems.org")
.contentMaxAge(1440)
.metadataMaxAge(1440)
.build())
.negativeCache(RepositoryRubygemsProxyNegativeCacheArgs.builder()
.enabled(true)
.ttl(1440)
.build())
.httpClient(RepositoryRubygemsProxyHttpClientArgs.builder()
.blocked(false)
.autoBlock(true)
.build())
.build());
var group = new RepositoryRubygemsGroup("group", RepositoryRubygemsGroupArgs.builder()
.online(true)
.group(RepositoryRubygemsGroupGroupArgs.builder()
.memberNames(
internal.name(),
rubygemsOrg.name())
.build())
.storage(RepositoryRubygemsGroupStorageArgs.builder()
.blobStoreName("default")
.strictContentTypeValidation(true)
.build())
.build());
}
}
resources:
internal:
type: nexus:RepositoryRubygemsHosted
properties:
online: true
storage:
blobStoreName: default
strictContentTypeValidation: true
writePolicy: ALLOW
rubygemsOrg:
type: nexus:RepositoryRubygemsProxy
properties:
online: true
storage:
blobStoreName: default
strictContentTypeValidation: true
proxy:
remoteUrl: https://rubygems.org
contentMaxAge: 1440
metadataMaxAge: 1440
negativeCache:
enabled: true
ttl: 1440
httpClient:
blocked: false
autoBlock: true
group:
type: nexus:RepositoryRubygemsGroup
properties:
online: true
group:
memberNames:
- ${internal.name}
- ${rubygemsOrg.name}
storage:
blobStoreName: default
strictContentTypeValidation: true
Create RepositoryRubygemsGroup Resource
Resources are created with functions called constructors. To learn more about declaring and configuring resources, see Resources.
Constructor syntax
new RepositoryRubygemsGroup(name: string, args: RepositoryRubygemsGroupArgs, opts?: CustomResourceOptions);
@overload
def RepositoryRubygemsGroup(resource_name: str,
args: RepositoryRubygemsGroupArgs,
opts: Optional[ResourceOptions] = None)
@overload
def RepositoryRubygemsGroup(resource_name: str,
opts: Optional[ResourceOptions] = None,
group: Optional[RepositoryRubygemsGroupGroupArgs] = None,
storage: Optional[RepositoryRubygemsGroupStorageArgs] = None,
name: Optional[str] = None,
online: Optional[bool] = None)
func NewRepositoryRubygemsGroup(ctx *Context, name string, args RepositoryRubygemsGroupArgs, opts ...ResourceOption) (*RepositoryRubygemsGroup, error)
public RepositoryRubygemsGroup(string name, RepositoryRubygemsGroupArgs args, CustomResourceOptions? opts = null)
public RepositoryRubygemsGroup(String name, RepositoryRubygemsGroupArgs args)
public RepositoryRubygemsGroup(String name, RepositoryRubygemsGroupArgs args, CustomResourceOptions options)
type: nexus:RepositoryRubygemsGroup
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 RepositoryRubygemsGroupArgs
- 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 RepositoryRubygemsGroupArgs
- 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 RepositoryRubygemsGroupArgs
- The arguments to resource properties.
- opts ResourceOption
- Bag of options to control resource's behavior.
- name string
- The unique name of the resource.
- args RepositoryRubygemsGroupArgs
- The arguments to resource properties.
- opts CustomResourceOptions
- Bag of options to control resource's behavior.
- name String
- The unique name of the resource.
- args RepositoryRubygemsGroupArgs
- 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 repositoryRubygemsGroupResource = new Nexus.RepositoryRubygemsGroup("repositoryRubygemsGroupResource", new()
{
Group = new Nexus.Inputs.RepositoryRubygemsGroupGroupArgs
{
MemberNames = new[]
{
"string",
},
},
Storage = new Nexus.Inputs.RepositoryRubygemsGroupStorageArgs
{
BlobStoreName = "string",
StrictContentTypeValidation = false,
},
Name = "string",
Online = false,
});
example, err := nexus.NewRepositoryRubygemsGroup(ctx, "repositoryRubygemsGroupResource", &nexus.RepositoryRubygemsGroupArgs{
Group: &nexus.RepositoryRubygemsGroupGroupArgs{
MemberNames: pulumi.StringArray{
pulumi.String("string"),
},
},
Storage: &nexus.RepositoryRubygemsGroupStorageArgs{
BlobStoreName: pulumi.String("string"),
StrictContentTypeValidation: pulumi.Bool(false),
},
Name: pulumi.String("string"),
Online: pulumi.Bool(false),
})
var repositoryRubygemsGroupResource = new RepositoryRubygemsGroup("repositoryRubygemsGroupResource", RepositoryRubygemsGroupArgs.builder()
.group(RepositoryRubygemsGroupGroupArgs.builder()
.memberNames("string")
.build())
.storage(RepositoryRubygemsGroupStorageArgs.builder()
.blobStoreName("string")
.strictContentTypeValidation(false)
.build())
.name("string")
.online(false)
.build());
repository_rubygems_group_resource = nexus.RepositoryRubygemsGroup("repositoryRubygemsGroupResource",
group={
"member_names": ["string"],
},
storage={
"blob_store_name": "string",
"strict_content_type_validation": False,
},
name="string",
online=False)
const repositoryRubygemsGroupResource = new nexus.RepositoryRubygemsGroup("repositoryRubygemsGroupResource", {
group: {
memberNames: ["string"],
},
storage: {
blobStoreName: "string",
strictContentTypeValidation: false,
},
name: "string",
online: false,
});
type: nexus:RepositoryRubygemsGroup
properties:
group:
memberNames:
- string
name: string
online: false
storage:
blobStoreName: string
strictContentTypeValidation: false
RepositoryRubygemsGroup 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 RepositoryRubygemsGroup resource accepts the following input properties:
- Group
Repository
Rubygems Group Group - Configuration for repository group
- Storage
Repository
Rubygems Group Storage - The storage configuration of the repository
- Name string
- A unique identifier for this repository
- Online bool
- Whether this repository accepts incoming requests
- Group
Repository
Rubygems Group Group Args - Configuration for repository group
- Storage
Repository
Rubygems Group Storage Args - The storage configuration of the repository
- Name string
- A unique identifier for this repository
- Online bool
- Whether this repository accepts incoming requests
- group
Repository
Rubygems Group Group - Configuration for repository group
- storage
Repository
Rubygems Group Storage - The storage configuration of the repository
- name String
- A unique identifier for this repository
- online Boolean
- Whether this repository accepts incoming requests
- group
Repository
Rubygems Group Group - Configuration for repository group
- storage
Repository
Rubygems Group Storage - The storage configuration of the repository
- name string
- A unique identifier for this repository
- online boolean
- Whether this repository accepts incoming requests
- group
Repository
Rubygems Group Group Args - Configuration for repository group
- storage
Repository
Rubygems Group Storage Args - The storage configuration of the repository
- name str
- A unique identifier for this repository
- online bool
- Whether this repository accepts incoming requests
- group Property Map
- Configuration for repository group
- storage Property Map
- The storage configuration of the repository
- name String
- A unique identifier for this repository
- online Boolean
- Whether this repository accepts incoming requests
Outputs
All input properties are implicitly available as output properties. Additionally, the RepositoryRubygemsGroup resource produces the following output properties:
- Id string
- The provider-assigned unique ID for this managed resource.
- Id string
- The provider-assigned unique ID for this managed resource.
- id String
- The provider-assigned unique ID for this managed resource.
- id string
- The provider-assigned unique ID for this managed resource.
- id str
- The provider-assigned unique ID for this managed resource.
- id String
- The provider-assigned unique ID for this managed resource.
Look up Existing RepositoryRubygemsGroup Resource
Get an existing RepositoryRubygemsGroup 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?: RepositoryRubygemsGroupState, opts?: CustomResourceOptions): RepositoryRubygemsGroup
@staticmethod
def get(resource_name: str,
id: str,
opts: Optional[ResourceOptions] = None,
group: Optional[RepositoryRubygemsGroupGroupArgs] = None,
name: Optional[str] = None,
online: Optional[bool] = None,
storage: Optional[RepositoryRubygemsGroupStorageArgs] = None) -> RepositoryRubygemsGroup
func GetRepositoryRubygemsGroup(ctx *Context, name string, id IDInput, state *RepositoryRubygemsGroupState, opts ...ResourceOption) (*RepositoryRubygemsGroup, error)
public static RepositoryRubygemsGroup Get(string name, Input<string> id, RepositoryRubygemsGroupState? state, CustomResourceOptions? opts = null)
public static RepositoryRubygemsGroup get(String name, Output<String> id, RepositoryRubygemsGroupState state, CustomResourceOptions options)
resources: _: type: nexus:RepositoryRubygemsGroup 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.
- Group
Repository
Rubygems Group Group - Configuration for repository group
- Name string
- A unique identifier for this repository
- Online bool
- Whether this repository accepts incoming requests
- Storage
Repository
Rubygems Group Storage - The storage configuration of the repository
- Group
Repository
Rubygems Group Group Args - Configuration for repository group
- Name string
- A unique identifier for this repository
- Online bool
- Whether this repository accepts incoming requests
- Storage
Repository
Rubygems Group Storage Args - The storage configuration of the repository
- group
Repository
Rubygems Group Group - Configuration for repository group
- name String
- A unique identifier for this repository
- online Boolean
- Whether this repository accepts incoming requests
- storage
Repository
Rubygems Group Storage - The storage configuration of the repository
- group
Repository
Rubygems Group Group - Configuration for repository group
- name string
- A unique identifier for this repository
- online boolean
- Whether this repository accepts incoming requests
- storage
Repository
Rubygems Group Storage - The storage configuration of the repository
- group
Repository
Rubygems Group Group Args - Configuration for repository group
- name str
- A unique identifier for this repository
- online bool
- Whether this repository accepts incoming requests
- storage
Repository
Rubygems Group Storage Args - The storage configuration of the repository
- group Property Map
- Configuration for repository group
- name String
- A unique identifier for this repository
- online Boolean
- Whether this repository accepts incoming requests
- storage Property Map
- The storage configuration of the repository
Supporting Types
RepositoryRubygemsGroupGroup, RepositoryRubygemsGroupGroupArgs
- Member
Names List<string> - Member repositories names
- Member
Names []string - Member repositories names
- member
Names List<String> - Member repositories names
- member
Names string[] - Member repositories names
- member_
names Sequence[str] - Member repositories names
- member
Names List<String> - Member repositories names
RepositoryRubygemsGroupStorage, RepositoryRubygemsGroupStorageArgs
- Blob
Store stringName - Blob store used to store repository contents
- Strict
Content boolType Validation - Whether to validate uploaded content's MIME type appropriate for the repository format
- Blob
Store stringName - Blob store used to store repository contents
- Strict
Content boolType Validation - Whether to validate uploaded content's MIME type appropriate for the repository format
- blob
Store StringName - Blob store used to store repository contents
- strict
Content BooleanType Validation - Whether to validate uploaded content's MIME type appropriate for the repository format
- blob
Store stringName - Blob store used to store repository contents
- strict
Content booleanType Validation - Whether to validate uploaded content's MIME type appropriate for the repository format
- blob_
store_ strname - Blob store used to store repository contents
- strict_
content_ booltype_ validation - Whether to validate uploaded content's MIME type appropriate for the repository format
- blob
Store StringName - Blob store used to store repository contents
- strict
Content BooleanType Validation - Whether to validate uploaded content's MIME type appropriate for the repository format
Import
import using the name of repository
$ pulumi import nexus:index/repositoryRubygemsGroup:RepositoryRubygemsGroup group rubygems-group
To learn more about importing existing cloud resources, see Importing resources.
Package Details
- Repository
- nexus datadrivers/terraform-provider-nexus
- License
- Notes
- This Pulumi package is based on the
nexus
Terraform Provider.