mirror of
https://github.com/Ombi-app/Ombi.git
synced 2025-08-20 21:33:15 -07:00
Merge pull request #2468 from pooley182/master
Allow for the ability to set Pushover notification sound and priority…
This commit is contained in:
commit
f5dfaf024b
7 changed files with 52 additions and 4 deletions
|
@ -5,6 +5,6 @@ namespace Ombi.Api.Pushover
|
||||||
{
|
{
|
||||||
public interface IPushoverApi
|
public interface IPushoverApi
|
||||||
{
|
{
|
||||||
Task<PushoverResponse> PushAsync(string accessToken, string message, string userToken);
|
Task<PushoverResponse> PushAsync(string accessToken, string message, string userToken, sbyte priority, string sound);
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -16,13 +16,13 @@ namespace Ombi.Api.Pushover
|
||||||
private readonly IApi _api;
|
private readonly IApi _api;
|
||||||
private const string PushoverEndpoint = "https://api.pushover.net/1";
|
private const string PushoverEndpoint = "https://api.pushover.net/1";
|
||||||
|
|
||||||
public async Task<PushoverResponse> PushAsync(string accessToken, string message, string userToken)
|
public async Task<PushoverResponse> PushAsync(string accessToken, string message, string userToken, sbyte priority, string sound)
|
||||||
{
|
{
|
||||||
if (message.Contains("'"))
|
if (message.Contains("'"))
|
||||||
{
|
{
|
||||||
message = message.Replace("'", "'");
|
message = message.Replace("'", "'");
|
||||||
}
|
}
|
||||||
var request = new Request($"messages.json?token={accessToken}&user={userToken}&message={WebUtility.HtmlEncode(message)}", PushoverEndpoint, HttpMethod.Post);
|
var request = new Request($"messages.json?token={accessToken}&user={userToken}&priority={priority}&sound={sound}&message={WebUtility.HtmlEncode(message)}", PushoverEndpoint, HttpMethod.Post);
|
||||||
|
|
||||||
var result = await _api.Request<PushoverResponse>(request);
|
var result = await _api.Request<PushoverResponse>(request);
|
||||||
return result;
|
return result;
|
||||||
|
|
|
@ -178,7 +178,7 @@ namespace Ombi.Notifications.Agents
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
//&+' < >
|
//&+' < >
|
||||||
await Api.PushAsync(settings.AccessToken, model.Message.StripCharacters('&','+','<','>'), settings.UserToken);
|
await Api.PushAsync(settings.AccessToken, model.Message.StripCharacters('&','+','<','>'), settings.UserToken, settings.Priority, settings.Sound);
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
|
|
|
@ -8,5 +8,7 @@ namespace Ombi.Settings.Settings.Models.Notifications
|
||||||
public bool Enabled { get; set; }
|
public bool Enabled { get; set; }
|
||||||
public string AccessToken { get; set; }
|
public string AccessToken { get; set; }
|
||||||
public string UserToken { get; set; }
|
public string UserToken { get; set; }
|
||||||
|
public sbyte Priority { get; set; } = 0;
|
||||||
|
public string Sound { get; set; } = "pushover";
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -88,6 +88,8 @@ export interface IPushoverNotificationSettings extends INotificationSettings {
|
||||||
accessToken: string;
|
accessToken: string;
|
||||||
notificationTemplates: INotificationTemplates[];
|
notificationTemplates: INotificationTemplates[];
|
||||||
userToken: string;
|
userToken: string;
|
||||||
|
priority: number;
|
||||||
|
sound: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface IMattermostNotifcationSettings extends INotificationSettings {
|
export interface IMattermostNotifcationSettings extends INotificationSettings {
|
||||||
|
|
|
@ -28,6 +28,48 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="priority" class="control-label">Priority</label>
|
||||||
|
<div>
|
||||||
|
<select class="form-control form-control-custom " id="priority" name="priority" formControlName="priority" pTooltip="The priority you want your pushover notifications sent as.">
|
||||||
|
<option value="0">Normal</option>
|
||||||
|
<option value="1">High</option>
|
||||||
|
<option value="-1">Low</option>
|
||||||
|
<option value="-2">Lowest</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="sound" class="control-label">Sound</label>
|
||||||
|
<div>
|
||||||
|
<select class="form-control form-control-custom " id="sound" name="sound" formControlName="sound" pTooltip="The sound you want your pushover notifications sent with.">
|
||||||
|
<option value="pushover">Pushover</option>
|
||||||
|
<option value="bike">Bike</option>
|
||||||
|
<option value="bugle">Bugle</option>
|
||||||
|
<option value="cashregister">Cash Register</option>
|
||||||
|
<option value="classical">Classical</option>
|
||||||
|
<option value="cosmic">Cosmic</option>
|
||||||
|
<option value="falling">Falling</option>
|
||||||
|
<option value="gamelan">Gamelan</option>
|
||||||
|
<option value="incoming">Incoming</option>
|
||||||
|
<option value="intermission">Intermission</option>
|
||||||
|
<option value="magic">Magic</option>
|
||||||
|
<option value="mechanical">Mechanical</option>
|
||||||
|
<option value="pianobar">Piano Bar</option>
|
||||||
|
<option value="siren">Siren</option>
|
||||||
|
<option value="spacealarm">Space Alarm</option>
|
||||||
|
<option value="tugboat">Tug Boat</option>
|
||||||
|
<option value="alien">Alien Alarm (long)</option>
|
||||||
|
<option value="climb">Climb (long)</option>
|
||||||
|
<option value="persistent">Persistent (long)</option>
|
||||||
|
<option value="echo">Pushover Echo (long)</option>
|
||||||
|
<option value="updown">Up Down (long)</option>
|
||||||
|
<option value="none">None</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
|
|
|
@ -27,6 +27,8 @@ export class PushoverComponent implements OnInit {
|
||||||
enabled: [x.enabled],
|
enabled: [x.enabled],
|
||||||
userToken: [x.userToken],
|
userToken: [x.userToken],
|
||||||
accessToken: [x.accessToken, [Validators.required]],
|
accessToken: [x.accessToken, [Validators.required]],
|
||||||
|
priority: [x.priority],
|
||||||
|
sound: [x.sound],
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue