mirror of
				https://github.com/louislam/uptime-kuma.git
				synced 2025-10-25 07:39:22 +08:00 
			
		
		
		
	feat: add SerwerSMS notification provider
This commit is contained in:
		
							
								
								
									
										44
									
								
								server/notification-providers/serwersms.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								server/notification-providers/serwersms.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| const NotificationProvider = require("./notification-provider"); | ||||
| const axios = require("axios"); | ||||
|  | ||||
| class SerwerSMS extends NotificationProvider { | ||||
|  | ||||
|     name = "serwersms"; | ||||
|  | ||||
|     async send(notification, msg, monitorJSON = null, heartbeatJSON = null) { | ||||
|         let okMsg = "Sent Successfully."; | ||||
|  | ||||
|         try { | ||||
|             let config = { | ||||
|                 headers: { | ||||
|                     "Content-Type": "application/json", | ||||
|                 } | ||||
|             }; | ||||
|             let data = { | ||||
|                 "username": notification.serwersmsUsername, | ||||
|                 "password": notification.serwersmsPassword, | ||||
|                 "phone": notification.serwersmsPhoneNumber, | ||||
|                 "text": msg.replace(/[^\x00-\x7F]/g, ""), | ||||
|                 "sender": notification.serwersmsSenderName | ||||
|             }; | ||||
|  | ||||
|             let resp = await axios.post("https://api2.serwersms.pl/messages/send_sms", data, config); | ||||
|  | ||||
|             if (!resp.data.success) { | ||||
|                 if (resp.data.error) { | ||||
|                     let error = `SerwerSMS.pl API returned error code ${resp.data.error.code} (${resp.data.error.type}) with error message: ${resp.data.error.message}`; | ||||
|                     this.throwGeneralAxiosError(error); | ||||
|                 } else { | ||||
|                     let error = "SerwerSMS.pl API returned an unexpected response"; | ||||
|                     this.throwGeneralAxiosError(error); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             return okMsg; | ||||
|         } catch (error) { | ||||
|             this.throwGeneralAxiosError(error); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| module.exports = SerwerSMS; | ||||
| @@ -23,6 +23,7 @@ const Feishu = require("./notification-providers/feishu"); | ||||
| const AliyunSms = require("./notification-providers/aliyun-sms"); | ||||
| const DingDing = require("./notification-providers/dingding"); | ||||
| const Bark = require("./notification-providers/bark"); | ||||
| const SerwerSMS = require("./notification-providers/serwersms"); | ||||
|  | ||||
| class Notification { | ||||
|  | ||||
| @@ -58,6 +59,7 @@ class Notification { | ||||
|             new Telegram(), | ||||
|             new Webhook(), | ||||
|             new Bark(), | ||||
|             new SerwerSMS(), | ||||
|         ]; | ||||
|  | ||||
|         for (let item of list) { | ||||
|   | ||||
							
								
								
									
										28
									
								
								src/components/notifications/SerwerSMS.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								src/components/notifications/SerwerSMS.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | ||||
| <template> | ||||
|     <div class="mb-3"> | ||||
|         <label for="serwersms-username" class="form-label">{{ $t('serwersmsAPIUser') }}</label> | ||||
|         <input id="serwersms-username" v-model="$parent.notification.serwersmsUsername" type="text" class="form-control" required> | ||||
|     </div> | ||||
|     <div class="mb-3"> | ||||
|         <label for="serwersms-key" class="form-label">{{ $t('serwersmsAPIPassword') }}</label> | ||||
|         <HiddenInput id="serwersms-key" v-model="$parent.notification.serwersmsPassword" :required="true" autocomplete="one-time-code"></HiddenInput> | ||||
|     </div> | ||||
|     <div class="mb-3"> | ||||
|         <label for="serwersms-phone-number" class="form-label">{{ $t("serwersmsPhoneNumber") }}</label> | ||||
|         <input id="serwersms-phone-number" v-model="$parent.notification.serwersmsPhoneNumber" type="text" class="form-control" required> | ||||
|     </div> | ||||
|     <div class="mb-3"> | ||||
|         <label for="serwersms-sender-name" class="form-label">{{ $t("serwersmsSenderName") }}</label> | ||||
|         <input id="serwersms-sender-name" v-model="$parent.notification.serwersmsSenderName" type="text" minlength="3" maxlength="11" class="form-control"> | ||||
|     </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import HiddenInput from "../HiddenInput.vue"; | ||||
|  | ||||
| export default { | ||||
|     components: { | ||||
|         HiddenInput, | ||||
|     }, | ||||
| }; | ||||
| </script> | ||||
| @@ -22,6 +22,7 @@ import Matrix from "./Matrix.vue"; | ||||
| import AliyunSMS from "./AliyunSms.vue"; | ||||
| import DingDing from "./DingDing.vue"; | ||||
| import Bark from "./Bark.vue"; | ||||
| import SerwerSMS from "./SerwerSMS.vue"; | ||||
|  | ||||
| /** | ||||
|  * Manage all notification form. | ||||
| @@ -52,7 +53,8 @@ const NotificationFormList = { | ||||
|     "mattermost": Mattermost, | ||||
|     "matrix": Matrix, | ||||
|     "DingDing": DingDing, | ||||
|     "Bark": Bark | ||||
|     "Bark": Bark, | ||||
|     "serwersms": SerwerSMS | ||||
| } | ||||
|  | ||||
| export default NotificationFormList | ||||
|   | ||||
| @@ -308,4 +308,9 @@ export default { | ||||
|     "Current User": "Current User", | ||||
|     recent: "Recent", | ||||
|     shrinkDatabaseDescription: "Trigger database VACUUM for SQLite. If your database is created after 1.10.0, AUTO_VACUUM is already enabled and this action is not needed.", | ||||
|     serwersms: "SerwerSMS.pl", | ||||
|     serwersmsAPIUser: "API Username (incl. webapi_ prefix)", | ||||
|     serwersmsAPIPassword: "API Password", | ||||
|     serwersmsPhoneNumber: "Phone number", | ||||
|     serwersmsSenderName: "SMS Sender Name (registered via customer portal)", | ||||
| }; | ||||
|   | ||||
| @@ -307,4 +307,9 @@ export default { | ||||
|     recent: "Ostatnie", | ||||
|     clicksendsms: "ClickSend SMS", | ||||
|     apiCredentials: "Poświadczenia API", | ||||
|     serwersms: "SerwerSMS.pl", | ||||
|     serwersmsAPIUser: "Nazwa Użytkownika API (z prefiksem webapi_)", | ||||
|     serwersmsAPIPassword: "Hasło API", | ||||
|     serwersmsPhoneNumber: "Numer Telefonu", | ||||
|     serwersmsSenderName: "Nazwa Nadawcy (zatwierdzona w panelu klienta)", | ||||
| }; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user