feature/add-client #22
| @ -2,6 +2,7 @@ | ||||
|   "projects": { | ||||
|     "debug": "fitlien-dev", | ||||
|     "qa": "fitlien-qa", | ||||
|     "release": "fitlien" | ||||
|     "release": "fitlien", | ||||
|     "default": "fitlien-dev" | ||||
|   } | ||||
| } | ||||
| } | ||||
|  | ||||
| @ -14,8 +14,7 @@ | ||||
|         "firebase-debug.*.log", | ||||
|         "*.local" | ||||
|       ], | ||||
|       "predeploy": [ | ||||
|       ] | ||||
|       "predeploy": [] | ||||
|     } | ||||
|   ], | ||||
|   "storage": { | ||||
|  | ||||
| @ -1,5 +1,33 @@ | ||||
| { | ||||
|   "indexes": [ | ||||
|     { | ||||
|       "collectionGroup": "day_pass_bookings", | ||||
|       "queryScope": "COLLECTION", | ||||
|       "fields": [ | ||||
|         { | ||||
|           "fieldPath": "userId", | ||||
|           "order": "ASCENDING" | ||||
|         }, | ||||
|         { | ||||
|           "fieldPath": "createdAt", | ||||
|           "order": "DESCENDING" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "collectionGroup": "day_pass_entries", | ||||
|       "queryScope": "COLLECTION", | ||||
|       "fields": [ | ||||
|         { | ||||
|           "fieldPath": "bookingId", | ||||
|           "order": "ASCENDING" | ||||
|         }, | ||||
|         { | ||||
|           "fieldPath": "entryDate", | ||||
|           "order": "ASCENDING" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "collectionGroup": "gyms", | ||||
|       "queryScope": "COLLECTION_GROUP", | ||||
| @ -13,6 +41,144 @@ | ||||
|           "order": "ASCENDING" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "collectionGroup": "gyms", | ||||
|       "queryScope": "COLLECTION", | ||||
|       "fields": [ | ||||
|         { | ||||
|           "fieldPath": "userId", | ||||
|           "order": "ASCENDING" | ||||
|         }, | ||||
|         { | ||||
|           "fieldPath": "name", | ||||
|           "order": "ASCENDING" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "collectionGroup": "memberships", | ||||
|       "queryScope": "COLLECTION", | ||||
|       "fields": [ | ||||
|         { | ||||
|           "fieldPath": "gymId", | ||||
|           "order": "ASCENDING" | ||||
|         }, | ||||
|         { | ||||
|           "fieldPath": "createdAt", | ||||
|           "order": "DESCENDING" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "collectionGroup": "notifications", | ||||
|       "queryScope": "COLLECTION", | ||||
|       "fields": [ | ||||
|         { | ||||
|           "fieldPath": "clientId", | ||||
|           "order": "ASCENDING" | ||||
|         }, | ||||
|         { | ||||
|           "fieldPath": "timestamp", | ||||
|           "order": "DESCENDING" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "collectionGroup": "notifications", | ||||
|       "queryScope": "COLLECTION", | ||||
|       "fields": [ | ||||
|         { | ||||
|           "fieldPath": "clientId", | ||||
|           "order": "ASCENDING" | ||||
|         }, | ||||
|         { | ||||
|           "fieldPath": "type", | ||||
|           "order": "ASCENDING" | ||||
|         }, | ||||
|         { | ||||
|           "fieldPath": "timestamp", | ||||
|           "order": "DESCENDING" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "collectionGroup": "notifications", | ||||
|       "queryScope": "COLLECTION", | ||||
|       "fields": [ | ||||
|         { | ||||
|           "fieldPath": "ownerId", | ||||
|           "order": "ASCENDING" | ||||
|         }, | ||||
|         { | ||||
|           "fieldPath": "timestamp", | ||||
|           "order": "DESCENDING" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "collectionGroup": "notifications", | ||||
|       "queryScope": "COLLECTION", | ||||
|       "fields": [ | ||||
|         { | ||||
|           "fieldPath": "ownerId", | ||||
|           "order": "ASCENDING" | ||||
|         }, | ||||
|         { | ||||
|           "fieldPath": "type", | ||||
|           "order": "ASCENDING" | ||||
|         }, | ||||
|         { | ||||
|           "fieldPath": "timestamp", | ||||
|           "order": "DESCENDING" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "collectionGroup": "notifications", | ||||
|       "queryScope": "COLLECTION", | ||||
|       "fields": [ | ||||
|         { | ||||
|           "fieldPath": "trainerId", | ||||
|           "order": "ASCENDING" | ||||
|         }, | ||||
|         { | ||||
|           "fieldPath": "timestamp", | ||||
|           "order": "DESCENDING" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "collectionGroup": "notifications", | ||||
|       "queryScope": "COLLECTION", | ||||
|       "fields": [ | ||||
|         { | ||||
|           "fieldPath": "type", | ||||
|           "order": "ASCENDING" | ||||
|         }, | ||||
|         { | ||||
|           "fieldPath": "userId", | ||||
|           "order": "ASCENDING" | ||||
|         }, | ||||
|         { | ||||
|           "fieldPath": "timestamp", | ||||
|           "order": "DESCENDING" | ||||
|         } | ||||
|       ] | ||||
|     }, | ||||
|     { | ||||
|       "collectionGroup": "termsandconditions", | ||||
|       "queryScope": "COLLECTION", | ||||
|       "fields": [ | ||||
|         { | ||||
|           "fieldPath": "normalizedName", | ||||
|           "order": "ASCENDING" | ||||
|         }, | ||||
|         { | ||||
|           "fieldPath": "userUid", | ||||
|           "order": "ASCENDING" | ||||
|         } | ||||
|       ] | ||||
|     } | ||||
|   ], | ||||
|   "fieldOverrides": [] | ||||
|  | ||||
| @ -1,19 +1,16 @@ | ||||
| rules_version = '2'; | ||||
| 
 | ||||
| service cloud.firestore { | ||||
|   match /databases/{database}/documents { | ||||
| 
 | ||||
|     // This rule allows anyone with your Firestore database reference to view, edit, | ||||
|     // and delete all data in your Firestore database. It is useful for getting | ||||
|     // started, but it is configured to expire after 30 days because it | ||||
|     // leaves your app open to attackers. At that time, all client | ||||
|     // requests to your Firestore database will be denied. | ||||
|     // | ||||
|     // Make sure to write security rules for your app before that time, or else | ||||
|     // all client requests to your Firestore database will be denied until you Update | ||||
|     // your rules | ||||
|     match /{document=**} { | ||||
|       allow read, write: if request.time < timestamp.date(2025, 1, 10); | ||||
|       allow read, write: if request.auth != null; | ||||
|     } | ||||
|     match /day_pass_bookings/{bookingId} { | ||||
|       allow read: if true; | ||||
|       allow write: if request.auth != null; | ||||
|     } | ||||
|     match /gyms/{gymId} { | ||||
|       allow read: if true; | ||||
|       allow write: if request.auth != null; | ||||
|     } | ||||
|   } | ||||
| } | ||||
							
								
								
									
										5
									
								
								functions/package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										5
									
								
								functions/package-lock.json
									
									
									
										generated
									
									
									
								
							| @ -14,6 +14,7 @@ | ||||
|         "firebase-admin": "^12.6.0", | ||||
|         "firebase-functions": "^6.0.1", | ||||
|         "form-data": "^4.0.1", | ||||
|         "functions": "file:", | ||||
|         "html-to-text": "^9.0.5", | ||||
|         "long": "^4.0.0", | ||||
|         "mailgun.js": "^10.4.0", | ||||
| @ -3084,6 +3085,10 @@ | ||||
|       "integrity": "sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g==", | ||||
|       "optional": true | ||||
|     }, | ||||
|     "node_modules/functions": { | ||||
|       "resolved": "", | ||||
|       "link": true | ||||
|     }, | ||||
|     "node_modules/gaxios": { | ||||
|       "version": "6.7.1", | ||||
|       "resolved": "https://registry.npmjs.org/gaxios/-/gaxios-6.7.1.tgz", | ||||
|  | ||||
| @ -21,6 +21,7 @@ | ||||
|     "firebase-admin": "^12.6.0", | ||||
|     "firebase-functions": "^6.0.1", | ||||
|     "form-data": "^4.0.1", | ||||
|     "functions": "file:", | ||||
|     "html-to-text": "^9.0.5", | ||||
|     "long": "^4.0.0", | ||||
|     "mailgun.js": "^10.4.0", | ||||
|  | ||||
| @ -384,7 +384,8 @@ export const createCashfreeOrder = onRequest({ | ||||
|           productInfo, | ||||
|           userId, | ||||
|           gymId, | ||||
|           orderId | ||||
|           orderId, | ||||
|           webHostUrl, | ||||
|         } = request.body; | ||||
| 
 | ||||
|         if (!amount || !customerEmail || !customerPhone) { | ||||
| @ -422,8 +423,7 @@ export const createCashfreeOrder = onRequest({ | ||||
|                 customer_phone: customerPhone | ||||
|               }, | ||||
|               order_meta: { | ||||
|                 return_url: `https://${process.env.FITLIENHOST}/payment-bridge?order_id=${orderId}&hash_key=${hashKey}&user_id=${userId}&gym_id=${gymId}`, | ||||
|                 // notify_url: `https://$filien.web.app/verifyCashfreePayment`
 | ||||
|                 return_url: `http://${webHostUrl}/?order_id=${orderId}&hash_key=${hashKey}&user_id=${userId}&gym_id=${gymId}#/payment-status-screen`, | ||||
|               }, | ||||
|               order_note: productInfo || 'Fitlien Membership' | ||||
|             }, | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user