gen clients

This commit is contained in:
timonrieger
2026-02-27 23:51:41 +01:00
parent 81c5eb1bcd
commit 48187e7c71
214 changed files with 4863 additions and 2674 deletions

View File

@@ -370,6 +370,7 @@ Class | Method | HTTP request | Description
- [AssetFaceUpdateItem](doc//AssetFaceUpdateItem.md) - [AssetFaceUpdateItem](doc//AssetFaceUpdateItem.md)
- [AssetFaceWithoutPersonResponseDto](doc//AssetFaceWithoutPersonResponseDto.md) - [AssetFaceWithoutPersonResponseDto](doc//AssetFaceWithoutPersonResponseDto.md)
- [AssetFullSyncDto](doc//AssetFullSyncDto.md) - [AssetFullSyncDto](doc//AssetFullSyncDto.md)
- [AssetIdErrorReason](doc//AssetIdErrorReason.md)
- [AssetIdsDto](doc//AssetIdsDto.md) - [AssetIdsDto](doc//AssetIdsDto.md)
- [AssetIdsResponseDto](doc//AssetIdsResponseDto.md) - [AssetIdsResponseDto](doc//AssetIdsResponseDto.md)
- [AssetJobName](doc//AssetJobName.md) - [AssetJobName](doc//AssetJobName.md)
@@ -387,10 +388,12 @@ Class | Method | HTTP request | Description
- [AssetMetadataUpsertItemDto](doc//AssetMetadataUpsertItemDto.md) - [AssetMetadataUpsertItemDto](doc//AssetMetadataUpsertItemDto.md)
- [AssetOcrResponseDto](doc//AssetOcrResponseDto.md) - [AssetOcrResponseDto](doc//AssetOcrResponseDto.md)
- [AssetOrder](doc//AssetOrder.md) - [AssetOrder](doc//AssetOrder.md)
- [AssetRejectReason](doc//AssetRejectReason.md)
- [AssetResponseDto](doc//AssetResponseDto.md) - [AssetResponseDto](doc//AssetResponseDto.md)
- [AssetStackResponseDto](doc//AssetStackResponseDto.md) - [AssetStackResponseDto](doc//AssetStackResponseDto.md)
- [AssetStatsResponseDto](doc//AssetStatsResponseDto.md) - [AssetStatsResponseDto](doc//AssetStatsResponseDto.md)
- [AssetTypeEnum](doc//AssetTypeEnum.md) - [AssetTypeEnum](doc//AssetTypeEnum.md)
- [AssetUploadAction](doc//AssetUploadAction.md)
- [AssetVisibility](doc//AssetVisibility.md) - [AssetVisibility](doc//AssetVisibility.md)
- [AudioCodec](doc//AudioCodec.md) - [AudioCodec](doc//AudioCodec.md)
- [AuthStatusResponseDto](doc//AuthStatusResponseDto.md) - [AuthStatusResponseDto](doc//AuthStatusResponseDto.md)
@@ -437,7 +440,6 @@ Class | Method | HTTP request | Description
- [LibraryResponseDto](doc//LibraryResponseDto.md) - [LibraryResponseDto](doc//LibraryResponseDto.md)
- [LibraryStatsResponseDto](doc//LibraryStatsResponseDto.md) - [LibraryStatsResponseDto](doc//LibraryStatsResponseDto.md)
- [LicenseKeyDto](doc//LicenseKeyDto.md) - [LicenseKeyDto](doc//LicenseKeyDto.md)
- [LicenseResponseDto](doc//LicenseResponseDto.md)
- [LogLevel](doc//LogLevel.md) - [LogLevel](doc//LogLevel.md)
- [LoginCredentialDto](doc//LoginCredentialDto.md) - [LoginCredentialDto](doc//LoginCredentialDto.md)
- [LoginResponseDto](doc//LoginResponseDto.md) - [LoginResponseDto](doc//LoginResponseDto.md)
@@ -501,6 +503,10 @@ Class | Method | HTTP request | Description
- [PluginActionResponseDto](doc//PluginActionResponseDto.md) - [PluginActionResponseDto](doc//PluginActionResponseDto.md)
- [PluginContextType](doc//PluginContextType.md) - [PluginContextType](doc//PluginContextType.md)
- [PluginFilterResponseDto](doc//PluginFilterResponseDto.md) - [PluginFilterResponseDto](doc//PluginFilterResponseDto.md)
- [PluginJsonSchema](doc//PluginJsonSchema.md)
- [PluginJsonSchemaProperty](doc//PluginJsonSchemaProperty.md)
- [PluginJsonSchemaPropertyAdditionalProperties](doc//PluginJsonSchemaPropertyAdditionalProperties.md)
- [PluginJsonSchemaType](doc//PluginJsonSchemaType.md)
- [PluginResponseDto](doc//PluginResponseDto.md) - [PluginResponseDto](doc//PluginResponseDto.md)
- [PluginTriggerResponseDto](doc//PluginTriggerResponseDto.md) - [PluginTriggerResponseDto](doc//PluginTriggerResponseDto.md)
- [PluginTriggerType](doc//PluginTriggerType.md) - [PluginTriggerType](doc//PluginTriggerType.md)

View File

@@ -109,6 +109,7 @@ part 'model/asset_face_update_dto.dart';
part 'model/asset_face_update_item.dart'; part 'model/asset_face_update_item.dart';
part 'model/asset_face_without_person_response_dto.dart'; part 'model/asset_face_without_person_response_dto.dart';
part 'model/asset_full_sync_dto.dart'; part 'model/asset_full_sync_dto.dart';
part 'model/asset_id_error_reason.dart';
part 'model/asset_ids_dto.dart'; part 'model/asset_ids_dto.dart';
part 'model/asset_ids_response_dto.dart'; part 'model/asset_ids_response_dto.dart';
part 'model/asset_job_name.dart'; part 'model/asset_job_name.dart';
@@ -126,10 +127,12 @@ part 'model/asset_metadata_upsert_dto.dart';
part 'model/asset_metadata_upsert_item_dto.dart'; part 'model/asset_metadata_upsert_item_dto.dart';
part 'model/asset_ocr_response_dto.dart'; part 'model/asset_ocr_response_dto.dart';
part 'model/asset_order.dart'; part 'model/asset_order.dart';
part 'model/asset_reject_reason.dart';
part 'model/asset_response_dto.dart'; part 'model/asset_response_dto.dart';
part 'model/asset_stack_response_dto.dart'; part 'model/asset_stack_response_dto.dart';
part 'model/asset_stats_response_dto.dart'; part 'model/asset_stats_response_dto.dart';
part 'model/asset_type_enum.dart'; part 'model/asset_type_enum.dart';
part 'model/asset_upload_action.dart';
part 'model/asset_visibility.dart'; part 'model/asset_visibility.dart';
part 'model/audio_codec.dart'; part 'model/audio_codec.dart';
part 'model/auth_status_response_dto.dart'; part 'model/auth_status_response_dto.dart';
@@ -176,7 +179,6 @@ part 'model/job_settings_dto.dart';
part 'model/library_response_dto.dart'; part 'model/library_response_dto.dart';
part 'model/library_stats_response_dto.dart'; part 'model/library_stats_response_dto.dart';
part 'model/license_key_dto.dart'; part 'model/license_key_dto.dart';
part 'model/license_response_dto.dart';
part 'model/log_level.dart'; part 'model/log_level.dart';
part 'model/login_credential_dto.dart'; part 'model/login_credential_dto.dart';
part 'model/login_response_dto.dart'; part 'model/login_response_dto.dart';
@@ -240,6 +242,10 @@ part 'model/places_response_dto.dart';
part 'model/plugin_action_response_dto.dart'; part 'model/plugin_action_response_dto.dart';
part 'model/plugin_context_type.dart'; part 'model/plugin_context_type.dart';
part 'model/plugin_filter_response_dto.dart'; part 'model/plugin_filter_response_dto.dart';
part 'model/plugin_json_schema.dart';
part 'model/plugin_json_schema_property.dart';
part 'model/plugin_json_schema_property_additional_properties.dart';
part 'model/plugin_json_schema_type.dart';
part 'model/plugin_response_dto.dart'; part 'model/plugin_response_dto.dart';
part 'model/plugin_trigger_response_dto.dart'; part 'model/plugin_trigger_response_dto.dart';
part 'model/plugin_trigger_type.dart'; part 'model/plugin_trigger_type.dart';

View File

@@ -136,10 +136,8 @@ class ActivitiesApi {
/// Asset ID (if activity is for an asset) /// Asset ID (if activity is for an asset)
/// ///
/// * [ReactionLevel] level: /// * [ReactionLevel] level:
/// Filter by activity level
/// ///
/// * [ReactionType] type: /// * [ReactionType] type:
/// Filter by activity type
/// ///
/// * [String] userId: /// * [String] userId:
/// Filter by user ID /// Filter by user ID
@@ -195,10 +193,8 @@ class ActivitiesApi {
/// Asset ID (if activity is for an asset) /// Asset ID (if activity is for an asset)
/// ///
/// * [ReactionLevel] level: /// * [ReactionLevel] level:
/// Filter by activity level
/// ///
/// * [ReactionType] type: /// * [ReactionType] type:
/// Filter by activity type
/// ///
/// * [String] userId: /// * [String] userId:
/// Filter by user ID /// Filter by user ID

View File

@@ -864,7 +864,6 @@ class AssetsApi {
/// Filter by trash status /// Filter by trash status
/// ///
/// * [AssetVisibility] visibility: /// * [AssetVisibility] visibility:
/// Filter by visibility
Future<Response> getAssetStatisticsWithHttpInfo({ bool? isFavorite, bool? isTrashed, AssetVisibility? visibility, }) async { Future<Response> getAssetStatisticsWithHttpInfo({ bool? isFavorite, bool? isTrashed, AssetVisibility? visibility, }) async {
// ignore: prefer_const_declarations // ignore: prefer_const_declarations
final apiPath = r'/assets/statistics'; final apiPath = r'/assets/statistics';
@@ -913,7 +912,6 @@ class AssetsApi {
/// Filter by trash status /// Filter by trash status
/// ///
/// * [AssetVisibility] visibility: /// * [AssetVisibility] visibility:
/// Filter by visibility
Future<AssetStatsResponseDto?> getAssetStatistics({ bool? isFavorite, bool? isTrashed, AssetVisibility? visibility, }) async { Future<AssetStatsResponseDto?> getAssetStatistics({ bool? isFavorite, bool? isTrashed, AssetVisibility? visibility, }) async {
final response = await getAssetStatisticsWithHttpInfo( isFavorite: isFavorite, isTrashed: isTrashed, visibility: visibility, ); final response = await getAssetStatisticsWithHttpInfo( isFavorite: isFavorite, isTrashed: isTrashed, visibility: visibility, );
if (response.statusCode >= HttpStatus.badRequest) { if (response.statusCode >= HttpStatus.badRequest) {
@@ -1592,7 +1590,6 @@ class AssetsApi {
/// Sidecar file data /// Sidecar file data
/// ///
/// * [AssetVisibility] visibility: /// * [AssetVisibility] visibility:
/// Asset visibility
Future<Response> uploadAssetWithHttpInfo(MultipartFile assetData, String deviceAssetId, String deviceId, DateTime fileCreatedAt, DateTime fileModifiedAt, { String? key, String? slug, String? xImmichChecksum, String? duration, String? filename, bool? isFavorite, String? livePhotoVideoId, List<AssetMetadataUpsertItemDto>? metadata, MultipartFile? sidecarData, AssetVisibility? visibility, }) async { Future<Response> uploadAssetWithHttpInfo(MultipartFile assetData, String deviceAssetId, String deviceId, DateTime fileCreatedAt, DateTime fileModifiedAt, { String? key, String? slug, String? xImmichChecksum, String? duration, String? filename, bool? isFavorite, String? livePhotoVideoId, List<AssetMetadataUpsertItemDto>? metadata, MultipartFile? sidecarData, AssetVisibility? visibility, }) async {
// ignore: prefer_const_declarations // ignore: prefer_const_declarations
final apiPath = r'/assets'; final apiPath = r'/assets';
@@ -1731,7 +1728,6 @@ class AssetsApi {
/// Sidecar file data /// Sidecar file data
/// ///
/// * [AssetVisibility] visibility: /// * [AssetVisibility] visibility:
/// Asset visibility
Future<AssetMediaResponseDto?> uploadAsset(MultipartFile assetData, String deviceAssetId, String deviceId, DateTime fileCreatedAt, DateTime fileModifiedAt, { String? key, String? slug, String? xImmichChecksum, String? duration, String? filename, bool? isFavorite, String? livePhotoVideoId, List<AssetMetadataUpsertItemDto>? metadata, MultipartFile? sidecarData, AssetVisibility? visibility, }) async { Future<AssetMediaResponseDto?> uploadAsset(MultipartFile assetData, String deviceAssetId, String deviceId, DateTime fileCreatedAt, DateTime fileModifiedAt, { String? key, String? slug, String? xImmichChecksum, String? duration, String? filename, bool? isFavorite, String? livePhotoVideoId, List<AssetMetadataUpsertItemDto>? metadata, MultipartFile? sidecarData, AssetVisibility? visibility, }) async {
final response = await uploadAssetWithHttpInfo(assetData, deviceAssetId, deviceId, fileCreatedAt, fileModifiedAt, key: key, slug: slug, xImmichChecksum: xImmichChecksum, duration: duration, filename: filename, isFavorite: isFavorite, livePhotoVideoId: livePhotoVideoId, metadata: metadata, sidecarData: sidecarData, visibility: visibility, ); final response = await uploadAssetWithHttpInfo(assetData, deviceAssetId, deviceId, fileCreatedAt, fileModifiedAt, key: key, slug: slug, xImmichChecksum: xImmichChecksum, duration: duration, filename: filename, isFavorite: isFavorite, livePhotoVideoId: livePhotoVideoId, metadata: metadata, sidecarData: sidecarData, visibility: visibility, );
if (response.statusCode >= HttpStatus.badRequest) { if (response.statusCode >= HttpStatus.badRequest) {
@@ -1763,7 +1759,6 @@ class AssetsApi {
/// * [String] key: /// * [String] key:
/// ///
/// * [AssetMediaSize] size: /// * [AssetMediaSize] size:
/// Asset media size
/// ///
/// * [String] slug: /// * [String] slug:
Future<Response> viewAssetWithHttpInfo(String id, { bool? edited, String? key, AssetMediaSize? size, String? slug, }) async { Future<Response> viewAssetWithHttpInfo(String id, { bool? edited, String? key, AssetMediaSize? size, String? slug, }) async {
@@ -1819,7 +1814,6 @@ class AssetsApi {
/// * [String] key: /// * [String] key:
/// ///
/// * [AssetMediaSize] size: /// * [AssetMediaSize] size:
/// Asset media size
/// ///
/// * [String] slug: /// * [String] slug:
Future<MultipartFile?> viewAsset(String id, { bool? edited, String? key, AssetMediaSize? size, String? slug, }) async { Future<MultipartFile?> viewAsset(String id, { bool? edited, String? key, AssetMediaSize? size, String? slug, }) async {

View File

@@ -218,6 +218,7 @@ class DatabaseBackupsAdminApi {
/// Parameters: /// Parameters:
/// ///
/// * [MultipartFile] file: /// * [MultipartFile] file:
/// Database backup file
Future<Response> uploadDatabaseBackupWithHttpInfo({ MultipartFile? file, }) async { Future<Response> uploadDatabaseBackupWithHttpInfo({ MultipartFile? file, }) async {
// ignore: prefer_const_declarations // ignore: prefer_const_declarations
final apiPath = r'/admin/database-backups/upload'; final apiPath = r'/admin/database-backups/upload';
@@ -260,6 +261,7 @@ class DatabaseBackupsAdminApi {
/// Parameters: /// Parameters:
/// ///
/// * [MultipartFile] file: /// * [MultipartFile] file:
/// Database backup file
Future<void> uploadDatabaseBackup({ MultipartFile? file, }) async { Future<void> uploadDatabaseBackup({ MultipartFile? file, }) async {
final response = await uploadDatabaseBackupWithHttpInfo( file: file, ); final response = await uploadDatabaseBackupWithHttpInfo( file: file, );
if (response.statusCode >= HttpStatus.badRequest) { if (response.statusCode >= HttpStatus.badRequest) {

View File

@@ -520,7 +520,6 @@ class DeprecatedApi {
/// Parameters: /// Parameters:
/// ///
/// * [QueueName] name (required): /// * [QueueName] name (required):
/// Queue name
/// ///
/// * [QueueCommandDto] queueCommandDto (required): /// * [QueueCommandDto] queueCommandDto (required):
Future<Response> runQueueCommandLegacyWithHttpInfo(QueueName name, QueueCommandDto queueCommandDto,) async { Future<Response> runQueueCommandLegacyWithHttpInfo(QueueName name, QueueCommandDto queueCommandDto,) async {
@@ -556,7 +555,6 @@ class DeprecatedApi {
/// Parameters: /// Parameters:
/// ///
/// * [QueueName] name (required): /// * [QueueName] name (required):
/// Queue name
/// ///
/// * [QueueCommandDto] queueCommandDto (required): /// * [QueueCommandDto] queueCommandDto (required):
Future<QueueResponseLegacyDto?> runQueueCommandLegacy(QueueName name, QueueCommandDto queueCommandDto,) async { Future<QueueResponseLegacyDto?> runQueueCommandLegacy(QueueName name, QueueCommandDto queueCommandDto,) async {

View File

@@ -121,7 +121,6 @@ class JobsApi {
/// Parameters: /// Parameters:
/// ///
/// * [QueueName] name (required): /// * [QueueName] name (required):
/// Queue name
/// ///
/// * [QueueCommandDto] queueCommandDto (required): /// * [QueueCommandDto] queueCommandDto (required):
Future<Response> runQueueCommandLegacyWithHttpInfo(QueueName name, QueueCommandDto queueCommandDto,) async { Future<Response> runQueueCommandLegacyWithHttpInfo(QueueName name, QueueCommandDto queueCommandDto,) async {
@@ -157,7 +156,6 @@ class JobsApi {
/// Parameters: /// Parameters:
/// ///
/// * [QueueName] name (required): /// * [QueueName] name (required):
/// Queue name
/// ///
/// * [QueueCommandDto] queueCommandDto (required): /// * [QueueCommandDto] queueCommandDto (required):
Future<QueueResponseLegacyDto?> runQueueCommandLegacy(QueueName name, QueueCommandDto queueCommandDto,) async { Future<QueueResponseLegacyDto?> runQueueCommandLegacy(QueueName name, QueueCommandDto queueCommandDto,) async {

View File

@@ -260,13 +260,11 @@ class MemoriesApi {
/// Include trashed memories /// Include trashed memories
/// ///
/// * [MemorySearchOrder] order: /// * [MemorySearchOrder] order:
/// Sort order
/// ///
/// * [int] size: /// * [int] size:
/// Number of memories to return /// Number of memories to return
/// ///
/// * [MemoryType] type: /// * [MemoryType] type:
/// Memory type
Future<Response> memoriesStatisticsWithHttpInfo({ DateTime? for_, bool? isSaved, bool? isTrashed, MemorySearchOrder? order, int? size, MemoryType? type, }) async { Future<Response> memoriesStatisticsWithHttpInfo({ DateTime? for_, bool? isSaved, bool? isTrashed, MemorySearchOrder? order, int? size, MemoryType? type, }) async {
// ignore: prefer_const_declarations // ignore: prefer_const_declarations
final apiPath = r'/memories/statistics'; final apiPath = r'/memories/statistics';
@@ -327,13 +325,11 @@ class MemoriesApi {
/// Include trashed memories /// Include trashed memories
/// ///
/// * [MemorySearchOrder] order: /// * [MemorySearchOrder] order:
/// Sort order
/// ///
/// * [int] size: /// * [int] size:
/// Number of memories to return /// Number of memories to return
/// ///
/// * [MemoryType] type: /// * [MemoryType] type:
/// Memory type
Future<MemoryStatisticsResponseDto?> memoriesStatistics({ DateTime? for_, bool? isSaved, bool? isTrashed, MemorySearchOrder? order, int? size, MemoryType? type, }) async { Future<MemoryStatisticsResponseDto?> memoriesStatistics({ DateTime? for_, bool? isSaved, bool? isTrashed, MemorySearchOrder? order, int? size, MemoryType? type, }) async {
final response = await memoriesStatisticsWithHttpInfo( for_: for_, isSaved: isSaved, isTrashed: isTrashed, order: order, size: size, type: type, ); final response = await memoriesStatisticsWithHttpInfo( for_: for_, isSaved: isSaved, isTrashed: isTrashed, order: order, size: size, type: type, );
if (response.statusCode >= HttpStatus.badRequest) { if (response.statusCode >= HttpStatus.badRequest) {
@@ -431,13 +427,11 @@ class MemoriesApi {
/// Include trashed memories /// Include trashed memories
/// ///
/// * [MemorySearchOrder] order: /// * [MemorySearchOrder] order:
/// Sort order
/// ///
/// * [int] size: /// * [int] size:
/// Number of memories to return /// Number of memories to return
/// ///
/// * [MemoryType] type: /// * [MemoryType] type:
/// Memory type
Future<Response> searchMemoriesWithHttpInfo({ DateTime? for_, bool? isSaved, bool? isTrashed, MemorySearchOrder? order, int? size, MemoryType? type, }) async { Future<Response> searchMemoriesWithHttpInfo({ DateTime? for_, bool? isSaved, bool? isTrashed, MemorySearchOrder? order, int? size, MemoryType? type, }) async {
// ignore: prefer_const_declarations // ignore: prefer_const_declarations
final apiPath = r'/memories'; final apiPath = r'/memories';
@@ -498,13 +492,11 @@ class MemoriesApi {
/// Include trashed memories /// Include trashed memories
/// ///
/// * [MemorySearchOrder] order: /// * [MemorySearchOrder] order:
/// Sort order
/// ///
/// * [int] size: /// * [int] size:
/// Number of memories to return /// Number of memories to return
/// ///
/// * [MemoryType] type: /// * [MemoryType] type:
/// Memory type
Future<List<MemoryResponseDto>?> searchMemories({ DateTime? for_, bool? isSaved, bool? isTrashed, MemorySearchOrder? order, int? size, MemoryType? type, }) async { Future<List<MemoryResponseDto>?> searchMemories({ DateTime? for_, bool? isSaved, bool? isTrashed, MemorySearchOrder? order, int? size, MemoryType? type, }) async {
final response = await searchMemoriesWithHttpInfo( for_: for_, isSaved: isSaved, isTrashed: isTrashed, order: order, size: size, type: type, ); final response = await searchMemoriesWithHttpInfo( for_: for_, isSaved: isSaved, isTrashed: isTrashed, order: order, size: size, type: type, );
if (response.statusCode >= HttpStatus.badRequest) { if (response.statusCode >= HttpStatus.badRequest) {

View File

@@ -182,10 +182,8 @@ class NotificationsApi {
/// Filter by notification ID /// Filter by notification ID
/// ///
/// * [NotificationLevel] level: /// * [NotificationLevel] level:
/// Filter by notification level
/// ///
/// * [NotificationType] type: /// * [NotificationType] type:
/// Filter by notification type
/// ///
/// * [bool] unread: /// * [bool] unread:
/// Filter by unread status /// Filter by unread status
@@ -237,10 +235,8 @@ class NotificationsApi {
/// Filter by notification ID /// Filter by notification ID
/// ///
/// * [NotificationLevel] level: /// * [NotificationLevel] level:
/// Filter by notification level
/// ///
/// * [NotificationType] type: /// * [NotificationType] type:
/// Filter by notification type
/// ///
/// * [bool] unread: /// * [bool] unread:
/// Filter by unread status /// Filter by unread status

View File

@@ -138,7 +138,6 @@ class PartnersApi {
/// Parameters: /// Parameters:
/// ///
/// * [PartnerDirection] direction (required): /// * [PartnerDirection] direction (required):
/// Partner direction
Future<Response> getPartnersWithHttpInfo(PartnerDirection direction,) async { Future<Response> getPartnersWithHttpInfo(PartnerDirection direction,) async {
// ignore: prefer_const_declarations // ignore: prefer_const_declarations
final apiPath = r'/partners'; final apiPath = r'/partners';
@@ -173,7 +172,6 @@ class PartnersApi {
/// Parameters: /// Parameters:
/// ///
/// * [PartnerDirection] direction (required): /// * [PartnerDirection] direction (required):
/// Partner direction
Future<List<PartnerResponseDto>?> getPartners(PartnerDirection direction,) async { Future<List<PartnerResponseDto>?> getPartners(PartnerDirection direction,) async {
final response = await getPartnersWithHttpInfo(direction,); final response = await getPartnersWithHttpInfo(direction,);
if (response.statusCode >= HttpStatus.badRequest) { if (response.statusCode >= HttpStatus.badRequest) {

View File

@@ -25,7 +25,6 @@ class QueuesApi {
/// Parameters: /// Parameters:
/// ///
/// * [QueueName] name (required): /// * [QueueName] name (required):
/// Queue name
/// ///
/// * [QueueDeleteDto] queueDeleteDto (required): /// * [QueueDeleteDto] queueDeleteDto (required):
Future<Response> emptyQueueWithHttpInfo(QueueName name, QueueDeleteDto queueDeleteDto,) async { Future<Response> emptyQueueWithHttpInfo(QueueName name, QueueDeleteDto queueDeleteDto,) async {
@@ -61,7 +60,6 @@ class QueuesApi {
/// Parameters: /// Parameters:
/// ///
/// * [QueueName] name (required): /// * [QueueName] name (required):
/// Queue name
/// ///
/// * [QueueDeleteDto] queueDeleteDto (required): /// * [QueueDeleteDto] queueDeleteDto (required):
Future<void> emptyQueue(QueueName name, QueueDeleteDto queueDeleteDto,) async { Future<void> emptyQueue(QueueName name, QueueDeleteDto queueDeleteDto,) async {
@@ -80,7 +78,6 @@ class QueuesApi {
/// Parameters: /// Parameters:
/// ///
/// * [QueueName] name (required): /// * [QueueName] name (required):
/// Queue name
Future<Response> getQueueWithHttpInfo(QueueName name,) async { Future<Response> getQueueWithHttpInfo(QueueName name,) async {
// ignore: prefer_const_declarations // ignore: prefer_const_declarations
final apiPath = r'/queues/{name}' final apiPath = r'/queues/{name}'
@@ -114,7 +111,6 @@ class QueuesApi {
/// Parameters: /// Parameters:
/// ///
/// * [QueueName] name (required): /// * [QueueName] name (required):
/// Queue name
Future<QueueResponseDto?> getQueue(QueueName name,) async { Future<QueueResponseDto?> getQueue(QueueName name,) async {
final response = await getQueueWithHttpInfo(name,); final response = await getQueueWithHttpInfo(name,);
if (response.statusCode >= HttpStatus.badRequest) { if (response.statusCode >= HttpStatus.badRequest) {
@@ -139,7 +135,6 @@ class QueuesApi {
/// Parameters: /// Parameters:
/// ///
/// * [QueueName] name (required): /// * [QueueName] name (required):
/// Queue name
/// ///
/// * [List<QueueJobStatus>] status: /// * [List<QueueJobStatus>] status:
/// Filter jobs by status /// Filter jobs by status
@@ -180,7 +175,6 @@ class QueuesApi {
/// Parameters: /// Parameters:
/// ///
/// * [QueueName] name (required): /// * [QueueName] name (required):
/// Queue name
/// ///
/// * [List<QueueJobStatus>] status: /// * [List<QueueJobStatus>] status:
/// Filter jobs by status /// Filter jobs by status
@@ -262,7 +256,6 @@ class QueuesApi {
/// Parameters: /// Parameters:
/// ///
/// * [QueueName] name (required): /// * [QueueName] name (required):
/// Queue name
/// ///
/// * [QueueUpdateDto] queueUpdateDto (required): /// * [QueueUpdateDto] queueUpdateDto (required):
Future<Response> updateQueueWithHttpInfo(QueueName name, QueueUpdateDto queueUpdateDto,) async { Future<Response> updateQueueWithHttpInfo(QueueName name, QueueUpdateDto queueUpdateDto,) async {
@@ -298,7 +291,6 @@ class QueuesApi {
/// Parameters: /// Parameters:
/// ///
/// * [QueueName] name (required): /// * [QueueName] name (required):
/// Queue name
/// ///
/// * [QueueUpdateDto] queueUpdateDto (required): /// * [QueueUpdateDto] queueUpdateDto (required):
Future<QueueResponseDto?> updateQueue(QueueName name, QueueUpdateDto queueUpdateDto,) async { Future<QueueResponseDto?> updateQueue(QueueName name, QueueUpdateDto queueUpdateDto,) async {

View File

@@ -127,7 +127,6 @@ class SearchApi {
/// Parameters: /// Parameters:
/// ///
/// * [SearchSuggestionType] type (required): /// * [SearchSuggestionType] type (required):
/// Suggestion type
/// ///
/// * [String] country: /// * [String] country:
/// Filter by country /// Filter by country
@@ -198,7 +197,6 @@ class SearchApi {
/// Parameters: /// Parameters:
/// ///
/// * [SearchSuggestionType] type (required): /// * [SearchSuggestionType] type (required):
/// Suggestion type
/// ///
/// * [String] country: /// * [String] country:
/// Filter by country /// Filter by country
@@ -434,7 +432,6 @@ class SearchApi {
/// Filter by trash date (before) /// Filter by trash date (before)
/// ///
/// * [AssetTypeEnum] type: /// * [AssetTypeEnum] type:
/// Asset type filter
/// ///
/// * [DateTime] updatedAfter: /// * [DateTime] updatedAfter:
/// Filter by update date (after) /// Filter by update date (after)
@@ -443,7 +440,6 @@ class SearchApi {
/// Filter by update date (before) /// Filter by update date (before)
/// ///
/// * [AssetVisibility] visibility: /// * [AssetVisibility] visibility:
/// Filter by visibility
/// ///
/// * [bool] withDeleted: /// * [bool] withDeleted:
/// Include deleted assets /// Include deleted assets
@@ -657,7 +653,6 @@ class SearchApi {
/// Filter by trash date (before) /// Filter by trash date (before)
/// ///
/// * [AssetTypeEnum] type: /// * [AssetTypeEnum] type:
/// Asset type filter
/// ///
/// * [DateTime] updatedAfter: /// * [DateTime] updatedAfter:
/// Filter by update date (after) /// Filter by update date (after)
@@ -666,7 +661,6 @@ class SearchApi {
/// Filter by update date (before) /// Filter by update date (before)
/// ///
/// * [AssetVisibility] visibility: /// * [AssetVisibility] visibility:
/// Filter by visibility
/// ///
/// * [bool] withDeleted: /// * [bool] withDeleted:
/// Include deleted assets /// Include deleted assets

View File

@@ -281,7 +281,7 @@ class ServerApi {
/// Get product key /// Get product key
/// ///
/// Retrieve information about whether the server currently has a product key registered. /// Retrieve information about whether the server currently has a product key registered.
Future<LicenseResponseDto?> getServerLicense() async { Future<UserLicense?> getServerLicense() async {
final response = await getServerLicenseWithHttpInfo(); final response = await getServerLicenseWithHttpInfo();
if (response.statusCode >= HttpStatus.badRequest) { if (response.statusCode >= HttpStatus.badRequest) {
throw ApiException(response.statusCode, await _decodeBodyBytes(response)); throw ApiException(response.statusCode, await _decodeBodyBytes(response));
@@ -290,7 +290,7 @@ class ServerApi {
// At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // At the time of writing this, `dart:convert` will throw an "Unexpected end of input"
// FormatException when trying to decode an empty string. // FormatException when trying to decode an empty string.
if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) {
return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'LicenseResponseDto',) as LicenseResponseDto; return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'UserLicense',) as UserLicense;
} }
return null; return null;
@@ -724,7 +724,7 @@ class ServerApi {
/// Parameters: /// Parameters:
/// ///
/// * [LicenseKeyDto] licenseKeyDto (required): /// * [LicenseKeyDto] licenseKeyDto (required):
Future<LicenseResponseDto?> setServerLicense(LicenseKeyDto licenseKeyDto,) async { Future<UserLicense?> setServerLicense(LicenseKeyDto licenseKeyDto,) async {
final response = await setServerLicenseWithHttpInfo(licenseKeyDto,); final response = await setServerLicenseWithHttpInfo(licenseKeyDto,);
if (response.statusCode >= HttpStatus.badRequest) { if (response.statusCode >= HttpStatus.badRequest) {
throw ApiException(response.statusCode, await _decodeBodyBytes(response)); throw ApiException(response.statusCode, await _decodeBodyBytes(response));
@@ -733,7 +733,7 @@ class ServerApi {
// At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // At the time of writing this, `dart:convert` will throw an "Unexpected end of input"
// FormatException when trying to decode an empty string. // FormatException when trying to decode an empty string.
if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) {
return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'LicenseResponseDto',) as LicenseResponseDto; return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'UserLicense',) as UserLicense;
} }
return null; return null;

View File

@@ -25,7 +25,7 @@ class TimelineApi {
/// Parameters: /// Parameters:
/// ///
/// * [String] timeBucket (required): /// * [String] timeBucket (required):
/// Time bucket identifier in YYYY-MM-DD format (e.g., \"2024-01-01\" for January 2024) /// Time bucket identifier in YYYY-MM-DD format
/// ///
/// * [String] albumId: /// * [String] albumId:
/// Filter assets belonging to a specific album /// Filter assets belonging to a specific album
@@ -142,7 +142,7 @@ class TimelineApi {
/// Parameters: /// Parameters:
/// ///
/// * [String] timeBucket (required): /// * [String] timeBucket (required):
/// Time bucket identifier in YYYY-MM-DD format (e.g., \"2024-01-01\" for January 2024) /// Time bucket identifier in YYYY-MM-DD format
/// ///
/// * [String] albumId: /// * [String] albumId:
/// Filter assets belonging to a specific album /// Filter assets belonging to a specific album

View File

@@ -324,7 +324,6 @@ class UsersAdminApi {
/// Filter by trash status /// Filter by trash status
/// ///
/// * [AssetVisibility] visibility: /// * [AssetVisibility] visibility:
/// Filter by visibility
Future<Response> getUserStatisticsAdminWithHttpInfo(String id, { bool? isFavorite, bool? isTrashed, AssetVisibility? visibility, }) async { Future<Response> getUserStatisticsAdminWithHttpInfo(String id, { bool? isFavorite, bool? isTrashed, AssetVisibility? visibility, }) async {
// ignore: prefer_const_declarations // ignore: prefer_const_declarations
final apiPath = r'/admin/users/{id}/statistics' final apiPath = r'/admin/users/{id}/statistics'
@@ -376,7 +375,6 @@ class UsersAdminApi {
/// Filter by trash status /// Filter by trash status
/// ///
/// * [AssetVisibility] visibility: /// * [AssetVisibility] visibility:
/// Filter by visibility
Future<AssetStatsResponseDto?> getUserStatisticsAdmin(String id, { bool? isFavorite, bool? isTrashed, AssetVisibility? visibility, }) async { Future<AssetStatsResponseDto?> getUserStatisticsAdmin(String id, { bool? isFavorite, bool? isTrashed, AssetVisibility? visibility, }) async {
final response = await getUserStatisticsAdminWithHttpInfo(id, isFavorite: isFavorite, isTrashed: isTrashed, visibility: visibility, ); final response = await getUserStatisticsAdminWithHttpInfo(id, isFavorite: isFavorite, isTrashed: isTrashed, visibility: visibility, );
if (response.statusCode >= HttpStatus.badRequest) { if (response.statusCode >= HttpStatus.badRequest) {

View File

@@ -447,7 +447,7 @@ class UsersApi {
/// Retrieve user product key /// Retrieve user product key
/// ///
/// Retrieve information about whether the current user has a registered product key. /// Retrieve information about whether the current user has a registered product key.
Future<LicenseResponseDto?> getUserLicense() async { Future<UserLicense?> getUserLicense() async {
final response = await getUserLicenseWithHttpInfo(); final response = await getUserLicenseWithHttpInfo();
if (response.statusCode >= HttpStatus.badRequest) { if (response.statusCode >= HttpStatus.badRequest) {
throw ApiException(response.statusCode, await _decodeBodyBytes(response)); throw ApiException(response.statusCode, await _decodeBodyBytes(response));
@@ -456,7 +456,7 @@ class UsersApi {
// At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // At the time of writing this, `dart:convert` will throw an "Unexpected end of input"
// FormatException when trying to decode an empty string. // FormatException when trying to decode an empty string.
if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) {
return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'LicenseResponseDto',) as LicenseResponseDto; return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'UserLicense',) as UserLicense;
} }
return null; return null;
@@ -602,7 +602,7 @@ class UsersApi {
/// Parameters: /// Parameters:
/// ///
/// * [LicenseKeyDto] licenseKeyDto (required): /// * [LicenseKeyDto] licenseKeyDto (required):
Future<LicenseResponseDto?> setUserLicense(LicenseKeyDto licenseKeyDto,) async { Future<UserLicense?> setUserLicense(LicenseKeyDto licenseKeyDto,) async {
final response = await setUserLicenseWithHttpInfo(licenseKeyDto,); final response = await setUserLicenseWithHttpInfo(licenseKeyDto,);
if (response.statusCode >= HttpStatus.badRequest) { if (response.statusCode >= HttpStatus.badRequest) {
throw ApiException(response.statusCode, await _decodeBodyBytes(response)); throw ApiException(response.statusCode, await _decodeBodyBytes(response));
@@ -611,7 +611,7 @@ class UsersApi {
// At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // At the time of writing this, `dart:convert` will throw an "Unexpected end of input"
// FormatException when trying to decode an empty string. // FormatException when trying to decode an empty string.
if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) {
return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'LicenseResponseDto',) as LicenseResponseDto; return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'UserLicense',) as UserLicense;
} }
return null; return null;

View File

@@ -264,6 +264,8 @@ class ApiClient {
return AssetFaceWithoutPersonResponseDto.fromJson(value); return AssetFaceWithoutPersonResponseDto.fromJson(value);
case 'AssetFullSyncDto': case 'AssetFullSyncDto':
return AssetFullSyncDto.fromJson(value); return AssetFullSyncDto.fromJson(value);
case 'AssetIdErrorReason':
return AssetIdErrorReasonTypeTransformer().decode(value);
case 'AssetIdsDto': case 'AssetIdsDto':
return AssetIdsDto.fromJson(value); return AssetIdsDto.fromJson(value);
case 'AssetIdsResponseDto': case 'AssetIdsResponseDto':
@@ -298,6 +300,8 @@ class ApiClient {
return AssetOcrResponseDto.fromJson(value); return AssetOcrResponseDto.fromJson(value);
case 'AssetOrder': case 'AssetOrder':
return AssetOrderTypeTransformer().decode(value); return AssetOrderTypeTransformer().decode(value);
case 'AssetRejectReason':
return AssetRejectReasonTypeTransformer().decode(value);
case 'AssetResponseDto': case 'AssetResponseDto':
return AssetResponseDto.fromJson(value); return AssetResponseDto.fromJson(value);
case 'AssetStackResponseDto': case 'AssetStackResponseDto':
@@ -306,6 +310,8 @@ class ApiClient {
return AssetStatsResponseDto.fromJson(value); return AssetStatsResponseDto.fromJson(value);
case 'AssetTypeEnum': case 'AssetTypeEnum':
return AssetTypeEnumTypeTransformer().decode(value); return AssetTypeEnumTypeTransformer().decode(value);
case 'AssetUploadAction':
return AssetUploadActionTypeTransformer().decode(value);
case 'AssetVisibility': case 'AssetVisibility':
return AssetVisibilityTypeTransformer().decode(value); return AssetVisibilityTypeTransformer().decode(value);
case 'AudioCodec': case 'AudioCodec':
@@ -398,8 +404,6 @@ class ApiClient {
return LibraryStatsResponseDto.fromJson(value); return LibraryStatsResponseDto.fromJson(value);
case 'LicenseKeyDto': case 'LicenseKeyDto':
return LicenseKeyDto.fromJson(value); return LicenseKeyDto.fromJson(value);
case 'LicenseResponseDto':
return LicenseResponseDto.fromJson(value);
case 'LogLevel': case 'LogLevel':
return LogLevelTypeTransformer().decode(value); return LogLevelTypeTransformer().decode(value);
case 'LoginCredentialDto': case 'LoginCredentialDto':
@@ -526,6 +530,14 @@ class ApiClient {
return PluginContextTypeTypeTransformer().decode(value); return PluginContextTypeTypeTransformer().decode(value);
case 'PluginFilterResponseDto': case 'PluginFilterResponseDto':
return PluginFilterResponseDto.fromJson(value); return PluginFilterResponseDto.fromJson(value);
case 'PluginJsonSchema':
return PluginJsonSchema.fromJson(value);
case 'PluginJsonSchemaProperty':
return PluginJsonSchemaProperty.fromJson(value);
case 'PluginJsonSchemaPropertyAdditionalProperties':
return PluginJsonSchemaPropertyAdditionalProperties.fromJson(value);
case 'PluginJsonSchemaType':
return PluginJsonSchemaTypeTypeTransformer().decode(value);
case 'PluginResponseDto': case 'PluginResponseDto':
return PluginResponseDto.fromJson(value); return PluginResponseDto.fromJson(value);
case 'PluginTriggerResponseDto': case 'PluginTriggerResponseDto':

View File

@@ -61,6 +61,9 @@ String parameterToString(dynamic value) {
if (value is AssetEditAction) { if (value is AssetEditAction) {
return AssetEditActionTypeTransformer().encode(value).toString(); return AssetEditActionTypeTransformer().encode(value).toString();
} }
if (value is AssetIdErrorReason) {
return AssetIdErrorReasonTypeTransformer().encode(value).toString();
}
if (value is AssetJobName) { if (value is AssetJobName) {
return AssetJobNameTypeTransformer().encode(value).toString(); return AssetJobNameTypeTransformer().encode(value).toString();
} }
@@ -73,9 +76,15 @@ String parameterToString(dynamic value) {
if (value is AssetOrder) { if (value is AssetOrder) {
return AssetOrderTypeTransformer().encode(value).toString(); return AssetOrderTypeTransformer().encode(value).toString();
} }
if (value is AssetRejectReason) {
return AssetRejectReasonTypeTransformer().encode(value).toString();
}
if (value is AssetTypeEnum) { if (value is AssetTypeEnum) {
return AssetTypeEnumTypeTransformer().encode(value).toString(); return AssetTypeEnumTypeTransformer().encode(value).toString();
} }
if (value is AssetUploadAction) {
return AssetUploadActionTypeTransformer().encode(value).toString();
}
if (value is AssetVisibility) { if (value is AssetVisibility) {
return AssetVisibilityTypeTransformer().encode(value).toString(); return AssetVisibilityTypeTransformer().encode(value).toString();
} }
@@ -133,6 +142,9 @@ String parameterToString(dynamic value) {
if (value is PluginContextType) { if (value is PluginContextType) {
return PluginContextTypeTypeTransformer().encode(value).toString(); return PluginContextTypeTypeTransformer().encode(value).toString();
} }
if (value is PluginJsonSchemaType) {
return PluginJsonSchemaTypeTypeTransformer().encode(value).toString();
}
if (value is PluginTriggerType) { if (value is PluginTriggerType) {
return PluginTriggerTypeTypeTransformer().encode(value).toString(); return PluginTriggerTypeTypeTransformer().encode(value).toString();
} }

View File

@@ -40,7 +40,6 @@ class ActivityCreateDto {
/// ///
String? comment; String? comment;
/// Activity type (like or comment)
ReactionType type; ReactionType type;
@override @override

View File

@@ -21,10 +21,8 @@ class ActivityResponseDto {
required this.user, required this.user,
}); });
/// Asset ID (if activity is for an asset)
String? assetId; String? assetId;
/// Comment text (for comment activities)
String? comment; String? comment;
/// Creation date /// Creation date
@@ -33,7 +31,6 @@ class ActivityResponseDto {
/// Activity ID /// Activity ID
String id; String id;
/// Activity type
ReactionType type; ReactionType type;
UserResponseDto user; UserResponseDto user;
@@ -72,7 +69,9 @@ class ActivityResponseDto {
} else { } else {
// json[r'comment'] = null; // json[r'comment'] = null;
} }
json[r'createdAt'] = this.createdAt.toUtc().toIso8601String(); json[r'createdAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.createdAt.millisecondsSinceEpoch
: this.createdAt.toUtc().toIso8601String();
json[r'id'] = this.id; json[r'id'] = this.id;
json[r'type'] = this.type; json[r'type'] = this.type;
json[r'user'] = this.user; json[r'user'] = this.user;
@@ -90,7 +89,7 @@ class ActivityResponseDto {
return ActivityResponseDto( return ActivityResponseDto(
assetId: mapValueOfType<String>(json, r'assetId'), assetId: mapValueOfType<String>(json, r'assetId'),
comment: mapValueOfType<String>(json, r'comment'), comment: mapValueOfType<String>(json, r'comment'),
createdAt: mapDateTime(json, r'createdAt', r'')!, createdAt: mapDateTime(json, r'createdAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
id: mapValueOfType<String>(json, r'id')!, id: mapValueOfType<String>(json, r'id')!,
type: ReactionType.fromJson(json[r'type'])!, type: ReactionType.fromJson(json[r'type'])!,
user: UserResponseDto.fromJson(json[r'user'])!, user: UserResponseDto.fromJson(json[r'user'])!,

View File

@@ -18,9 +18,15 @@ class ActivityStatisticsResponseDto {
}); });
/// Number of comments /// Number of comments
///
/// Minimum value: 0
/// Maximum value: 9007199254740991
int comments; int comments;
/// Number of likes /// Number of likes
///
/// Minimum value: 0
/// Maximum value: 9007199254740991
int likes; int likes;
@override @override

View File

@@ -37,12 +37,14 @@ class AlbumResponseDto {
/// Album name /// Album name
String albumName; String albumName;
/// Thumbnail asset ID
String? albumThumbnailAssetId; String? albumThumbnailAssetId;
List<AlbumUserResponseDto> albumUsers; List<AlbumUserResponseDto> albumUsers;
/// Number of assets /// Number of assets
///
/// Minimum value: 0
/// Maximum value: 9007199254740991
int assetCount; int assetCount;
List<AssetResponseDto> assets; List<AssetResponseDto> assets;
@@ -82,7 +84,6 @@ class AlbumResponseDto {
/// ///
DateTime? lastModifiedAssetTimestamp; DateTime? lastModifiedAssetTimestamp;
/// Asset sort order
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated

View File

@@ -19,12 +19,21 @@ class AlbumStatisticsResponseDto {
}); });
/// Number of non-shared albums /// Number of non-shared albums
///
/// Minimum value: 0
/// Maximum value: 9007199254740991
int notShared; int notShared;
/// Number of owned albums /// Number of owned albums
///
/// Minimum value: 0
/// Maximum value: 9007199254740991
int owned; int owned;
/// Number of shared albums /// Number of shared albums
///
/// Minimum value: 0
/// Maximum value: 9007199254740991
int shared; int shared;
@override @override

View File

@@ -13,12 +13,17 @@ part of openapi.api;
class AlbumUserAddDto { class AlbumUserAddDto {
/// Returns a new [AlbumUserAddDto] instance. /// Returns a new [AlbumUserAddDto] instance.
AlbumUserAddDto({ AlbumUserAddDto({
this.role = AlbumUserRole.editor, this.role,
required this.userId, required this.userId,
}); });
/// Album user role ///
AlbumUserRole role; /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated
/// source code must fall back to having a nullable type.
/// Consider adding a "default:" property in the specification file to hide this note.
///
AlbumUserRole? role;
/// User ID /// User ID
String userId; String userId;
@@ -31,7 +36,7 @@ class AlbumUserAddDto {
@override @override
int get hashCode => int get hashCode =>
// ignore: unnecessary_parenthesis // ignore: unnecessary_parenthesis
(role.hashCode) + (role == null ? 0 : role!.hashCode) +
(userId.hashCode); (userId.hashCode);
@override @override
@@ -39,7 +44,11 @@ class AlbumUserAddDto {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
if (this.role != null) {
json[r'role'] = this.role; json[r'role'] = this.role;
} else {
// json[r'role'] = null;
}
json[r'userId'] = this.userId; json[r'userId'] = this.userId;
return json; return json;
} }
@@ -53,7 +62,7 @@ class AlbumUserAddDto {
final json = value.cast<String, dynamic>(); final json = value.cast<String, dynamic>();
return AlbumUserAddDto( return AlbumUserAddDto(
role: AlbumUserRole.fromJson(json[r'role']) ?? AlbumUserRole.editor, role: AlbumUserRole.fromJson(json[r'role']),
userId: mapValueOfType<String>(json, r'userId')!, userId: mapValueOfType<String>(json, r'userId')!,
); );
} }

View File

@@ -17,7 +17,6 @@ class AlbumUserCreateDto {
required this.userId, required this.userId,
}); });
/// Album user role
AlbumUserRole role; AlbumUserRole role;
/// User ID /// User ID

View File

@@ -17,7 +17,6 @@ class AlbumUserResponseDto {
required this.user, required this.user,
}); });
/// Album user role
AlbumUserRole role; AlbumUserRole role;
UserResponseDto user; UserResponseDto user;

View File

@@ -17,7 +17,6 @@ class AlbumsAddAssetsResponseDto {
required this.success, required this.success,
}); });
/// Error reason
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated

View File

@@ -13,10 +13,9 @@ part of openapi.api;
class AlbumsResponse { class AlbumsResponse {
/// Returns a new [AlbumsResponse] instance. /// Returns a new [AlbumsResponse] instance.
AlbumsResponse({ AlbumsResponse({
this.defaultAssetOrder = AssetOrder.desc, required this.defaultAssetOrder,
}); });
/// Default asset order for albums
AssetOrder defaultAssetOrder; AssetOrder defaultAssetOrder;
@override @override

View File

@@ -16,7 +16,6 @@ class AlbumsUpdate {
this.defaultAssetOrder, this.defaultAssetOrder,
}); });
/// Default asset order for albums
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated

View File

@@ -57,11 +57,15 @@ class APIKeyResponseDto {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
json[r'createdAt'] = this.createdAt.toUtc().toIso8601String(); json[r'createdAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.createdAt.millisecondsSinceEpoch
: this.createdAt.toUtc().toIso8601String();
json[r'id'] = this.id; json[r'id'] = this.id;
json[r'name'] = this.name; json[r'name'] = this.name;
json[r'permissions'] = this.permissions; json[r'permissions'] = this.permissions;
json[r'updatedAt'] = this.updatedAt.toUtc().toIso8601String(); json[r'updatedAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.updatedAt.millisecondsSinceEpoch
: this.updatedAt.toUtc().toIso8601String();
return json; return json;
} }
@@ -74,11 +78,11 @@ class APIKeyResponseDto {
final json = value.cast<String, dynamic>(); final json = value.cast<String, dynamic>();
return APIKeyResponseDto( return APIKeyResponseDto(
createdAt: mapDateTime(json, r'createdAt', r'')!, createdAt: mapDateTime(json, r'createdAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
id: mapValueOfType<String>(json, r'id')!, id: mapValueOfType<String>(json, r'id')!,
name: mapValueOfType<String>(json, r'name')!, name: mapValueOfType<String>(json, r'name')!,
permissions: Permission.listFromJson(json[r'permissions']), permissions: Permission.listFromJson(json[r'permissions']),
updatedAt: mapDateTime(json, r'updatedAt', r'')!, updatedAt: mapDateTime(json, r'updatedAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
); );
} }
return null; return null;

View File

@@ -53,7 +53,6 @@ class AssetBulkUpdateDto {
/// ///
String? description; String? description;
/// Duplicate ID
String? duplicateId; String? duplicateId;
/// Asset IDs to update /// Asset IDs to update
@@ -70,6 +69,9 @@ class AssetBulkUpdateDto {
/// Latitude coordinate /// Latitude coordinate
/// ///
/// Minimum value: -90
/// Maximum value: 90
///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated
/// source code must fall back to having a nullable type. /// source code must fall back to having a nullable type.
@@ -79,6 +81,9 @@ class AssetBulkUpdateDto {
/// Longitude coordinate /// Longitude coordinate
/// ///
/// Minimum value: -180
/// Maximum value: 180
///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated
/// source code must fall back to having a nullable type. /// source code must fall back to having a nullable type.
@@ -86,11 +91,9 @@ class AssetBulkUpdateDto {
/// ///
num? longitude; num? longitude;
/// Rating in range [1-5], or null for unrated
///
/// Minimum value: -1 /// Minimum value: -1
/// Maximum value: 5 /// Maximum value: 5
num? rating; int? rating;
/// Time zone (IANA timezone) /// Time zone (IANA timezone)
/// ///
@@ -101,7 +104,6 @@ class AssetBulkUpdateDto {
/// ///
String? timeZone; String? timeZone;
/// Asset visibility
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated
@@ -217,9 +219,7 @@ class AssetBulkUpdateDto {
isFavorite: mapValueOfType<bool>(json, r'isFavorite'), isFavorite: mapValueOfType<bool>(json, r'isFavorite'),
latitude: num.parse('${json[r'latitude']}'), latitude: num.parse('${json[r'latitude']}'),
longitude: num.parse('${json[r'longitude']}'), longitude: num.parse('${json[r'longitude']}'),
rating: json[r'rating'] == null rating: mapValueOfType<int>(json, r'rating'),
? null
: num.parse('${json[r'rating']}'),
timeZone: mapValueOfType<String>(json, r'timeZone'), timeZone: mapValueOfType<String>(json, r'timeZone'),
visibility: AssetVisibility.fromJson(json[r'visibility']), visibility: AssetVisibility.fromJson(json[r'visibility']),
); );

View File

@@ -20,8 +20,7 @@ class AssetBulkUploadCheckResult {
this.reason, this.reason,
}); });
/// Upload action AssetUploadAction action;
AssetBulkUploadCheckResultActionEnum action;
/// Existing asset ID if duplicate /// Existing asset ID if duplicate
/// ///
@@ -44,8 +43,13 @@ class AssetBulkUploadCheckResult {
/// ///
bool? isTrashed; bool? isTrashed;
/// Rejection reason if rejected ///
AssetBulkUploadCheckResultReasonEnum? reason; /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated
/// source code must fall back to having a nullable type.
/// Consider adding a "default:" property in the specification file to hide this note.
///
AssetRejectReason? reason;
@override @override
bool operator ==(Object other) => identical(this, other) || other is AssetBulkUploadCheckResult && bool operator ==(Object other) => identical(this, other) || other is AssetBulkUploadCheckResult &&
@@ -98,11 +102,11 @@ class AssetBulkUploadCheckResult {
final json = value.cast<String, dynamic>(); final json = value.cast<String, dynamic>();
return AssetBulkUploadCheckResult( return AssetBulkUploadCheckResult(
action: AssetBulkUploadCheckResultActionEnum.fromJson(json[r'action'])!, action: AssetUploadAction.fromJson(json[r'action'])!,
assetId: mapValueOfType<String>(json, r'assetId'), assetId: mapValueOfType<String>(json, r'assetId'),
id: mapValueOfType<String>(json, r'id')!, id: mapValueOfType<String>(json, r'id')!,
isTrashed: mapValueOfType<bool>(json, r'isTrashed'), isTrashed: mapValueOfType<bool>(json, r'isTrashed'),
reason: AssetBulkUploadCheckResultReasonEnum.fromJson(json[r'reason']), reason: AssetRejectReason.fromJson(json[r'reason']),
); );
} }
return null; return null;
@@ -155,151 +159,3 @@ class AssetBulkUploadCheckResult {
}; };
} }
/// Upload action
class AssetBulkUploadCheckResultActionEnum {
/// Instantiate a new enum with the provided [value].
const AssetBulkUploadCheckResultActionEnum._(this.value);
/// The underlying value of this enum member.
final String value;
@override
String toString() => value;
String toJson() => value;
static const accept = AssetBulkUploadCheckResultActionEnum._(r'accept');
static const reject = AssetBulkUploadCheckResultActionEnum._(r'reject');
/// List of all possible values in this [enum][AssetBulkUploadCheckResultActionEnum].
static const values = <AssetBulkUploadCheckResultActionEnum>[
accept,
reject,
];
static AssetBulkUploadCheckResultActionEnum? fromJson(dynamic value) => AssetBulkUploadCheckResultActionEnumTypeTransformer().decode(value);
static List<AssetBulkUploadCheckResultActionEnum> listFromJson(dynamic json, {bool growable = false,}) {
final result = <AssetBulkUploadCheckResultActionEnum>[];
if (json is List && json.isNotEmpty) {
for (final row in json) {
final value = AssetBulkUploadCheckResultActionEnum.fromJson(row);
if (value != null) {
result.add(value);
}
}
}
return result.toList(growable: growable);
}
}
/// Transformation class that can [encode] an instance of [AssetBulkUploadCheckResultActionEnum] to String,
/// and [decode] dynamic data back to [AssetBulkUploadCheckResultActionEnum].
class AssetBulkUploadCheckResultActionEnumTypeTransformer {
factory AssetBulkUploadCheckResultActionEnumTypeTransformer() => _instance ??= const AssetBulkUploadCheckResultActionEnumTypeTransformer._();
const AssetBulkUploadCheckResultActionEnumTypeTransformer._();
String encode(AssetBulkUploadCheckResultActionEnum data) => data.value;
/// Decodes a [dynamic value][data] to a AssetBulkUploadCheckResultActionEnum.
///
/// If [allowNull] is true and the [dynamic value][data] cannot be decoded successfully,
/// then null is returned. However, if [allowNull] is false and the [dynamic value][data]
/// cannot be decoded successfully, then an [UnimplementedError] is thrown.
///
/// The [allowNull] is very handy when an API changes and a new enum value is added or removed,
/// and users are still using an old app with the old code.
AssetBulkUploadCheckResultActionEnum? decode(dynamic data, {bool allowNull = true}) {
if (data != null) {
switch (data) {
case r'accept': return AssetBulkUploadCheckResultActionEnum.accept;
case r'reject': return AssetBulkUploadCheckResultActionEnum.reject;
default:
if (!allowNull) {
throw ArgumentError('Unknown enum value to decode: $data');
}
}
}
return null;
}
/// Singleton [AssetBulkUploadCheckResultActionEnumTypeTransformer] instance.
static AssetBulkUploadCheckResultActionEnumTypeTransformer? _instance;
}
/// Rejection reason if rejected
class AssetBulkUploadCheckResultReasonEnum {
/// Instantiate a new enum with the provided [value].
const AssetBulkUploadCheckResultReasonEnum._(this.value);
/// The underlying value of this enum member.
final String value;
@override
String toString() => value;
String toJson() => value;
static const duplicate = AssetBulkUploadCheckResultReasonEnum._(r'duplicate');
static const unsupportedFormat = AssetBulkUploadCheckResultReasonEnum._(r'unsupported-format');
/// List of all possible values in this [enum][AssetBulkUploadCheckResultReasonEnum].
static const values = <AssetBulkUploadCheckResultReasonEnum>[
duplicate,
unsupportedFormat,
];
static AssetBulkUploadCheckResultReasonEnum? fromJson(dynamic value) => AssetBulkUploadCheckResultReasonEnumTypeTransformer().decode(value);
static List<AssetBulkUploadCheckResultReasonEnum> listFromJson(dynamic json, {bool growable = false,}) {
final result = <AssetBulkUploadCheckResultReasonEnum>[];
if (json is List && json.isNotEmpty) {
for (final row in json) {
final value = AssetBulkUploadCheckResultReasonEnum.fromJson(row);
if (value != null) {
result.add(value);
}
}
}
return result.toList(growable: growable);
}
}
/// Transformation class that can [encode] an instance of [AssetBulkUploadCheckResultReasonEnum] to String,
/// and [decode] dynamic data back to [AssetBulkUploadCheckResultReasonEnum].
class AssetBulkUploadCheckResultReasonEnumTypeTransformer {
factory AssetBulkUploadCheckResultReasonEnumTypeTransformer() => _instance ??= const AssetBulkUploadCheckResultReasonEnumTypeTransformer._();
const AssetBulkUploadCheckResultReasonEnumTypeTransformer._();
String encode(AssetBulkUploadCheckResultReasonEnum data) => data.value;
/// Decodes a [dynamic value][data] to a AssetBulkUploadCheckResultReasonEnum.
///
/// If [allowNull] is true and the [dynamic value][data] cannot be decoded successfully,
/// then null is returned. However, if [allowNull] is false and the [dynamic value][data]
/// cannot be decoded successfully, then an [UnimplementedError] is thrown.
///
/// The [allowNull] is very handy when an API changes and a new enum value is added or removed,
/// and users are still using an old app with the old code.
AssetBulkUploadCheckResultReasonEnum? decode(dynamic data, {bool allowNull = true}) {
if (data != null) {
switch (data) {
case r'duplicate': return AssetBulkUploadCheckResultReasonEnum.duplicate;
case r'unsupported-format': return AssetBulkUploadCheckResultReasonEnum.unsupportedFormat;
default:
if (!allowNull) {
throw ArgumentError('Unknown enum value to decode: $data');
}
}
}
return null;
}
/// Singleton [AssetBulkUploadCheckResultReasonEnumTypeTransformer] instance.
static AssetBulkUploadCheckResultReasonEnumTypeTransformer? _instance;
}

View File

@@ -39,7 +39,9 @@ class AssetDeltaSyncDto {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
json[r'updatedAfter'] = this.updatedAfter.toUtc().toIso8601String(); json[r'updatedAfter'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.updatedAfter.millisecondsSinceEpoch
: this.updatedAfter.toUtc().toIso8601String();
json[r'userIds'] = this.userIds; json[r'userIds'] = this.userIds;
return json; return json;
} }
@@ -53,7 +55,7 @@ class AssetDeltaSyncDto {
final json = value.cast<String, dynamic>(); final json = value.cast<String, dynamic>();
return AssetDeltaSyncDto( return AssetDeltaSyncDto(
updatedAfter: mapDateTime(json, r'updatedAfter', r'')!, updatedAfter: mapDateTime(json, r'updatedAfter', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
userIds: json[r'userIds'] is Iterable userIds: json[r'userIds'] is Iterable
? (json[r'userIds'] as Iterable).cast<String>().toList(growable: false) ? (json[r'userIds'] as Iterable).cast<String>().toList(growable: false)
: const [], : const [],

View File

@@ -24,7 +24,6 @@ class AssetDeltaSyncResponseDto {
/// Whether full sync is needed /// Whether full sync is needed
bool needsFullSync; bool needsFullSync;
/// Upserted assets
List<AssetResponseDto> upserted; List<AssetResponseDto> upserted;
@override @override

View File

@@ -17,7 +17,6 @@ class AssetEditActionItemDto {
required this.parameters, required this.parameters,
}); });
/// Type of edit action to perform
AssetEditAction action; AssetEditAction action;
AssetEditActionItemDtoParameters parameters; AssetEditActionItemDtoParameters parameters;

View File

@@ -44,7 +44,6 @@ class AssetEditActionItemDtoParameters {
/// Rotation angle in degrees /// Rotation angle in degrees
num angle; num angle;
/// Axis to mirror along
MirrorAxis axis; MirrorAxis axis;
@override @override

View File

@@ -18,9 +18,9 @@ class AssetEditActionItemResponseDto {
required this.parameters, required this.parameters,
}); });
/// Type of edit action to perform
AssetEditAction action; AssetEditAction action;
/// Asset edit ID
String id; String id;
AssetEditActionItemDtoParameters parameters; AssetEditActionItemDtoParameters parameters;

View File

@@ -27,24 +27,42 @@ class AssetFaceCreateDto {
String assetId; String assetId;
/// Face bounding box height /// Face bounding box height
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int height; int height;
/// Image height in pixels /// Image height in pixels
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int imageHeight; int imageHeight;
/// Image width in pixels /// Image width in pixels
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int imageWidth; int imageWidth;
/// Person ID /// Person ID
String personId; String personId;
/// Face bounding box width /// Face bounding box width
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int width; int width;
/// Face bounding box X coordinate /// Face bounding box X coordinate
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int x; int x;
/// Face bounding box Y coordinate /// Face bounding box Y coordinate
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int y; int y;
@override @override

View File

@@ -25,30 +25,46 @@ class AssetFaceResponseDto {
}); });
/// Bounding box X1 coordinate /// Bounding box X1 coordinate
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int boundingBoxX1; int boundingBoxX1;
/// Bounding box X2 coordinate /// Bounding box X2 coordinate
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int boundingBoxX2; int boundingBoxX2;
/// Bounding box Y1 coordinate /// Bounding box Y1 coordinate
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int boundingBoxY1; int boundingBoxY1;
/// Bounding box Y2 coordinate /// Bounding box Y2 coordinate
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int boundingBoxY2; int boundingBoxY2;
/// Face ID /// Face ID
String id; String id;
/// Image height in pixels /// Image height in pixels
///
/// Minimum value: 0
/// Maximum value: 9007199254740991
int imageHeight; int imageHeight;
/// Image width in pixels /// Image width in pixels
///
/// Minimum value: 0
/// Maximum value: 9007199254740991
int imageWidth; int imageWidth;
/// Person associated with face PersonResponseDto person;
PersonResponseDto? person;
/// Face detection source type
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated
@@ -79,7 +95,7 @@ class AssetFaceResponseDto {
(id.hashCode) + (id.hashCode) +
(imageHeight.hashCode) + (imageHeight.hashCode) +
(imageWidth.hashCode) + (imageWidth.hashCode) +
(person == null ? 0 : person!.hashCode) + (person.hashCode) +
(sourceType == null ? 0 : sourceType!.hashCode); (sourceType == null ? 0 : sourceType!.hashCode);
@override @override
@@ -94,11 +110,7 @@ class AssetFaceResponseDto {
json[r'id'] = this.id; json[r'id'] = this.id;
json[r'imageHeight'] = this.imageHeight; json[r'imageHeight'] = this.imageHeight;
json[r'imageWidth'] = this.imageWidth; json[r'imageWidth'] = this.imageWidth;
if (this.person != null) {
json[r'person'] = this.person; json[r'person'] = this.person;
} else {
// json[r'person'] = null;
}
if (this.sourceType != null) { if (this.sourceType != null) {
json[r'sourceType'] = this.sourceType; json[r'sourceType'] = this.sourceType;
} else { } else {
@@ -123,7 +135,7 @@ class AssetFaceResponseDto {
id: mapValueOfType<String>(json, r'id')!, id: mapValueOfType<String>(json, r'id')!,
imageHeight: mapValueOfType<int>(json, r'imageHeight')!, imageHeight: mapValueOfType<int>(json, r'imageHeight')!,
imageWidth: mapValueOfType<int>(json, r'imageWidth')!, imageWidth: mapValueOfType<int>(json, r'imageWidth')!,
person: PersonResponseDto.fromJson(json[r'person']), person: PersonResponseDto.fromJson(json[r'person'])!,
sourceType: SourceType.fromJson(json[r'sourceType']), sourceType: SourceType.fromJson(json[r'sourceType']),
); );
} }

View File

@@ -24,27 +24,44 @@ class AssetFaceWithoutPersonResponseDto {
}); });
/// Bounding box X1 coordinate /// Bounding box X1 coordinate
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int boundingBoxX1; int boundingBoxX1;
/// Bounding box X2 coordinate /// Bounding box X2 coordinate
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int boundingBoxX2; int boundingBoxX2;
/// Bounding box Y1 coordinate /// Bounding box Y1 coordinate
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int boundingBoxY1; int boundingBoxY1;
/// Bounding box Y2 coordinate /// Bounding box Y2 coordinate
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int boundingBoxY2; int boundingBoxY2;
/// Face ID /// Face ID
String id; String id;
/// Image height in pixels /// Image height in pixels
///
/// Minimum value: 0
/// Maximum value: 9007199254740991
int imageHeight; int imageHeight;
/// Image width in pixels /// Image width in pixels
///
/// Minimum value: 0
/// Maximum value: 9007199254740991
int imageWidth; int imageWidth;
/// Face detection source type
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated

View File

@@ -31,6 +31,7 @@ class AssetFullSyncDto {
/// Maximum number of assets to return /// Maximum number of assets to return
/// ///
/// Minimum value: 1 /// Minimum value: 1
/// Maximum value: 9007199254740991
int limit; int limit;
/// Sync assets updated until this date /// Sync assets updated until this date
@@ -71,7 +72,9 @@ class AssetFullSyncDto {
// json[r'lastId'] = null; // json[r'lastId'] = null;
} }
json[r'limit'] = this.limit; json[r'limit'] = this.limit;
json[r'updatedUntil'] = this.updatedUntil.toUtc().toIso8601String(); json[r'updatedUntil'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.updatedUntil.millisecondsSinceEpoch
: this.updatedUntil.toUtc().toIso8601String();
if (this.userId != null) { if (this.userId != null) {
json[r'userId'] = this.userId; json[r'userId'] = this.userId;
} else { } else {
@@ -91,7 +94,7 @@ class AssetFullSyncDto {
return AssetFullSyncDto( return AssetFullSyncDto(
lastId: mapValueOfType<String>(json, r'lastId'), lastId: mapValueOfType<String>(json, r'lastId'),
limit: mapValueOfType<int>(json, r'limit')!, limit: mapValueOfType<int>(json, r'limit')!,
updatedUntil: mapDateTime(json, r'updatedUntil', r'')!, updatedUntil: mapDateTime(json, r'updatedUntil', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
userId: mapValueOfType<String>(json, r'userId'), userId: mapValueOfType<String>(json, r'userId'),
); );
} }

View File

@@ -0,0 +1,88 @@
//
// AUTO-GENERATED FILE, DO NOT MODIFY!
//
// @dart=2.18
// ignore_for_file: unused_element, unused_import
// ignore_for_file: always_put_required_named_parameters_first
// ignore_for_file: constant_identifier_names
// ignore_for_file: lines_longer_than_80_chars
part of openapi.api;
/// Error reason if failed
class AssetIdErrorReason {
/// Instantiate a new enum with the provided [value].
const AssetIdErrorReason._(this.value);
/// The underlying value of this enum member.
final String value;
@override
String toString() => value;
String toJson() => value;
static const duplicate = AssetIdErrorReason._(r'duplicate');
static const noPermission = AssetIdErrorReason._(r'no_permission');
static const notFound = AssetIdErrorReason._(r'not_found');
/// List of all possible values in this [enum][AssetIdErrorReason].
static const values = <AssetIdErrorReason>[
duplicate,
noPermission,
notFound,
];
static AssetIdErrorReason? fromJson(dynamic value) => AssetIdErrorReasonTypeTransformer().decode(value);
static List<AssetIdErrorReason> listFromJson(dynamic json, {bool growable = false,}) {
final result = <AssetIdErrorReason>[];
if (json is List && json.isNotEmpty) {
for (final row in json) {
final value = AssetIdErrorReason.fromJson(row);
if (value != null) {
result.add(value);
}
}
}
return result.toList(growable: growable);
}
}
/// Transformation class that can [encode] an instance of [AssetIdErrorReason] to String,
/// and [decode] dynamic data back to [AssetIdErrorReason].
class AssetIdErrorReasonTypeTransformer {
factory AssetIdErrorReasonTypeTransformer() => _instance ??= const AssetIdErrorReasonTypeTransformer._();
const AssetIdErrorReasonTypeTransformer._();
String encode(AssetIdErrorReason data) => data.value;
/// Decodes a [dynamic value][data] to a AssetIdErrorReason.
///
/// If [allowNull] is true and the [dynamic value][data] cannot be decoded successfully,
/// then null is returned. However, if [allowNull] is false and the [dynamic value][data]
/// cannot be decoded successfully, then an [UnimplementedError] is thrown.
///
/// The [allowNull] is very handy when an API changes and a new enum value is added or removed,
/// and users are still using an old app with the old code.
AssetIdErrorReason? decode(dynamic data, {bool allowNull = true}) {
if (data != null) {
switch (data) {
case r'duplicate': return AssetIdErrorReason.duplicate;
case r'no_permission': return AssetIdErrorReason.noPermission;
case r'not_found': return AssetIdErrorReason.notFound;
default:
if (!allowNull) {
throw ArgumentError('Unknown enum value to decode: $data');
}
}
}
return null;
}
/// Singleton [AssetIdErrorReasonTypeTransformer] instance.
static AssetIdErrorReasonTypeTransformer? _instance;
}

View File

@@ -21,8 +21,13 @@ class AssetIdsResponseDto {
/// Asset ID /// Asset ID
String assetId; String assetId;
/// Error reason if failed ///
AssetIdsResponseDtoErrorEnum? error; /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated
/// source code must fall back to having a nullable type.
/// Consider adding a "default:" property in the specification file to hide this note.
///
AssetIdErrorReason? error;
/// Whether operation succeeded /// Whether operation succeeded
bool success; bool success;
@@ -65,7 +70,7 @@ class AssetIdsResponseDto {
return AssetIdsResponseDto( return AssetIdsResponseDto(
assetId: mapValueOfType<String>(json, r'assetId')!, assetId: mapValueOfType<String>(json, r'assetId')!,
error: AssetIdsResponseDtoErrorEnum.fromJson(json[r'error']), error: AssetIdErrorReason.fromJson(json[r'error']),
success: mapValueOfType<bool>(json, r'success')!, success: mapValueOfType<bool>(json, r'success')!,
); );
} }
@@ -119,80 +124,3 @@ class AssetIdsResponseDto {
}; };
} }
/// Error reason if failed
class AssetIdsResponseDtoErrorEnum {
/// Instantiate a new enum with the provided [value].
const AssetIdsResponseDtoErrorEnum._(this.value);
/// The underlying value of this enum member.
final String value;
@override
String toString() => value;
String toJson() => value;
static const duplicate = AssetIdsResponseDtoErrorEnum._(r'duplicate');
static const noPermission = AssetIdsResponseDtoErrorEnum._(r'no_permission');
static const notFound = AssetIdsResponseDtoErrorEnum._(r'not_found');
/// List of all possible values in this [enum][AssetIdsResponseDtoErrorEnum].
static const values = <AssetIdsResponseDtoErrorEnum>[
duplicate,
noPermission,
notFound,
];
static AssetIdsResponseDtoErrorEnum? fromJson(dynamic value) => AssetIdsResponseDtoErrorEnumTypeTransformer().decode(value);
static List<AssetIdsResponseDtoErrorEnum> listFromJson(dynamic json, {bool growable = false,}) {
final result = <AssetIdsResponseDtoErrorEnum>[];
if (json is List && json.isNotEmpty) {
for (final row in json) {
final value = AssetIdsResponseDtoErrorEnum.fromJson(row);
if (value != null) {
result.add(value);
}
}
}
return result.toList(growable: growable);
}
}
/// Transformation class that can [encode] an instance of [AssetIdsResponseDtoErrorEnum] to String,
/// and [decode] dynamic data back to [AssetIdsResponseDtoErrorEnum].
class AssetIdsResponseDtoErrorEnumTypeTransformer {
factory AssetIdsResponseDtoErrorEnumTypeTransformer() => _instance ??= const AssetIdsResponseDtoErrorEnumTypeTransformer._();
const AssetIdsResponseDtoErrorEnumTypeTransformer._();
String encode(AssetIdsResponseDtoErrorEnum data) => data.value;
/// Decodes a [dynamic value][data] to a AssetIdsResponseDtoErrorEnum.
///
/// If [allowNull] is true and the [dynamic value][data] cannot be decoded successfully,
/// then null is returned. However, if [allowNull] is false and the [dynamic value][data]
/// cannot be decoded successfully, then an [UnimplementedError] is thrown.
///
/// The [allowNull] is very handy when an API changes and a new enum value is added or removed,
/// and users are still using an old app with the old code.
AssetIdsResponseDtoErrorEnum? decode(dynamic data, {bool allowNull = true}) {
if (data != null) {
switch (data) {
case r'duplicate': return AssetIdsResponseDtoErrorEnum.duplicate;
case r'no_permission': return AssetIdsResponseDtoErrorEnum.noPermission;
case r'not_found': return AssetIdsResponseDtoErrorEnum.notFound;
default:
if (!allowNull) {
throw ArgumentError('Unknown enum value to decode: $data');
}
}
}
return null;
}
/// Singleton [AssetIdsResponseDtoErrorEnumTypeTransformer] instance.
static AssetIdsResponseDtoErrorEnumTypeTransformer? _instance;
}

View File

@@ -20,7 +20,6 @@ class AssetJobsDto {
/// Asset IDs /// Asset IDs
List<String> assetIds; List<String> assetIds;
/// Job name
AssetJobName name; AssetJobName name;
@override @override

View File

@@ -20,7 +20,6 @@ class AssetMediaResponseDto {
/// Asset media ID /// Asset media ID
String id; String id;
/// Upload status
AssetMediaStatus status; AssetMediaStatus status;
@override @override

View File

@@ -10,7 +10,7 @@
part of openapi.api; part of openapi.api;
/// Asset media size
class AssetMediaSize { class AssetMediaSize {
/// Instantiate a new enum with the provided [value]. /// Instantiate a new enum with the provided [value].
const AssetMediaSize._(this.value); const AssetMediaSize._(this.value);

View File

@@ -16,7 +16,7 @@ class AssetMetadataBulkResponseDto {
required this.assetId, required this.assetId,
required this.key, required this.key,
required this.updatedAt, required this.updatedAt,
required this.value, this.value = const {},
}); });
/// Asset ID /// Asset ID
@@ -29,14 +29,14 @@ class AssetMetadataBulkResponseDto {
DateTime updatedAt; DateTime updatedAt;
/// Metadata value (object) /// Metadata value (object)
Object value; Map<String, Object> value;
@override @override
bool operator ==(Object other) => identical(this, other) || other is AssetMetadataBulkResponseDto && bool operator ==(Object other) => identical(this, other) || other is AssetMetadataBulkResponseDto &&
other.assetId == assetId && other.assetId == assetId &&
other.key == key && other.key == key &&
other.updatedAt == updatedAt && other.updatedAt == updatedAt &&
other.value == value; _deepEquality.equals(other.value, value);
@override @override
int get hashCode => int get hashCode =>
@@ -53,7 +53,9 @@ class AssetMetadataBulkResponseDto {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
json[r'assetId'] = this.assetId; json[r'assetId'] = this.assetId;
json[r'key'] = this.key; json[r'key'] = this.key;
json[r'updatedAt'] = this.updatedAt.toUtc().toIso8601String(); json[r'updatedAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.updatedAt.millisecondsSinceEpoch
: this.updatedAt.toUtc().toIso8601String();
json[r'value'] = this.value; json[r'value'] = this.value;
return json; return json;
} }
@@ -69,8 +71,8 @@ class AssetMetadataBulkResponseDto {
return AssetMetadataBulkResponseDto( return AssetMetadataBulkResponseDto(
assetId: mapValueOfType<String>(json, r'assetId')!, assetId: mapValueOfType<String>(json, r'assetId')!,
key: mapValueOfType<String>(json, r'key')!, key: mapValueOfType<String>(json, r'key')!,
updatedAt: mapDateTime(json, r'updatedAt', r'')!, updatedAt: mapDateTime(json, r'updatedAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
value: mapValueOfType<Object>(json, r'value')!, value: mapCastOfType<String, Object>(json, r'value')!,
); );
} }
return null; return null;

View File

@@ -15,7 +15,7 @@ class AssetMetadataBulkUpsertItemDto {
AssetMetadataBulkUpsertItemDto({ AssetMetadataBulkUpsertItemDto({
required this.assetId, required this.assetId,
required this.key, required this.key,
required this.value, this.value = const {},
}); });
/// Asset ID /// Asset ID
@@ -25,13 +25,13 @@ class AssetMetadataBulkUpsertItemDto {
String key; String key;
/// Metadata value (object) /// Metadata value (object)
Object value; Map<String, Object> value;
@override @override
bool operator ==(Object other) => identical(this, other) || other is AssetMetadataBulkUpsertItemDto && bool operator ==(Object other) => identical(this, other) || other is AssetMetadataBulkUpsertItemDto &&
other.assetId == assetId && other.assetId == assetId &&
other.key == key && other.key == key &&
other.value == value; _deepEquality.equals(other.value, value);
@override @override
int get hashCode => int get hashCode =>
@@ -62,7 +62,7 @@ class AssetMetadataBulkUpsertItemDto {
return AssetMetadataBulkUpsertItemDto( return AssetMetadataBulkUpsertItemDto(
assetId: mapValueOfType<String>(json, r'assetId')!, assetId: mapValueOfType<String>(json, r'assetId')!,
key: mapValueOfType<String>(json, r'key')!, key: mapValueOfType<String>(json, r'key')!,
value: mapValueOfType<Object>(json, r'value')!, value: mapCastOfType<String, Object>(json, r'value')!,
); );
} }
return null; return null;

View File

@@ -15,7 +15,7 @@ class AssetMetadataResponseDto {
AssetMetadataResponseDto({ AssetMetadataResponseDto({
required this.key, required this.key,
required this.updatedAt, required this.updatedAt,
required this.value, this.value = const {},
}); });
/// Metadata key /// Metadata key
@@ -25,13 +25,13 @@ class AssetMetadataResponseDto {
DateTime updatedAt; DateTime updatedAt;
/// Metadata value (object) /// Metadata value (object)
Object value; Map<String, Object> value;
@override @override
bool operator ==(Object other) => identical(this, other) || other is AssetMetadataResponseDto && bool operator ==(Object other) => identical(this, other) || other is AssetMetadataResponseDto &&
other.key == key && other.key == key &&
other.updatedAt == updatedAt && other.updatedAt == updatedAt &&
other.value == value; _deepEquality.equals(other.value, value);
@override @override
int get hashCode => int get hashCode =>
@@ -46,7 +46,9 @@ class AssetMetadataResponseDto {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
json[r'key'] = this.key; json[r'key'] = this.key;
json[r'updatedAt'] = this.updatedAt.toUtc().toIso8601String(); json[r'updatedAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.updatedAt.millisecondsSinceEpoch
: this.updatedAt.toUtc().toIso8601String();
json[r'value'] = this.value; json[r'value'] = this.value;
return json; return json;
} }
@@ -61,8 +63,8 @@ class AssetMetadataResponseDto {
return AssetMetadataResponseDto( return AssetMetadataResponseDto(
key: mapValueOfType<String>(json, r'key')!, key: mapValueOfType<String>(json, r'key')!,
updatedAt: mapDateTime(json, r'updatedAt', r'')!, updatedAt: mapDateTime(json, r'updatedAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
value: mapValueOfType<Object>(json, r'value')!, value: mapCastOfType<String, Object>(json, r'value')!,
); );
} }
return null; return null;

View File

@@ -14,19 +14,19 @@ class AssetMetadataUpsertItemDto {
/// Returns a new [AssetMetadataUpsertItemDto] instance. /// Returns a new [AssetMetadataUpsertItemDto] instance.
AssetMetadataUpsertItemDto({ AssetMetadataUpsertItemDto({
required this.key, required this.key,
required this.value, this.value = const {},
}); });
/// Metadata key /// Metadata key
String key; String key;
/// Metadata value (object) /// Metadata value (object)
Object value; Map<String, Object> value;
@override @override
bool operator ==(Object other) => identical(this, other) || other is AssetMetadataUpsertItemDto && bool operator ==(Object other) => identical(this, other) || other is AssetMetadataUpsertItemDto &&
other.key == key && other.key == key &&
other.value == value; _deepEquality.equals(other.value, value);
@override @override
int get hashCode => int get hashCode =>
@@ -54,7 +54,7 @@ class AssetMetadataUpsertItemDto {
return AssetMetadataUpsertItemDto( return AssetMetadataUpsertItemDto(
key: mapValueOfType<String>(json, r'key')!, key: mapValueOfType<String>(json, r'key')!,
value: mapValueOfType<Object>(json, r'value')!, value: mapCastOfType<String, Object>(json, r'value')!,
); );
} }
return null; return null;

View File

@@ -0,0 +1,85 @@
//
// AUTO-GENERATED FILE, DO NOT MODIFY!
//
// @dart=2.18
// ignore_for_file: unused_element, unused_import
// ignore_for_file: always_put_required_named_parameters_first
// ignore_for_file: constant_identifier_names
// ignore_for_file: lines_longer_than_80_chars
part of openapi.api;
/// Rejection reason if rejected
class AssetRejectReason {
/// Instantiate a new enum with the provided [value].
const AssetRejectReason._(this.value);
/// The underlying value of this enum member.
final String value;
@override
String toString() => value;
String toJson() => value;
static const duplicate = AssetRejectReason._(r'duplicate');
static const unsupportedFormat = AssetRejectReason._(r'unsupported-format');
/// List of all possible values in this [enum][AssetRejectReason].
static const values = <AssetRejectReason>[
duplicate,
unsupportedFormat,
];
static AssetRejectReason? fromJson(dynamic value) => AssetRejectReasonTypeTransformer().decode(value);
static List<AssetRejectReason> listFromJson(dynamic json, {bool growable = false,}) {
final result = <AssetRejectReason>[];
if (json is List && json.isNotEmpty) {
for (final row in json) {
final value = AssetRejectReason.fromJson(row);
if (value != null) {
result.add(value);
}
}
}
return result.toList(growable: growable);
}
}
/// Transformation class that can [encode] an instance of [AssetRejectReason] to String,
/// and [decode] dynamic data back to [AssetRejectReason].
class AssetRejectReasonTypeTransformer {
factory AssetRejectReasonTypeTransformer() => _instance ??= const AssetRejectReasonTypeTransformer._();
const AssetRejectReasonTypeTransformer._();
String encode(AssetRejectReason data) => data.value;
/// Decodes a [dynamic value][data] to a AssetRejectReason.
///
/// If [allowNull] is true and the [dynamic value][data] cannot be decoded successfully,
/// then null is returned. However, if [allowNull] is false and the [dynamic value][data]
/// cannot be decoded successfully, then an [UnimplementedError] is thrown.
///
/// The [allowNull] is very handy when an API changes and a new enum value is added or removed,
/// and users are still using an old app with the old code.
AssetRejectReason? decode(dynamic data, {bool allowNull = true}) {
if (data != null) {
switch (data) {
case r'duplicate': return AssetRejectReason.duplicate;
case r'unsupported-format': return AssetRejectReason.unsupportedFormat;
default:
if (!allowNull) {
throw ArgumentError('Unknown enum value to decode: $data');
}
}
}
return null;
}
/// Singleton [AssetRejectReasonTypeTransformer] instance.
static AssetRejectReasonTypeTransformer? _instance;
}

View File

@@ -62,7 +62,6 @@ class AssetResponseDto {
/// Device ID /// Device ID
String deviceId; String deviceId;
/// Duplicate group ID
String? duplicateId; String? duplicateId;
/// Video duration (for videos) /// Video duration (for videos)
@@ -85,7 +84,7 @@ class AssetResponseDto {
/// Whether asset has metadata /// Whether asset has metadata
bool hasMetadata; bool hasMetadata;
/// Asset height /// Minimum value: 0
num? height; num? height;
/// Asset ID /// Asset ID
@@ -106,10 +105,8 @@ class AssetResponseDto {
/// Is trashed /// Is trashed
bool isTrashed; bool isTrashed;
/// Library ID
String? libraryId; String? libraryId;
/// Live photo video ID
String? livePhotoVideoId; String? livePhotoVideoId;
/// The local date and time when the photo/video was taken, derived from EXIF metadata. This represents the photographer's local time regardless of timezone, stored as a timezone-agnostic timestamp. Used for timeline grouping by \"local\" days and months. /// The local date and time when the photo/video was taken, derived from EXIF metadata. This represents the photographer's local time regardless of timezone, stored as a timezone-agnostic timestamp. Used for timeline grouping by \"local\" days and months.
@@ -152,6 +149,12 @@ class AssetResponseDto {
/// ///
bool? resized; bool? resized;
///
/// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated
/// source code must fall back to having a nullable type.
/// Consider adding a "default:" property in the specification file to hide this note.
///
AssetStackResponseDto? stack; AssetStackResponseDto? stack;
List<TagResponseDto> tags; List<TagResponseDto> tags;
@@ -159,7 +162,6 @@ class AssetResponseDto {
/// Thumbhash for thumbnail generation (base64) also used as the c query param for thumbnail cache busting. /// Thumbhash for thumbnail generation (base64) also used as the c query param for thumbnail cache busting.
String? thumbhash; String? thumbhash;
/// Asset type
AssetTypeEnum type; AssetTypeEnum type;
List<AssetFaceWithoutPersonResponseDto> unassignedFaces; List<AssetFaceWithoutPersonResponseDto> unassignedFaces;
@@ -167,10 +169,9 @@ class AssetResponseDto {
/// The UTC timestamp when the asset record was last updated in the database. This is automatically maintained by the database and reflects when any field in the asset was last modified. /// The UTC timestamp when the asset record was last updated in the database. This is automatically maintained by the database and reflects when any field in the asset was last modified.
DateTime updatedAt; DateTime updatedAt;
/// Asset visibility
AssetVisibility visibility; AssetVisibility visibility;
/// Asset width /// Minimum value: 0
num? width; num? width;
@override @override

View File

@@ -19,6 +19,9 @@ class AssetStackResponseDto {
}); });
/// Number of assets in stack /// Number of assets in stack
///
/// Minimum value: 0
/// Maximum value: 9007199254740991
int assetCount; int assetCount;
/// Stack ID /// Stack ID

View File

@@ -19,12 +19,21 @@ class AssetStatsResponseDto {
}); });
/// Number of images /// Number of images
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int images; int images;
/// Total number of assets /// Total number of assets
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int total; int total;
/// Number of videos /// Number of videos
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int videos; int videos;
@override @override

View File

@@ -0,0 +1,85 @@
//
// AUTO-GENERATED FILE, DO NOT MODIFY!
//
// @dart=2.18
// ignore_for_file: unused_element, unused_import
// ignore_for_file: always_put_required_named_parameters_first
// ignore_for_file: constant_identifier_names
// ignore_for_file: lines_longer_than_80_chars
part of openapi.api;
/// Upload action
class AssetUploadAction {
/// Instantiate a new enum with the provided [value].
const AssetUploadAction._(this.value);
/// The underlying value of this enum member.
final String value;
@override
String toString() => value;
String toJson() => value;
static const accept = AssetUploadAction._(r'accept');
static const reject = AssetUploadAction._(r'reject');
/// List of all possible values in this [enum][AssetUploadAction].
static const values = <AssetUploadAction>[
accept,
reject,
];
static AssetUploadAction? fromJson(dynamic value) => AssetUploadActionTypeTransformer().decode(value);
static List<AssetUploadAction> listFromJson(dynamic json, {bool growable = false,}) {
final result = <AssetUploadAction>[];
if (json is List && json.isNotEmpty) {
for (final row in json) {
final value = AssetUploadAction.fromJson(row);
if (value != null) {
result.add(value);
}
}
}
return result.toList(growable: growable);
}
}
/// Transformation class that can [encode] an instance of [AssetUploadAction] to String,
/// and [decode] dynamic data back to [AssetUploadAction].
class AssetUploadActionTypeTransformer {
factory AssetUploadActionTypeTransformer() => _instance ??= const AssetUploadActionTypeTransformer._();
const AssetUploadActionTypeTransformer._();
String encode(AssetUploadAction data) => data.value;
/// Decodes a [dynamic value][data] to a AssetUploadAction.
///
/// If [allowNull] is true and the [dynamic value][data] cannot be decoded successfully,
/// then null is returned. However, if [allowNull] is false and the [dynamic value][data]
/// cannot be decoded successfully, then an [UnimplementedError] is thrown.
///
/// The [allowNull] is very handy when an API changes and a new enum value is added or removed,
/// and users are still using an old app with the old code.
AssetUploadAction? decode(dynamic data, {bool allowNull = true}) {
if (data != null) {
switch (data) {
case r'accept': return AssetUploadAction.accept;
case r'reject': return AssetUploadAction.reject;
default:
if (!allowNull) {
throw ArgumentError('Unknown enum value to decode: $data');
}
}
}
return null;
}
/// Singleton [AssetUploadActionTypeTransformer] instance.
static AssetUploadActionTypeTransformer? _instance;
}

View File

@@ -16,7 +16,6 @@ class AvatarUpdate {
this.color, this.color,
}); });
/// Avatar color
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated

View File

@@ -18,8 +18,13 @@ class BulkIdResponseDto {
required this.success, required this.success,
}); });
/// Error reason if failed ///
BulkIdResponseDtoErrorEnum? error; /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated
/// source code must fall back to having a nullable type.
/// Consider adding a "default:" property in the specification file to hide this note.
///
BulkIdErrorReason? error;
/// ID /// ID
String id; String id;
@@ -64,7 +69,7 @@ class BulkIdResponseDto {
final json = value.cast<String, dynamic>(); final json = value.cast<String, dynamic>();
return BulkIdResponseDto( return BulkIdResponseDto(
error: BulkIdResponseDtoErrorEnum.fromJson(json[r'error']), error: BulkIdErrorReason.fromJson(json[r'error']),
id: mapValueOfType<String>(json, r'id')!, id: mapValueOfType<String>(json, r'id')!,
success: mapValueOfType<bool>(json, r'success')!, success: mapValueOfType<bool>(json, r'success')!,
); );
@@ -119,83 +124,3 @@ class BulkIdResponseDto {
}; };
} }
/// Error reason if failed
class BulkIdResponseDtoErrorEnum {
/// Instantiate a new enum with the provided [value].
const BulkIdResponseDtoErrorEnum._(this.value);
/// The underlying value of this enum member.
final String value;
@override
String toString() => value;
String toJson() => value;
static const duplicate = BulkIdResponseDtoErrorEnum._(r'duplicate');
static const noPermission = BulkIdResponseDtoErrorEnum._(r'no_permission');
static const notFound = BulkIdResponseDtoErrorEnum._(r'not_found');
static const unknown = BulkIdResponseDtoErrorEnum._(r'unknown');
/// List of all possible values in this [enum][BulkIdResponseDtoErrorEnum].
static const values = <BulkIdResponseDtoErrorEnum>[
duplicate,
noPermission,
notFound,
unknown,
];
static BulkIdResponseDtoErrorEnum? fromJson(dynamic value) => BulkIdResponseDtoErrorEnumTypeTransformer().decode(value);
static List<BulkIdResponseDtoErrorEnum> listFromJson(dynamic json, {bool growable = false,}) {
final result = <BulkIdResponseDtoErrorEnum>[];
if (json is List && json.isNotEmpty) {
for (final row in json) {
final value = BulkIdResponseDtoErrorEnum.fromJson(row);
if (value != null) {
result.add(value);
}
}
}
return result.toList(growable: growable);
}
}
/// Transformation class that can [encode] an instance of [BulkIdResponseDtoErrorEnum] to String,
/// and [decode] dynamic data back to [BulkIdResponseDtoErrorEnum].
class BulkIdResponseDtoErrorEnumTypeTransformer {
factory BulkIdResponseDtoErrorEnumTypeTransformer() => _instance ??= const BulkIdResponseDtoErrorEnumTypeTransformer._();
const BulkIdResponseDtoErrorEnumTypeTransformer._();
String encode(BulkIdResponseDtoErrorEnum data) => data.value;
/// Decodes a [dynamic value][data] to a BulkIdResponseDtoErrorEnum.
///
/// If [allowNull] is true and the [dynamic value][data] cannot be decoded successfully,
/// then null is returned. However, if [allowNull] is false and the [dynamic value][data]
/// cannot be decoded successfully, then an [UnimplementedError] is thrown.
///
/// The [allowNull] is very handy when an API changes and a new enum value is added or removed,
/// and users are still using an old app with the old code.
BulkIdResponseDtoErrorEnum? decode(dynamic data, {bool allowNull = true}) {
if (data != null) {
switch (data) {
case r'duplicate': return BulkIdResponseDtoErrorEnum.duplicate;
case r'no_permission': return BulkIdResponseDtoErrorEnum.noPermission;
case r'not_found': return BulkIdResponseDtoErrorEnum.notFound;
case r'unknown': return BulkIdResponseDtoErrorEnum.unknown;
default:
if (!allowNull) {
throw ArgumentError('Unknown enum value to decode: $data');
}
}
}
return null;
}
/// Singleton [BulkIdResponseDtoErrorEnumTypeTransformer] instance.
static BulkIdResponseDtoErrorEnumTypeTransformer? _instance;
}

View File

@@ -13,7 +13,7 @@ part of openapi.api;
class CastResponse { class CastResponse {
/// Returns a new [CastResponse] instance. /// Returns a new [CastResponse] instance.
CastResponse({ CastResponse({
this.gCastEnabled = false, required this.gCastEnabled,
}); });
/// Whether Google Cast is enabled /// Whether Google Cast is enabled

View File

@@ -18,6 +18,9 @@ class ContributorCountResponseDto {
}); });
/// Number of assets contributed /// Number of assets contributed
///
/// Minimum value: 0
/// Maximum value: 9007199254740991
int assetCount; int assetCount;
/// User ID /// User ID

View File

@@ -13,17 +13,17 @@ part of openapi.api;
class CreateLibraryDto { class CreateLibraryDto {
/// Returns a new [CreateLibraryDto] instance. /// Returns a new [CreateLibraryDto] instance.
CreateLibraryDto({ CreateLibraryDto({
this.exclusionPatterns = const {}, this.exclusionPatterns = const [],
this.importPaths = const {}, this.importPaths = const [],
this.name, this.name,
required this.ownerId, required this.ownerId,
}); });
/// Exclusion patterns (max 128) /// Exclusion patterns (max 128)
Set<String> exclusionPatterns; List<String> exclusionPatterns;
/// Import paths (max 128) /// Import paths (max 128)
Set<String> importPaths; List<String> importPaths;
/// Library name /// Library name
/// ///
@@ -57,8 +57,8 @@ class CreateLibraryDto {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
json[r'exclusionPatterns'] = this.exclusionPatterns.toList(growable: false); json[r'exclusionPatterns'] = this.exclusionPatterns;
json[r'importPaths'] = this.importPaths.toList(growable: false); json[r'importPaths'] = this.importPaths;
if (this.name != null) { if (this.name != null) {
json[r'name'] = this.name; json[r'name'] = this.name;
} else { } else {
@@ -78,11 +78,11 @@ class CreateLibraryDto {
return CreateLibraryDto( return CreateLibraryDto(
exclusionPatterns: json[r'exclusionPatterns'] is Iterable exclusionPatterns: json[r'exclusionPatterns'] is Iterable
? (json[r'exclusionPatterns'] as Iterable).cast<String>().toSet() ? (json[r'exclusionPatterns'] as Iterable).cast<String>().toList(growable: false)
: const {}, : const [],
importPaths: json[r'importPaths'] is Iterable importPaths: json[r'importPaths'] is Iterable
? (json[r'importPaths'] as Iterable).cast<String>().toSet() ? (json[r'importPaths'] as Iterable).cast<String>().toList(growable: false)
: const {}, : const [],
name: mapValueOfType<String>(json, r'name'), name: mapValueOfType<String>(json, r'name'),
ownerId: mapValueOfType<String>(json, r'ownerId')!, ownerId: mapValueOfType<String>(json, r'ownerId')!,
); );

View File

@@ -45,7 +45,9 @@ class CreateProfileImageResponseDto {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
json[r'profileChangedAt'] = this.profileChangedAt.toUtc().toIso8601String(); json[r'profileChangedAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.profileChangedAt.millisecondsSinceEpoch
: this.profileChangedAt.toUtc().toIso8601String();
json[r'profileImagePath'] = this.profileImagePath; json[r'profileImagePath'] = this.profileImagePath;
json[r'userId'] = this.userId; json[r'userId'] = this.userId;
return json; return json;
@@ -60,7 +62,7 @@ class CreateProfileImageResponseDto {
final json = value.cast<String, dynamic>(); final json = value.cast<String, dynamic>();
return CreateProfileImageResponseDto( return CreateProfileImageResponseDto(
profileChangedAt: mapDateTime(json, r'profileChangedAt', r'')!, profileChangedAt: mapDateTime(json, r'profileChangedAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
profileImagePath: mapValueOfType<String>(json, r'profileImagePath')!, profileImagePath: mapValueOfType<String>(json, r'profileImagePath')!,
userId: mapValueOfType<String>(json, r'userId')!, userId: mapValueOfType<String>(json, r'userId')!,
); );

View File

@@ -16,6 +16,7 @@ class DatabaseBackupDeleteDto {
this.backups = const [], this.backups = const [],
}); });
/// Backup filenames to delete
List<String> backups; List<String> backups;
@override @override

View File

@@ -17,8 +17,10 @@ class DatabaseBackupDto {
required this.filesize, required this.filesize,
}); });
/// Backup filename
String filename; String filename;
/// Backup file size
num filesize; num filesize;
@override @override

View File

@@ -16,6 +16,7 @@ class DatabaseBackupListResponseDto {
this.backups = const [], this.backups = const [],
}); });
/// List of backups
List<DatabaseBackupDto> backups; List<DatabaseBackupDto> backups;
@override @override

View File

@@ -21,6 +21,9 @@ class DownloadArchiveInfo {
List<String> assetIds; List<String> assetIds;
/// Archive size in bytes /// Archive size in bytes
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int size; int size;
@override @override

View File

@@ -31,6 +31,7 @@ class DownloadInfoDto {
/// Archive size limit in bytes /// Archive size limit in bytes
/// ///
/// Minimum value: 1 /// Minimum value: 1
/// Maximum value: 9007199254740991
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated

View File

@@ -14,10 +14,13 @@ class DownloadResponse {
/// Returns a new [DownloadResponse] instance. /// Returns a new [DownloadResponse] instance.
DownloadResponse({ DownloadResponse({
required this.archiveSize, required this.archiveSize,
this.includeEmbeddedVideos = false, required this.includeEmbeddedVideos,
}); });
/// Maximum archive size in bytes /// Maximum archive size in bytes
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int archiveSize; int archiveSize;
/// Whether to include embedded videos in downloads /// Whether to include embedded videos in downloads

View File

@@ -21,6 +21,9 @@ class DownloadResponseDto {
List<DownloadArchiveInfo> archives; List<DownloadArchiveInfo> archives;
/// Total size in bytes /// Total size in bytes
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int totalSize; int totalSize;
@override @override

View File

@@ -20,6 +20,7 @@ class DownloadUpdate {
/// Maximum archive size in bytes /// Maximum archive size in bytes
/// ///
/// Minimum value: 1 /// Minimum value: 1
/// Maximum value: 9007199254740991
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated

View File

@@ -37,70 +37,52 @@ class ExifResponseDto {
this.timeZone, this.timeZone,
}); });
/// City name
String? city; String? city;
/// Country name
String? country; String? country;
/// Original date/time
DateTime? dateTimeOriginal; DateTime? dateTimeOriginal;
/// Image description
String? description; String? description;
/// Image height in pixels /// Minimum value: 0
num? exifImageHeight; num? exifImageHeight;
/// Image width in pixels /// Minimum value: 0
num? exifImageWidth; num? exifImageWidth;
/// Exposure time
String? exposureTime; String? exposureTime;
/// F-number (aperture)
num? fNumber; num? fNumber;
/// File size in bytes /// Minimum value: 0
/// Maximum value: 9007199254740991
int? fileSizeInByte; int? fileSizeInByte;
/// Focal length in mm
num? focalLength; num? focalLength;
/// ISO sensitivity
num? iso; num? iso;
/// GPS latitude
num? latitude; num? latitude;
/// Lens model
String? lensModel; String? lensModel;
/// GPS longitude
num? longitude; num? longitude;
/// Camera make
String? make; String? make;
/// Camera model
String? model; String? model;
/// Modification date/time
DateTime? modifyDate; DateTime? modifyDate;
/// Image orientation
String? orientation; String? orientation;
/// Projection type
String? projectionType; String? projectionType;
/// Rating
num? rating; num? rating;
/// State/province name
String? state; String? state;
/// Time zone
String? timeZone; String? timeZone;
@override @override

View File

@@ -32,6 +32,7 @@ class FacialRecognitionConfig {
/// Minimum number of faces required for recognition /// Minimum number of faces required for recognition
/// ///
/// Minimum value: 1 /// Minimum value: 1
/// Maximum value: 9007199254740991
int minFaces; int minFaces;
/// Minimum confidence score for face detection /// Minimum confidence score for face detection

View File

@@ -13,8 +13,8 @@ part of openapi.api;
class FoldersResponse { class FoldersResponse {
/// Returns a new [FoldersResponse] instance. /// Returns a new [FoldersResponse] instance.
FoldersResponse({ FoldersResponse({
this.enabled = false, required this.enabled,
this.sidebarWeb = false, required this.sidebarWeb,
}); });
/// Whether folders are enabled /// Whether folders are enabled

View File

@@ -16,7 +16,6 @@ class JobCreateDto {
required this.name, required this.name,
}); });
/// Job name
ManualJobName name; ManualJobName name;
@override @override

View File

@@ -19,6 +19,7 @@ class JobSettingsDto {
/// Concurrency /// Concurrency
/// ///
/// Minimum value: 1 /// Minimum value: 1
/// Maximum value: 9007199254740991
int concurrency; int concurrency;
@override @override

View File

@@ -25,6 +25,9 @@ class LibraryResponseDto {
}); });
/// Number of assets /// Number of assets
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int assetCount; int assetCount;
/// Creation date /// Creation date
@@ -45,7 +48,6 @@ class LibraryResponseDto {
/// Owner user ID /// Owner user ID
String ownerId; String ownerId;
/// Last refresh date
DateTime? refreshedAt; DateTime? refreshedAt;
/// Last update date /// Last update date
@@ -82,18 +84,24 @@ class LibraryResponseDto {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
json[r'assetCount'] = this.assetCount; json[r'assetCount'] = this.assetCount;
json[r'createdAt'] = this.createdAt.toUtc().toIso8601String(); json[r'createdAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.createdAt.millisecondsSinceEpoch
: this.createdAt.toUtc().toIso8601String();
json[r'exclusionPatterns'] = this.exclusionPatterns; json[r'exclusionPatterns'] = this.exclusionPatterns;
json[r'id'] = this.id; json[r'id'] = this.id;
json[r'importPaths'] = this.importPaths; json[r'importPaths'] = this.importPaths;
json[r'name'] = this.name; json[r'name'] = this.name;
json[r'ownerId'] = this.ownerId; json[r'ownerId'] = this.ownerId;
if (this.refreshedAt != null) { if (this.refreshedAt != null) {
json[r'refreshedAt'] = this.refreshedAt!.toUtc().toIso8601String(); json[r'refreshedAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.refreshedAt!.millisecondsSinceEpoch
: this.refreshedAt!.toUtc().toIso8601String();
} else { } else {
// json[r'refreshedAt'] = null; // json[r'refreshedAt'] = null;
} }
json[r'updatedAt'] = this.updatedAt.toUtc().toIso8601String(); json[r'updatedAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.updatedAt.millisecondsSinceEpoch
: this.updatedAt.toUtc().toIso8601String();
return json; return json;
} }
@@ -107,7 +115,7 @@ class LibraryResponseDto {
return LibraryResponseDto( return LibraryResponseDto(
assetCount: mapValueOfType<int>(json, r'assetCount')!, assetCount: mapValueOfType<int>(json, r'assetCount')!,
createdAt: mapDateTime(json, r'createdAt', r'')!, createdAt: mapDateTime(json, r'createdAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
exclusionPatterns: json[r'exclusionPatterns'] is Iterable exclusionPatterns: json[r'exclusionPatterns'] is Iterable
? (json[r'exclusionPatterns'] as Iterable).cast<String>().toList(growable: false) ? (json[r'exclusionPatterns'] as Iterable).cast<String>().toList(growable: false)
: const [], : const [],
@@ -117,8 +125,8 @@ class LibraryResponseDto {
: const [], : const [],
name: mapValueOfType<String>(json, r'name')!, name: mapValueOfType<String>(json, r'name')!,
ownerId: mapValueOfType<String>(json, r'ownerId')!, ownerId: mapValueOfType<String>(json, r'ownerId')!,
refreshedAt: mapDateTime(json, r'refreshedAt', r''), refreshedAt: mapDateTime(json, r'refreshedAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
updatedAt: mapDateTime(json, r'updatedAt', r'')!, updatedAt: mapDateTime(json, r'updatedAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
); );
} }
return null; return null;

View File

@@ -13,22 +13,34 @@ part of openapi.api;
class LibraryStatsResponseDto { class LibraryStatsResponseDto {
/// Returns a new [LibraryStatsResponseDto] instance. /// Returns a new [LibraryStatsResponseDto] instance.
LibraryStatsResponseDto({ LibraryStatsResponseDto({
this.photos = 0, required this.photos,
this.total = 0, required this.total,
this.usage = 0, required this.usage,
this.videos = 0, required this.videos,
}); });
/// Number of photos /// Number of photos
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int photos; int photos;
/// Total number of assets /// Total number of assets
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int total; int total;
/// Storage usage in bytes /// Storage usage in bytes
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int usage; int usage;
/// Number of videos /// Number of videos
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int videos; int videos;
@override @override

View File

@@ -20,7 +20,7 @@ class LicenseKeyDto {
/// Activation key /// Activation key
String activationKey; String activationKey;
/// License key (format: IM(SV|CL)(-XXXX){8}) /// License key (format: /^IM(SV|CL)(-[\\dA-Za-z]{4}){8}$/)
String licenseKey; String licenseKey;
@override @override

View File

@@ -1,118 +0,0 @@
//
// AUTO-GENERATED FILE, DO NOT MODIFY!
//
// @dart=2.18
// ignore_for_file: unused_element, unused_import
// ignore_for_file: always_put_required_named_parameters_first
// ignore_for_file: constant_identifier_names
// ignore_for_file: lines_longer_than_80_chars
part of openapi.api;
class LicenseResponseDto {
/// Returns a new [LicenseResponseDto] instance.
LicenseResponseDto({
required this.activatedAt,
required this.activationKey,
required this.licenseKey,
});
/// Activation date
DateTime activatedAt;
/// Activation key
String activationKey;
/// License key (format: IM(SV|CL)(-XXXX){8})
String licenseKey;
@override
bool operator ==(Object other) => identical(this, other) || other is LicenseResponseDto &&
other.activatedAt == activatedAt &&
other.activationKey == activationKey &&
other.licenseKey == licenseKey;
@override
int get hashCode =>
// ignore: unnecessary_parenthesis
(activatedAt.hashCode) +
(activationKey.hashCode) +
(licenseKey.hashCode);
@override
String toString() => 'LicenseResponseDto[activatedAt=$activatedAt, activationKey=$activationKey, licenseKey=$licenseKey]';
Map<String, dynamic> toJson() {
final json = <String, dynamic>{};
json[r'activatedAt'] = this.activatedAt.toUtc().toIso8601String();
json[r'activationKey'] = this.activationKey;
json[r'licenseKey'] = this.licenseKey;
return json;
}
/// Returns a new [LicenseResponseDto] instance and imports its values from
/// [value] if it's a [Map], null otherwise.
// ignore: prefer_constructors_over_static_methods
static LicenseResponseDto? fromJson(dynamic value) {
upgradeDto(value, "LicenseResponseDto");
if (value is Map) {
final json = value.cast<String, dynamic>();
return LicenseResponseDto(
activatedAt: mapDateTime(json, r'activatedAt', r'')!,
activationKey: mapValueOfType<String>(json, r'activationKey')!,
licenseKey: mapValueOfType<String>(json, r'licenseKey')!,
);
}
return null;
}
static List<LicenseResponseDto> listFromJson(dynamic json, {bool growable = false,}) {
final result = <LicenseResponseDto>[];
if (json is List && json.isNotEmpty) {
for (final row in json) {
final value = LicenseResponseDto.fromJson(row);
if (value != null) {
result.add(value);
}
}
}
return result.toList(growable: growable);
}
static Map<String, LicenseResponseDto> mapFromJson(dynamic json) {
final map = <String, LicenseResponseDto>{};
if (json is Map && json.isNotEmpty) {
json = json.cast<String, dynamic>(); // ignore: parameter_assignments
for (final entry in json.entries) {
final value = LicenseResponseDto.fromJson(entry.value);
if (value != null) {
map[entry.key] = value;
}
}
}
return map;
}
// maps a json object with a list of LicenseResponseDto-objects as value to a dart map
static Map<String, List<LicenseResponseDto>> mapListFromJson(dynamic json, {bool growable = false,}) {
final map = <String, List<LicenseResponseDto>>{};
if (json is Map && json.isNotEmpty) {
// ignore: parameter_assignments
json = json.cast<String, dynamic>();
for (final entry in json.entries) {
map[entry.key] = LicenseResponseDto.listFromJson(entry.value, growable: growable,);
}
}
return map;
}
/// The list of required keys that must be present in a JSON.
static const requiredKeys = <String>{
'activatedAt',
'activationKey',
'licenseKey',
};
}

View File

@@ -10,7 +10,7 @@
part of openapi.api; part of openapi.api;
/// Log level
class LogLevel { class LogLevel {
/// Instantiate a new enum with the provided [value]. /// Instantiate a new enum with the provided [value].
const LogLevel._(this.value); const LogLevel._(this.value);

View File

@@ -22,7 +22,6 @@ class MaintenanceDetectInstallStorageFolderDto {
/// Number of files in the folder /// Number of files in the folder
num files; num files;
/// Storage folder
StorageFolder folder; StorageFolder folder;
/// Whether the folder is readable /// Whether the folder is readable

View File

@@ -20,7 +20,6 @@ class MaintenanceStatusResponseDto {
this.task, this.task,
}); });
/// Maintenance action
MaintenanceAction action; MaintenanceAction action;
bool active; bool active;

View File

@@ -10,7 +10,7 @@
part of openapi.api; part of openapi.api;
/// Job name /// Manual job name
class ManualJobName { class ManualJobName {
/// Instantiate a new enum with the provided [value]. /// Instantiate a new enum with the provided [value].
const ManualJobName._(this.value); const ManualJobName._(this.value);

View File

@@ -21,10 +21,8 @@ class MapMarkerResponseDto {
required this.state, required this.state,
}); });
/// City name
String? city; String? city;
/// Country name
String? country; String? country;
/// Asset ID /// Asset ID
@@ -36,7 +34,6 @@ class MapMarkerResponseDto {
/// Longitude /// Longitude
double lon; double lon;
/// State/Province name
String? state; String? state;
@override @override

View File

@@ -18,13 +18,10 @@ class MapReverseGeocodeResponseDto {
required this.state, required this.state,
}); });
/// City name
String? city; String? city;
/// Country name
String? country; String? country;
/// State/Province name
String? state; String? state;
@override @override

View File

@@ -13,11 +13,14 @@ part of openapi.api;
class MemoriesResponse { class MemoriesResponse {
/// Returns a new [MemoriesResponse] instance. /// Returns a new [MemoriesResponse] instance.
MemoriesResponse({ MemoriesResponse({
this.duration = 5, required this.duration,
this.enabled = true, required this.enabled,
}); });
/// Memory duration in seconds /// Memory duration in seconds
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int duration; int duration;
/// Whether memories are enabled /// Whether memories are enabled

View File

@@ -20,6 +20,7 @@ class MemoriesUpdate {
/// Memory duration in seconds /// Memory duration in seconds
/// ///
/// Minimum value: 1 /// Minimum value: 1
/// Maximum value: 9007199254740991
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated

View File

@@ -67,7 +67,6 @@ class MemoryCreateDto {
/// ///
DateTime? showAt; DateTime? showAt;
/// Memory type
MemoryType type; MemoryType type;
@override @override
@@ -101,7 +100,9 @@ class MemoryCreateDto {
json[r'assetIds'] = this.assetIds; json[r'assetIds'] = this.assetIds;
json[r'data'] = this.data; json[r'data'] = this.data;
if (this.hideAt != null) { if (this.hideAt != null) {
json[r'hideAt'] = this.hideAt!.toUtc().toIso8601String(); json[r'hideAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.hideAt!.millisecondsSinceEpoch
: this.hideAt!.toUtc().toIso8601String();
} else { } else {
// json[r'hideAt'] = null; // json[r'hideAt'] = null;
} }
@@ -110,14 +111,20 @@ class MemoryCreateDto {
} else { } else {
// json[r'isSaved'] = null; // json[r'isSaved'] = null;
} }
json[r'memoryAt'] = this.memoryAt.toUtc().toIso8601String(); json[r'memoryAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.memoryAt.millisecondsSinceEpoch
: this.memoryAt.toUtc().toIso8601String();
if (this.seenAt != null) { if (this.seenAt != null) {
json[r'seenAt'] = this.seenAt!.toUtc().toIso8601String(); json[r'seenAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.seenAt!.millisecondsSinceEpoch
: this.seenAt!.toUtc().toIso8601String();
} else { } else {
// json[r'seenAt'] = null; // json[r'seenAt'] = null;
} }
if (this.showAt != null) { if (this.showAt != null) {
json[r'showAt'] = this.showAt!.toUtc().toIso8601String(); json[r'showAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.showAt!.millisecondsSinceEpoch
: this.showAt!.toUtc().toIso8601String();
} else { } else {
// json[r'showAt'] = null; // json[r'showAt'] = null;
} }
@@ -138,11 +145,11 @@ class MemoryCreateDto {
? (json[r'assetIds'] as Iterable).cast<String>().toList(growable: false) ? (json[r'assetIds'] as Iterable).cast<String>().toList(growable: false)
: const [], : const [],
data: OnThisDayDto.fromJson(json[r'data'])!, data: OnThisDayDto.fromJson(json[r'data'])!,
hideAt: mapDateTime(json, r'hideAt', r''), hideAt: mapDateTime(json, r'hideAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
isSaved: mapValueOfType<bool>(json, r'isSaved'), isSaved: mapValueOfType<bool>(json, r'isSaved'),
memoryAt: mapDateTime(json, r'memoryAt', r'')!, memoryAt: mapDateTime(json, r'memoryAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
seenAt: mapDateTime(json, r'seenAt', r''), seenAt: mapDateTime(json, r'seenAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
showAt: mapDateTime(json, r'showAt', r''), showAt: mapDateTime(json, r'showAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
type: MemoryType.fromJson(json[r'type'])!, type: MemoryType.fromJson(json[r'type'])!,
); );
} }

View File

@@ -83,7 +83,6 @@ class MemoryResponseDto {
/// ///
DateTime? showAt; DateTime? showAt;
/// Memory type
MemoryType type; MemoryType type;
/// Last update date /// Last update date
@@ -128,34 +127,48 @@ class MemoryResponseDto {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
json[r'assets'] = this.assets; json[r'assets'] = this.assets;
json[r'createdAt'] = this.createdAt.toUtc().toIso8601String(); json[r'createdAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.createdAt.millisecondsSinceEpoch
: this.createdAt.toUtc().toIso8601String();
json[r'data'] = this.data; json[r'data'] = this.data;
if (this.deletedAt != null) { if (this.deletedAt != null) {
json[r'deletedAt'] = this.deletedAt!.toUtc().toIso8601String(); json[r'deletedAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.deletedAt!.millisecondsSinceEpoch
: this.deletedAt!.toUtc().toIso8601String();
} else { } else {
// json[r'deletedAt'] = null; // json[r'deletedAt'] = null;
} }
if (this.hideAt != null) { if (this.hideAt != null) {
json[r'hideAt'] = this.hideAt!.toUtc().toIso8601String(); json[r'hideAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.hideAt!.millisecondsSinceEpoch
: this.hideAt!.toUtc().toIso8601String();
} else { } else {
// json[r'hideAt'] = null; // json[r'hideAt'] = null;
} }
json[r'id'] = this.id; json[r'id'] = this.id;
json[r'isSaved'] = this.isSaved; json[r'isSaved'] = this.isSaved;
json[r'memoryAt'] = this.memoryAt.toUtc().toIso8601String(); json[r'memoryAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.memoryAt.millisecondsSinceEpoch
: this.memoryAt.toUtc().toIso8601String();
json[r'ownerId'] = this.ownerId; json[r'ownerId'] = this.ownerId;
if (this.seenAt != null) { if (this.seenAt != null) {
json[r'seenAt'] = this.seenAt!.toUtc().toIso8601String(); json[r'seenAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.seenAt!.millisecondsSinceEpoch
: this.seenAt!.toUtc().toIso8601String();
} else { } else {
// json[r'seenAt'] = null; // json[r'seenAt'] = null;
} }
if (this.showAt != null) { if (this.showAt != null) {
json[r'showAt'] = this.showAt!.toUtc().toIso8601String(); json[r'showAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.showAt!.millisecondsSinceEpoch
: this.showAt!.toUtc().toIso8601String();
} else { } else {
// json[r'showAt'] = null; // json[r'showAt'] = null;
} }
json[r'type'] = this.type; json[r'type'] = this.type;
json[r'updatedAt'] = this.updatedAt.toUtc().toIso8601String(); json[r'updatedAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.updatedAt.millisecondsSinceEpoch
: this.updatedAt.toUtc().toIso8601String();
return json; return json;
} }
@@ -169,18 +182,18 @@ class MemoryResponseDto {
return MemoryResponseDto( return MemoryResponseDto(
assets: AssetResponseDto.listFromJson(json[r'assets']), assets: AssetResponseDto.listFromJson(json[r'assets']),
createdAt: mapDateTime(json, r'createdAt', r'')!, createdAt: mapDateTime(json, r'createdAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
data: OnThisDayDto.fromJson(json[r'data'])!, data: OnThisDayDto.fromJson(json[r'data'])!,
deletedAt: mapDateTime(json, r'deletedAt', r''), deletedAt: mapDateTime(json, r'deletedAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
hideAt: mapDateTime(json, r'hideAt', r''), hideAt: mapDateTime(json, r'hideAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
id: mapValueOfType<String>(json, r'id')!, id: mapValueOfType<String>(json, r'id')!,
isSaved: mapValueOfType<bool>(json, r'isSaved')!, isSaved: mapValueOfType<bool>(json, r'isSaved')!,
memoryAt: mapDateTime(json, r'memoryAt', r'')!, memoryAt: mapDateTime(json, r'memoryAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
ownerId: mapValueOfType<String>(json, r'ownerId')!, ownerId: mapValueOfType<String>(json, r'ownerId')!,
seenAt: mapDateTime(json, r'seenAt', r''), seenAt: mapDateTime(json, r'seenAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
showAt: mapDateTime(json, r'showAt', r''), showAt: mapDateTime(json, r'showAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
type: MemoryType.fromJson(json[r'type'])!, type: MemoryType.fromJson(json[r'type'])!,
updatedAt: mapDateTime(json, r'updatedAt', r'')!, updatedAt: mapDateTime(json, r'updatedAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
); );
} }
return null; return null;

View File

@@ -10,7 +10,7 @@
part of openapi.api; part of openapi.api;
/// Sort order
class MemorySearchOrder { class MemorySearchOrder {
/// Instantiate a new enum with the provided [value]. /// Instantiate a new enum with the provided [value].
const MemorySearchOrder._(this.value); const MemorySearchOrder._(this.value);

View File

@@ -17,6 +17,9 @@ class MemoryStatisticsResponseDto {
}); });
/// Total number of memories /// Total number of memories
///
/// Minimum value: -9007199254740991
/// Maximum value: 9007199254740991
int total; int total;
@override @override

View File

@@ -10,7 +10,7 @@
part of openapi.api; part of openapi.api;
/// Memory type
class MemoryType { class MemoryType {
/// Instantiate a new enum with the provided [value]. /// Instantiate a new enum with the provided [value].
const MemoryType._(this.value); const MemoryType._(this.value);

View File

@@ -69,12 +69,16 @@ class MemoryUpdateDto {
// json[r'isSaved'] = null; // json[r'isSaved'] = null;
} }
if (this.memoryAt != null) { if (this.memoryAt != null) {
json[r'memoryAt'] = this.memoryAt!.toUtc().toIso8601String(); json[r'memoryAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.memoryAt!.millisecondsSinceEpoch
: this.memoryAt!.toUtc().toIso8601String();
} else { } else {
// json[r'memoryAt'] = null; // json[r'memoryAt'] = null;
} }
if (this.seenAt != null) { if (this.seenAt != null) {
json[r'seenAt'] = this.seenAt!.toUtc().toIso8601String(); json[r'seenAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.seenAt!.millisecondsSinceEpoch
: this.seenAt!.toUtc().toIso8601String();
} else { } else {
// json[r'seenAt'] = null; // json[r'seenAt'] = null;
} }
@@ -91,8 +95,8 @@ class MemoryUpdateDto {
return MemoryUpdateDto( return MemoryUpdateDto(
isSaved: mapValueOfType<bool>(json, r'isSaved'), isSaved: mapValueOfType<bool>(json, r'isSaved'),
memoryAt: mapDateTime(json, r'memoryAt', r''), memoryAt: mapDateTime(json, r'memoryAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
seenAt: mapDateTime(json, r'seenAt', r''), seenAt: mapDateTime(json, r'seenAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
); );
} }
return null; return null;

View File

@@ -34,7 +34,7 @@ class MetadataSearchDto {
this.make, this.make,
this.model, this.model,
this.ocr, this.ocr,
this.order = AssetOrder.desc, this.order,
this.originalFileName, this.originalFileName,
this.originalPath, this.originalPath,
this.page, this.page,
@@ -71,10 +71,8 @@ class MetadataSearchDto {
/// ///
String? checksum; String? checksum;
/// Filter by city name
String? city; String? city;
/// Filter by country name
String? country; String? country;
/// Filter by creation date (after) /// Filter by creation date (after)
@@ -185,22 +183,12 @@ class MetadataSearchDto {
/// ///
bool? isOffline; bool? isOffline;
/// Filter by lens model
String? lensModel; String? lensModel;
/// Library ID to filter by
String? libraryId; String? libraryId;
/// Filter by camera make
///
/// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated
/// source code must fall back to having a nullable type.
/// Consider adding a "default:" property in the specification file to hide this note.
///
String? make; String? make;
/// Filter by camera model
String? model; String? model;
/// Filter by OCR text content /// Filter by OCR text content
@@ -212,8 +200,13 @@ class MetadataSearchDto {
/// ///
String? ocr; String? ocr;
/// Sort order ///
AssetOrder order; /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated
/// source code must fall back to having a nullable type.
/// Consider adding a "default:" property in the specification file to hide this note.
///
AssetOrder? order;
/// Filter by original file name /// Filter by original file name
/// ///
@@ -256,8 +249,6 @@ class MetadataSearchDto {
/// ///
String? previewPath; String? previewPath;
/// Filter by rating [1-5], or null for unrated
///
/// Minimum value: -1 /// Minimum value: -1
/// Maximum value: 5 /// Maximum value: 5
num? rating; num? rating;
@@ -274,10 +265,8 @@ class MetadataSearchDto {
/// ///
num? size; num? size;
/// Filter by state/province name
String? state; String? state;
/// Filter by tag IDs
List<String>? tagIds; List<String>? tagIds;
/// Filter by taken date (after) /// Filter by taken date (after)
@@ -325,7 +314,6 @@ class MetadataSearchDto {
/// ///
DateTime? trashedBefore; DateTime? trashedBefore;
/// Asset type filter
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated
@@ -352,7 +340,6 @@ class MetadataSearchDto {
/// ///
DateTime? updatedBefore; DateTime? updatedBefore;
/// Filter by visibility
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated
@@ -468,7 +455,7 @@ class MetadataSearchDto {
(make == null ? 0 : make!.hashCode) + (make == null ? 0 : make!.hashCode) +
(model == null ? 0 : model!.hashCode) + (model == null ? 0 : model!.hashCode) +
(ocr == null ? 0 : ocr!.hashCode) + (ocr == null ? 0 : ocr!.hashCode) +
(order.hashCode) + (order == null ? 0 : order!.hashCode) +
(originalFileName == null ? 0 : originalFileName!.hashCode) + (originalFileName == null ? 0 : originalFileName!.hashCode) +
(originalPath == null ? 0 : originalPath!.hashCode) + (originalPath == null ? 0 : originalPath!.hashCode) +
(page == null ? 0 : page!.hashCode) + (page == null ? 0 : page!.hashCode) +
@@ -514,12 +501,16 @@ class MetadataSearchDto {
// json[r'country'] = null; // json[r'country'] = null;
} }
if (this.createdAfter != null) { if (this.createdAfter != null) {
json[r'createdAfter'] = this.createdAfter!.toUtc().toIso8601String(); json[r'createdAfter'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.createdAfter!.millisecondsSinceEpoch
: this.createdAfter!.toUtc().toIso8601String();
} else { } else {
// json[r'createdAfter'] = null; // json[r'createdAfter'] = null;
} }
if (this.createdBefore != null) { if (this.createdBefore != null) {
json[r'createdBefore'] = this.createdBefore!.toUtc().toIso8601String(); json[r'createdBefore'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.createdBefore!.millisecondsSinceEpoch
: this.createdBefore!.toUtc().toIso8601String();
} else { } else {
// json[r'createdBefore'] = null; // json[r'createdBefore'] = null;
} }
@@ -598,7 +589,11 @@ class MetadataSearchDto {
} else { } else {
// json[r'ocr'] = null; // json[r'ocr'] = null;
} }
if (this.order != null) {
json[r'order'] = this.order; json[r'order'] = this.order;
} else {
// json[r'order'] = null;
}
if (this.originalFileName != null) { if (this.originalFileName != null) {
json[r'originalFileName'] = this.originalFileName; json[r'originalFileName'] = this.originalFileName;
} else { } else {
@@ -641,12 +636,16 @@ class MetadataSearchDto {
// json[r'tagIds'] = null; // json[r'tagIds'] = null;
} }
if (this.takenAfter != null) { if (this.takenAfter != null) {
json[r'takenAfter'] = this.takenAfter!.toUtc().toIso8601String(); json[r'takenAfter'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.takenAfter!.millisecondsSinceEpoch
: this.takenAfter!.toUtc().toIso8601String();
} else { } else {
// json[r'takenAfter'] = null; // json[r'takenAfter'] = null;
} }
if (this.takenBefore != null) { if (this.takenBefore != null) {
json[r'takenBefore'] = this.takenBefore!.toUtc().toIso8601String(); json[r'takenBefore'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.takenBefore!.millisecondsSinceEpoch
: this.takenBefore!.toUtc().toIso8601String();
} else { } else {
// json[r'takenBefore'] = null; // json[r'takenBefore'] = null;
} }
@@ -656,12 +655,16 @@ class MetadataSearchDto {
// json[r'thumbnailPath'] = null; // json[r'thumbnailPath'] = null;
} }
if (this.trashedAfter != null) { if (this.trashedAfter != null) {
json[r'trashedAfter'] = this.trashedAfter!.toUtc().toIso8601String(); json[r'trashedAfter'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.trashedAfter!.millisecondsSinceEpoch
: this.trashedAfter!.toUtc().toIso8601String();
} else { } else {
// json[r'trashedAfter'] = null; // json[r'trashedAfter'] = null;
} }
if (this.trashedBefore != null) { if (this.trashedBefore != null) {
json[r'trashedBefore'] = this.trashedBefore!.toUtc().toIso8601String(); json[r'trashedBefore'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.trashedBefore!.millisecondsSinceEpoch
: this.trashedBefore!.toUtc().toIso8601String();
} else { } else {
// json[r'trashedBefore'] = null; // json[r'trashedBefore'] = null;
} }
@@ -671,12 +674,16 @@ class MetadataSearchDto {
// json[r'type'] = null; // json[r'type'] = null;
} }
if (this.updatedAfter != null) { if (this.updatedAfter != null) {
json[r'updatedAfter'] = this.updatedAfter!.toUtc().toIso8601String(); json[r'updatedAfter'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.updatedAfter!.millisecondsSinceEpoch
: this.updatedAfter!.toUtc().toIso8601String();
} else { } else {
// json[r'updatedAfter'] = null; // json[r'updatedAfter'] = null;
} }
if (this.updatedBefore != null) { if (this.updatedBefore != null) {
json[r'updatedBefore'] = this.updatedBefore!.toUtc().toIso8601String(); json[r'updatedBefore'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.updatedBefore!.millisecondsSinceEpoch
: this.updatedBefore!.toUtc().toIso8601String();
} else { } else {
// json[r'updatedBefore'] = null; // json[r'updatedBefore'] = null;
} }
@@ -723,8 +730,8 @@ class MetadataSearchDto {
checksum: mapValueOfType<String>(json, r'checksum'), checksum: mapValueOfType<String>(json, r'checksum'),
city: mapValueOfType<String>(json, r'city'), city: mapValueOfType<String>(json, r'city'),
country: mapValueOfType<String>(json, r'country'), country: mapValueOfType<String>(json, r'country'),
createdAfter: mapDateTime(json, r'createdAfter', r''), createdAfter: mapDateTime(json, r'createdAfter', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
createdBefore: mapDateTime(json, r'createdBefore', r''), createdBefore: mapDateTime(json, r'createdBefore', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
description: mapValueOfType<String>(json, r'description'), description: mapValueOfType<String>(json, r'description'),
deviceAssetId: mapValueOfType<String>(json, r'deviceAssetId'), deviceAssetId: mapValueOfType<String>(json, r'deviceAssetId'),
deviceId: mapValueOfType<String>(json, r'deviceId'), deviceId: mapValueOfType<String>(json, r'deviceId'),
@@ -740,7 +747,7 @@ class MetadataSearchDto {
make: mapValueOfType<String>(json, r'make'), make: mapValueOfType<String>(json, r'make'),
model: mapValueOfType<String>(json, r'model'), model: mapValueOfType<String>(json, r'model'),
ocr: mapValueOfType<String>(json, r'ocr'), ocr: mapValueOfType<String>(json, r'ocr'),
order: AssetOrder.fromJson(json[r'order']) ?? AssetOrder.desc, order: AssetOrder.fromJson(json[r'order']),
originalFileName: mapValueOfType<String>(json, r'originalFileName'), originalFileName: mapValueOfType<String>(json, r'originalFileName'),
originalPath: mapValueOfType<String>(json, r'originalPath'), originalPath: mapValueOfType<String>(json, r'originalPath'),
page: num.parse('${json[r'page']}'), page: num.parse('${json[r'page']}'),
@@ -756,14 +763,14 @@ class MetadataSearchDto {
tagIds: json[r'tagIds'] is Iterable tagIds: json[r'tagIds'] is Iterable
? (json[r'tagIds'] as Iterable).cast<String>().toList(growable: false) ? (json[r'tagIds'] as Iterable).cast<String>().toList(growable: false)
: const [], : const [],
takenAfter: mapDateTime(json, r'takenAfter', r''), takenAfter: mapDateTime(json, r'takenAfter', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
takenBefore: mapDateTime(json, r'takenBefore', r''), takenBefore: mapDateTime(json, r'takenBefore', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
thumbnailPath: mapValueOfType<String>(json, r'thumbnailPath'), thumbnailPath: mapValueOfType<String>(json, r'thumbnailPath'),
trashedAfter: mapDateTime(json, r'trashedAfter', r''), trashedAfter: mapDateTime(json, r'trashedAfter', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
trashedBefore: mapDateTime(json, r'trashedBefore', r''), trashedBefore: mapDateTime(json, r'trashedBefore', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
type: AssetTypeEnum.fromJson(json[r'type']), type: AssetTypeEnum.fromJson(json[r'type']),
updatedAfter: mapDateTime(json, r'updatedAfter', r''), updatedAfter: mapDateTime(json, r'updatedAfter', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
updatedBefore: mapDateTime(json, r'updatedBefore', r''), updatedBefore: mapDateTime(json, r'updatedBefore', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
visibility: AssetVisibility.fromJson(json[r'visibility']), visibility: AssetVisibility.fromJson(json[r'visibility']),
withDeleted: mapValueOfType<bool>(json, r'withDeleted'), withDeleted: mapValueOfType<bool>(json, r'withDeleted'),
withExif: mapValueOfType<bool>(json, r'withExif'), withExif: mapValueOfType<bool>(json, r'withExif'),

View File

@@ -16,7 +16,6 @@ class MirrorParameters {
required this.axis, required this.axis,
}); });
/// Axis to mirror along
MirrorAxis axis; MirrorAxis axis;
@override @override

View File

@@ -13,7 +13,7 @@ part of openapi.api;
class NotificationCreateDto { class NotificationCreateDto {
/// Returns a new [NotificationCreateDto] instance. /// Returns a new [NotificationCreateDto] instance.
NotificationCreateDto({ NotificationCreateDto({
this.data, this.data = const {},
this.description, this.description,
this.level, this.level,
this.readAt, this.readAt,
@@ -23,18 +23,10 @@ class NotificationCreateDto {
}); });
/// Additional notification data /// Additional notification data
/// Map<String, Object> data;
/// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated
/// source code must fall back to having a nullable type.
/// Consider adding a "default:" property in the specification file to hide this note.
///
Object? data;
/// Notification description
String? description; String? description;
/// Notification level
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated
@@ -43,13 +35,11 @@ class NotificationCreateDto {
/// ///
NotificationLevel? level; NotificationLevel? level;
/// Date when notification was read
DateTime? readAt; DateTime? readAt;
/// Notification title /// Notification title
String title; String title;
/// Notification type
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated
@@ -63,7 +53,7 @@ class NotificationCreateDto {
@override @override
bool operator ==(Object other) => identical(this, other) || other is NotificationCreateDto && bool operator ==(Object other) => identical(this, other) || other is NotificationCreateDto &&
other.data == data && _deepEquality.equals(other.data, data) &&
other.description == description && other.description == description &&
other.level == level && other.level == level &&
other.readAt == readAt && other.readAt == readAt &&
@@ -74,7 +64,7 @@ class NotificationCreateDto {
@override @override
int get hashCode => int get hashCode =>
// ignore: unnecessary_parenthesis // ignore: unnecessary_parenthesis
(data == null ? 0 : data!.hashCode) + (data.hashCode) +
(description == null ? 0 : description!.hashCode) + (description == null ? 0 : description!.hashCode) +
(level == null ? 0 : level!.hashCode) + (level == null ? 0 : level!.hashCode) +
(readAt == null ? 0 : readAt!.hashCode) + (readAt == null ? 0 : readAt!.hashCode) +
@@ -87,11 +77,7 @@ class NotificationCreateDto {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
if (this.data != null) {
json[r'data'] = this.data; json[r'data'] = this.data;
} else {
// json[r'data'] = null;
}
if (this.description != null) { if (this.description != null) {
json[r'description'] = this.description; json[r'description'] = this.description;
} else { } else {
@@ -103,7 +89,9 @@ class NotificationCreateDto {
// json[r'level'] = null; // json[r'level'] = null;
} }
if (this.readAt != null) { if (this.readAt != null) {
json[r'readAt'] = this.readAt!.toUtc().toIso8601String(); json[r'readAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.readAt!.millisecondsSinceEpoch
: this.readAt!.toUtc().toIso8601String();
} else { } else {
// json[r'readAt'] = null; // json[r'readAt'] = null;
} }
@@ -126,10 +114,10 @@ class NotificationCreateDto {
final json = value.cast<String, dynamic>(); final json = value.cast<String, dynamic>();
return NotificationCreateDto( return NotificationCreateDto(
data: mapValueOfType<Object>(json, r'data'), data: mapCastOfType<String, Object>(json, r'data') ?? const {},
description: mapValueOfType<String>(json, r'description'), description: mapValueOfType<String>(json, r'description'),
level: NotificationLevel.fromJson(json[r'level']), level: NotificationLevel.fromJson(json[r'level']),
readAt: mapDateTime(json, r'readAt', r''), readAt: mapDateTime(json, r'readAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
title: mapValueOfType<String>(json, r'title')!, title: mapValueOfType<String>(json, r'title')!,
type: NotificationType.fromJson(json[r'type']), type: NotificationType.fromJson(json[r'type']),
userId: mapValueOfType<String>(json, r'userId')!, userId: mapValueOfType<String>(json, r'userId')!,

View File

@@ -14,7 +14,7 @@ class NotificationDto {
/// Returns a new [NotificationDto] instance. /// Returns a new [NotificationDto] instance.
NotificationDto({ NotificationDto({
required this.createdAt, required this.createdAt,
this.data, this.data = const {},
this.description, this.description,
required this.id, required this.id,
required this.level, required this.level,
@@ -27,13 +27,7 @@ class NotificationDto {
DateTime createdAt; DateTime createdAt;
/// Additional notification data /// Additional notification data
/// Map<String, Object> data;
/// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated
/// source code must fall back to having a nullable type.
/// Consider adding a "default:" property in the specification file to hide this note.
///
Object? data;
/// Notification description /// Notification description
/// ///
@@ -47,7 +41,6 @@ class NotificationDto {
/// Notification ID /// Notification ID
String id; String id;
/// Notification level
NotificationLevel level; NotificationLevel level;
/// Date when notification was read /// Date when notification was read
@@ -62,13 +55,12 @@ class NotificationDto {
/// Notification title /// Notification title
String title; String title;
/// Notification type
NotificationType type; NotificationType type;
@override @override
bool operator ==(Object other) => identical(this, other) || other is NotificationDto && bool operator ==(Object other) => identical(this, other) || other is NotificationDto &&
other.createdAt == createdAt && other.createdAt == createdAt &&
other.data == data && _deepEquality.equals(other.data, data) &&
other.description == description && other.description == description &&
other.id == id && other.id == id &&
other.level == level && other.level == level &&
@@ -80,7 +72,7 @@ class NotificationDto {
int get hashCode => int get hashCode =>
// ignore: unnecessary_parenthesis // ignore: unnecessary_parenthesis
(createdAt.hashCode) + (createdAt.hashCode) +
(data == null ? 0 : data!.hashCode) + (data.hashCode) +
(description == null ? 0 : description!.hashCode) + (description == null ? 0 : description!.hashCode) +
(id.hashCode) + (id.hashCode) +
(level.hashCode) + (level.hashCode) +
@@ -93,12 +85,10 @@ class NotificationDto {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
json[r'createdAt'] = this.createdAt.toUtc().toIso8601String(); json[r'createdAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
if (this.data != null) { ? this.createdAt.millisecondsSinceEpoch
: this.createdAt.toUtc().toIso8601String();
json[r'data'] = this.data; json[r'data'] = this.data;
} else {
// json[r'data'] = null;
}
if (this.description != null) { if (this.description != null) {
json[r'description'] = this.description; json[r'description'] = this.description;
} else { } else {
@@ -107,7 +97,9 @@ class NotificationDto {
json[r'id'] = this.id; json[r'id'] = this.id;
json[r'level'] = this.level; json[r'level'] = this.level;
if (this.readAt != null) { if (this.readAt != null) {
json[r'readAt'] = this.readAt!.toUtc().toIso8601String(); json[r'readAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.readAt!.millisecondsSinceEpoch
: this.readAt!.toUtc().toIso8601String();
} else { } else {
// json[r'readAt'] = null; // json[r'readAt'] = null;
} }
@@ -125,12 +117,12 @@ class NotificationDto {
final json = value.cast<String, dynamic>(); final json = value.cast<String, dynamic>();
return NotificationDto( return NotificationDto(
createdAt: mapDateTime(json, r'createdAt', r'')!, createdAt: mapDateTime(json, r'createdAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')!,
data: mapValueOfType<Object>(json, r'data'), data: mapCastOfType<String, Object>(json, r'data') ?? const {},
description: mapValueOfType<String>(json, r'description'), description: mapValueOfType<String>(json, r'description'),
id: mapValueOfType<String>(json, r'id')!, id: mapValueOfType<String>(json, r'id')!,
level: NotificationLevel.fromJson(json[r'level'])!, level: NotificationLevel.fromJson(json[r'level'])!,
readAt: mapDateTime(json, r'readAt', r''), readAt: mapDateTime(json, r'readAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
title: mapValueOfType<String>(json, r'title')!, title: mapValueOfType<String>(json, r'title')!,
type: NotificationType.fromJson(json[r'type'])!, type: NotificationType.fromJson(json[r'type'])!,
); );

View File

@@ -10,7 +10,7 @@
part of openapi.api; part of openapi.api;
/// Notification level
class NotificationLevel { class NotificationLevel {
/// Instantiate a new enum with the provided [value]. /// Instantiate a new enum with the provided [value].
const NotificationLevel._(this.value); const NotificationLevel._(this.value);

View File

@@ -10,7 +10,7 @@
part of openapi.api; part of openapi.api;
/// Notification type
class NotificationType { class NotificationType {
/// Instantiate a new enum with the provided [value]. /// Instantiate a new enum with the provided [value].
const NotificationType._(this.value); const NotificationType._(this.value);

View File

@@ -20,7 +20,6 @@ class NotificationUpdateAllDto {
/// Notification IDs to update /// Notification IDs to update
List<String> ids; List<String> ids;
/// Date when notifications were read
DateTime? readAt; DateTime? readAt;
@override @override
@@ -41,7 +40,9 @@ class NotificationUpdateAllDto {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
json[r'ids'] = this.ids; json[r'ids'] = this.ids;
if (this.readAt != null) { if (this.readAt != null) {
json[r'readAt'] = this.readAt!.toUtc().toIso8601String(); json[r'readAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.readAt!.millisecondsSinceEpoch
: this.readAt!.toUtc().toIso8601String();
} else { } else {
// json[r'readAt'] = null; // json[r'readAt'] = null;
} }
@@ -60,7 +61,7 @@ class NotificationUpdateAllDto {
ids: json[r'ids'] is Iterable ids: json[r'ids'] is Iterable
? (json[r'ids'] as Iterable).cast<String>().toList(growable: false) ? (json[r'ids'] as Iterable).cast<String>().toList(growable: false)
: const [], : const [],
readAt: mapDateTime(json, r'readAt', r''), readAt: mapDateTime(json, r'readAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
); );
} }
return null; return null;

View File

@@ -16,7 +16,6 @@ class NotificationUpdateDto {
this.readAt, this.readAt,
}); });
/// Date when notification was read
DateTime? readAt; DateTime? readAt;
@override @override
@@ -34,7 +33,9 @@ class NotificationUpdateDto {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
if (this.readAt != null) { if (this.readAt != null) {
json[r'readAt'] = this.readAt!.toUtc().toIso8601String(); json[r'readAt'] = _isEpochMarker(r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/')
? this.readAt!.millisecondsSinceEpoch
: this.readAt!.toUtc().toIso8601String();
} else { } else {
// json[r'readAt'] = null; // json[r'readAt'] = null;
} }
@@ -50,7 +51,7 @@ class NotificationUpdateDto {
final json = value.cast<String, dynamic>(); final json = value.cast<String, dynamic>();
return NotificationUpdateDto( return NotificationUpdateDto(
readAt: mapDateTime(json, r'readAt', r''), readAt: mapDateTime(json, r'readAt', r'/^(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))T(?:(?:[01]\\d|2[0-3]):[0-5]\\d(?::[0-5]\\d(?:\\.\\d+)?)?(?:Z))$/'),
); );
} }
return null; return null;

Some files were not shown because too many files have changed in this diff Show More