@pulumi/dnsimple
Version:
A Pulumi package for creating and managing dnsimple cloud resources.
145 lines • 4.72 kB
JavaScript
;
// *** WARNING: this file was generated by pulumi-language-nodejs. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***
Object.defineProperty(exports, "__esModule", { value: true });
exports.DsRecord = void 0;
const pulumi = require("@pulumi/pulumi");
const utilities = require("./utilities");
/**
* Provides a DNSimple domain delegation signer record resource.
*
* ## Example Usage
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as dnsimple from "@pulumi/dnsimple";
*
* const foobar = new dnsimple.DsRecord("foobar", {
* domain: dnsimple.domain,
* algorithm: "8",
* digest: "6CEEA0117A02480216EBF745A7B690F938860074E4AD11AF2AC573007205682B",
* digestType: "2",
* keyTag: "12345",
* });
* ```
*
* ## Import
*
* DNSimple DS record resources can be imported using their domain ID and numeric record ID.
*
* bash
*
* ```sh
* $ pulumi import dnsimple:index/dsRecord:DsRecord resource_name example.com_5678
* ```
*
* The record ID can be found within [DNSimple DNSSEC API](https://developer.dnsimple.com/v2/domains/dnssec/#listDomainDelegationSignerRecords). Check out [Authentication](https://developer.dnsimple.com/v2/#authentication) in API Overview for available options.
*
* bash
*
* curl -u 'EMAIL:PASSWORD' https://api.dnsimple.com/v2/1010/domains/example.com/ds_records | jq
*
* {
*
* "data": [
*
* {
*
* "id": 24,
*
* "domain_id": 1010,
*
* "algorithm": "8",
*
* "digest": "C1F6E04A5A61FBF65BF9DC8294C363CF11C89E802D926BDAB79C55D27BEFA94F",
*
* "digest_type": "2",
*
* "keytag": "44620",
*
* "public_key": null,
*
* "created_at": "2017-03-03T13:49:58Z",
*
* "updated_at": "2017-03-03T13:49:58Z"
*
* }
*
* ],
*
* "pagination": {
*
* "current_page": 1,
*
* "per_page": 30,
*
* "total_entries": 1,
*
* "total_pages": 1
*
* }
*
* }
*/
class DsRecord extends pulumi.CustomResource {
/**
* Get an existing DsRecord resource's state with the given name, ID, and optional extra
* properties used to qualify the lookup.
*
* @param name The _unique_ name of the resulting resource.
* @param id The _unique_ provider ID of the resource to lookup.
* @param state Any extra arguments used during the lookup.
* @param opts Optional settings to control the behavior of the CustomResource.
*/
static get(name, id, state, opts) {
return new DsRecord(name, state, { ...opts, id: id });
}
/**
* Returns true if the given object is an instance of DsRecord. This is designed to work even
* when multiple copies of the Pulumi SDK have been loaded into the same process.
*/
static isInstance(obj) {
if (obj === undefined || obj === null) {
return false;
}
return obj['__pulumiType'] === DsRecord.__pulumiType;
}
constructor(name, argsOrState, opts) {
let resourceInputs = {};
opts = opts || {};
if (opts.id) {
const state = argsOrState;
resourceInputs["algorithm"] = state?.algorithm;
resourceInputs["createdAt"] = state?.createdAt;
resourceInputs["digest"] = state?.digest;
resourceInputs["digestType"] = state?.digestType;
resourceInputs["domain"] = state?.domain;
resourceInputs["keytag"] = state?.keytag;
resourceInputs["publicKey"] = state?.publicKey;
resourceInputs["updatedAt"] = state?.updatedAt;
}
else {
const args = argsOrState;
if (args?.algorithm === undefined && !opts.urn) {
throw new Error("Missing required property 'algorithm'");
}
if (args?.domain === undefined && !opts.urn) {
throw new Error("Missing required property 'domain'");
}
resourceInputs["algorithm"] = args?.algorithm;
resourceInputs["digest"] = args?.digest;
resourceInputs["digestType"] = args?.digestType;
resourceInputs["domain"] = args?.domain;
resourceInputs["keytag"] = args?.keytag;
resourceInputs["publicKey"] = args?.publicKey;
resourceInputs["createdAt"] = undefined /*out*/;
resourceInputs["updatedAt"] = undefined /*out*/;
}
opts = pulumi.mergeOptions(utilities.resourceOptsDefaults(), opts);
super(DsRecord.__pulumiType, name, resourceInputs, opts);
}
}
exports.DsRecord = DsRecord;
/** @internal */
DsRecord.__pulumiType = 'dnsimple:index/dsRecord:DsRecord';
//# sourceMappingURL=dsRecord.js.map