@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.createRoleAndPolicies = createRoleAndPolicies;
exports.createRole = createRole;
const aws = require("@pulumi/aws");
const utils = require("./utils");
/** @internal */
function createRoleAndPolicies(name, assumeRolePolicy, policyArns, opts) {
if (typeof assumeRolePolicy !== "string") {
assumeRolePolicy = JSON.stringify(assumeRolePolicy);
}
const role = new aws.iam.Role(name, { assumeRolePolicy }, opts);
const policies = [];
for (let i = 0; i < policyArns.length; i++) {
const policyArn = policyArns[i];
policies.push(new aws.iam.RolePolicyAttachment(`${name}-${utils.sha1hash(policyArn)}`, { role, policyArn }, opts));
}
return { role, policies };
}
/** @internal */
function createRole(name, assumeRolePolicy, policyArns, opts) {
const { role } = createRoleAndPolicies(name, assumeRolePolicy, policyArns, opts);
return role;
}
//# sourceMappingURL=role.js.map