diff --git a/netlify/functions/fetch-url.js b/netlify/functions/fetch-url.js new file mode 100644 index 000000000..9163419c5 --- /dev/null +++ b/netlify/functions/fetch-url.js @@ -0,0 +1,46 @@ +import axios from 'axios'; + +async function handleURL({ url }) { + try { + const { data } = await axios.get(url, { + // Throws error whenever response status >= 400 + validateStatus: (status) => { + console.log(`Returning status ${status} for ${url}`); + return status < 400; + }, + }); + + return new Response(data, { + status: 200, + headers: { + 'Cache-Control': 'public, durable, max-age=300', + }, + }); + } catch (err) { + console.log({ err }); + + if (axios.isAxiosError(err) && err.response) { + return new Response(null, { status: err.response.status }); + } + return new Response(null, { status: 500 }); + } +} + +// This function exists only to help proxy URLs that were originally causing 403 errors, potentially due +// to IP addresses. (DOP-5189) +async function handler(req, context) { + const params = context.url.searchParams; + const url = params.get('url'); + + // Log to help keep track of requests + console.log({ req, context }); + + if (url) { + return handleURL({ url }); + } + + // Expected to only work when a url query param is defined + return new Response(null, { status: 400 }); +} + +export default handler; diff --git a/src/components/ActionBar/styles.js b/src/components/ActionBar/styles.js index 3a93e7471..502b1a2f0 100644 --- a/src/components/ActionBar/styles.js +++ b/src/components/ActionBar/styles.js @@ -186,7 +186,9 @@ export const searchInputStyling = ({ mobileSearchActive }) => css` ${displayNone.onMedium}; @media ${theme.screenSize.upToMedium} { - font-size: ${theme.fontSize.default}; + input[type='search'] { + font-size: ${theme.fontSize.default}; + } } ${mobileSearchActive &&