PhoenixKit.Storage.FileInstance (phoenix_kit v1.6.15)
View SourceSchema for file variants (thumbnails, resizes, video qualities).
Each file can have multiple instances representing different versions:
- original - The unchanged uploaded file
- thumbnail - Small preview (150x150)
- small - Small variant (300x300)
- medium - Medium variant (800x600)
- large - Large variant (1920x1080)
- 360p - Video quality variant (640x360)
- 720p - Video quality variant (1280x720)
- 1080p - Video quality variant (1920x1080)
- video_thumbnail - Thumbnail extracted from video (640x360)
All instances are stored next to the original file in the same directory.
Processing Status
pending- Instance not yet processedprocessing- Currently being generatedcompleted- Successfully generatedfailed- Generation failed
Fields
variant_name- Name of the variant (original, thumbnail, medium, etc.)file_name- System filename (uuid_v7-variant.ext)mime_type- MIME type of this variantext- File extensionchecksum- Hash for integrity verificationsize- Variant file size in byteswidth- Width in pixels (nullable)height- Height in pixels (nullable)processing_status- Current processing statefile_id- Parent file reference
Examples
# Original instance
%FileInstance{
variant_name: "original",
file_name: "018e3c4a-9f6b-7890-original.jpg",
mime_type: "image/jpeg",
ext: "jpg",
checksum: "abc123...",
size: 524_288,
width: 2000,
height: 2000,
processing_status: "completed",
file_id: "018e3c4a-9f6b-7890-abcd-ef1234567890"
}
# Thumbnail instance
%FileInstance{
variant_name: "thumbnail",
file_name: "018e3c4a-9f6b-7890-thumbnail.jpg",
mime_type: "image/jpeg",
ext: "jpg",
checksum: "def456...",
size: 8_192, # 8 KB
width: 150,
height: 150,
processing_status: "completed",
file_id: "018e3c4a-9f6b-7890-abcd-ef1234567890"
}
# Video quality variant
%FileInstance{
variant_name: "720p",
file_name: "018e3c4a-9f6b-7890-720p.mp4",
mime_type: "video/mp4",
ext: "mp4",
size: 5_242_880, # 5 MB
width: 1280,
height: 720,
processing_status: "processing"
}
Summary
Functions
Changeset for creating or updating a file instance.
Returns whether this instance has been successfully processed.
Returns whether this instance failed processing.
Returns whether this is the original file instance.
Returns whether this instance is pending processing.
Returns whether this instance is currently being processed.
Types
@type t() :: %PhoenixKit.Storage.FileInstance{ __meta__: term(), checksum: String.t(), ext: String.t(), file: PhoenixKit.Storage.File.t() | Ecto.Association.NotLoaded.t(), file_id: UUIDv7.t() | nil, file_name: String.t(), height: integer() | nil, id: UUIDv7.t() | nil, inserted_at: NaiveDateTime.t() | nil, locations: [PhoenixKit.Storage.FileLocation.t()] | Ecto.Association.NotLoaded.t(), mime_type: String.t(), processing_status: String.t(), size: integer(), updated_at: NaiveDateTime.t() | nil, variant_name: String.t(), width: integer() | nil }
Functions
Changeset for creating or updating a file instance.
Required Fields
variant_namefile_namemime_typeextchecksumsizefile_id
Validation Rules
- Processing status must be valid (pending, processing, completed, failed)
- Size must be positive
- Width/height must be positive (if provided)
- Unique variant_name per file
Returns whether this instance has been successfully processed.
Returns whether this instance failed processing.
Returns whether this is the original file instance.
Returns whether this instance is pending processing.
Returns whether this instance is currently being processed.