def create_vpc(): print("AWS VPC를 생성합니다.") print("AWS VPC 생성시 이름을 입력하세요 : ") vpcNm = input() #생성될 object들의 접두사. #print("AWS VPC 의 IP 대역을 입력하세요. 예)10.5.0.0/16 ") vpc_ips = "10.5.0.0/16" #default vpc cidr startNo = 5 print("VPC Cidr을 찾고 있습니다.") vpc_ips = get_unregistered_vpcmax_cidr(5) print(vpc_ips + " IP 대역으로 Vpc를 생성합니다.") print("1.생성합니다. 2.IP 대역을 직접 입력합니다.") step1 = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 if step1 == "1": print("Vpc 생성을 시작합니다.") elif step1 == "2": while 0 < 1: print("IP 대역을 직접 입력해주세요. 예) 10.5.0.0/16") vpc_ips = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 ret_obj = search_vpcs_byCidr(vpc_ips) if len(ret_obj) > 0: print("입력하신 IP 대역이 이미 등록되어 있습니다. 다시 입력해주세요") else: break else: print("잘못 입력하셨습니다.") goMain.go_second_menu(selected_first_menu) command = 'aws ec2 create-vpc --cidr-block ' + vpc_ips + ' --query Vpc.VpcId --output text' credVpcId = cmdUtil.create_resource(command, vpcNm) print("Vpc 가 생성되었습니다.") retStr = {"vpcId": credVpcId, "cidr": vpc_ips} return retStr
def create_instance(): print("ec2 instance 를 생성합니다.") print("instance 생성시 이름을 입력하세요 : ") instanceNm = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 instanceId = "" print("instance 로 생성할 linux이미지를 선택합니다.") print("linux 이미지는 Default로 amazon Linux를 설치합니다.") while 1 > 0: print("1.Default로 설치합니다. 2.검색해서 설치합니다.") nextStep = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 selectedImageInfoArr = [] searchImageKeyword = "" if nextStep == "2": while 0 < 1: print("이미지를 검색할 단어를 입력하세요.") searchImageKeyword = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 selectedImageInfoArr = search_instance_image( searchImageKeyword) if selectedImageInfoArr != "research": break break elif nextStep == "1": selectedImageInfoArr = search_instance_image("") break else: print("잘못 선택하셨습니다. 다시 선택해주세요.") #selectedImageInfoArr[3] print("Subnet을 선택합니다.") selectedSubnetInfoArr = mySubnet.select_subnet() #selectedSubnetInfoArr[3] print("Security Group을 선택합니다.") selectedSGInfoArr = mysg.select_sg("vpc-id", selectedSubnetInfoArr[4]) print("instance 에 접속에 필요한 key-pairs 를 선택합니다.") selectedkeysInfoArr = mykeys.select_keypairs() print("instance 에 적용할 권한인 instance profile을 선택합니다.") selectedInstanceProfileInfoArr = myroles.select_instance_profiles() print("instance 를 생성하시겠습니까?(y/n)") netStepYN = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 if netStepYN.lower() == 'y': command = "aws ec2 run-instances --image-id " + selectedImageInfoArr[3] command = command + " --instance-type t2.micro --count 1" command = command + " --subnet-id " + selectedSubnetInfoArr[ 3] + " --associate-public-ip-address" command = command + " --security-group-ids " + selectedSGInfoArr[1] command = command + " --iam-instance-profile Name=" + selectedInstanceProfileInfoArr[ 0] + " --key-name " + selectedkeysInfoArr[1] command = command + " --query Instances[*].InstanceId --output text" instanceId = cmdUtil.create_resource(command, instanceNm) print("Instance 생성 되었습니다.") print("instance OS 명을 입력하세요 (예: ubuntu): ") osNm = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 cmdUtil.create_anytag(instanceId, 'OSType', osNm) retStr = {"instanceNm": instanceNm, "instanceId": instanceId} return retStr
def start_instance(): print("1.instance 리부팅 2.instance 시작") nextStep1_YN = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 search_instance_state = "running" comment_1 = "리부팅" commd_str = "reboot-instances" if nextStep1_YN == "2": search_instance_state = "stopped" commd_str = "start-instances" comment_1 = "시작" if nextStep1_YN != "1" and nextStep1_YN != "2": print("다시 선택해주세요.") start_instance() print("ec2 Instance를 선택해 주세요.") selectedObjInfoArr = select_ec2instance("", "", "", search_instance_state) print("(" + selectedObjInfoArr[0] + ")" + selectedObjInfoArr[4] + " instance 를 " + comment_1 + "하시겠습니까?(y/n)") nextStep2_YN = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 if nextStep2_YN[0] == 'Y' or nextStep2_YN[0] == 'y': command = "aws ec2 " + commd_str + " --instance-ids " + selectedObjInfoArr[ 4] retMsg = cmdUtil.exec_commd(command) print(comment_1 + " 요청이 완료되었습니다.") goMain.go_second_menu(selected_first_menu) else: goMain.go_second_menu(selected_first_menu) return "success"
def select_subnet(): ret_obj = search_subnets('search-all') objArr = [] if len(ret_obj) < 1: print("먼저 Subnet을 생성해 주세요.") goMain.go_second_menu(selected_first_menu) else: i = 0 for oneObj in ret_obj: i += 1 objInfo = get_simple_subnet_info(oneObj) objArr.append(objInfo) print(str(i) + "." + objInfo) selectedNo = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 # 사용자가 입력한 번호가 vpc arr 보다 많으면 처음부터 다시 시작. if int(selectedNo) > len(objArr): print("잘못 선택하셨습니다.") goMain.go_second_menu(selected_first_menu) # 선택한 번호에 맞는 vpcid를 변수에 저장합니다. selectedObjInfoArr = [] for index in range(len(objArr)): if selectedNo == str(index + 1): selectedObjInfoArr = (objArr[index]).split(' : ') break return selectedObjInfoArr
def select_vpc(): vpcArr = [] ret_obj = search_vpcs("search-all") if len(ret_obj) < 1: print("먼저 Vpc를 생성해 주세요.") goMain.go_second_menu(selected_first_menu) else: i = 0 for vpcObj in ret_obj: i += 1 vpcInfo = get_simple_vpc_info(vpcObj) vpcArr.append(vpcInfo) print(str(i) + "." + vpcInfo) selectedVpcNo = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 # 사용자가 입력한 번호가 vpc arr 보다 많으면 처음부터 다시 시작. if int(selectedVpcNo) > len(vpcArr): print("잘못 선택하셨습니다.") goMain.go_second_menu(selected_first_menu) # 선택한 번호에 맞는 vpcid를 변수에 저장합니다. selectedVpcInfoArr = [] for index in range(len(vpcArr)): if selectedVpcNo == str(index + 1): selectedVpcInfoArr = (vpcArr[index]).split(' : ') break return selectedVpcInfoArr
def create_gateway(): print("Gateway를 생성합니다.") print("Gateway 생성시 이름을 입력하세요 : ") gwNm=goMain.goPage_inputValCheck(selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 print("Gateway를 생성합니다.") command = 'aws ec2 create-internet-gateway --query InternetGateway.InternetGatewayId --output text' credGwId = cmdUtil.create_resource(command, gwNm) print("Internet gateway가 생성되었습니다.") print("생성하신 Gateway와 Vpc를 연결하시겠습니까?(y/n)") nextStepYN=goMain.goPage_inputValCheck(selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 if nextStepYN == 'Y' or nextStepYN == 'y': print("연결할 vpc를 선택하세요.") # 등록된 vpc 목록을 가져옵니다. selectedVpcInfoArr = myVpcs.select_vpc() attach_gw_to_vpc(credGwId, selectedVpcInfoArr[2]) else: goMain.go_second_menu(selected_first_menu) retStr = {"GatewayId":credGwId,"vpcId":selectedVpcInfoArr[2]} return retStr
def create_routeTable(): print("Route table을 생성합니다.") print("Route table 생성시 이름을 입력하세요 (예 test_public_RT): ") routeTableNm = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 print("Route table을 생성할 Vpc를 선택합니다.") # 등록된 vpc 목록을 가져옵니다. selectedVpcInfoArr = myVpcs.select_vpc() print("Route table 생성중입니다.") command = 'aws ec2 create-route-table --vpc-id ' + selectedVpcInfoArr[ 2] + ' --query RouteTable.RouteTableId --output text' credRtId = cmdUtil.create_resource(command, routeTableNm) print("Route table이 생성되었습니다.") retStr = {"RouteTableId": credRtId, "RouteTableName": routeTableNm} #route 생성..- gateway연결등 start.. print("Public network 이용을 위해 route-table에 Gateway를 연결해야 합니다.") print("route-table에 Internet Gateway 또는 NAT Gateway를 연결을 진행하시겠습니까? (y/n)") nextStepYN = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 if nextStepYN[0] == 'Y' or nextStepYN[0] == 'y': create_route() #route 생성..- gateway연결등 end.. return retStr
def create_subnet(): print("AWS Subnet을 생성합니다.") print("Subnet 생성시 이름을 입력하세요 : ") subnetNm = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 print("Subnet을 생성할 Vpc를 선택합니다.") # 등록된 vpc 목록을 가져옵니다. selectedVpcInfoArr = myVpcs.select_vpc() #print(selectedVpcInfoArr) print("Subnet의 cidr-block을 선별하고 있습니다.") subnetCidrB = get_unregistered_subnetmax_cidr(selectedVpcInfoArr[2], selectedVpcInfoArr[1]) print(subnetCidrB + " cidr-block으로 subnet을 생성하시겠습니까?") print("1.생성합니다. 2.IP 대역을 직접 입력합니다.") step1 = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 if step1 == "1": print("subnet 생성 진행중입니다.") elif step1 == "2": print("IP 대역을 직접 입력해주세요. 예) " + subnetCidrB) subnetCidrB = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 ret_obj = search_subnets_byCidr(selectedVpcInfoArr[2], subnetCidrB) if len(ret_obj) > 0: print("입력하신 IP 대역이 이미 등록되어 있습니다.") goMain.go_second_menu(selected_first_menu) else: print("잘못 입력하셨습니다. 프로그램을 다시 시작해주세요.") goMain.go_second_menu(selected_first_menu) command = 'aws ec2 create-subnet --vpc-id ' + selectedVpcInfoArr[ 2] + ' --cidr-block ' + subnetCidrB + ' --availability-zone ap-northeast-2a --query Subnet.SubnetId --output text' credSubnetId = cmdUtil.create_resource(command, subnetNm) print("subnet이 생성되었습니다.") retStr = {"SubnetId": credSubnetId, "cidr-block": subnetCidrB} return retStr
def add_inoutBound(doType): doComment = "Inbound" awsCmd = "authorize-security-group-ingress" if doType == "out": doComment = "Outbound" awsCmd = "authorize-security-group-egress" print("Security Group 에 " + doComment + " 를 추가합니다.") print("먼저 추가할 Security Group을 선택합니다.") selectedSGInfoArr = select_sg("", "") print("TCP Protocol 만 등록 가능합니다.") print("허용할 Port 를 입력해주세요 (예: 80)") inPort = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 print("허용할 IP 대역을 입력해주세요 (예: 192.168.10.23/32") inipRange = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 if cmdUtil.ipValidate(inipRange): print(doComment + " 정책 추가 중입니다.") command = 'aws ec2 ' + awsCmd + ' --group-id ' + selectedSGInfoArr[ 1] + ' --ip-permissions IpProtocol=tcp,FromPort=' + inPort + ',ToPort=' + inPort + ',IpRanges="[{CidrIp=' + inipRange + '}]"' cmdUtil.exec_commd(command) return "success"
def create_sg(): print("Security Group 을 생성합니다.") print("Security Group 생성시 이름을 입력하세요 (예 test_sg): ") sgNm = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 print("Security Group 을 생성할 Vpc를 선택합니다.") # 등록된 vpc 목록을 가져옵니다. selectedVpcInfoArr = myVpcs.select_vpc() print("Security Group 생성중입니다.") command = 'aws ec2 create-security-group --group-name ' + sgNm + ' --description "' + sgNm + '" --vpc-id ' + selectedVpcInfoArr[ 2] + ' --query GroupId --output text' credGwId = cmdUtil.create_resource(command, sgNm) print("Security Group 이 생성되었습니다.") retStr = {"SecurityGroupId": credGwId, "SecurityGroupNm": sgNm} return retStr
def select_inoutBound(): retArr = search_inoutBound("inout") print("p.처음으로 가기") selectNo = "0" while 1 > 0: print("삭제할 IN/OUT 정책을 선택합니다.") selectNo = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 if selectNo.lower() == "p": goMain.go_second_menu(selected_first_menu) elif int(selectNo) > len(retArr): print("잘못 선택하셨습니다.") else: break return retArr[int(selectNo) - 1]
def remove_instance(): print("삭제할 ec2 Instance를 선택해 주세요.") search_instance_state = "running,stopping,stopped" selectedObjInfoArr = select_ec2instance("", "", "", search_instance_state) print("(" + selectedObjInfoArr[0] + ")" + selectedObjInfoArr[4] + " instance 를 삭제하시겠습니까?(y/n)") nextStep2_YN = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 if nextStep2_YN[0] == 'Y' or nextStep2_YN[0] == 'y': command = "aws ec2 terminate-instances --instance-ids " + selectedObjInfoArr[ 4] retMsg = cmdUtil.exec_commd(command) print("삭제 요청이 완료되었습니다.") goMain.go_second_menu(selected_first_menu) else: goMain.go_second_menu(selected_first_menu) return "success"
def search_instance_image(searchStr): if searchStr == "": command = 'aws ec2 describe-images --owners amazon --filters "Name=name,Values=amzn2-ami-hvm-*-x86_64-gp2" "Name=state,Values=available" --query "reverse(sort_by(Images, &CreationDate))[:3]"' #elif (searchStr.lower()).contains("ubuntu"): elif "ubuntu" in searchStr.lower(): command = 'aws ec2 describe-images --image-id ami-04876f29fd3a5e8ba ami-0ba5cd124d7a79612 ami-08508144e576d5b64 --query "reverse(sort_by(Images, &CreationDate))[:3]"' else: searchStr = "*" + searchStr + "*" command = 'aws ec2 describe-images --owners amazon --filters "Name=name,Values=' + searchStr + '" "Name=state,Values=available" --query "reverse(sort_by(Images, &CreationDate))[:3]"' ret_obj = cmdUtil.getJson_exec_commd(command) selectedObjInfoArr = [] objArr = [] if len(ret_obj) < 1: print("해당 이미지가 없습니다.") goMain.go_second_menu(selected_first_menu) else: i = 0 for oneObj in ret_obj: i += 1 objInfo = get_simple_image_info(oneObj) objArr.append(objInfo) print(str(i) + "." + objInfo) print("p.다시 검색해서 선택합니다.") selectedNo = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 # 사용자가 입력한 번호가 vpc arr 보다 많으면 처음부터 다시 시작. if selectedNo == "p" or selectedNo == "P": selectedObjInfoArr = "research" elif int(selectedNo) > len(objArr): print("잘못 선택하셨습니다. 처음부터 다시 시작합니다.") goMain.go_second_menu(selected_first_menu) else: # 선택한 번호에 맞는 vpcid를 변수에 저장합니다. selectedObjInfoArr = (objArr[int(selectedNo) - 1]).split(' : ') # for index in range(len(objArr)): # if selectedNo == str(index+1): # selectedObjInfoArr = (objArr[index]).split(' : ') # break return selectedObjInfoArr
def del_inoutBound(): awsCmd = "" selectedObj = select_inoutBound() selectedInOutBoundArr = (selectedObj).split(' | ') print("선택하신 (" + selectedObj + ") 삭제하시겠습니까?(y/n)") nextStep2_YN = goMain.goPage_inputValCheck( selected_first_menu) # 입력시 p, x 입력시 이전 메뉴 또는 프로그램 종료 진행 if nextStep2_YN.lower() == 'y': if selectedInOutBoundArr[0] == "in": awsCmd = "revoke-security-group-ingress" else: awsCmd = " revoke-security-group-egress" #revoke-security-group-ingress command = 'aws ec2 ' + awsCmd + ' --group-id ' + selectedInOutBoundArr[ 5] + ' --ip-permissions IpProtocol=' + selectedInOutBoundArr[4] if selectedInOutBoundArr[4] != "-1": command = command + ',FromPort=' + selectedInOutBoundArr[ 2] + ',ToPort=' + selectedInOutBoundArr[3] command = command + ',IpRanges="[{CidrIp=' + selectedInOutBoundArr[ 1] + '}]"' cmdUtil.exec_commd(command) print("선택하신 (" + selectedObj + ") 삭제되었습니다.") return "success"