Search in sources :

Example 1 with UserEventInlineSource

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());
    }
}
Also used : ImportUserEventsResponse(com.google.cloud.retail.v2.ImportUserEventsResponse) Instant(java.time.Instant) ArrayList(java.util.ArrayList) Timestamp(com.google.protobuf.Timestamp) UserEventInputConfig(com.google.cloud.retail.v2.UserEventInputConfig) UserEvent(com.google.cloud.retail.v2.UserEvent) UserEventServiceClient(com.google.cloud.retail.v2.UserEventServiceClient) UserEventInlineSource(com.google.cloud.retail.v2.UserEventInlineSource) ImportUserEventsRequest(com.google.cloud.retail.v2.ImportUserEventsRequest) BigQueryException(com.google.cloud.bigquery.BigQueryException) ImportMetadata(com.google.cloud.retail.v2.ImportMetadata)

Aggregations

BigQueryException (com.google.cloud.bigquery.BigQueryException)1 ImportMetadata (com.google.cloud.retail.v2.ImportMetadata)1 ImportUserEventsRequest (com.google.cloud.retail.v2.ImportUserEventsRequest)1 ImportUserEventsResponse (com.google.cloud.retail.v2.ImportUserEventsResponse)1 UserEvent (com.google.cloud.retail.v2.UserEvent)1 UserEventInlineSource (com.google.cloud.retail.v2.UserEventInlineSource)1 UserEventInputConfig (com.google.cloud.retail.v2.UserEventInputConfig)1 UserEventServiceClient (com.google.cloud.retail.v2.UserEventServiceClient)1 Timestamp (com.google.protobuf.Timestamp)1 Instant (java.time.Instant)1 ArrayList (java.util.ArrayList)1