markus / MarkusAutoUpdate / src / NetSparkle / Interfaces / IAppCastHandler.cs @ 38d69491
이력 | 보기 | 이력해설 | 다운로드 (2.59 KB)
1 | d8f5045e | taeseongkim | using NetSparkleUpdater.Configurations; |
---|---|---|---|
2 | using System; |
||
3 | using System.Collections.Generic; |
||
4 | using System.Text; |
||
5 | |||
6 | namespace NetSparkleUpdater.Interfaces |
||
7 | { |
||
8 | /// <summary> |
||
9 | /// Interface used by objects that initiate a download process |
||
10 | /// for an app cast, perform any needed signature verification on |
||
11 | /// the app cast, and parse the app cast's items into a list of |
||
12 | /// <see cref="AppCastItem"/>. |
||
13 | /// Implement this interface if you would like to use a custom parsing |
||
14 | /// method for your app cast that isn't yet built into NetSparkle. |
||
15 | /// </summary> |
||
16 | public interface IAppCastHandler |
||
17 | { |
||
18 | /// <summary> |
||
19 | /// Setup the app cast handler info for downloading and parsing app cast information |
||
20 | /// </summary> |
||
21 | /// <param name="dataDownloader">downloader that will manage the app cast download |
||
22 | /// (provided by <see cref="SparkleUpdater"/> via the |
||
23 | /// <see cref="SparkleUpdater.AppCastDataDownloader"/> property.</param> |
||
24 | /// <param name="castUrl">full URL to the app cast file</param> |
||
25 | /// <param name="config">configuration for handling update intervals/checks |
||
26 | /// (user skipped versions, etc.)</param> |
||
27 | /// <param name="signatureVerifier">Object to check signatures of app cast information</param> |
||
28 | /// <param name="logWriter">object that you can utilize to do any necessary logging</param> |
||
29 | void SetupAppCastHandler(IAppCastDataDownloader dataDownloader, string castUrl, Configuration config, |
||
30 | ISignatureVerifier signatureVerifier, ILogger logWriter = null); |
||
31 | |||
32 | /// <summary> |
||
33 | /// Download the app cast file via the <see cref="IAppCastDataDownloader"/> |
||
34 | /// object and parse the downloaded information. |
||
35 | /// If this function is successful, <see cref="SparkleUpdater"/> will call <see cref="GetAvailableUpdates"/> |
||
36 | /// to get the <see cref="AppCastItem"/> information. |
||
37 | /// Note that you must handle your own exceptions if they occur. Otherwise, <see cref="SparkleUpdater"/> |
||
38 | /// will act as though the appc ast failed to download. |
||
39 | /// </summary> |
||
40 | /// <returns>true if downloading and parsing succeeded; false otherwise</returns> |
||
41 | bool DownloadAndParse(); |
||
42 | |||
43 | /// <summary> |
||
44 | /// Retrieve the available updates from the app cast. |
||
45 | /// This should be called after <see cref="DownloadAndParse"/> has |
||
46 | /// successfully completed. |
||
47 | /// </summary> |
||
48 | /// <returns>a list of <see cref="AppCastItem"/> updates. Can be empty if no updates are available.</returns> |
||
49 | List<AppCastItem> GetAvailableUpdates(); |
||
50 | } |
||
51 | } |