use of com.sequenceiq.cloudbreak.cloud.model.CloudSshKey in project cloudbreak by hortonworks.
the class AwsPlatformResources method sshKeys.
@Override
public CloudSshKeys sshKeys(CloudCredential cloudCredential, Region region, Map<String, String> filters) {
Map<String, Set<CloudSshKey>> result = new HashMap<>();
for (Region actualRegion : regions(cloudCredential, region, new HashMap<>()).getCloudRegions().keySet()) {
// If region is provided then should filter for those region
if (regionMatch(actualRegion, region)) {
Set<CloudSshKey> cloudSshKeys = new HashSet<>();
AmazonEC2Client ec2Client = awsClient.createAccess(new AwsCredentialView(cloudCredential), actualRegion.value());
// create sshkey filter view
PlatformResourceSshKeyFilterView filter = new PlatformResourceSshKeyFilterView(filters);
DescribeKeyPairsRequest describeKeyPairsRequest = new DescribeKeyPairsRequest();
// If the filtervalue is provided then we should filter only for those securitygroups
if (!Strings.isNullOrEmpty(filter.getKeyName())) {
describeKeyPairsRequest.withKeyNames(filter.getKeyName());
}
for (KeyPairInfo keyPairInfo : ec2Client.describeKeyPairs(describeKeyPairsRequest).getKeyPairs()) {
Map<String, Object> properties = new HashMap<>();
properties.put("fingerPrint", keyPairInfo.getKeyFingerprint());
cloudSshKeys.add(new CloudSshKey(keyPairInfo.getKeyName(), properties));
}
result.put(actualRegion.value(), cloudSshKeys);
}
}
return new CloudSshKeys(result);
}
use of com.sequenceiq.cloudbreak.cloud.model.CloudSshKey in project cloudbreak by hortonworks.
the class OpenStackPlatformResources method sshKeys.
@Override
public CloudSshKeys sshKeys(CloudCredential cloudCredential, Region region, Map<String, String> filters) {
OSClient<?> osClient = openStackClient.createOSClient(cloudCredential);
KeystoneCredentialView osCredential = openStackClient.createKeystoneCredential(cloudCredential);
Set<CloudSshKey> cloudSshKeys = new HashSet<>();
for (Keypair keypair : osClient.compute().keypairs().list()) {
Map<String, Object> properties = new HashMap<>();
properties.put("fingerprint", keypair.getFingerprint());
properties.put("id", keypair.getId());
properties.put("publicKey", keypair.getPublicKey());
properties.put("createdAt", keypair.getCreatedAt());
CloudSshKey cloudSshKey = new CloudSshKey();
cloudSshKey.setName(keypair.getName());
cloudSshKey.setProperties(properties);
cloudSshKeys.add(cloudSshKey);
}
Map<String, Set<CloudSshKey>> result = new HashMap<>();
result.put(region.value() == null ? osCredential.getTenantName() : region.value(), cloudSshKeys);
LOGGER.info("openstack cloud ssh keys result: {}", result);
return new CloudSshKeys(result);
}
use of com.sequenceiq.cloudbreak.cloud.model.CloudSshKey in project cloudbreak by hortonworks.
the class CloudSshKeysToPlatformSshKeysResponseConverter method convert.
@Override
public PlatformSshKeysResponse convert(CloudSshKeys source) {
Map<String, Set<PlatformSshKeyResponse>> result = new HashMap<>();
for (Entry<String, Set<CloudSshKey>> entry : source.getCloudSshKeysResponses().entrySet()) {
Set<PlatformSshKeyResponse> sshKeyResponses = new HashSet<>();
for (CloudSshKey cloudSshKey : entry.getValue()) {
PlatformSshKeyResponse actual = new PlatformSshKeyResponse(cloudSshKey.getName(), cloudSshKey.getProperties());
sshKeyResponses.add(actual);
}
result.put(entry.getKey(), sshKeyResponses);
}
return new PlatformSshKeysResponse(result);
}
Aggregations