@edgedev/firebase 2.1.41 → 2.1.42

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/edgeFirebase.ts +68 -45
  2. package/package.json +1 -1
package/edgeFirebase.ts CHANGED
@@ -55,7 +55,7 @@ import {
55
55
  } from "firebase/auth";
56
56
 
57
57
 
58
- import { getStorage, ref, uploadBytes, getDownloadURL, connectStorageEmulator, listAll, deleteObject} from "firebase/storage";
58
+ import { getStorage, ref, uploadBytesResumable, getDownloadURL, connectStorageEmulator, listAll, deleteObject} from "firebase/storage";
59
59
 
60
60
  import { getFunctions, httpsCallable, connectFunctionsEmulator } from "firebase/functions";
61
61
 
@@ -2077,58 +2077,81 @@ export const EdgeFirebase = class {
2077
2077
  };
2078
2078
 
2079
2079
 
2080
+ // File functions
2080
2081
  // File functions
2081
2082
  public uploadFile = async (filePath: string, file: Blob, isPublic: boolean): Promise<actionResponse> => {
2082
2083
 
2083
- // Validate if file is provided
2084
- if (!file) {
2085
- return this.sendResponse({
2086
- success: false,
2087
- message: "No file provided for upload.",
2088
- meta: {}
2089
- });
2090
- }
2084
+ // Validate if file is provided
2085
+ if (!file) {
2086
+ return this.sendResponse({
2087
+ success: false,
2088
+ message: "No file provided for upload.",
2089
+ meta: {}
2090
+ });
2091
+ }
2091
2092
 
2092
- // Check if the user has write permission to the filePath
2093
- let hasWritePermission = await this.permissionCheck("write", filePath);
2094
- if (isPublic) {
2095
- hasWritePermission = true;
2096
- filePath = "public";
2097
- }
2098
- if (!hasWritePermission) {
2099
- return this.sendResponse({
2100
- success: false,
2101
- message: "You do not have permission to upload files to this path.",
2102
- meta: {}
2103
- });
2104
- }
2093
+ // Check if the user has write permission to the filePath
2094
+ let hasWritePermission = await this.permissionCheck("write", filePath);
2095
+ if (isPublic) {
2096
+ hasWritePermission = true;
2097
+ filePath = "public";
2098
+ }
2099
+ if (!hasWritePermission) {
2100
+ return this.sendResponse({
2101
+ success: false,
2102
+ message: "You do not have permission to upload files to this path.",
2103
+ meta: {}
2104
+ });
2105
+ }
2105
2106
 
2106
- try {
2107
- let randomId = ''
2108
- if (isPublic) {
2109
- randomId = Math.random().toString(36).substring(2, 6) + '-'
2110
- }
2111
- const tempFilePath = `${filePath.replaceAll('/', '-')}` + '/' + randomId + file.name;
2112
- const fileRef = ref(this.storage, tempFilePath);
2113
- if (isPublic) {
2114
- await uploadBytes(fileRef, file, { contentType: file.type, cacheControl: 'public, max-age=31536000' });
2115
- } else {
2116
- await uploadBytes(fileRef, file);
2117
- }
2118
- return this.sendResponse({
2119
- success: true,
2120
- message: "File uploaded successfully.",
2121
- meta: {file: tempFilePath}
2122
- });
2123
- } catch (error) {
2124
- return this.sendResponse({
2125
- success: false,
2126
- message: "An error occurred during file upload.",
2127
- meta: {}
2128
- });
2107
+ try {
2108
+ const chunkSize = 5 * 1024 * 1024; // 5 MB per chunk
2109
+ const totalChunks = Math.ceil(file.size / chunkSize);
2110
+ const uploadPath = `${filePath.replaceAll('/', '-')}/${file.name}`;
2111
+ const chunkPromises = [];
2112
+
2113
+ for (let i = 0; i < totalChunks; i++) {
2114
+ const chunkStart = i * chunkSize;
2115
+ const chunkEnd = Math.min(chunkStart + chunkSize, file.size);
2116
+ const chunk = file.slice(chunkStart, chunkEnd);
2117
+
2118
+ const chunkFilePath = `${uploadPath}.part-${i + 1}`;
2119
+ const fileRef = ref(this.storage, chunkFilePath);
2120
+ const uploadTask = uploadBytesResumable(fileRef, chunk, { contentType: file.type });
2121
+
2122
+ chunkPromises.push(new Promise((resolve, reject) => {
2123
+ uploadTask.on(
2124
+ 'state_changed',
2125
+ (snapshot) => {
2126
+ // Progress tracking (optional)
2127
+ const progress = (snapshot.bytesTransferred / snapshot.totalBytes) * 100;
2128
+ console.log(`Upload is ${progress}% done`);
2129
+ },
2130
+ (error) => reject(error),
2131
+ () => resolve(uploadTask.snapshot)
2132
+ );
2133
+ }));
2129
2134
  }
2135
+
2136
+ // Wait for all chunks to finish uploading
2137
+ await Promise.all(chunkPromises);
2138
+
2139
+ return this.sendResponse({
2140
+ success: true,
2141
+ message: "File uploaded successfully in chunks.",
2142
+ meta: {file: uploadPath}
2143
+ });
2144
+
2145
+ } catch (error) {
2146
+ return this.sendResponse({
2147
+ success: false,
2148
+ message: "An error occurred during file upload.",
2149
+ meta: {}
2150
+ });
2151
+ }
2130
2152
  };
2131
2153
 
2154
+
2132
2155
  public deleteFile = async (filePath: string): Promise<actionResponse> => {
2133
2156
  let hasDeletePermission = await this.permissionCheck("write", filePath);
2134
2157
  if (filePath.substring(0, 6) === 'public') {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@edgedev/firebase",
3
- "version": "2.1.41",
3
+ "version": "2.1.42",
4
4
  "description": "Vue 3 / Nuxt 3 Plugin or Nuxt 3 plugin for firebase authentication and firestore.",
5
5
  "main": "index.ts",
6
6
  "scripts": {