diff options
author | crupest <crupest@outlook.com> | 2020-08-07 23:51:29 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2020-08-07 23:51:29 +0800 |
commit | 151105f387c65f2285f61f8e492ad06734ec9f64 (patch) | |
tree | c2186add6890e2a5af233345b08af065cada4d68 /Timeline/ClientApp/src/app/http/common.ts | |
parent | bace0870ee294e44d0112ba49de12b27fa3c0a31 (diff) | |
download | timeline-151105f387c65f2285f61f8e492ad06734ec9f64.tar.gz timeline-151105f387c65f2285f61f8e492ad06734ec9f64.tar.bz2 timeline-151105f387c65f2285f61f8e492ad06734ec9f64.zip |
...
Diffstat (limited to 'Timeline/ClientApp/src/app/http/common.ts')
-rw-r--r-- | Timeline/ClientApp/src/app/http/common.ts | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/Timeline/ClientApp/src/app/http/common.ts b/Timeline/ClientApp/src/app/http/common.ts index 3c2f2ba6..8b082d1f 100644 --- a/Timeline/ClientApp/src/app/http/common.ts +++ b/Timeline/ClientApp/src/app/http/common.ts @@ -45,6 +45,12 @@ export class HttpNetworkError extends Error { }
}
+export class HttpForbiddenError extends Error {
+ constructor(public innerError?: AxiosError) {
+ super();
+ }
+}
+
export class NotModified {}
export interface BlobWithEtag {
@@ -119,6 +125,20 @@ export function convertToNetworkError( }
}
+export function convertToForbiddenError(
+ error: AxiosError<CommonErrorResponse>
+): never {
+ if (
+ error.isAxiosError &&
+ error.response != null &&
+ (error.response.status == 403 || error.response.status == 403)
+ ) {
+ throw new HttpForbiddenError(error);
+ } else {
+ throw error;
+ }
+}
+
export function extractDataOrConvert304ToNotModified<T>(
res: AxiosResponse<T>
): T | NotModified {
|