// // 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 Device { /// Returns a new [Device] instance. Device({ required this.id, required this.configurationId, required this.connected, required this.instanceId, this.identifier, this.name, this.ipAddressWLAN, this.ipAddressETH, this.configuration, this.dateCreation, this.dateUpdate, this.batteryLevel, this.lastBatteryLevel, this.connectionLevel, this.lastConnectionLevel, }); String id; String configurationId; bool connected; String instanceId; String? identifier; String? name; String? ipAddressWLAN; String? ipAddressETH; AppConfigurationLinkConfiguration? configuration; /// /// 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. /// DateTime? dateCreation; /// /// 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. /// DateTime? dateUpdate; String? batteryLevel; /// /// 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. /// DateTime? lastBatteryLevel; String? connectionLevel; /// /// 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. /// DateTime? lastConnectionLevel; @override bool operator ==(Object other) => identical(this, other) || other is Device && other.id == id && other.configurationId == configurationId && other.connected == connected && other.instanceId == instanceId && other.identifier == identifier && other.name == name && other.ipAddressWLAN == ipAddressWLAN && other.ipAddressETH == ipAddressETH && other.configuration == configuration && other.dateCreation == dateCreation && other.dateUpdate == dateUpdate && other.batteryLevel == batteryLevel && other.lastBatteryLevel == lastBatteryLevel && other.connectionLevel == connectionLevel && other.lastConnectionLevel == lastConnectionLevel; @override int get hashCode => // ignore: unnecessary_parenthesis (id.hashCode) + (configurationId.hashCode) + (connected.hashCode) + (instanceId.hashCode) + (identifier == null ? 0 : identifier!.hashCode) + (name == null ? 0 : name!.hashCode) + (ipAddressWLAN == null ? 0 : ipAddressWLAN!.hashCode) + (ipAddressETH == null ? 0 : ipAddressETH!.hashCode) + (configuration == null ? 0 : configuration!.hashCode) + (dateCreation == null ? 0 : dateCreation!.hashCode) + (dateUpdate == null ? 0 : dateUpdate!.hashCode) + (batteryLevel == null ? 0 : batteryLevel!.hashCode) + (lastBatteryLevel == null ? 0 : lastBatteryLevel!.hashCode) + (connectionLevel == null ? 0 : connectionLevel!.hashCode) + (lastConnectionLevel == null ? 0 : lastConnectionLevel!.hashCode); @override String toString() => 'Device[id=$id, configurationId=$configurationId, connected=$connected, instanceId=$instanceId, identifier=$identifier, name=$name, ipAddressWLAN=$ipAddressWLAN, ipAddressETH=$ipAddressETH, configuration=$configuration, dateCreation=$dateCreation, dateUpdate=$dateUpdate, batteryLevel=$batteryLevel, lastBatteryLevel=$lastBatteryLevel, connectionLevel=$connectionLevel, lastConnectionLevel=$lastConnectionLevel]'; Map toJson() { final json = {}; json[r'id'] = this.id; json[r'configurationId'] = this.configurationId; json[r'connected'] = this.connected; json[r'instanceId'] = this.instanceId; if (this.identifier != null) { json[r'identifier'] = this.identifier; } else { json[r'identifier'] = null; } if (this.name != null) { json[r'name'] = this.name; } else { json[r'name'] = null; } if (this.ipAddressWLAN != null) { json[r'ipAddressWLAN'] = this.ipAddressWLAN; } else { json[r'ipAddressWLAN'] = null; } if (this.ipAddressETH != null) { json[r'ipAddressETH'] = this.ipAddressETH; } else { json[r'ipAddressETH'] = null; } if (this.configuration != null) { json[r'configuration'] = this.configuration; } else { json[r'configuration'] = null; } if (this.dateCreation != null) { json[r'dateCreation'] = this.dateCreation!.toUtc().toIso8601String(); } else { json[r'dateCreation'] = null; } if (this.dateUpdate != null) { json[r'dateUpdate'] = this.dateUpdate!.toUtc().toIso8601String(); } else { json[r'dateUpdate'] = null; } if (this.batteryLevel != null) { json[r'batteryLevel'] = this.batteryLevel; } else { json[r'batteryLevel'] = null; } if (this.lastBatteryLevel != null) { json[r'lastBatteryLevel'] = this.lastBatteryLevel!.toUtc().toIso8601String(); } else { json[r'lastBatteryLevel'] = null; } if (this.connectionLevel != null) { json[r'connectionLevel'] = this.connectionLevel; } else { json[r'connectionLevel'] = null; } if (this.lastConnectionLevel != null) { json[r'lastConnectionLevel'] = this.lastConnectionLevel!.toUtc().toIso8601String(); } else { json[r'lastConnectionLevel'] = null; } return json; } /// Returns a new [Device] instance and imports its values from /// [value] if it's a [Map], null otherwise. // ignore: prefer_constructors_over_static_methods static Device? fromJson(dynamic value) { if (value is Map) { final json = value.cast(); // Ensure that the map contains the required keys. // Note 1: the values aren't checked for validity beyond being non-null. // Note 2: this code is stripped in release mode! assert(() { requiredKeys.forEach((key) { assert(json.containsKey(key), 'Required key "Device[$key]" is missing from JSON.'); assert(json[key] != null, 'Required key "Device[$key]" has a null value in JSON.'); }); return true; }()); return Device( id: mapValueOfType(json, r'id')!, configurationId: mapValueOfType(json, r'configurationId')!, connected: mapValueOfType(json, r'connected')!, instanceId: mapValueOfType(json, r'instanceId')!, identifier: mapValueOfType(json, r'identifier'), name: mapValueOfType(json, r'name'), ipAddressWLAN: mapValueOfType(json, r'ipAddressWLAN'), ipAddressETH: mapValueOfType(json, r'ipAddressETH'), configuration: AppConfigurationLinkConfiguration.fromJson(json[r'configuration']), dateCreation: mapDateTime(json, r'dateCreation', r''), dateUpdate: mapDateTime(json, r'dateUpdate', r''), batteryLevel: mapValueOfType(json, r'batteryLevel'), lastBatteryLevel: mapDateTime(json, r'lastBatteryLevel', r''), connectionLevel: mapValueOfType(json, r'connectionLevel'), lastConnectionLevel: mapDateTime(json, r'lastConnectionLevel', r''), ); } return null; } static List listFromJson( dynamic json, { bool growable = false, }) { final result = []; if (json is List && json.isNotEmpty) { for (final row in json) { final value = Device.fromJson(row); if (value != null) { result.add(value); } } } return result.toList(growable: growable); } static Map mapFromJson(dynamic json) { final map = {}; if (json is Map && json.isNotEmpty) { json = json.cast(); // ignore: parameter_assignments for (final entry in json.entries) { final value = Device.fromJson(entry.value); if (value != null) { map[entry.key] = value; } } } return map; } // maps a json object with a list of Device-objects as value to a dart map static Map> mapListFromJson( dynamic json, { bool growable = false, }) { final map = >{}; if (json is Map && json.isNotEmpty) { // ignore: parameter_assignments json = json.cast(); for (final entry in json.entries) { map[entry.key] = Device.listFromJson( entry.value, growable: growable, ); } } return map; } /// The list of required keys that must be present in a JSON. static const requiredKeys = { 'id', 'configurationId', 'connected', 'instanceId', }; }