mirror of
https://github.com/immich-app/immich.git
synced 2025-11-27 00:35:16 -05:00
* feat: plugins * feat: table definition * feat: type and migration * feat: add repositories * feat: validate manifest with class-validator and load manifest info to database * feat: workflow/plugin controller/service layer * feat: implement workflow logic * feat: make trigger static * feat: dynamical instantiate plugin instances * fix: access control and helper script * feat: it works * chore: simplify * refactor: refactor and use queue for workflow execution * refactor: remove unsused property in plugin-schema * build wasm in prod * feat: plugin loader in transaction * fix: docker build arm64 * generated files * shell check * fix tests * fix: waiting for migration to finish before loading plugin * remove context reassignment * feat: use mise to manage extism tools (#23760) * pr feedback * refactor: create workflow now including create filters and actions * feat: workflow medium tests * fix: broken medium test * feat: medium tests * chore: unify workflow job * sign user id with jwt * chore: query plugin with filters and action * chore: read manifest in repository * chore: load manifest from server configs * merge main * feat: endpoint documentation * pr feedback * load plugin from absolute path * refactor:handle trigger * throw error and return early * pr feedback * unify plugin services * fix: plugins code * clean up * remove triggerConfig * clean up * displayName and methodName --------- Co-authored-by: Jason Rasmussen <jason@rasm.me> Co-authored-by: bo0tzz <git@bo0tzz.me>
172 lines
4.9 KiB
Dart
Generated
172 lines
4.9 KiB
Dart
Generated
//
|
|
// 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 PluginResponseDto {
|
|
/// Returns a new [PluginResponseDto] instance.
|
|
PluginResponseDto({
|
|
this.actions = const [],
|
|
required this.author,
|
|
required this.createdAt,
|
|
required this.description,
|
|
this.filters = const [],
|
|
required this.id,
|
|
required this.name,
|
|
required this.title,
|
|
required this.updatedAt,
|
|
required this.version,
|
|
});
|
|
|
|
List<PluginActionResponseDto> actions;
|
|
|
|
String author;
|
|
|
|
String createdAt;
|
|
|
|
String description;
|
|
|
|
List<PluginFilterResponseDto> filters;
|
|
|
|
String id;
|
|
|
|
String name;
|
|
|
|
String title;
|
|
|
|
String updatedAt;
|
|
|
|
String version;
|
|
|
|
@override
|
|
bool operator ==(Object other) => identical(this, other) || other is PluginResponseDto &&
|
|
_deepEquality.equals(other.actions, actions) &&
|
|
other.author == author &&
|
|
other.createdAt == createdAt &&
|
|
other.description == description &&
|
|
_deepEquality.equals(other.filters, filters) &&
|
|
other.id == id &&
|
|
other.name == name &&
|
|
other.title == title &&
|
|
other.updatedAt == updatedAt &&
|
|
other.version == version;
|
|
|
|
@override
|
|
int get hashCode =>
|
|
// ignore: unnecessary_parenthesis
|
|
(actions.hashCode) +
|
|
(author.hashCode) +
|
|
(createdAt.hashCode) +
|
|
(description.hashCode) +
|
|
(filters.hashCode) +
|
|
(id.hashCode) +
|
|
(name.hashCode) +
|
|
(title.hashCode) +
|
|
(updatedAt.hashCode) +
|
|
(version.hashCode);
|
|
|
|
@override
|
|
String toString() => 'PluginResponseDto[actions=$actions, author=$author, createdAt=$createdAt, description=$description, filters=$filters, id=$id, name=$name, title=$title, updatedAt=$updatedAt, version=$version]';
|
|
|
|
Map<String, dynamic> toJson() {
|
|
final json = <String, dynamic>{};
|
|
json[r'actions'] = this.actions;
|
|
json[r'author'] = this.author;
|
|
json[r'createdAt'] = this.createdAt;
|
|
json[r'description'] = this.description;
|
|
json[r'filters'] = this.filters;
|
|
json[r'id'] = this.id;
|
|
json[r'name'] = this.name;
|
|
json[r'title'] = this.title;
|
|
json[r'updatedAt'] = this.updatedAt;
|
|
json[r'version'] = this.version;
|
|
return json;
|
|
}
|
|
|
|
/// Returns a new [PluginResponseDto] instance and imports its values from
|
|
/// [value] if it's a [Map], null otherwise.
|
|
// ignore: prefer_constructors_over_static_methods
|
|
static PluginResponseDto? fromJson(dynamic value) {
|
|
upgradeDto(value, "PluginResponseDto");
|
|
if (value is Map) {
|
|
final json = value.cast<String, dynamic>();
|
|
|
|
return PluginResponseDto(
|
|
actions: PluginActionResponseDto.listFromJson(json[r'actions']),
|
|
author: mapValueOfType<String>(json, r'author')!,
|
|
createdAt: mapValueOfType<String>(json, r'createdAt')!,
|
|
description: mapValueOfType<String>(json, r'description')!,
|
|
filters: PluginFilterResponseDto.listFromJson(json[r'filters']),
|
|
id: mapValueOfType<String>(json, r'id')!,
|
|
name: mapValueOfType<String>(json, r'name')!,
|
|
title: mapValueOfType<String>(json, r'title')!,
|
|
updatedAt: mapValueOfType<String>(json, r'updatedAt')!,
|
|
version: mapValueOfType<String>(json, r'version')!,
|
|
);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
static List<PluginResponseDto> listFromJson(dynamic json, {bool growable = false,}) {
|
|
final result = <PluginResponseDto>[];
|
|
if (json is List && json.isNotEmpty) {
|
|
for (final row in json) {
|
|
final value = PluginResponseDto.fromJson(row);
|
|
if (value != null) {
|
|
result.add(value);
|
|
}
|
|
}
|
|
}
|
|
return result.toList(growable: growable);
|
|
}
|
|
|
|
static Map<String, PluginResponseDto> mapFromJson(dynamic json) {
|
|
final map = <String, PluginResponseDto>{};
|
|
if (json is Map && json.isNotEmpty) {
|
|
json = json.cast<String, dynamic>(); // ignore: parameter_assignments
|
|
for (final entry in json.entries) {
|
|
final value = PluginResponseDto.fromJson(entry.value);
|
|
if (value != null) {
|
|
map[entry.key] = value;
|
|
}
|
|
}
|
|
}
|
|
return map;
|
|
}
|
|
|
|
// maps a json object with a list of PluginResponseDto-objects as value to a dart map
|
|
static Map<String, List<PluginResponseDto>> mapListFromJson(dynamic json, {bool growable = false,}) {
|
|
final map = <String, List<PluginResponseDto>>{};
|
|
if (json is Map && json.isNotEmpty) {
|
|
// ignore: parameter_assignments
|
|
json = json.cast<String, dynamic>();
|
|
for (final entry in json.entries) {
|
|
map[entry.key] = PluginResponseDto.listFromJson(entry.value, growable: growable,);
|
|
}
|
|
}
|
|
return map;
|
|
}
|
|
|
|
/// The list of required keys that must be present in a JSON.
|
|
static const requiredKeys = <String>{
|
|
'actions',
|
|
'author',
|
|
'createdAt',
|
|
'description',
|
|
'filters',
|
|
'id',
|
|
'name',
|
|
'title',
|
|
'updatedAt',
|
|
'version',
|
|
};
|
|
}
|
|
|