api_client.dart 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331
  1. //
  2. // AUTO-GENERATED FILE, DO NOT MODIFY!
  3. //
  4. // @dart=2.12
  5. // ignore_for_file: unused_element, unused_import
  6. // ignore_for_file: always_put_required_named_parameters_first
  7. // ignore_for_file: constant_identifier_names
  8. // ignore_for_file: lines_longer_than_80_chars
  9. part of openapi.api;
  10. class ApiClient {
  11. ApiClient({this.basePath = '/api', this.authentication});
  12. final String basePath;
  13. var _client = Client();
  14. /// Returns the current HTTP [Client] instance to use in this class.
  15. ///
  16. /// The return value is guaranteed to never be null.
  17. Client get client => _client;
  18. /// Requests to use a new HTTP [Client] in this class.
  19. set client(Client newClient) {
  20. _client = newClient;
  21. }
  22. final _defaultHeaderMap = <String, String>{};
  23. final Authentication? authentication;
  24. void addDefaultHeader(String key, String value) {
  25. _defaultHeaderMap[key] = value;
  26. }
  27. Map<String,String> get defaultHeaderMap => _defaultHeaderMap;
  28. // We don't use a Map<String, String> for queryParams.
  29. // If collectionFormat is 'multi', a key might appear multiple times.
  30. Future<Response> invokeAPI(
  31. String path,
  32. String method,
  33. List<QueryParam> queryParams,
  34. Object? body,
  35. Map<String, String> headerParams,
  36. Map<String, String> formParams,
  37. String? contentType,
  38. ) async {
  39. _updateParamsForAuth(queryParams, headerParams);
  40. headerParams.addAll(_defaultHeaderMap);
  41. if (contentType != null) {
  42. headerParams['Content-Type'] = contentType;
  43. }
  44. final urlEncodedQueryParams = queryParams.map((param) => '$param');
  45. final queryString = urlEncodedQueryParams.isNotEmpty ? '?${urlEncodedQueryParams.join('&')}' : '';
  46. final uri = Uri.parse('$basePath$path$queryString');
  47. try {
  48. // Special case for uploading a single file which isn't a 'multipart/form-data'.
  49. if (
  50. body is MultipartFile && (contentType == null ||
  51. !contentType.toLowerCase().startsWith('multipart/form-data'))
  52. ) {
  53. final request = StreamedRequest(method, uri);
  54. request.headers.addAll(headerParams);
  55. request.contentLength = body.length;
  56. body.finalize().listen(
  57. request.sink.add,
  58. onDone: request.sink.close,
  59. // ignore: avoid_types_on_closure_parameters
  60. onError: (Object error, StackTrace trace) => request.sink.close(),
  61. cancelOnError: true,
  62. );
  63. final response = await _client.send(request);
  64. return Response.fromStream(response);
  65. }
  66. if (body is MultipartRequest) {
  67. final request = MultipartRequest(method, uri);
  68. request.fields.addAll(body.fields);
  69. request.files.addAll(body.files);
  70. request.headers.addAll(body.headers);
  71. request.headers.addAll(headerParams);
  72. final response = await _client.send(request);
  73. return Response.fromStream(response);
  74. }
  75. final msgBody = contentType == 'application/x-www-form-urlencoded'
  76. ? formParams
  77. : await serializeAsync(body);
  78. final nullableHeaderParams = headerParams.isEmpty ? null : headerParams;
  79. switch(method) {
  80. case 'POST': return await _client.post(uri, headers: nullableHeaderParams, body: msgBody,);
  81. case 'PUT': return await _client.put(uri, headers: nullableHeaderParams, body: msgBody,);
  82. case 'DELETE': return await _client.delete(uri, headers: nullableHeaderParams, body: msgBody,);
  83. case 'PATCH': return await _client.patch(uri, headers: nullableHeaderParams, body: msgBody,);
  84. case 'HEAD': return await _client.head(uri, headers: nullableHeaderParams,);
  85. case 'GET': return await _client.get(uri, headers: nullableHeaderParams,);
  86. }
  87. } on SocketException catch (error, trace) {
  88. throw ApiException.withInner(
  89. HttpStatus.badRequest,
  90. 'Socket operation failed: $method $path',
  91. error,
  92. trace,
  93. );
  94. } on TlsException catch (error, trace) {
  95. throw ApiException.withInner(
  96. HttpStatus.badRequest,
  97. 'TLS/SSL communication failed: $method $path',
  98. error,
  99. trace,
  100. );
  101. } on IOException catch (error, trace) {
  102. throw ApiException.withInner(
  103. HttpStatus.badRequest,
  104. 'I/O operation failed: $method $path',
  105. error,
  106. trace,
  107. );
  108. } on ClientException catch (error, trace) {
  109. throw ApiException.withInner(
  110. HttpStatus.badRequest,
  111. 'HTTP connection failed: $method $path',
  112. error,
  113. trace,
  114. );
  115. } on Exception catch (error, trace) {
  116. throw ApiException.withInner(
  117. HttpStatus.badRequest,
  118. 'Exception occurred: $method $path',
  119. error,
  120. trace,
  121. );
  122. }
  123. throw ApiException(
  124. HttpStatus.badRequest,
  125. 'Invalid HTTP operation: $method $path',
  126. );
  127. }
  128. Future<dynamic> deserializeAsync(String json, String targetType, {bool growable = false,}) async =>
  129. // ignore: deprecated_member_use_from_same_package
  130. deserialize(json, targetType, growable: growable);
  131. @Deprecated('Scheduled for removal in OpenAPI Generator 6.x. Use deserializeAsync() instead.')
  132. dynamic deserialize(String json, String targetType, {bool growable = false,}) {
  133. // Remove all spaces. Necessary for regular expressions as well.
  134. targetType = targetType.replaceAll(' ', ''); // ignore: parameter_assignments
  135. // If the expected target type is String, nothing to do...
  136. return targetType == 'String'
  137. ? json
  138. : _deserialize(jsonDecode(json), targetType, growable: growable);
  139. }
  140. // ignore: deprecated_member_use_from_same_package
  141. Future<String> serializeAsync(Object? value) async => serialize(value);
  142. @Deprecated('Scheduled for removal in OpenAPI Generator 6.x. Use serializeAsync() instead.')
  143. String serialize(Object? value) => value == null ? '' : json.encode(value);
  144. /// Update query and header parameters based on authentication settings.
  145. void _updateParamsForAuth(
  146. List<QueryParam> queryParams,
  147. Map<String, String> headerParams,
  148. ) {
  149. if (authentication != null) {
  150. authentication!.applyToParams(queryParams, headerParams);
  151. }
  152. }
  153. static dynamic _deserialize(dynamic value, String targetType, {bool growable = false}) {
  154. try {
  155. switch (targetType) {
  156. case 'String':
  157. return value is String ? value : value.toString();
  158. case 'int':
  159. return value is int ? value : int.parse('$value');
  160. case 'double':
  161. return value is double ? value : double.parse('$value');
  162. case 'bool':
  163. if (value is bool) {
  164. return value;
  165. }
  166. final valueString = '$value'.toLowerCase();
  167. return valueString == 'true' || valueString == '1';
  168. case 'DateTime':
  169. return value is DateTime ? value : DateTime.tryParse(value);
  170. case 'AddAssetsDto':
  171. return AddAssetsDto.fromJson(value);
  172. case 'AddUsersDto':
  173. return AddUsersDto.fromJson(value);
  174. case 'AdminSignupResponseDto':
  175. return AdminSignupResponseDto.fromJson(value);
  176. case 'AlbumResponseDto':
  177. return AlbumResponseDto.fromJson(value);
  178. case 'AssetFileUploadResponseDto':
  179. return AssetFileUploadResponseDto.fromJson(value);
  180. case 'AssetResponseDto':
  181. return AssetResponseDto.fromJson(value);
  182. case 'AssetTypeEnum':
  183. return AssetTypeEnumTypeTransformer().decode(value);
  184. case 'CheckDuplicateAssetDto':
  185. return CheckDuplicateAssetDto.fromJson(value);
  186. case 'CheckDuplicateAssetResponseDto':
  187. return CheckDuplicateAssetResponseDto.fromJson(value);
  188. case 'CreateAlbumDto':
  189. return CreateAlbumDto.fromJson(value);
  190. case 'CreateDeviceInfoDto':
  191. return CreateDeviceInfoDto.fromJson(value);
  192. case 'CreateProfileImageResponseDto':
  193. return CreateProfileImageResponseDto.fromJson(value);
  194. case 'CreateUserDto':
  195. return CreateUserDto.fromJson(value);
  196. case 'CuratedLocationsResponseDto':
  197. return CuratedLocationsResponseDto.fromJson(value);
  198. case 'CuratedObjectsResponseDto':
  199. return CuratedObjectsResponseDto.fromJson(value);
  200. case 'DeleteAssetDto':
  201. return DeleteAssetDto.fromJson(value);
  202. case 'DeleteAssetResponseDto':
  203. return DeleteAssetResponseDto.fromJson(value);
  204. case 'DeleteAssetStatus':
  205. return DeleteAssetStatusTypeTransformer().decode(value);
  206. case 'DeviceInfoResponseDto':
  207. return DeviceInfoResponseDto.fromJson(value);
  208. case 'DeviceTypeEnum':
  209. return DeviceTypeEnumTypeTransformer().decode(value);
  210. case 'ExifResponseDto':
  211. return ExifResponseDto.fromJson(value);
  212. case 'LoginCredentialDto':
  213. return LoginCredentialDto.fromJson(value);
  214. case 'LoginResponseDto':
  215. return LoginResponseDto.fromJson(value);
  216. case 'LogoutResponseDto':
  217. return LogoutResponseDto.fromJson(value);
  218. case 'RemoveAssetsDto':
  219. return RemoveAssetsDto.fromJson(value);
  220. case 'SearchAssetDto':
  221. return SearchAssetDto.fromJson(value);
  222. case 'ServerInfoResponseDto':
  223. return ServerInfoResponseDto.fromJson(value);
  224. case 'ServerPingResponse':
  225. return ServerPingResponse.fromJson(value);
  226. case 'ServerVersionReponseDto':
  227. return ServerVersionReponseDto.fromJson(value);
  228. case 'SignUpDto':
  229. return SignUpDto.fromJson(value);
  230. case 'SmartInfoResponseDto':
  231. return SmartInfoResponseDto.fromJson(value);
  232. case 'ThumbnailFormat':
  233. return ThumbnailFormatTypeTransformer().decode(value);
  234. case 'UpdateAlbumDto':
  235. return UpdateAlbumDto.fromJson(value);
  236. case 'UpdateDeviceInfoDto':
  237. return UpdateDeviceInfoDto.fromJson(value);
  238. case 'UpdateUserDto':
  239. return UpdateUserDto.fromJson(value);
  240. case 'UserCountResponseDto':
  241. return UserCountResponseDto.fromJson(value);
  242. case 'UserResponseDto':
  243. return UserResponseDto.fromJson(value);
  244. case 'ValidateAccessTokenResponseDto':
  245. return ValidateAccessTokenResponseDto.fromJson(value);
  246. default:
  247. dynamic match;
  248. if (value is List && (match = _regList.firstMatch(targetType)?.group(1)) != null) {
  249. return value
  250. .map<dynamic>((dynamic v) => _deserialize(v, match, growable: growable,))
  251. .toList(growable: growable);
  252. }
  253. if (value is Set && (match = _regSet.firstMatch(targetType)?.group(1)) != null) {
  254. return value
  255. .map<dynamic>((dynamic v) => _deserialize(v, match, growable: growable,))
  256. .toSet();
  257. }
  258. if (value is Map && (match = _regMap.firstMatch(targetType)?.group(1)) != null) {
  259. return Map<String, dynamic>.fromIterables(
  260. value.keys.cast<String>(),
  261. value.values.map<dynamic>((dynamic v) => _deserialize(v, match, growable: growable,)),
  262. );
  263. }
  264. }
  265. } on Exception catch (error, trace) {
  266. throw ApiException.withInner(HttpStatus.internalServerError, 'Exception during deserialization.', error, trace,);
  267. }
  268. throw ApiException(HttpStatus.internalServerError, 'Could not find a suitable class for deserialization',);
  269. }
  270. }
  271. /// Primarily intended for use in an isolate.
  272. class DeserializationMessage {
  273. const DeserializationMessage({
  274. required this.json,
  275. required this.targetType,
  276. this.growable = false,
  277. });
  278. /// The JSON value to deserialize.
  279. final String json;
  280. /// Target type to deserialize to.
  281. final String targetType;
  282. /// Whether to make deserialized lists or maps growable.
  283. final bool growable;
  284. }
  285. /// Primarily intended for use in an isolate.
  286. Future<dynamic> deserializeAsync(DeserializationMessage message) async {
  287. // Remove all spaces. Necessary for regular expressions as well.
  288. final targetType = message.targetType.replaceAll(' ', '');
  289. // If the expected target type is String, nothing to do...
  290. return targetType == 'String'
  291. ? message.json
  292. : ApiClient._deserialize(
  293. jsonDecode(message.json),
  294. targetType,
  295. growable: message.growable,
  296. );
  297. }
  298. /// Primarily intended for use in an isolate.
  299. Future<String> serializeAsync(Object? value) async => value == null ? '' : json.encode(value);