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

com.google.firebase.database.core.operation.AckUserWrite Maven / Gradle / Ivy

/*
 * Copyright 2017 Google Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.google.firebase.database.core.operation;

import static com.google.firebase.database.utilities.Utilities.hardAssert;

import com.google.firebase.database.core.Path;
import com.google.firebase.database.core.utilities.ImmutableTree;
import com.google.firebase.database.snapshot.ChildKey;

public class AckUserWrite extends Operation {

  private final boolean revert;
  // A tree containing true for each affected path.  Affected paths can't overlap.
  private final ImmutableTree affectedTree;

  public AckUserWrite(Path path, ImmutableTree affectedTree, boolean revert) {
    super(OperationType.AckUserWrite, OperationSource.USER, path);
    this.affectedTree = affectedTree;
    this.revert = revert;
  }

  public ImmutableTree getAffectedTree() {
    return this.affectedTree;
  }

  public boolean isRevert() {
    return this.revert;
  }

  @Override
  public Operation operationForChild(ChildKey childKey) {
    if (!this.path.isEmpty()) {
      hardAssert(
          this.path.getFront().equals(childKey),
          "operationForChild called for unrelated " + "child.");
      return new AckUserWrite(this.path.popFront(), this.affectedTree, this.revert);
    } else if (this.affectedTree.getValue() != null) {
      hardAssert(
          this.affectedTree.getChildren().isEmpty(),
          "affectedTree should not have overlapping affected paths.");
      // All child locations are affected as well; just return same operation.
      return this;
    } else {
      ImmutableTree childTree = this.affectedTree.subtree(new Path(childKey));
      return new AckUserWrite(Path.getEmptyPath(), childTree, this.revert);
    }
  }

  @Override
  public String toString() {
    return String.format(
        "AckUserWrite { path=%s, revert=%s, affectedTree=%s }",
        getPath(), this.revert, this.affectedTree);
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy