Шифрование диска в Google Cloud Platform с ошибкой предоставленного клиентом ключа - PullRequest
0 голосов
/ 10 декабря 2018

Я использую клиентский API Google для Java и интегрировал мой пример кода, чтобы запустить новый экземпляр в облаке Google.Здесь я просто проверяю все возможности получения решения, но не удалось

 System.out.println("================== Starting New Instance ==================");


    // Create VM Instance object with the required properties.
    Instance instance = new Instance();

    instance.setName(instanceName);
    instance.setMachineType(
        "https://www.googleapis.com/compute/beta/projects/"
        + PROJECT_ID + "/zones/" + ZONE_NAME + "/machineTypes/n1-standard-1");

    // Add Network Interface to be used by VM Instance.
    NetworkInterface ifc = new NetworkInterface();
    ifc.setNetwork("https://www.googleapis.com/compute/beta/projects/" + PROJECT_ID + "/global/networks/default");
    List<AccessConfig> configs = new ArrayList<>();
    AccessConfig config = new AccessConfig();
    config.setType(NETWORK_INTERFACE_CONFIG);
    config.setName(NETWORK_ACCESS_CONFIG);
    configs.add(config);
    ifc.setAccessConfigs(configs);
    instance.setNetworkInterfaces(Collections.singletonList(ifc));



    CustomerEncryptionKey key= new CustomerEncryptionKey();
    key.set("rsaEncryptedKey", "myencryptedKey");
    // Add attached Persistent Disk to be used by VM Instance.
    AttachedDisk disk = new AttachedDisk();
    disk.setBoot(true);
    disk.setAutoDelete(true);
    disk.setType("PERSISTENT");
    disk.setDiskEncryptionKey(key);

    AttachedDiskInitializeParams params = new AttachedDiskInitializeParams();
    // Assign the Persistent Disk the same name as the VM Instance.
    params.setDiskName(instanceName);
    // Specify the source operating system machine image to be used by the VM Instance.
    params.setSourceImage(SOURCE_IMAGE_PREFIX + SOURCE_IMAGE_PATH);
    params.setSourceImageEncryptionKey(key);
    // Specify the disk type as Standard Persistent Disk
    params.setDiskType("https://www.googleapis.com/compute/beta/projects/" + PROJECT_ID + "/zones/"
                       + ZONE_NAME + "/diskTypes/pd-standard");


    disk.setInitializeParams(params);

    instance.setDisks(Collections.singletonList(disk));

    // Initialize the service account to be used by the VM Instance and set the API access scopes.
    ServiceAccount account = new ServiceAccount();
    account.setEmail("default");
    List<String> scopes = new ArrayList<>();
    scopes.add("https://www.googleapis.com/auth/devstorage.full_control");
    scopes.add("https://www.googleapis.com/auth/compute");
    scopes.add("https://www.googleapis.com/auth/servicecontrol");
    scopes.add("https://www.googleapis.com/auth/service.management.readonly");
    scopes.add("https://www.googleapis.com/auth/trace.append");
    scopes.add("https://www.googleapis.com/auth/logging.write");
    account.setScopes(scopes);
    instance.setServiceAccounts(Collections.singletonList(account));

    // Optional - Add a startup script to be used by the VM Instance.
    Metadata meta = new Metadata();
    Metadata.Items item = new Metadata.Items();
    item.setKey("startup-script-url");
    // If you put a script called "vm-startup.sh" in this Google Cloud Storage
    // bucket, it will execute on VM startup.  This assumes you've created a
    // bucket named the same as your PROJECT_ID.
    // For info on creating buckets see: https://cloud.google.com/storage/docs/cloud-console#_creatingbuckets
    item.setValue("gs://" + PROJECT_ID + "/vm-startup.sh");
    meta.setItems(Collections.singletonList(item));
    instance.setMetadata(meta);

    System.out.println(instance.toPrettyString());

    Compute.Instances.Insert insert = compute.instances().insert(PROJECT_ID, ZONE_NAME, instance);
    final HttpHeaders httpHeaders = new HttpHeaders();
    //httpHeaders.set("x-goog-encryption-algorithm", "AES256");
    //httpHeaders.set("x-goog-encryption-key", key);
   // httpHeaders.set("x-goog-copy-source-encryption-algorithm", "AES256");
    httpHeaders.set("x-goog-copy-source-encryption-key", key);
    insert.setRequestHeaders(httpHeaders);

    return insert.execute();

Но выдает ошибку, что я не предоставил предоставленный клиентом ключ.

400 Bad Request
{
  "code" : 400,
  "errors" : [ {
    "domain" : "global",
    "message" : "'projects/#####/global/images/image-byok' is protected with a customer supplied encryption key, but none was provided.",
    "reason" : "resourceIsEncryptedWithCustomerEncryptionKey"
  } ],
  "message" : "'projects/######/global/images/image-byok' is protected with a customer supplied encryption key, but none was provided."
}
com.google.api.client.googleapis.json.GoogleJsonResponseException: 400 Bad Request
{
  "code" : 400,
  "errors" : [ {
    "domain" : "global",
    "message" : "'projects/######/global/images/image-byok' is protected with a customer supplied encryption key, but none was provided.",
    "reason" : "resourceIsEncryptedWithCustomerEncryptionKey"
  } ],
  "message" : "'projects/######/global/images/image-byok' is protected with a customer supplied encryption key, but none was provided."
}
    at com.google.api.client.googleapis.json.GoogleJsonResponseException.from(GoogleJsonResponseException.java:150)
    at com.google.api.client.googleapis.services.json.AbstractGoogleJsonClientRequest.newExceptionOnError(AbstractGoogleJsonClientRequest.java:113)
    at com.google.api.client.googleapis.services.json.AbstractGoogleJsonClientRequest.newExceptionOnError(AbstractGoogleJsonClientRequest.java:40)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest$1.interceptResponse(AbstractGoogleClientRequest.java:321)
    at com.google.api.client.http.HttpRequest.execute(HttpRequest.java:1067)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:419)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:352)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.execute(AbstractGoogleClientRequest.java:469)
    at com.gem.byokGc.ComputeEngineSample.startInstance(ComputeEngineSample.java:294)
    at com.gem.byokGc.ComputeEngineSample.main(ComputeEngineSample.java:162)

Может кто-нибудь пожалуйстапомогите мне, потому что я могу выполнить тот же сценарий с помощью JSON.

...