feature/test-deploy #20
| @ -2,6 +2,7 @@ | |||||||
|   "projects": { |   "projects": { | ||||||
|     "debug": "fitlien-dev", |     "debug": "fitlien-dev", | ||||||
|     "qa": "fitlien-qa", |     "qa": "fitlien-qa", | ||||||
|     "release": "fitlien" |     "release": "fitlien", | ||||||
|  |     "default": "fitlien-dev" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
| @ -14,8 +14,7 @@ | |||||||
|         "firebase-debug.*.log", |         "firebase-debug.*.log", | ||||||
|         "*.local" |         "*.local" | ||||||
|       ], |       ], | ||||||
|       "predeploy": [ |       "predeploy": [] | ||||||
|       ] |  | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|   "storage": { |   "storage": { | ||||||
|  | |||||||
| @ -1,5 +1,33 @@ | |||||||
| { | { | ||||||
|   "indexes": [ |   "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", |       "collectionGroup": "gyms", | ||||||
|       "queryScope": "COLLECTION_GROUP", |       "queryScope": "COLLECTION_GROUP", | ||||||
| @ -13,7 +41,145 @@ | |||||||
|           "order": "ASCENDING" |           "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": "terms_and_conditions", | ||||||
|  |       "queryScope": "COLLECTION", | ||||||
|  |       "fields": [ | ||||||
|  |         { | ||||||
|  |           "fieldPath": "normalizedName", | ||||||
|  |           "order": "ASCENDING" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           "fieldPath": "userUid", | ||||||
|  |           "order": "ASCENDING" | ||||||
|  |         } | ||||||
|  |       ] | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|   "fieldOverrides": [] |   "fieldOverrides": [] | ||||||
| } | } | ||||||
| @ -1,19 +1,16 @@ | |||||||
| rules_version = '2'; | rules_version = '2'; | ||||||
| 
 |  | ||||||
| service cloud.firestore { | service cloud.firestore { | ||||||
|   match /databases/{database}/documents { |   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=**} { |     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; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @ -422,7 +422,7 @@ export const createCashfreeOrder = onRequest({ | |||||||
|                 customer_phone: customerPhone |                 customer_phone: customerPhone | ||||||
|               }, |               }, | ||||||
|               order_meta: { |               order_meta: { | ||||||
|                 return_url: `http://${webHostUrl}/?order_id=${orderId}&hash_key=${hashKey}&user_id=${userId}&gym_id=${gymId}#/payment-status-screen`, |                 return_url: `http://${webHostUrl}?order_id=${orderId}&hash_key=${hashKey}&user_id=${userId}&gym_id=${gymId}#/payment-status-screen`, | ||||||
|               }, |               }, | ||||||
|               order_note: productInfo || 'Fitlien Membership' |               order_note: productInfo || 'Fitlien Membership' | ||||||
|             }, |             }, | ||||||
|  | |||||||
| @ -1,12 +1,9 @@ | |||||||
| rules_version = '2'; | rules_version = '2'; | ||||||
| 
 | 
 | ||||||
| // Craft rules based on data in your Firestore database |  | ||||||
| // allow write: if firestore.get( |  | ||||||
| //    /databases/(default)/documents/users/$(request.auth.uid)).data.isAdmin; |  | ||||||
| service firebase.storage { | service firebase.storage { | ||||||
|   match /b/{bucket}/o { |   match /b/{bucket}/o { | ||||||
|     match /{allPaths=**} { |     match /{allPaths=**} { | ||||||
|       allow read, write: if false; |       allow read, write: if request.auth != null; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user