Skip to main content

Create Cron Job Via Lambda, to update certificate and put it to S3 Bucket.

Project description

NPM version PyPI version Release

cdk-certbot-dns-route53

cdk-certbot-dns-route53 is a CDK construct library that allows you to create Certbot Lambda Function on AWS with CDK, and setting schedule cron job to renew certificate to store on S3 Bucket.

Install

Use the npm dist tag to opt in CDKv1 or CDKv2:

// for CDKv2
npm install cdk-certbot-dns-route53
or
npm install cdk-certbot-dns-route53@latest

// for CDKv1
npm install cdk-certbot-dns-route53@cdkv1
import * as r53 from '@aws-cdk/aws-route53';
import * as s3 from '@aws-cdk/aws-s3';
import * as cdk from '@aws-cdk/core';
import { CertbotDnsRoute53Job } from 'cdk-certbot-dns-route53';

const devEnv = {
  account: process.env.CDK_DEFAULT_ACCOUNT,
  region: process.env.CDK_DEFAULT_REGION,
};

const app = new cdk.App();

const stack = new cdk.Stack(app, 'lambda-certbot-dev', { env: devEnv });

new CertbotDnsRoute53Job(stack, 'Demo', {
  certbotOptions: {
    domainName: '*.example.com',
    email: 'user@example.com',
  },
  zone: r53.HostedZone.fromHostedZoneAttributes(stack, 'myZone', {
    zoneName: 'example.com',
    hostedZoneId:  'mockId',
  }),
  destinationBucket: s3.Bucket.fromBucketName(stack, 'myBucket', 'mybucket'),
});

You can define Lambda Image Architecture now. 2022/04/19

import * as r53 from '@aws-cdk/aws-route53';
import * as s3 from '@aws-cdk/aws-s3';
import * as cdk from '@aws-cdk/core';
import * as lambda from '@aws-cdk/aws-lambda';
import { CertbotDnsRoute53Job } from 'cdk-certbot-dns-route53';
const mockApp = new cdk.App();
const stack = new cdk.Stack(mockApp, 'teststack', { env: devEnv });
const bucket = new s3.Bucket(stack, 'testingBucket');
const zone = r53.HostedZone.fromHostedZoneAttributes(stack, 'zone', {
  zoneName: mock.zoneName, hostedZoneId: mock.zoneId,
});
new CertbotDnsRoute53Job(stack, 'Testtask', {
  certbotOptions: {
    domainName: 'example.com',
    email: 'user@example.com',
    customPrefixDirectory: '/',
  },
  zone,
  destinationBucket: bucket,
  schedule: events.Schedule.cron({ month: '2' }),
  architecture: lambda.Architecture.ARM_64, // <- like this way.
});

Example: Invoke Lambda Function log.

Example: Renew certificate to store on S3 Bucket

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cdk_certbot_dns_route53-1.2.297.tar.gz (38.7 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file cdk_certbot_dns_route53-1.2.297.tar.gz.

File metadata

File hashes

Hashes for cdk_certbot_dns_route53-1.2.297.tar.gz
Algorithm Hash digest
SHA256 b4d04322bad973f236e0404a2728c8ff49dcb17a5c0c6eab0661fbc930f22df2
MD5 16afbcec172a50a3b87f061200e4fcf4
BLAKE2b-256 86633f8ba858b79aa5da0dcfb1541912b57fda81759e2f330ecaa12473c96bc5

See more details on using hashes here.

File details

Details for the file cdk_certbot_dns_route53-1.2.297-py3-none-any.whl.

File metadata

File hashes

Hashes for cdk_certbot_dns_route53-1.2.297-py3-none-any.whl
Algorithm Hash digest
SHA256 15287f7a88177885dfa3ba5f76e6cb2ae97fab5b0d60115882b1e1c916ae15fd
MD5 8a3e7ae2a105b318612451d86b3218b6
BLAKE2b-256 cb128fa7ab49bb98940dff2cdc7420a5bbee4c62a79e6190651fc680af4c1af1

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page