GCP Java - 1.0
Extension ID
com.castsoftware.java.gcp
What’s new
See GCP Java - 1.0 - Release Notes.
Supported services and frameworks
Framework → Services ↓ |
SDK 1.x | SDK 2.x |
---|---|---|
Bigtable | ||
Cloud Storage | ||
PubSub | N/A |
Objects
Icon | Description |
---|---|
Java GCP Bigtable Table | |
Java GCP Unknown Bigtable Table | |
Java GCP Cloud Storage Bucket | |
Java GCP Unknown Cloud Storage Bucket | |
Java GCP Pub/Sub Publisher | |
Java GCP Unknown Pub/Sub Publisher | |
Java GCP Pub/Sub Subscription | |
Java GCP Pub/Sub Receiver | |
Java GCP Unknown Pub/Sub Receiver |
In what situation should you install this extension?
This extension should be used for analyzing java source code using any of the supported GCP services.
Support for SDK
Support for Cloud Bigtable
Supported Cloud Bigtable APIs for SDK v2
For the following methods of the clients com.google.cloud.bigtable.data.v2.BigtableDataClient and com.google.cloud.bigtable.admin.v2.BigtableInstanceAdminClient, we create links to the Table:
Link Type | Client | Methods |
---|---|---|
useInsertLink | com.google.cloud.bigtable.data.v2.BigtableDataClient | bulkMutateRows bulkMutateRowsAsync bulkMutationCallable mutateRow mutateRowAsync mutateRowCallable checkAndMutateRow checkAndMutateRowAsync checkAndMutateRowCallable newBulkMutationBatcher |
useUpdateLink | com.google.cloud.bigtable.data.v2.BigtableDataClient | readModifyWriteRow readModifyWriteRowAsync readModifyWriteRowCallable bulkMutateRows bulkMutateRowsAsync bulkMutationCallable mutateRow mutateRowAsync mutateRowCallable checkAndMutateRow checkAndMutateRowAsync checkAndMutateRowCallable newBulkMutationBatcher |
useSelectLink | com.google.cloud.bigtable.data.v2.BigtableDataClient | readRow readRowAsync readRowCallable readRows readRowsAsync readRowsCallable sampleRowKeys sampleRowKeysAsync sampleRowKeysCallable newBulkReadRowsBatcher |
useDeleteLink | com.google.cloud.bigtable.data.v2.BigtableDataClient | bulkMutateRows bulkMutateRowsAsync bulkMutationCallable mutateRow mutateRowAsync mutateRowCallable checkAndMutateRow checkAndMutateRowAsync checkAndMutateRowCallable newBulkMutationBatcher |
useDeleteLink | com.google.cloud.bigtable.admin.v2.BigtableInstanceAdminClient | dropAllRows dropAllRowsAsync dropRowRange dropRowRangeAsync |
What results you can expect?
When the name of a given referred table in the code is not resolved, an unknown table object will be created with name Unknown. There can be a maximum of one unknown table per project.
The analysis of the following source code will create a Java Call to GCP Bigtable object named mobile-time-series with a useUpdateLink from the WriteIncrement to that object:
package com.example.bigtable;
import com.google.cloud.bigtable.data.v2.BigtableDataClient;
import com.google.cloud.bigtable.data.v2.models.ReadModifyWriteRow;
import com.google.cloud.bigtable.data.v2.models.Row;
import java.nio.charset.Charset;
public class WriteIncrement {
private static final String COLUMN_FAMILY_NAME = "stats_summary";
public static void writeIncrement(String projectId, String instanceId, String tableId) {
String projectId = "my-project-id";
String instanceId = "my-instance-id";
String tableId = "mobile-time-series";
try (BigtableDataClient dataClient = BigtableDataClient.create(projectId, instanceId)) {
String rowkey = "phone#4c410523#20190501";
ReadModifyWriteRow mutation =
ReadModifyWriteRow.create(tableId, rowkey)
.increment(COLUMN_FAMILY_NAME, "connected_cell", -1);
Row success = dataClient.readModifyWriteRow(mutation);
System.out.printf(
"Successfully updated row %s", success.getKey().toString(Charset.defaultCharset()));
} catch (Exception e) {
System.out.println("Error during WriteIncrement: \n" + e.toString());
}
}
}
Support for Cloud Storage
Supported Cloud Storage APIs for SDK v2
For the following methods of the client com.google.cloud.storage, we create links to the Bucket:
Link Type | Methods |
---|---|
useUpdateLink | Blob.writer Storage.createFrom Storage.copy Storage.writer |
useSelectLink | Blob.copyTo Blob.downloadTo Blob.reader Blob.getContent Storage.downloadTo Storage.reader Storage.copy Storage.readAllBytes |
useInsertLink | Blob.copyTo Blob.writer Storage.createFrom Storage.copy Storage.writer Storage.create |
useDeleteLink | Storage.delete Blob.delete |
What results you can expect?
When the name of a given referred bucket in the code is not resolved, an unknown bucket object will be created with name Unknown. There can be a maximum of one unknown bucket per project.
The analysis of the following source code will create a Java GCP Cloud Storage Bucket object named my-delete-bucket-o1 with a useDeleteLink.
package com.example.storage.object;
import com.google.cloud.storage.BlobId;
import com.google.cloud.storage.Storage;
import com.google.cloud.storage.StorageOptions;
import java.util.LinkedList;
import java.util.List;
public class DeleteOldVersionOfObject {
public static void deleteOverloadedOne(String projectId, String bucketName, String objectName, long generationToDelete){
bucketName = "my-delete-bucket-o1";
String blobName1 = "my-blob-name1";
String blobName2 = "my-blob-name2";
Storage storage = StorageOptions.newBuilder().setProjectId(projectId).build().getService();
BlobId firstBlob = BlobId.of(bucketName, blobName1);
BlobId secondBlob = BlobId.of(bucketName, blobName2);
storage.delete(firstBlob, secondBlob);
}
}
Support for PubSub
Supported PubSub APIs for SDK v1
The following APIs are supported:
Object Created | Methods |
---|---|
Publisher | com.google.cloud.pubsub.v1.Publisher.publish com.google.cloud.pubsub.v1.TopicAdminClient.publish |
Subscription | com.google.cloud.pubsub.v1.SubscriptionAdminClient.createSubscription |
Receiver | com.google.cloud.pubsub.v1.SubscriptionAdminClient.pull com.google.cloud.pubsub.v1.Subscriber.startAsync com.google.api.gax.rpc.UnaryCallable.call com.google.api.gax.rpc.UnaryCallable.futureCall |
- For the publish method a Java GCP Pub/Sub Publisher object is created. Its name is of topic name.
- For the create subscription method a Java GCP Pub/Sub Subscription object is created. Its name is of subscription name and will have topics as its properties.
- For the startAsync or pull method a Java GCP Pub/Sub Receiver object is created. Its name is of the subscription.
- The com.castsoftware.wbslinker will create a callLink between the Publisher, Subscription and Reciever.
- A publisher object is linked to subscription object when the topic name matches, and the subscription object is linked to receiver object when the subscription name matches.
What results you can expect?
When the name of a given referred publisher/subscriber in the code is not resolved, an unknown publisher/receiver object will be created with name Unknown.
The analysis of the following source code will create a Java GCP Pub/Sub Publisher object with callLink, a Java GCP Pub/Sub Subscription object and a Java GCP Pub/Sub Receiver object with callLink.
Publisher example:
Publishing a message
import com.google.api.core.ApiFuture;
import com.google.cloud.pubsub.v1.Publisher;
import com.google.protobuf.ByteString;
import com.google.pubsub.v1.PubsubMessage;
import com.google.pubsub.v1.TopicName;
import java.io.IOException;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.TimeUnit;
public class PublisherExample {
public static void main(String... args) throws Exception {
String projectId = "your-project-id";
String topicId = "topic_id_01";
publisherExample(projectId, topicId);
}
public static void publisherExample(String projectId, String topicId)
throws IOException, ExecutionException, InterruptedException {
TopicName topicName = TopicName.of(projectId, topicId);
Publisher publisher = null;
try {
publisher = Publisher.newBuilder(topicName).build();
String message = "Hello World!";
ByteString data = ByteString.copyFromUtf8(message);
PubsubMessage pubsubMessage = PubsubMessage.newBuilder().setData(data).build();
ApiFuture<String> messageIdFuture = publisher.publish(pubsubMessage);
} finally {
if (publisher != null) {
publisher.shutdown();
publisher.awaitTermination(1, TimeUnit.MINUTES);
}
}
}
}
Subscription example:
Create a subscription to a given topic
import com.google.cloud.pubsub.v1.SubscriptionAdminClient;
import com.google.pubsub.v1.PushConfig;
import com.google.pubsub.v1.Subscription;
import com.google.pubsub.v1.SubscriptionName;
import com.google.pubsub.v1.TopicName;
import java.io.IOException;
public class CreatePullSubscriptionExample {
public static void main(String... args) throws Exception {
String projectId = "your-project-id";
String subscriptionId = "subscription_id_01";
String topicId = "topic_id_01";
createPullSubscriptionExample(projectId, subscriptionId, topicId);
}
public static void createPullSubscriptionExample(
String projectId, String subscriptionId, String topicId) throws IOException {
try (SubscriptionAdminClient subscriptionAdminClient = SubscriptionAdminClient.create()) {
TopicName topicName = TopicName.of(projectId, topicId);
SubscriptionName subscriptionName = SubscriptionName.of(projectId, subscriptionId);
Subscription subscription =
subscriptionAdminClient.createSubscription(
subscriptionName, topicName, PushConfig.getDefaultInstance(), 10);
System.out.println("Created pull subscription: " + subscription.getName());
}
}
}
Receiver example:
Receiving a message
import com.google.cloud.pubsub.v1.AckReplyConsumer;
import com.google.cloud.pubsub.v1.MessageReceiver;
import com.google.cloud.pubsub.v1.Subscriber;
import com.google.pubsub.v1.ProjectSubscriptionName;
import com.google.pubsub.v1.PubsubMessage;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.TimeoutException;
public class SubscribeAsyncExample {
public static void main(String... args) throws Exception {
String projectId = "your-project-id";
String subscriptionId = "subscription_id_01";
subscribeAsyncExample(projectId, subscriptionId);
}
public static void subscribeAsyncExample(String projectId, String subscriptionId) {
ProjectSubscriptionName subscriptionName =
ProjectSubscriptionName.of(projectId, subscriptionId);
MessageReceiver receiver =
(PubsubMessage message, AckReplyConsumer consumer) -> {
consumer.ack();
};
Subscriber subscriber = null;
try {
subscriber = Subscriber.newBuilder(subscriptionName, receiver).build();
subscriber.startAsync().awaitRunning();
subscriber.awaitTerminated(30, TimeUnit.SECONDS);
} catch (TimeoutException timeoutException) {
subscriber.stopAsync();
}
}
}
Data sensitivity
This extension is capable of setting a property on GCP Cloud Storage Bucket objects for the following:
- custom sensitivity
- GDPR
- PCI-DSS
See Data Sensitivity for more information.
Known limitations
- LinkType is not evaluated for mutateRow calls, all linktypes are created by default.