mirror of
https://github.com/immich-app/immich.git
synced 2025-11-27 16:55:17 -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>
152 lines
4.5 KiB
Dart
Generated
152 lines
4.5 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 PluginActionResponseDto {
|
|
/// Returns a new [PluginActionResponseDto] instance.
|
|
PluginActionResponseDto({
|
|
required this.description,
|
|
required this.id,
|
|
required this.methodName,
|
|
required this.pluginId,
|
|
required this.schema,
|
|
this.supportedContexts = const [],
|
|
required this.title,
|
|
});
|
|
|
|
String description;
|
|
|
|
String id;
|
|
|
|
String methodName;
|
|
|
|
String pluginId;
|
|
|
|
Object? schema;
|
|
|
|
List<PluginContext> supportedContexts;
|
|
|
|
String title;
|
|
|
|
@override
|
|
bool operator ==(Object other) => identical(this, other) || other is PluginActionResponseDto &&
|
|
other.description == description &&
|
|
other.id == id &&
|
|
other.methodName == methodName &&
|
|
other.pluginId == pluginId &&
|
|
other.schema == schema &&
|
|
_deepEquality.equals(other.supportedContexts, supportedContexts) &&
|
|
other.title == title;
|
|
|
|
@override
|
|
int get hashCode =>
|
|
// ignore: unnecessary_parenthesis
|
|
(description.hashCode) +
|
|
(id.hashCode) +
|
|
(methodName.hashCode) +
|
|
(pluginId.hashCode) +
|
|
(schema == null ? 0 : schema!.hashCode) +
|
|
(supportedContexts.hashCode) +
|
|
(title.hashCode);
|
|
|
|
@override
|
|
String toString() => 'PluginActionResponseDto[description=$description, id=$id, methodName=$methodName, pluginId=$pluginId, schema=$schema, supportedContexts=$supportedContexts, title=$title]';
|
|
|
|
Map<String, dynamic> toJson() {
|
|
final json = <String, dynamic>{};
|
|
json[r'description'] = this.description;
|
|
json[r'id'] = this.id;
|
|
json[r'methodName'] = this.methodName;
|
|
json[r'pluginId'] = this.pluginId;
|
|
if (this.schema != null) {
|
|
json[r'schema'] = this.schema;
|
|
} else {
|
|
// json[r'schema'] = null;
|
|
}
|
|
json[r'supportedContexts'] = this.supportedContexts;
|
|
json[r'title'] = this.title;
|
|
return json;
|
|
}
|
|
|
|
/// Returns a new [PluginActionResponseDto] instance and imports its values from
|
|
/// [value] if it's a [Map], null otherwise.
|
|
// ignore: prefer_constructors_over_static_methods
|
|
static PluginActionResponseDto? fromJson(dynamic value) {
|
|
upgradeDto(value, "PluginActionResponseDto");
|
|
if (value is Map) {
|
|
final json = value.cast<String, dynamic>();
|
|
|
|
return PluginActionResponseDto(
|
|
description: mapValueOfType<String>(json, r'description')!,
|
|
id: mapValueOfType<String>(json, r'id')!,
|
|
methodName: mapValueOfType<String>(json, r'methodName')!,
|
|
pluginId: mapValueOfType<String>(json, r'pluginId')!,
|
|
schema: mapValueOfType<Object>(json, r'schema'),
|
|
supportedContexts: PluginContext.listFromJson(json[r'supportedContexts']),
|
|
title: mapValueOfType<String>(json, r'title')!,
|
|
);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
static List<PluginActionResponseDto> listFromJson(dynamic json, {bool growable = false,}) {
|
|
final result = <PluginActionResponseDto>[];
|
|
if (json is List && json.isNotEmpty) {
|
|
for (final row in json) {
|
|
final value = PluginActionResponseDto.fromJson(row);
|
|
if (value != null) {
|
|
result.add(value);
|
|
}
|
|
}
|
|
}
|
|
return result.toList(growable: growable);
|
|
}
|
|
|
|
static Map<String, PluginActionResponseDto> mapFromJson(dynamic json) {
|
|
final map = <String, PluginActionResponseDto>{};
|
|
if (json is Map && json.isNotEmpty) {
|
|
json = json.cast<String, dynamic>(); // ignore: parameter_assignments
|
|
for (final entry in json.entries) {
|
|
final value = PluginActionResponseDto.fromJson(entry.value);
|
|
if (value != null) {
|
|
map[entry.key] = value;
|
|
}
|
|
}
|
|
}
|
|
return map;
|
|
}
|
|
|
|
// maps a json object with a list of PluginActionResponseDto-objects as value to a dart map
|
|
static Map<String, List<PluginActionResponseDto>> mapListFromJson(dynamic json, {bool growable = false,}) {
|
|
final map = <String, List<PluginActionResponseDto>>{};
|
|
if (json is Map && json.isNotEmpty) {
|
|
// ignore: parameter_assignments
|
|
json = json.cast<String, dynamic>();
|
|
for (final entry in json.entries) {
|
|
map[entry.key] = PluginActionResponseDto.listFromJson(entry.value, growable: growable,);
|
|
}
|
|
}
|
|
return map;
|
|
}
|
|
|
|
/// The list of required keys that must be present in a JSON.
|
|
static const requiredKeys = <String>{
|
|
'description',
|
|
'id',
|
|
'methodName',
|
|
'pluginId',
|
|
'schema',
|
|
'supportedContexts',
|
|
'title',
|
|
};
|
|
}
|
|
|