1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
// Copyright (C) 2026 Dylan Jones
// SPDX-License-Identifier: GPL-3.0-only
use diesel::prelude::*;
#[cfg(feature = "napi")]
use napi_derive::napi;
#[cfg(feature = "pyo3")]
use pyo3::prelude::*;
#[cfg(feature = "pyo3")]
use rbox_derives::PyMutableMapping;
use super::schema::imageFile;
use super::{Date, DateString};
use crate::model_traits::Model;
#[cfg(feature = "pyo3")]
use crate::util::{PyItemsIter, PyObjectIter, PyStrIter};
/// Represents the `imageFile` table in the Rekordbox database.
///
/// This struct maps to the `imageFile` table in the SQLite database used by Rekordbox.
/// It stores information about image files, including metadata such as file paths,
/// hashes, and synchronization details.
#[derive(Debug, Clone, PartialEq, Default, HasQuery, Identifiable, Insertable, AsChangeset)]
#[diesel(table_name = imageFile)]
#[diesel(primary_key(id))]
#[diesel(check_for_backend(diesel::sqlite::Sqlite))]
#[cfg_attr(feature = "pyo3", pyclass(get_all, set_all, mapping))]
#[cfg_attr(feature = "pyo3", derive(PyMutableMapping))]
#[cfg_attr(feature = "napi", napi(object))]
pub struct ImageFile {
/// A unique identifier for the entry.
pub id: String,
/// A unique universal identifier for the entry.
pub uuid: String,
/// An integer representing the data status in Rekordbox.
pub rb_data_status: i32,
/// An integer representing the local data status in Rekordbox.
pub rb_local_data_status: i32,
/// An integer indicating whether the entry is locally deleted.
pub rb_local_deleted: i32,
/// An integer indicating whether the entry is locally synced.
pub rb_local_synced: i32,
/// An optional integer representing the update sequence number.
pub usn: Option<i32>,
/// An optional integer representing the local update sequence number.
pub rb_local_usn: Option<i32>,
/// The timestamp when the entry was created, serialized/deserialized as `DateString`.
#[diesel(serialize_as = DateString)]
#[diesel(deserialize_as = DateString)]
pub created_at: Date,
/// The timestamp when the entry was last updated, serialized/deserialized as `DateString`.
#[diesel(serialize_as = DateString)]
#[diesel(deserialize_as = DateString)]
pub updated_at: Date,
/// An optional string representing the table name associated with the image file.
pub table_name: Option<String>,
/// An optional string representing the target UUID associated with the image file.
pub target_uuid: Option<String>,
/// An optional string representing the target ID associated with the image file.
pub target_id: Option<String>,
/// An optional string representing the file path of the image.
pub path: Option<String>,
/// An optional string representing the hash of the image file.
pub hash: Option<String>,
/// An optional integer representing the size of the image file.
pub size: Option<i32>,
/// An optional string representing the local path of the image file in Rekordbox.
pub rb_local_path: Option<String>,
/// An optional string representing the in-sync hash of the image file.
pub rb_insync_hash: Option<String>,
/// An optional integer representing the in-sync local update sequence number.
pub rb_insync_local_usn: Option<i32>,
/// An optional integer indicating whether the file hash is dirty.
pub rb_file_hash_dirty: Option<i32>,
/// An optional integer representing the local file status in Rekordbox.
pub rb_local_file_status: Option<i32>,
/// An optional integer indicating whether the file is in progress.
pub rb_in_progress: Option<i32>,
/// An optional integer representing the process type of the file.
pub rb_process_type: Option<i32>,
/// An optional string representing the temporary path of the file.
pub rb_temp_path: Option<String>,
/// An optional integer representing the priority of the file.
pub rb_priority: Option<i32>,
/// An optional integer indicating whether the file size is dirty.
pub rb_file_size_dirty: Option<i32>,
}
impl Model for ImageFile {
type Id = str;
fn all(conn: &mut SqliteConnection) -> QueryResult<Vec<Self>> {
Self::query().load(conn)
}
fn find(conn: &mut SqliteConnection, id: &Self::Id) -> QueryResult<Option<Self>> {
Self::query().find(id).first(conn).optional()
}
fn id_exists(conn: &mut SqliteConnection, id: &Self::Id) -> QueryResult<bool> {
diesel::dsl::select(diesel::dsl::exists(Self::query().find(id))).get_result(conn)
}
}