191 lines
No EOL
6.3 KiB
Dart
191 lines
No EOL
6.3 KiB
Dart
|
|
|
|
import 'package:dio/dio.dart';
|
|
import 'package:meta/meta.dart';
|
|
|
|
import "../client.dart";
|
|
import '../enums.dart';
|
|
import "../service.dart";
|
|
|
|
class Storage extends Service {
|
|
Storage(Client client): super(client);
|
|
|
|
/// List Files
|
|
///
|
|
/// Get a list of all the user files. You can use the query params to filter
|
|
/// your results. On admin mode, this endpoint will return a list of all of the
|
|
/// project files. [Learn more about different API modes](/docs/admin).
|
|
///
|
|
Future<Response> listFiles({String search = '', int limit = 25, int offset = 0, OrderType orderType = OrderType.asc}) {
|
|
final String path = '/storage/files';
|
|
|
|
final Map<String, dynamic> params = {
|
|
'search': search,
|
|
'limit': limit,
|
|
'offset': offset,
|
|
'orderType': orderType.name(),
|
|
};
|
|
|
|
final Map<String, String> headers = {
|
|
'content-type': 'application/json',
|
|
};
|
|
|
|
return client.call(HttpMethod.get, path: path, params: params, headers: headers);
|
|
}
|
|
|
|
/// Create File
|
|
///
|
|
/// Create a new file. The user who creates the file will automatically be
|
|
/// assigned to read and write access unless he has passed custom values for
|
|
/// read and write arguments.
|
|
///
|
|
Future<Response> createFile({@required MultipartFile file, @required List read, @required List write}) {
|
|
final String path = '/storage/files';
|
|
|
|
final Map<String, dynamic> params = {
|
|
'file': file,
|
|
'read': read,
|
|
'write': write,
|
|
};
|
|
|
|
final Map<String, String> headers = {
|
|
'content-type': 'multipart/form-data',
|
|
};
|
|
|
|
return client.call(HttpMethod.post, path: path, params: params, headers: headers);
|
|
}
|
|
|
|
/// Get File
|
|
///
|
|
/// Get file by its unique ID. This endpoint response returns a JSON object
|
|
/// with the file metadata.
|
|
///
|
|
Future<Response> getFile({@required String fileId}) {
|
|
final String path = '/storage/files/{fileId}'.replaceAll(RegExp('{fileId}'), fileId);
|
|
|
|
final Map<String, dynamic> params = {
|
|
};
|
|
|
|
final Map<String, String> headers = {
|
|
'content-type': 'application/json',
|
|
};
|
|
|
|
return client.call(HttpMethod.get, path: path, params: params, headers: headers);
|
|
}
|
|
|
|
/// Update File
|
|
///
|
|
/// Update file by its unique ID. Only users with write permissions have access
|
|
/// to update this resource.
|
|
///
|
|
Future<Response> updateFile({@required String fileId, @required List read, @required List write}) {
|
|
final String path = '/storage/files/{fileId}'.replaceAll(RegExp('{fileId}'), fileId);
|
|
|
|
final Map<String, dynamic> params = {
|
|
'read': read,
|
|
'write': write,
|
|
};
|
|
|
|
final Map<String, String> headers = {
|
|
'content-type': 'application/json',
|
|
};
|
|
|
|
return client.call(HttpMethod.put, path: path, params: params, headers: headers);
|
|
}
|
|
|
|
/// Delete File
|
|
///
|
|
/// Delete a file by its unique ID. Only users with write permissions have
|
|
/// access to delete this resource.
|
|
///
|
|
Future<Response> deleteFile({@required String fileId}) {
|
|
final String path = '/storage/files/{fileId}'.replaceAll(RegExp('{fileId}'), fileId);
|
|
|
|
final Map<String, dynamic> params = {
|
|
};
|
|
|
|
final Map<String, String> headers = {
|
|
'content-type': 'application/json',
|
|
};
|
|
|
|
return client.call(HttpMethod.delete, path: path, params: params, headers: headers);
|
|
}
|
|
|
|
/// Get File for Download
|
|
///
|
|
/// Get file content by its unique ID. The endpoint response return with a
|
|
/// 'Content-Disposition: attachment' header that tells the browser to start
|
|
/// downloading the file to user downloads directory.
|
|
///
|
|
String getFileDownload({@required String fileId}) {
|
|
final String path = '/storage/files/{fileId}/download'.replaceAll(RegExp('{fileId}'), fileId);
|
|
|
|
final Map<String, dynamic> params = {
|
|
'project': client.config['project'],
|
|
};
|
|
|
|
Uri endpoint = Uri.parse(client.endPoint);
|
|
Uri location = new Uri(scheme: endpoint.scheme,
|
|
host: endpoint.host,
|
|
port: endpoint.port,
|
|
path: endpoint.path + path,
|
|
queryParameters:params,
|
|
);
|
|
|
|
return location.toString();
|
|
}
|
|
|
|
/// Get File Preview
|
|
///
|
|
/// Get a file preview image. Currently, this method supports preview for image
|
|
/// files (jpg, png, and gif), other supported formats, like pdf, docs, slides,
|
|
/// and spreadsheets, will return the file icon image. You can also pass query
|
|
/// string arguments for cutting and resizing your preview image.
|
|
///
|
|
String getFilePreview({@required String fileId, int width = 0, int height = 0, int quality = 100, String background = '', String output = ''}) {
|
|
final String path = '/storage/files/{fileId}/preview'.replaceAll(RegExp('{fileId}'), fileId);
|
|
|
|
final Map<String, dynamic> params = {
|
|
'width': width,
|
|
'height': height,
|
|
'quality': quality,
|
|
'background': background,
|
|
'output': output,
|
|
'project': client.config['project'],
|
|
};
|
|
|
|
Uri endpoint = Uri.parse(client.endPoint);
|
|
Uri location = new Uri(scheme: endpoint.scheme,
|
|
host: endpoint.host,
|
|
port: endpoint.port,
|
|
path: endpoint.path + path,
|
|
queryParameters:params,
|
|
);
|
|
|
|
return location.toString();
|
|
}
|
|
|
|
/// Get File for View
|
|
///
|
|
/// Get file content by its unique ID. This endpoint is similar to the download
|
|
/// method but returns with no 'Content-Disposition: attachment' header.
|
|
///
|
|
String getFileView({@required String fileId, String as = ''}) {
|
|
final String path = '/storage/files/{fileId}/view'.replaceAll(RegExp('{fileId}'), fileId);
|
|
|
|
final Map<String, dynamic> params = {
|
|
'as': as,
|
|
'project': client.config['project'],
|
|
};
|
|
|
|
Uri endpoint = Uri.parse(client.endPoint);
|
|
Uri location = new Uri(scheme: endpoint.scheme,
|
|
host: endpoint.host,
|
|
port: endpoint.port,
|
|
path: endpoint.path + path,
|
|
queryParameters:params,
|
|
);
|
|
|
|
return location.toString();
|
|
}
|
|
} |