Merge pull request #2744 from bobby-ore/add-lunasea-user-id
Add ability to use User ID for LunaSea notifications
This commit is contained in:
		
						commit
						8d1847c032
					
				
					 2 changed files with 36 additions and 7 deletions
				
			
		|  | @ -8,7 +8,12 @@ class LunaSea extends NotificationProvider { | ||||||
| 
 | 
 | ||||||
|     async send(notification, msg, monitorJSON = null, heartbeatJSON = null) { |     async send(notification, msg, monitorJSON = null, heartbeatJSON = null) { | ||||||
|         let okMsg = "Sent Successfully."; |         let okMsg = "Sent Successfully."; | ||||||
|         let lunaseadevice = "https://notify.lunasea.app/v1/custom/device/" + notification.lunaseaDevice; |         let lunaseaurl = ""; | ||||||
|  |         if (notification.lunaseaTarget === "user") { | ||||||
|  |             lunaseaurl = "https://notify.lunasea.app/v1/custom/user/" + notification.lunaseaUserID; | ||||||
|  |         } else { | ||||||
|  |             lunaseaurl = "https://notify.lunasea.app/v1/custom/device/" + notification.lunaseaDevice; | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         try { |         try { | ||||||
|             if (heartbeatJSON == null) { |             if (heartbeatJSON == null) { | ||||||
|  | @ -16,7 +21,7 @@ class LunaSea extends NotificationProvider { | ||||||
|                     "title": "Uptime Kuma Alert", |                     "title": "Uptime Kuma Alert", | ||||||
|                     "body": msg, |                     "body": msg, | ||||||
|                 }; |                 }; | ||||||
|                 await axios.post(lunaseadevice, testdata); |                 await axios.post(lunaseaurl, testdata); | ||||||
|                 return okMsg; |                 return okMsg; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  | @ -25,7 +30,7 @@ class LunaSea extends NotificationProvider { | ||||||
|                     "title": "UptimeKuma Alert: " + monitorJSON["name"], |                     "title": "UptimeKuma Alert: " + monitorJSON["name"], | ||||||
|                     "body": "[🔴 Down] " + heartbeatJSON["msg"] + "\nTime (UTC): " + heartbeatJSON["time"], |                     "body": "[🔴 Down] " + heartbeatJSON["msg"] + "\nTime (UTC): " + heartbeatJSON["time"], | ||||||
|                 }; |                 }; | ||||||
|                 await axios.post(lunaseadevice, downdata); |                 await axios.post(lunaseaurl, downdata); | ||||||
|                 return okMsg; |                 return okMsg; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  | @ -34,7 +39,7 @@ class LunaSea extends NotificationProvider { | ||||||
|                     "title": "UptimeKuma Alert: " + monitorJSON["name"], |                     "title": "UptimeKuma Alert: " + monitorJSON["name"], | ||||||
|                     "body": "[✅ Up] " + heartbeatJSON["msg"] + "\nTime (UTC): " + heartbeatJSON["time"], |                     "body": "[✅ Up] " + heartbeatJSON["msg"] + "\nTime (UTC): " + heartbeatJSON["time"], | ||||||
|                 }; |                 }; | ||||||
|                 await axios.post(lunaseadevice, updata); |                 await axios.post(lunaseaurl, updata); | ||||||
|                 return okMsg; |                 return okMsg; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,9 +1,33 @@ | ||||||
| <template> | <template> | ||||||
|     <div class="mb-3"> |     <div class="mb-3"> | ||||||
|         <label for="lunasea-device" class="form-label">{{ $t("LunaSea Device ID") }}<span style="color: red;"><sup>*</sup></span></label> |         <label for="lunasea-notification-target" class="form-label">{{ $t("Target") }}<span style="color: red;"><sup>*</sup></span></label> | ||||||
|         <input id="lunasea-device" v-model="$parent.notification.lunaseaDevice" type="text" class="form-control" required> |  | ||||||
|         <div class="form-text"> |         <div class="form-text"> | ||||||
|             <p><span style="color: red;"><sup>*</sup></span>{{ $t("Required") }}</p> |             <p> | ||||||
|  |                 <select id="lunasea-notification-target" v-model="$parent.notification.lunaseaTarget" class="form-select" required> | ||||||
|  |                     <option value="device">Device</option> | ||||||
|  |                     <option value="user">User</option> | ||||||
|  |                 </select> | ||||||
|  |             </p> | ||||||
|  |         </div> | ||||||
|  |         <div v-if="$parent.notification.lunaseaTarget === 'device'"> | ||||||
|  |             <label for="lunasea-device" class="form-label">{{ $t("Device ID") }}<span style="color: red;"><sup>*</sup></span></label> | ||||||
|  |             <input id="lunasea-device" v-model="$parent.notification.lunaseaDevice" type="text" class="form-control"> | ||||||
|  |         </div> | ||||||
|  |         <div v-if="$parent.notification.lunaseaTarget === 'user'"> | ||||||
|  |             <label for="lunasea-device" class="form-label">{{ $t("User ID") }}<span style="color: red;"><sup>*</sup></span></label> | ||||||
|  |             <input id="lunasea-device" v-model="$parent.notification.lunaseaUserID" type="text" class="form-control"> | ||||||
|         </div> |         </div> | ||||||
|     </div> |     </div> | ||||||
| </template> | </template> | ||||||
|  | 
 | ||||||
|  | <script lang="ts"> | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  |     mounted() { | ||||||
|  |         if (typeof this.$parent.notification.lunaseaTarget === "undefined") { | ||||||
|  |             this.$parent.notification.lunaseaTarget = "device"; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | </script> | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue