라벨, 필드, 선택은 평생 특정 상태를 거칩니다. 또한 라벨의 버전이 다를 수 있습니다. 다음 다이어그램은 버전 관리를 포함한 라벨 수명 주기를 보여줍니다.
- 라벨 만들기 (
create()
) - 라벨이 생성되어 데이터베이스에revision_id=1
로 저장됩니다. 라벨의 상태는UNPUBLISHED_DRAFT
입니다. 이 상태에서는 다음과 같은 작업이 이루어집니다.- 사용자가 라벨을 볼 수 없음
- 사용자는 Drive 항목에 라벨을 적용할 수 없습니다.
- (선택사항) 라벨, 필드 또는 선택 항목 업데이트 (
delta()
) — 게시되기 전에 모든 업데이트가 데이터베이스에 저장되고 라벨의 버전이 증가합니다. - 라벨 게시 (
publish()
): 라벨의 상태는PUBLISHED
이며 사용자가 라벨을 적용할 수 있습니다. 라벨을 게시하면 라벨이 올라갑니다. - (선택사항) 라벨, 필드 또는 선택 항목 업데이트 (
delta()
) - 라벨, 필드 또는 선택 항목이 업데이트되어 데이터베이스에 초안 라벨로 저장됩니다. 라벨의 상태는PUBLISHED
이며hasUnpublishedChanges=true
는 임시 변경사항이 있지만 사용자는 이 변경사항을 사용할 수 없습니다. 업데이트할 때마다 라벨의 버전이 증가합니다. - (선택사항) 라벨 게시 (
publish()
) - 사용 가능한 경우 최신 초안이 게시됩니다. 라벨의 상태는PUBLISHED
이며 사용자가 이 라벨을 적용할 수 있습니다. 라벨을 게시하면 버전이 증가합니다. - 라벨 사용 중지 (
disable()
): 라벨의 상태는DISABLED
이지만 사용자는 API를 통해 라벨을 적용할 수 있습니다. 하지만 사용 중지된 라벨은 표시되도록 구성하지 않는 한 UI에 표시되지 않습니다. 라벨을 지원 중단하면 버전이 증가합니다. - 라벨 사용 설정 (
enable()
) - 라벨이PUBLISHED
상태로 반환되고 사용자가 라벨을 적용할 수 있습니다. 라벨을 게시하면 라벨이 올라갑니다. - 라벨 삭제 (
delete()
) - 라벨의 상태가DELETED
이므로 적용할 수 없습니다. 삭제된 라벨은 영구적으로 삭제됩니다.
라벨을 업데이트할 때마다 라벨의 버전이 증가한다는 점을 강조해야 합니다. 라벨이 이미 게시된 경우 n번 업데이트 후에 다시 게시하면 게시된 버전 번호는 버전 + n + 연속 업데이트 1회가 됩니다.