Matthias Andreas Benkard | 0511464 | 2021-12-29 21:51:29 +0100 | [diff] [blame] | 1 | package eu.mulk.jgvariant.ostree; |
| 2 | |
| 3 | import static org.apiguardian.api.API.Status.STABLE; |
| 4 | |
| 5 | import org.apiguardian.api.API; |
| 6 | |
| 7 | /** |
| 8 | * An object type as found in an OSTree repository. |
| 9 | * |
| 10 | * <p>Each object type has its own file extension. |
| 11 | * |
| 12 | * <p>In an OSTree repository, objects are located in a subfolder of the {@code /objects} folder |
| 13 | * based on their {@link Checksum}. The schema for looking up objects is {@code |
| 14 | * /objects/{checksumHead}/{checksumRest}.{fileExtension}} where: |
| 15 | * |
| 16 | * <dl> |
| 17 | * <dt>{@code {checksumHead}} |
| 18 | * <dd>the first two characters of {@link Checksum#hex()} |
| 19 | * <dt>{@code {checksumRest}} |
| 20 | * <dd>the substring of {@link Checksum#hex()} starting from the 3rd character |
| 21 | * <dt>{@code {fileExtension}} |
| 22 | * <dd>the {@link #fileExtension()} of the object type |
| 23 | * </dl> |
| 24 | */ |
| 25 | @API(status = STABLE) |
| 26 | public enum ObjectType { |
Matthias Andreas Benkard | c7aa2b6 | 2022-01-23 18:10:03 +0100 | [diff] [blame] | 27 | |
| 28 | /** |
| 29 | * A regular file. |
| 30 | * |
| 31 | * <p>File ending: {@code .file} |
| 32 | */ |
Matthias Andreas Benkard | 0511464 | 2021-12-29 21:51:29 +0100 | [diff] [blame] | 33 | FILE((byte) 1, "file"), |
Matthias Andreas Benkard | c7aa2b6 | 2022-01-23 18:10:03 +0100 | [diff] [blame] | 34 | |
| 35 | /** |
| 36 | * A serialized {@link DirTree} object. |
| 37 | * |
| 38 | * <p>File ending: {@code .dirtree} |
| 39 | */ |
Matthias Andreas Benkard | 0511464 | 2021-12-29 21:51:29 +0100 | [diff] [blame] | 40 | DIR_TREE((byte) 2, "dirtree"), |
Matthias Andreas Benkard | c7aa2b6 | 2022-01-23 18:10:03 +0100 | [diff] [blame] | 41 | |
| 42 | /** |
| 43 | * A serialized {@link DirMeta} object. |
| 44 | * |
| 45 | * <p>File ending: {@code .dirmeta} |
| 46 | */ |
Matthias Andreas Benkard | 0511464 | 2021-12-29 21:51:29 +0100 | [diff] [blame] | 47 | DIR_META((byte) 3, "dirmeta"), |
Matthias Andreas Benkard | c7aa2b6 | 2022-01-23 18:10:03 +0100 | [diff] [blame] | 48 | |
| 49 | /** |
| 50 | * A serialized {@link Commit} object. |
| 51 | * |
| 52 | * <p>File ending: {@code .commit} |
| 53 | */ |
Matthias Andreas Benkard | 0511464 | 2021-12-29 21:51:29 +0100 | [diff] [blame] | 54 | COMMIT((byte) 4, "commit"), |
Matthias Andreas Benkard | c7aa2b6 | 2022-01-23 18:10:03 +0100 | [diff] [blame] | 55 | |
| 56 | /** |
| 57 | * A tombstone file standing in for a commit that was deleted. |
| 58 | * |
| 59 | * <p>File ending: {@code .commit-tombstone} |
| 60 | */ |
Matthias Andreas Benkard | 0511464 | 2021-12-29 21:51:29 +0100 | [diff] [blame] | 61 | TOMBSTONE_COMMIT((byte) 5, "commit-tombstone"), |
Matthias Andreas Benkard | c7aa2b6 | 2022-01-23 18:10:03 +0100 | [diff] [blame] | 62 | |
| 63 | /** |
| 64 | * Detached metadata for a {@link Commit}. |
| 65 | * |
| 66 | * <p>Often goes together with a {@link #TOMBSTONE_COMMIT}. |
| 67 | * |
| 68 | * <p>File ending: {@code .commitmeta} |
| 69 | */ |
Matthias Andreas Benkard | 0511464 | 2021-12-29 21:51:29 +0100 | [diff] [blame] | 70 | COMMIT_META((byte) 6, "commitmeta"), |
Matthias Andreas Benkard | c7aa2b6 | 2022-01-23 18:10:03 +0100 | [diff] [blame] | 71 | |
| 72 | /** |
| 73 | * A symlink to a {@link #FILE} that lives somewhere else. |
| 74 | * |
| 75 | * <p>File ending: {@code .payload-link} |
| 76 | */ |
Matthias Andreas Benkard | 0511464 | 2021-12-29 21:51:29 +0100 | [diff] [blame] | 77 | PAYLOAD_LINK((byte) 7, "payload-link"); |
| 78 | |
| 79 | private final byte byteValue; |
| 80 | private final String fileExtension; |
| 81 | |
| 82 | /** |
| 83 | * The serialized byte value. |
| 84 | * |
| 85 | * @return a byte representing this value in serialized GVariant structures. |
| 86 | */ |
| 87 | public byte byteValue() { |
| 88 | return byteValue; |
| 89 | } |
| 90 | |
| 91 | /** |
| 92 | * The file extension carried by files of this type. |
| 93 | * |
| 94 | * @return a file extension. |
| 95 | */ |
| 96 | public String fileExtension() { |
| 97 | return fileExtension; |
| 98 | } |
| 99 | |
| 100 | ObjectType(byte byteValue, String fileExtension) { |
| 101 | this.byteValue = byteValue; |
| 102 | this.fileExtension = fileExtension; |
| 103 | } |
| 104 | |
| 105 | /** |
| 106 | * Returns the {@link ObjectType} corresponding to a serialized GVariant value. |
| 107 | * |
| 108 | * @param byteValue a serialized value as used in GVariant. |
| 109 | * @return the {@link ObjectType} corresponding to the serialized value. |
| 110 | * @throws IllegalArgumentException if the byte value is invalid. |
| 111 | */ |
| 112 | public static ObjectType valueOf(byte byteValue) { |
| 113 | return switch (byteValue) { |
| 114 | case 1 -> FILE; |
| 115 | case 2 -> DIR_TREE; |
| 116 | case 3 -> DIR_META; |
| 117 | case 4 -> COMMIT; |
| 118 | case 5 -> TOMBSTONE_COMMIT; |
| 119 | case 6 -> COMMIT_META; |
| 120 | case 7 -> PAYLOAD_LINK; |
| 121 | default -> throw new IllegalArgumentException("invalid ObjectType: %d".formatted(byteValue)); |
| 122 | }; |
| 123 | } |
| 124 | } |