img_src 0.3.2

Rust SDK for img-src image processing and delivery API
Documentation
/*
 * img-src API
 *
 * Image processing and delivery API.  A serverless image processing and delivery API built on Cloudflare Workers with parameter-driven image transformation and on-demand transcoding.  ## Features  - **Image Upload**: Store original images in R2 with SHA256-based deduplication - **On-Demand Transformation**: Resize, crop, and convert images via URL parameters - **Format Conversion**: WebP, AVIF, JPEG, PNG output formats - **Path Organization**: Organize images into folders with multiple paths per image - **CDN Caching**: Automatic edge caching for transformed images  ## Authentication  Authenticate using API Keys with `imgsrc_` prefix. Create your API key at https://img-src.io/settings  ## Rate Limiting  - **Free Plan**: 100 requests/minute - **Pro Plan**: 500 requests/minute  Rate limit headers are included in all responses.
 *
 * The version of the OpenAPI document: 1.0.0
 * Contact: taehun@taehun.dev
 * Generated by: https://openapi-generator.tech
 */

use crate::models;
use serde::{Deserialize, Serialize};

#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct MetadataResponse {
    /// Image ID
    #[serde(rename = "id")]
    pub id: String,
    /// Image visibility (public or private)
    #[serde(rename = "visibility")]
    pub visibility: String,
    #[serde(rename = "metadata")]
    pub metadata: Box<models::ImageMetadata>,
    #[serde(rename = "urls")]
    pub urls: Box<models::CdnUrls>,
    #[serde(rename = "_links")]
    pub _links: Box<models::HateoasLinks>,
}

impl MetadataResponse {
    pub fn new(
        id: String,
        visibility: String,
        metadata: models::ImageMetadata,
        urls: models::CdnUrls,
        _links: models::HateoasLinks,
    ) -> MetadataResponse {
        MetadataResponse {
            id,
            visibility,
            metadata: Box::new(metadata),
            urls: Box::new(urls),
            _links: Box::new(_links),
        }
    }
}