#!/bin/bash tft[0]="aws_config_configuration_recorder" pref[0]="ConfigurationRecorders" idfilt[0]="name" c=0 cm="$AWS configservice describe-configuration-recorders " if [[ "$1" != "" ]]; then cm=$(printf "$cm | jq '. | select(.ConfigurationRecorders[].name==\"%s\")'" $1) fi count=1 trole="" #rm -f ${tft[0]}.tf for c in $(seq 0 0); do ttft=${tft[(${c})]} echo $cm awsout=$(eval $cm 2>/dev/null) if [ "$awsout" == "" ]; then echo "$cm : You don't have access for this resource" exit fi count=$(echo $awsout | jq ".${pref[(${c})]} | length") if [ "$count" -gt "0" ]; then count=$(expr $count - 1) for i in $(seq 0 $count); do #echo $i cname=$(echo $awsout | jq ".${pref[(${c})]}[(${i})].${idfilt[(${c})]}" | tr -d '"') echo "$ttft $cname" fn=$(printf "%s__%s.tf" $ttft $cname) if [ -f "$fn" ]; then echo "$fn exists already skipping" continue fi #printf "resource \"%s\" \"%s\" {" $ttft $cname > $ttft.$cname.tf #printf "}" >> $ttft.$cname.tf #printf "terraform import %s.%s %s" $ttft $cname $cname > data/import_$ttft_$cname.sh #terraform import $ttft.$cname "$cname" | grep Importing #terraform state show -no-color $ttft.$cname > t1.txt #echo $awsj | jq . #rm -f $ttft.$cname.tf #file="t1.txt" #echo "$ttft $cname $rname state get ..." ../../scripts/parallel_import3.sh $ttft ${cname} #echo "$ttft $rname move" file=$(printf "%s-%s-1.txt" $ttft $cname) echo $aws2tfmess >$fn while IFS= read line; do skip=0 # display $line or do something with $line t1=$(echo "$line") if [[ ${t1} == *"="* ]]; then tt1=$(echo "$line" | cut -f1 -d'=' | tr -d ' ') tt2=$(echo "$line" | cut -f2- -d'=') if [[ ${tt1} == "arn" ]]; then skip=1; fi if [[ ${tt1} == "id" ]]; then skip=1; fi #if [[ ${tt1} == "role_arn" ]];then skip=1;fi if [[ ${tt1} == "owner_id" ]]; then skip=1; fi if [[ ${tt1} == "rule_id" ]]; then skip=1; fi #if [[ ${tt1} == "availability_zone" ]];then skip=1;fi if [[ ${tt1} == "availability_zone_id" ]]; then skip=1; fi if [[ ${tt1} == "role_arn" ]]; then rarn=$(echo $tt2 | tr -d '"') trole=$(echo $tt2 | rev | cut -f1 -d'/' | rev | tr -d '"') t1=$(printf "%s = aws_iam_role.r-%s.arn" $tt1 $trole) fi fi if [ "$skip" == "0" ]; then #echo $skip $t1 echo "$t1" >>$fn fi done <"$file" if [ "$trole" != "" ]; then ../../scripts/050-get-iam-roles.sh $trole fi done fi done ../../scripts/parallel_statemv.sh $ttft rm -f t*.txt