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

org.elasticsearch.script.ReindexMetadata Maven / Gradle / Ivy

There is a newer version: 8.14.0
Show newest version
/*
 * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
 * or more contributor license agreements. Licensed under the Elastic License
 * 2.0 and the Server Side Public License, v 1; you may not use this file except
 * in compliance with, at your election, the Elastic License 2.0 or the Server
 * Side Public License, v 1.
 */

package org.elasticsearch.script;

import org.elasticsearch.common.util.Maps;
import org.elasticsearch.ingest.IngestDocument;

import java.util.Map;
import java.util.Objects;
import java.util.Set;

/**
 * Metadata for the {@link ReindexScript} context.
 * _index, _id, _version, _routing are all read-write.  _id, _version and _routing are also nullable.
 * _now is millis since epoch and read-only
 * op is read-write one of 'index', 'noop', 'delete'
 *
 * If _version is set to null in the ctx map, that is interpreted as using internal versioning.
 *
 * The {@link #setVersionToInternal(Metadata)} and {@link #isVersionInternal(Metadata)} augmentations
 * are provided for users of this class.  These augmentations allow the class to appear as {@link Metadata}
 * but handle the internal versioning scheme without scripts accessing the ctx map.
 */
public class ReindexMetadata extends Metadata {
    static final Map> PROPERTIES = Map.of(
        INDEX,
        ObjectField.withWritable(),
        ID,
        ObjectField.withWritable().withNullable(),
        VERSION,
        LongField.withWritable().withNullable(),
        ROUTING,
        StringField.withWritable().withNullable(),
        OP,
        StringField.withWritable().withValidation(stringSetValidator(Set.of("noop", "index", "delete"))),
        NOW,
        LongField
    );

    protected final String index;
    protected final String id;
    protected final Long version;
    protected final String routing;

    public ReindexMetadata(String index, String id, Long version, String routing, String op, long timestamp) {
        super(metadataMap(index, id, version, routing, op, timestamp), PROPERTIES);
        this.index = index;
        this.id = id;
        this.version = version;
        this.routing = routing;
    }

    /**
     * Create the backing metadata map with the standard contents assuming default validators.
     */
    protected static Map metadataMap(String index, String id, Long version, String routing, String op, long timestamp) {
        Map metadata = Maps.newHashMapWithExpectedSize(IngestDocument.Metadata.values().length);
        metadata.put(INDEX, index);
        metadata.put(ID, id);
        metadata.put(VERSION, version);
        metadata.put(ROUTING, routing);
        metadata.put(OP, op);
        metadata.put(NOW, timestamp);
        return metadata;
    }

    /**
     * Get version, if it's null, return sentinel value {@link Long#MIN_VALUE}
     */
    @Override
    public long getVersion() {
        Number version = getNumber(VERSION);
        if (version == null) {
            return Long.MIN_VALUE;
        }
        return version.longValue();
    }

    public boolean isVersionInternal() {
        return get(VERSION) == null;
    }

    /**
     * Augmentation to allow {@link ReindexScript}s to check if the version is set to "internal"
     */
    public static boolean isVersionInternal(Metadata receiver) {
        return receiver.get(VERSION) == null;
    }

    /**
     * Augmentation to allow {@link ReindexScript}s to set the version to "internal".
     *
     * This is necessary because {@link #setVersion(long)} takes a primitive long.
     */
    public static void setVersionToInternal(Metadata receiver) {
        receiver.put(VERSION, null);
    }

    public boolean versionChanged() {
        Number updated = getNumber(VERSION);
        if (version == null || updated == null) {
            return version != updated;
        }
        return version != updated.longValue();
    }

    public boolean indexChanged() {
        return Objects.equals(index, getString(INDEX)) == false;
    }

    public boolean idChanged() {
        return Objects.equals(id, getString(ID)) == false;
    }

    public boolean routingChanged() {
        return Objects.equals(routing, getString(ROUTING)) == false;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy