From 5a77e2930ec14c728c69386f4a713b69c7d37fc2 Mon Sep 17 00:00:00 2001 From: 1aerostorm Date: Mon, 17 Jun 2024 14:54:37 +0300 Subject: [PATCH] Image proxy - imgur fallback --- app/redux/UserSaga_UploadImage.js | 84 ++++++++++++++++++------------- 1 file changed, 50 insertions(+), 34 deletions(-) diff --git a/app/redux/UserSaga_UploadImage.js b/app/redux/UserSaga_UploadImage.js index e3262f88..5e38af67 100644 --- a/app/redux/UserSaga_UploadImage.js +++ b/app/redux/UserSaga_UploadImage.js @@ -70,7 +70,27 @@ function* uploadImage(action) { } let postUrl = $STM_Config.images.upload_image + let golosImages = false + const user = yield select(state => state.user) + const switchToGolosImages = async () => { + const username = user.getIn(['current', 'username']); + const postingKey = user.getIn([ + 'current', + 'private_keys', + 'posting_private', + ]); + if (!username || !postingKey) { + onError(tt('user_saga_js.image_upload.error.login_first')); + return; + } + const signatures = signData(data, { + posting: postingKey, + }) + postUrl = new URL('/@' + username + '/' + signatures.posting, $STM_Config.images.img_proxy_prefix).toString(); + golosImages = true + } + if (file) { if (imageSizeLimit && file.size > imageSizeLimit) { onError(tt('user_saga_js.image_upload.error.image_size_is_too_large')); @@ -94,25 +114,18 @@ function* uploadImage(action) { console.error('image_proxy start_upload:', err) } if (recommended) { - const user = yield select(state => state.user); - const username = user.getIn(['current', 'username']); - const postingKey = user.getIn([ - 'current', - 'private_keys', - 'posting_private', - ]); - if (!username || !postingKey) { - onError(tt('user_saga_js.image_upload.error.login_first')); - return; - } - const signatures = signData(data, { - posting: postingKey, - }) - postUrl = new URL('/@' + username + '/' + signatures.posting, $STM_Config.images.img_proxy_prefix).toString(); - golosImages = true + yield switchToGolosImages() } } } + const onImgurFail = async (imgurErr) => { + console.log('onImgurFail - switch to Golos Images..') + await switchToGolosImages() + console.log('onImgurFail - ok, sending..') + xhr.open('POST', postUrl); + formData.append('fallback', imgurErr) + xhr.send(formData) + } /** * The challenge needs to be prefixed with a constant (both on the server @@ -140,7 +153,7 @@ function* uploadImage(action) { xhr.setRequestHeader('Authorization', 'Client-ID ' + $STM_Config.images.client_id) } - xhr.onload = function() { + xhr.onload = async function() { let data; try { @@ -167,37 +180,40 @@ function* uploadImage(action) { console.error('Cannot upload image:', xhr.responseText); - let repeat = false; if (!golosImages) { if (xhr.responseText.includes('Invalid client')) { ++imgurFailCounter; if (imgurFailCounter < 5) { - repeat = true; setTimeout(() => { xhr.open('POST', postUrl); xhr.setRequestHeader('Authorization', 'Client-ID ' + $STM_Config.images.client_id) xhr.send(formData); }, 1000); + return } } + if (!xhr.responseText.includes('file type invalid') + && !xhr.responseText.includes('We don\'t support that file type!')) { + await onImgurFail(xhr.responseText) + return + } } - if (!repeat) { - let err = xhr.responseText - if (golosImages) { - if (data.error === 'too_low_account_golos_power') { - const need = Asset(data.required) - const add = need.minus(Asset(data.power)) - err = tt('user_saga_js.image_upload.error.low_golos_power_NEED_ADD', - { - NEED: need.floatString, - ADD: add.floatString - }) - } else if (data.error === 'too_low_account_reputation') { - err = tt('user_saga_js.image_upload.error.low_reputation') + data.required - } + + let err = xhr.responseText + if (golosImages) { + if (data.error === 'too_low_account_golos_power') { + const need = Asset(data.required) + const add = need.minus(Asset(data.power)) + err = tt('user_saga_js.image_upload.error.low_golos_power_NEED_ADD', + { + NEED: need.floatString, + ADD: add.floatString + }) + } else if (data.error === 'too_low_account_reputation') { + err = tt('user_saga_js.image_upload.error.low_reputation') + data.required } - onError(err) } + onError(err) } else { let result = {} if (!golosImages) {