use of com.google.cloud.retail.v2.UserEventInlineSource in project java-retail by googleapis.
the class ImportUserEventsInline method importUserEventsFromInlineSource.
public static void importUserEventsFromInlineSource(String defaultCatalog) throws IOException, ExecutionException, InterruptedException {
try {
int userEventsNumber = 3;
int awaitDuration = 30;
List<UserEvent> userEvents = new ArrayList<>();
for (int i = 0; i < userEventsNumber; i++) {
Instant time = Instant.now();
Timestamp timestamp = Timestamp.newBuilder().setSeconds(time.getEpochSecond()).build();
UserEvent userEvent = UserEvent.newBuilder().setEventType("home-page-view").setVisitorId(UUID.randomUUID().toString()).setEventTime(timestamp).build();
userEvents.add(userEvent);
System.out.printf("User Event: %s%n", i);
System.out.println(userEvent);
}
UserEventInlineSource inlineSource = UserEventInlineSource.newBuilder().addAllUserEvents(userEvents).build();
UserEventInputConfig inputConfig = UserEventInputConfig.newBuilder().setUserEventInlineSource(inlineSource).build();
ImportUserEventsRequest importRequest = ImportUserEventsRequest.newBuilder().setParent(defaultCatalog).setInputConfig(inputConfig).build();
System.out.printf("Import user events from inline source request: %s%n", importRequest);
// the "close" method on the client to safely clean up any remaining background resources.
try (UserEventServiceClient userEventServiceClient = UserEventServiceClient.create()) {
OperationFuture<ImportUserEventsResponse, ImportMetadata> importOperation = userEventServiceClient.importUserEventsAsync(importRequest);
System.out.printf("The operation was started: %s%n", importOperation.getName());
System.out.println("Please wait till operation is done.");
userEventServiceClient.awaitTermination(awaitDuration, TimeUnit.SECONDS);
System.out.println("Import user events operation is done.");
if (importOperation.getMetadata().get() != null) {
System.out.printf("Number of successfully imported events: %s%n", importOperation.getMetadata().get().getSuccessCount());
System.out.printf("Number of failures during the importing: %s%n", importOperation.getMetadata().get().getFailureCount());
} else {
System.out.println("Metadata in bigQuery operation is empty.");
}
if (importOperation.get() != null) {
System.out.printf("Operation result: %s%n", importOperation.get());
} else {
System.out.println("Operation result is empty.");
}
}
} catch (BigQueryException e) {
System.out.printf("Exception message: %s", e.getMessage());
}
}
Aggregations