mirror of
https://github.com/usebruno/bruno.git
synced 2025-01-12 08:58:15 +01:00
feat(#119): basic auth support completed
This commit is contained in:
parent
48e4e60696
commit
3f4f7fb24c
@ -0,0 +1,10 @@
|
|||||||
|
import styled from 'styled-components';
|
||||||
|
|
||||||
|
const Wrapper = styled.div`
|
||||||
|
.single-line-editor-wrapper {
|
||||||
|
padding: 0.15rem 0.4rem;
|
||||||
|
border: ${(props) => props.theme.sidebar.search.border};
|
||||||
|
}
|
||||||
|
`;
|
||||||
|
|
||||||
|
export default Wrapper;
|
@ -0,0 +1,76 @@
|
|||||||
|
import React from 'react';
|
||||||
|
import get from 'lodash/get';
|
||||||
|
import { useTheme } from 'providers/Theme';
|
||||||
|
import { useDispatch } from 'react-redux';
|
||||||
|
import SingleLineEditor from 'components/SingleLineEditor';
|
||||||
|
import { updateAuth } from 'providers/ReduxStore/slices/collections';
|
||||||
|
import { sendRequest, saveRequest } from 'providers/ReduxStore/slices/collections/actions';
|
||||||
|
import StyledWrapper from './StyledWrapper';
|
||||||
|
|
||||||
|
const BasicAuth = ({ item, collection }) => {
|
||||||
|
const dispatch = useDispatch();
|
||||||
|
const { storedTheme } = useTheme();
|
||||||
|
|
||||||
|
const basicAuth = item.draft ? get(item, 'draft.request.auth.basic', {}) : get(item, 'request.auth.basic', {});
|
||||||
|
|
||||||
|
const handleRun = () => dispatch(sendRequest(item, collection.uid));
|
||||||
|
const handleSave = () => dispatch(saveRequest(item.uid, collection.uid));
|
||||||
|
|
||||||
|
const handleUsernameChange = (username) => {
|
||||||
|
dispatch(
|
||||||
|
updateAuth({
|
||||||
|
mode: 'basic',
|
||||||
|
collectionUid: collection.uid,
|
||||||
|
itemUid: item.uid,
|
||||||
|
content: {
|
||||||
|
username: username,
|
||||||
|
password: basicAuth.password
|
||||||
|
}
|
||||||
|
})
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
const handlePasswordChange = (password) => {
|
||||||
|
dispatch(
|
||||||
|
updateAuth({
|
||||||
|
mode: 'basic',
|
||||||
|
collectionUid: collection.uid,
|
||||||
|
itemUid: item.uid,
|
||||||
|
content: {
|
||||||
|
username: basicAuth.username,
|
||||||
|
password: password
|
||||||
|
}
|
||||||
|
})
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<StyledWrapper className="mt-2 w-full">
|
||||||
|
<label className="block font-medium mb-2">Username</label>
|
||||||
|
<div className="single-line-editor-wrapper mb-2">
|
||||||
|
<SingleLineEditor
|
||||||
|
value={basicAuth.username || ''}
|
||||||
|
theme={storedTheme}
|
||||||
|
onSave={handleSave}
|
||||||
|
onChange={(val) => handleUsernameChange(val)}
|
||||||
|
onRun={handleRun}
|
||||||
|
collection={collection}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<label className="block font-medium mb-2">Password</label>
|
||||||
|
<div className="single-line-editor-wrapper">
|
||||||
|
<SingleLineEditor
|
||||||
|
value={basicAuth.password || ''}
|
||||||
|
theme={storedTheme}
|
||||||
|
onSave={handleSave}
|
||||||
|
onChange={(val) => handlePasswordChange(val)}
|
||||||
|
onRun={handleRun}
|
||||||
|
collection={collection}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</StyledWrapper>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default BasicAuth;
|
@ -1,13 +1,13 @@
|
|||||||
import React, { useState } from 'react';
|
import React from 'react';
|
||||||
import get from 'lodash/get';
|
import get from 'lodash/get';
|
||||||
import { useTheme } from 'providers/Theme';
|
import { useTheme } from 'providers/Theme';
|
||||||
import { useDispatch } from 'react-redux';
|
import { useDispatch } from 'react-redux';
|
||||||
import SingleLineEditor from 'components/SingleLineEditor';
|
import SingleLineEditor from 'components/SingleLineEditor';
|
||||||
import { updateBearerToken } from 'providers/ReduxStore/slices/collections';
|
import { updateAuth } from 'providers/ReduxStore/slices/collections';
|
||||||
import { sendRequest, saveRequest } from 'providers/ReduxStore/slices/collections/actions';
|
import { sendRequest, saveRequest } from 'providers/ReduxStore/slices/collections/actions';
|
||||||
import StyledWrapper from './StyledWrapper';
|
import StyledWrapper from './StyledWrapper';
|
||||||
|
|
||||||
const BearerAuth = ({ onTokenChange, item, collection }) => {
|
const BearerAuth = ({ item, collection }) => {
|
||||||
const dispatch = useDispatch();
|
const dispatch = useDispatch();
|
||||||
const { storedTheme } = useTheme();
|
const { storedTheme } = useTheme();
|
||||||
|
|
||||||
@ -20,7 +20,8 @@ const BearerAuth = ({ onTokenChange, item, collection }) => {
|
|||||||
|
|
||||||
const handleTokenChange = (token) => {
|
const handleTokenChange = (token) => {
|
||||||
dispatch(
|
dispatch(
|
||||||
updateBearerToken({
|
updateAuth({
|
||||||
|
mode: 'bearer',
|
||||||
collectionUid: collection.uid,
|
collectionUid: collection.uid,
|
||||||
itemUid: item.uid,
|
itemUid: item.uid,
|
||||||
content: {
|
content: {
|
||||||
@ -32,9 +33,7 @@ const BearerAuth = ({ onTokenChange, item, collection }) => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<StyledWrapper className="mt-2 w-full">
|
<StyledWrapper className="mt-2 w-full">
|
||||||
<label htmlFor="bearerToken" className="block font-medium mb-2">
|
<label className="block font-medium mb-2">Token</label>
|
||||||
Token
|
|
||||||
</label>
|
|
||||||
<div className="single-line-editor-wrapper">
|
<div className="single-line-editor-wrapper">
|
||||||
<SingleLineEditor
|
<SingleLineEditor
|
||||||
value={bearerToken}
|
value={bearerToken}
|
||||||
|
@ -2,6 +2,7 @@ import React from 'react';
|
|||||||
import get from 'lodash/get';
|
import get from 'lodash/get';
|
||||||
import AuthMode from './AuthMode';
|
import AuthMode from './AuthMode';
|
||||||
import BearerAuth from './BearerAuth';
|
import BearerAuth from './BearerAuth';
|
||||||
|
import BasicAuth from './BasicAuth';
|
||||||
import StyledWrapper from './StyledWrapper';
|
import StyledWrapper from './StyledWrapper';
|
||||||
|
|
||||||
const Auth = ({ item, collection }) => {
|
const Auth = ({ item, collection }) => {
|
||||||
@ -10,7 +11,7 @@ const Auth = ({ item, collection }) => {
|
|||||||
const getAuthView = () => {
|
const getAuthView = () => {
|
||||||
switch (authMode) {
|
switch (authMode) {
|
||||||
case 'basic': {
|
case 'basic': {
|
||||||
return <div>Basic Auth</div>;
|
return <BasicAuth collection={collection} item={item} />;
|
||||||
}
|
}
|
||||||
case 'bearer': {
|
case 'bearer': {
|
||||||
return <BearerAuth collection={collection} item={item} />;
|
return <BearerAuth collection={collection} item={item} />;
|
||||||
|
@ -16,7 +16,7 @@ import CollectionItem from './CollectionItem';
|
|||||||
import RemoveCollection from './RemoveCollection';
|
import RemoveCollection from './RemoveCollection';
|
||||||
import CollectionProperties from './CollectionProperties';
|
import CollectionProperties from './CollectionProperties';
|
||||||
import { doesCollectionHaveItemsMatchingSearchText } from 'utils/collections/search';
|
import { doesCollectionHaveItemsMatchingSearchText } from 'utils/collections/search';
|
||||||
import { isItemAFolder, isItemARequest, transformCollectionToSaveToIdb } from 'utils/collections';
|
import { isItemAFolder, isItemARequest, transformCollectionToSaveToExportAsFile } from 'utils/collections';
|
||||||
import exportCollection from 'utils/collections/export';
|
import exportCollection from 'utils/collections/export';
|
||||||
|
|
||||||
import RenameCollection from './RenameCollection';
|
import RenameCollection from './RenameCollection';
|
||||||
@ -69,7 +69,7 @@ const Collection = ({ collection, searchText }) => {
|
|||||||
|
|
||||||
const handleExportClick = () => {
|
const handleExportClick = () => {
|
||||||
const collectionCopy = cloneDeep(collection);
|
const collectionCopy = cloneDeep(collection);
|
||||||
exportCollection(transformCollectionToSaveToIdb(collectionCopy));
|
exportCollection(transformCollectionToSaveToExportAsFile(collectionCopy));
|
||||||
};
|
};
|
||||||
|
|
||||||
const [{ isOver }, drop] = useDrop({
|
const [{ isOver }, drop] = useDrop({
|
||||||
|
@ -322,7 +322,7 @@ export const collectionsSlice = createSlice({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
updateBearerToken: (state, action) => {
|
updateAuth: (state, action) => {
|
||||||
const collection = findCollectionByUid(state.collections, action.payload.collectionUid);
|
const collection = findCollectionByUid(state.collections, action.payload.collectionUid);
|
||||||
|
|
||||||
if (collection) {
|
if (collection) {
|
||||||
@ -334,10 +334,15 @@ export const collectionsSlice = createSlice({
|
|||||||
}
|
}
|
||||||
|
|
||||||
item.draft.request.auth = item.draft.request.auth || {};
|
item.draft.request.auth = item.draft.request.auth || {};
|
||||||
switch (item.draft.request.auth.mode) {
|
switch (action.payload.mode) {
|
||||||
case 'bearer':
|
case 'bearer':
|
||||||
|
item.draft.request.auth.mode = 'bearer';
|
||||||
item.draft.request.auth.bearer = action.payload.content;
|
item.draft.request.auth.bearer = action.payload.content;
|
||||||
break;
|
break;
|
||||||
|
case 'basic':
|
||||||
|
item.draft.request.auth.mode = 'basic';
|
||||||
|
item.draft.request.auth.basic = action.payload.content;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1208,7 +1213,7 @@ export const {
|
|||||||
collectionClicked,
|
collectionClicked,
|
||||||
collectionFolderClicked,
|
collectionFolderClicked,
|
||||||
requestUrlChanged,
|
requestUrlChanged,
|
||||||
updateBearerToken,
|
updateAuth,
|
||||||
addQueryParam,
|
addQueryParam,
|
||||||
updateQueryParam,
|
updateQueryParam,
|
||||||
deleteQueryParam,
|
deleteQueryParam,
|
||||||
|
@ -207,7 +207,7 @@ export const getItemsToResequence = (parent, collection) => {
|
|||||||
return itemsToResequence;
|
return itemsToResequence;
|
||||||
};
|
};
|
||||||
|
|
||||||
export const transformCollectionToSaveToIdb = (collection, options = {}) => {
|
export const transformCollectionToSaveToExportAsFile = (collection, options = {}) => {
|
||||||
const copyHeaders = (headers) => {
|
const copyHeaders = (headers) => {
|
||||||
return map(headers, (header) => {
|
return map(headers, (header) => {
|
||||||
return {
|
return {
|
||||||
@ -285,6 +285,16 @@ export const transformCollectionToSaveToIdb = (collection, options = {}) => {
|
|||||||
formUrlEncoded: copyFormUrlEncodedParams(si.draft.request.body.formUrlEncoded),
|
formUrlEncoded: copyFormUrlEncodedParams(si.draft.request.body.formUrlEncoded),
|
||||||
multipartForm: copyMultipartFormParams(si.draft.request.body.multipartForm)
|
multipartForm: copyMultipartFormParams(si.draft.request.body.multipartForm)
|
||||||
},
|
},
|
||||||
|
auth: {
|
||||||
|
mode: get(si.draft.request, 'auth.mode', 'none'),
|
||||||
|
basic: {
|
||||||
|
username: get(si.draft.request, 'auth.basic.username', ''),
|
||||||
|
password: get(si.draft.request, 'auth.basic.password', '')
|
||||||
|
},
|
||||||
|
bearer: {
|
||||||
|
token: get(si.draft.request, 'auth.bearer.token', '')
|
||||||
|
}
|
||||||
|
},
|
||||||
script: si.draft.request.script,
|
script: si.draft.request.script,
|
||||||
vars: si.draft.request.vars,
|
vars: si.draft.request.vars,
|
||||||
assertions: si.draft.request.assertions,
|
assertions: si.draft.request.assertions,
|
||||||
@ -307,6 +317,16 @@ export const transformCollectionToSaveToIdb = (collection, options = {}) => {
|
|||||||
formUrlEncoded: copyFormUrlEncodedParams(si.request.body.formUrlEncoded),
|
formUrlEncoded: copyFormUrlEncodedParams(si.request.body.formUrlEncoded),
|
||||||
multipartForm: copyMultipartFormParams(si.request.body.multipartForm)
|
multipartForm: copyMultipartFormParams(si.request.body.multipartForm)
|
||||||
},
|
},
|
||||||
|
auth: {
|
||||||
|
mode: get(si.request, 'auth.mode', 'none'),
|
||||||
|
basic: {
|
||||||
|
username: get(si.request, 'auth.basic.username', ''),
|
||||||
|
password: get(si.request, 'auth.basic.password', '')
|
||||||
|
},
|
||||||
|
bearer: {
|
||||||
|
token: get(si.request, 'auth.bearer.token', '')
|
||||||
|
}
|
||||||
|
},
|
||||||
script: si.request.script,
|
script: si.request.script,
|
||||||
vars: si.request.vars,
|
vars: si.request.vars,
|
||||||
assertions: si.request.assertions,
|
assertions: si.request.assertions,
|
||||||
|
Loading…
Reference in New Issue
Block a user