@pulumi/awsx
Version:
[](https://github.com/pulumi/pulumi-awsx/actions) [](https://slack.pulumi.com) [;
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
Object.defineProperty(exports, "__esModule", { value: true });
exports.Trail = void 0;
const aws = require("@pulumi/aws");
const pulumi = require("@pulumi/pulumi");
class Trail extends pulumi.ComponentResource {
/**
* Create a Trail resource with the given unique name, arguments, and options.
*
* @param name The _unique_ name of the resource.
* @param args The arguments to use to populate this resource's properties.
* @param opts A bag of options that control this resource's behavior.
*/
constructor(name, args, opts) {
super("aws:cloudtrail:x:Trail", name, {}, opts);
let bucketName;
if (args.s3BucketName !== undefined) {
bucketName = pulumi.output(args.s3BucketName);
}
else {
this.bucket = bucketWithCloudTrailPolicy(name, this);
bucketName = this.bucket.id;
}
let cloudWatchLogGroupArn = undefined;
if (args.sendToCloudWatchLogs) {
this.logGroup = new aws.cloudwatch.LogGroup(name, args.cloudWatchLogGroupArgs, { parent: this });
cloudWatchLogGroupArn = pulumi.interpolate `${this.logGroup.arn}:*`;
}
const trailArgs = {
s3BucketName: bucketName,
cloudWatchLogGroupArn: cloudWatchLogGroupArn,
...args,
};
this.trail = new aws.cloudtrail.Trail(name, trailArgs, { parent: this });
}
}
exports.Trail = Trail;
function bucketWithCloudTrailPolicy(name, parent) {
const bucket = new aws.s3.Bucket(name, {}, { parent: parent });
const policy = new aws.s3.BucketPolicy(name, {
bucket: bucket.id,
policy: {
Version: "2012-10-17",
Statement: [{
Sid: "AWSCloudTrailAclCheck",
Effect: "Allow",
Principal: aws.iam.Principals.CloudtrailPrincipal,
Action: ["s3:GetBucketAcl"],
Resource: [bucket.arn],
}, {
Sid: "AWSCloudTrailWrite",
Effect: "Allow",
Principal: { Service: "cloudtrail.amazonaws.com" },
Action: ["s3:PutObject"],
Resource: [pulumi.interpolate `${bucket.arn}/*`],
Condition: { StringEquals: { "s3:x-amz-acl": "bucket-owner-full-control" } },
}],
},
}, { parent: parent });
return bucket;
}
//# sourceMappingURL=trail.js.map