All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.bazaarvoice.emodb.job.dao.DataStoreJobStatusDAO Maven / Gradle / Ivy

package com.bazaarvoice.emodb.job.dao;

import com.bazaarvoice.emodb.common.dropwizard.guice.SystemTablePlacement;
import com.bazaarvoice.emodb.common.json.JsonHelper;
import com.bazaarvoice.emodb.common.uuid.TimeUUIDs;
import com.bazaarvoice.emodb.job.api.JobIdentifier;
import com.bazaarvoice.emodb.job.api.JobStatus;
import com.bazaarvoice.emodb.sor.api.AuditBuilder;
import com.bazaarvoice.emodb.sor.api.DataStore;
import com.bazaarvoice.emodb.sor.api.Intrinsic;
import com.bazaarvoice.emodb.sor.api.ReadConsistency;
import com.bazaarvoice.emodb.sor.api.TableOptionsBuilder;
import com.bazaarvoice.emodb.sor.api.WriteConsistency;
import com.bazaarvoice.emodb.sor.delta.Delta;
import com.bazaarvoice.emodb.sor.delta.Deltas;
import com.google.common.base.Supplier;
import com.google.common.base.Suppliers;
import com.google.common.collect.ImmutableMap;
import com.google.inject.Inject;

import javax.annotation.Nullable;
import java.util.Map;

import static com.bazaarvoice.emodb.job.util.JobStatusUtil.narrow;
import static java.util.Objects.requireNonNull;

public class DataStoreJobStatusDAO implements JobStatusDAO {

    private final Supplier _tableNameSupplier;
    private final DataStore _dataStore;

    @Inject
    public DataStoreJobStatusDAO(@JobsTableName final Supplier tableNameSupplier,
                                 @SystemTablePlacement final String placement,
                                 DataStore dataStore) {
        _dataStore = dataStore;

        _tableNameSupplier = Suppliers.memoize(
            new Supplier() {
                @Override
                public String get() {
                    // Lazily ensure the table exists on the first use.
                    String tableName = tableNameSupplier.get();
                    if (!_dataStore.getTableExists(tableName)) {
                        _dataStore.createTable(tableName,
                                new TableOptionsBuilder().setPlacement(placement).build(),
                                ImmutableMap.of(),
                                new AuditBuilder().setLocalHost().setComment("create table").build()
                        );
                    }
                    return tableName;
                }
            }
        );
    }

    private String getTableName() {
        return _tableNameSupplier.get();
    }

    @Override
    public  void updateJobStatus(JobIdentifier jobId, JobStatus jobStatus) {
        requireNonNull(jobId, "jobId");
        requireNonNull(jobStatus, "jobStatus");

        Delta delta = Deltas.mapBuilder()
                .put("status", JsonHelper.convert(jobStatus, Object.class))
                .build();

        write(jobId, delta, "Update job status to " + jobStatus.getStatus());
    }

    @Nullable
    @Override
    public  JobStatus getJobStatus(JobIdentifier jobId) {
        requireNonNull(jobId, "jobId");

        Map result = _dataStore.get(getTableName(), jobId.toString(), ReadConsistency.STRONG);

        if (Intrinsic.isDeleted(result)) {
            return null;
        }

        Object status = result.get("status");
        return narrow(status, jobId.getJobType());
    }

    @Override
    public void deleteJobStatus(JobIdentifier jobId) {
        requireNonNull(jobId, "jobId");

        write(jobId, Deltas.delete(), "Deleting job status");
    }

    private void write(JobIdentifier jobId, Delta delta, String comment) {
        _dataStore.update(
                getTableName(),
                jobId.toString(),
                TimeUUIDs.newUUID(),
                delta,
                new AuditBuilder().setLocalHost().setComment(comment).build(),
                WriteConsistency.STRONG
        );
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy