feat(donate): remove unauthenticated routes

This commit is contained in:
Mrugesh Mohapatra
2019-11-14 01:33:53 +05:30
parent e13f35171c
commit ef0a801c90
3 changed files with 22 additions and 39 deletions

View File

@ -8,7 +8,6 @@ const log = debug('fcc:boot:donate');
export default function donateBoot(app, done) {
let stripe = false;
const { User } = app.models;
const api = app.loopback.Router();
const donateRouter = app.loopback.Router();
@ -105,8 +104,16 @@ export default function donateBoot(app, done) {
function createStripeDonation(req, res) {
const { user, body } = req;
if (!user) {
return res
.status(500)
.send({ error: 'User must be signed in for this request.' });
}
if (!body || !body.amount || !body.duration) {
return res.status(400).send({ error: 'Amount and duration Required.' });
return res.status(500).send({
error: 'The donation form had invalid values for this submission.'
});
}
const {
@ -116,29 +123,11 @@ export default function donateBoot(app, done) {
} = body;
if (!validStripeForm(amount, duration, email)) {
return res
.status(500)
.send({ error: 'Invalid donation form values submitted' });
return res.status(500).send({
error: 'The donation form had invalid values for this submission.'
});
}
const isOneTime = duration === 'onetime' ? true : false;
const fccUser = user
? Promise.resolve(user)
: new Promise((resolve, reject) =>
User.findOrCreate(
{ where: { email } },
{ email },
(err, instance, isNew) => {
log('is new user instance: ', isNew);
if (err) {
return reject(err);
}
return resolve(instance);
}
)
);
let donatingUser = {};
let donation = {
email,
@ -188,20 +177,20 @@ export default function donateBoot(app, done) {
});
};
return fccUser
.then(user => {
const { isDonating } = user;
return Promise.resolve(user)
.then(nonDonatingUser => {
const { isDonating } = nonDonatingUser;
if (isDonating) {
throw {
message: `User already has active donation(s).`,
type: 'AlreadyDonatingError'
};
}
return user;
return nonDonatingUser;
})
.then(createCustomer)
.then(customer => {
return isOneTime
return duration === 'onetime'
? createOneTimeCharge(customer).then(charge => {
donation.subscriptionId = 'one-time-charge-prefix-' + charge.id;
return res.send(charge);
@ -241,7 +230,6 @@ export default function donateBoot(app, done) {
donateRouter.use('/donate', api);
app.use(donateRouter);
app.use('/internal', donateRouter);
app.use('/unauthenticated', donateRouter);
connectToStripe().then(done);
}
}

View File

@ -15,7 +15,7 @@ import { injectStripe } from 'react-stripe-elements';
import StripeCardForm from './StripeCardForm';
import DonateCompletion from './DonateCompletion';
import { postChargeStripe } from '../../../utils/ajax';
import { userSelector, isSignedInSelector } from '../../../redux';
import { userSelector } from '../../../redux';
const propTypes = {
donationAmount: PropTypes.number.isRequired,
@ -39,8 +39,7 @@ const initialState = {
const mapStateToProps = createSelector(
userSelector,
isSignedInSelector,
({ email, theme }, isSignedIn) => ({ email, theme, isSignedIn })
({ email, theme }) => ({ email, theme })
);
class DonateFormChildViewForHOC extends Component {
@ -122,7 +121,6 @@ class DonateFormChildViewForHOC extends Component {
postDonation(token) {
const { donationAmount: amount, donationDuration: duration } = this.state;
const { isSignedIn } = this.props;
this.setState(state => ({
...state,
donationState: {
@ -131,7 +129,7 @@ class DonateFormChildViewForHOC extends Component {
}
}));
return postChargeStripe(isSignedIn, {
return postChargeStripe({
token,
amount,
duration

View File

@ -50,11 +50,8 @@ export function getArticleById(shortId) {
}
/** POST **/
export function postChargeStripe(isSignedIn, body) {
const donatePath = '/donate/charge-stripe';
return isSignedIn
? post(donatePath, body)
: postUnauthenticated(donatePath, body);
export function postChargeStripe(body) {
return post(`/donate/charge-stripe`, body);
}
export function putUpdateLegacyCert(body) {