pyiceberg/table/refs.py (29 lines of code) (raw):

# Licensed to the Apache Software Foundation (ASF) under one # or more contributor license agreements. See the NOTICE file # distributed with this work for additional information # regarding copyright ownership. The ASF licenses this file # to you 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. from enum import Enum from typing import Annotated, Optional from pydantic import Field, model_validator from pyiceberg.exceptions import ValidationError from pyiceberg.typedef import IcebergBaseModel MAIN_BRANCH = "main" class SnapshotRefType(str, Enum): BRANCH = "branch" TAG = "tag" def __repr__(self) -> str: """Return the string representation of the SnapshotRefType class.""" return f"SnapshotRefType.{self.name}" def __str__(self) -> str: """Return the string representation of the SnapshotRefType class.""" return self.value class SnapshotRef(IcebergBaseModel): snapshot_id: int = Field(alias="snapshot-id") snapshot_ref_type: SnapshotRefType = Field(alias="type") min_snapshots_to_keep: Annotated[Optional[int], Field(alias="min-snapshots-to-keep", default=None, gt=0)] max_snapshot_age_ms: Annotated[Optional[int], Field(alias="max-snapshot-age-ms", default=None, gt=0)] max_ref_age_ms: Annotated[Optional[int], Field(alias="max-ref-age-ms", default=None, gt=0)] @model_validator(mode="after") def check_min_snapshots_to_keep(self) -> "SnapshotRef": if self.min_snapshots_to_keep is not None and self.snapshot_ref_type == SnapshotRefType.TAG: raise ValidationError("Tags do not support setting minSnapshotsToKeep") return self @model_validator(mode="after") def check_max_snapshot_age_ms(self) -> "SnapshotRef": if self.max_snapshot_age_ms is not None and self.snapshot_ref_type == SnapshotRefType.TAG: raise ValidationError("Tags do not support setting maxSnapshotAgeMs") return self