mirror of
https://github.com/RoboSats/robosats.git
synced 2025-01-18 20:21:35 +00:00
Create order detail API endpoint, create order page. Not fully working yet
This commit is contained in:
parent
e087d0b686
commit
298efc394b
@ -4,7 +4,7 @@ from .models import Order
|
|||||||
class OrderSerializer(serializers.ModelSerializer):
|
class OrderSerializer(serializers.ModelSerializer):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Order
|
model = Order
|
||||||
fields = ('id','status','created_at','type','currency','amount','payment_method','premium','satoshis','maker')
|
fields = ('id','status','created_at','type','currency','amount','payment_method','premium','satoshis','maker','taker')
|
||||||
|
|
||||||
class MakeOrderSerializer(serializers.ModelSerializer):
|
class MakeOrderSerializer(serializers.ModelSerializer):
|
||||||
class Meta:
|
class Meta:
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
from django.urls import path
|
from django.urls import path
|
||||||
from .views import MakeOrder
|
from .views import MakeOrder, OrderView
|
||||||
|
|
||||||
urlpatterns = [
|
urlpatterns = [
|
||||||
path('make/', MakeOrder.as_view())
|
path('make/', MakeOrder.as_view()),
|
||||||
|
path('order/', OrderView.as_view()),
|
||||||
]
|
]
|
43
api/views.py
43
api/views.py
@ -2,6 +2,8 @@ from rest_framework import status
|
|||||||
from rest_framework.views import APIView
|
from rest_framework.views import APIView
|
||||||
from rest_framework.response import Response
|
from rest_framework.response import Response
|
||||||
|
|
||||||
|
from django.contrib.auth.models import User
|
||||||
|
|
||||||
from .serializers import OrderSerializer, MakeOrderSerializer
|
from .serializers import OrderSerializer, MakeOrderSerializer
|
||||||
from .models import Order
|
from .models import Order
|
||||||
|
|
||||||
@ -11,9 +13,8 @@ class MakeOrder(APIView):
|
|||||||
serializer_class = MakeOrderSerializer
|
serializer_class = MakeOrderSerializer
|
||||||
|
|
||||||
def post(self,request):
|
def post(self,request):
|
||||||
|
|
||||||
serializer = self.serializer_class(data=request.data)
|
serializer = self.serializer_class(data=request.data)
|
||||||
print(serializer)
|
|
||||||
if serializer.is_valid():
|
if serializer.is_valid():
|
||||||
otype = serializer.data.get('type')
|
otype = serializer.data.get('type')
|
||||||
currency = serializer.data.get('currency')
|
currency = serializer.data.get('currency')
|
||||||
@ -40,3 +41,41 @@ class MakeOrder(APIView):
|
|||||||
return Response(status=status.HTTP_400_BAD_REQUEST)
|
return Response(status=status.HTTP_400_BAD_REQUEST)
|
||||||
|
|
||||||
return Response(OrderSerializer(order).data, status=status.HTTP_201_CREATED)
|
return Response(OrderSerializer(order).data, status=status.HTTP_201_CREATED)
|
||||||
|
|
||||||
|
|
||||||
|
class OrderView(APIView):
|
||||||
|
serializer_class = OrderSerializer
|
||||||
|
lookup_url_kwarg = 'order_id'
|
||||||
|
|
||||||
|
def get(self, request, format=None):
|
||||||
|
order_id = request.GET.get(self.lookup_url_kwarg)
|
||||||
|
|
||||||
|
if order_id != None:
|
||||||
|
order = Order.objects.filter(id=order_id)
|
||||||
|
|
||||||
|
# check if exactly one order is found in the db
|
||||||
|
if len(order) == 1 :
|
||||||
|
print("It is only one!")
|
||||||
|
order = order[0]
|
||||||
|
data = self.serializer_class(order).data
|
||||||
|
|
||||||
|
# TODO
|
||||||
|
# # Check if requester is participant in the order and add boolean to response
|
||||||
|
|
||||||
|
# user = authenticate(username=username, password=password)
|
||||||
|
# data['is_participant'] = any(user.id == order.maker, user.id == order.taker)
|
||||||
|
|
||||||
|
# if data['is_participant']:
|
||||||
|
# return Response(data, status=status.HTTP_200_OK)
|
||||||
|
# else:
|
||||||
|
# # Non participants can't get access to the status or who is the taker
|
||||||
|
# data.pop(['status'],['taker'])
|
||||||
|
# return Response(data, status=status.HTTP_200_OK)
|
||||||
|
|
||||||
|
return Response(data, status=status.HTTP_200_OK)
|
||||||
|
|
||||||
|
return Response({'Order Not Found':'Invalid Order Id'},status=status.HTTP_404_NOT_FOUND)
|
||||||
|
|
||||||
|
return Response({'Bad Request':'Order ID parameter not found in request'}, status=status.HTTP_400_BAD_REQUEST)
|
||||||
|
|
||||||
|
|
||||||
|
@ -22,7 +22,7 @@ export default class HomePage extends Component {
|
|||||||
<Route path='/login'component={LoginPage}/>
|
<Route path='/login'component={LoginPage}/>
|
||||||
<Route path='/make' component={MakerPage}/>
|
<Route path='/make' component={MakerPage}/>
|
||||||
<Route path='/book' component={BookPage}/>
|
<Route path='/book' component={BookPage}/>
|
||||||
<Route path='/order' component={OrderPage}/>
|
<Route path="/order/:orderId" component={OrderPage}/>
|
||||||
<Route path='/wait' component={WaitingRoomPage}/>
|
<Route path='/wait' component={WaitingRoomPage}/>
|
||||||
</Switch>
|
</Switch>
|
||||||
</Router>
|
</Router>
|
||||||
|
@ -103,7 +103,7 @@ export default class MakerPage extends Component {
|
|||||||
};
|
};
|
||||||
fetch("/api/make/",requestOptions)
|
fetch("/api/make/",requestOptions)
|
||||||
.then((response) => response.json())
|
.then((response) => response.json())
|
||||||
.then((data) => console.log(data));
|
.then((data) => this.props.history.push('/order/' + data.id));
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
|
@ -3,9 +3,58 @@ import React, { Component } from "react";
|
|||||||
export default class OrderPage extends Component {
|
export default class OrderPage extends Component {
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
super(props);
|
super(props);
|
||||||
|
this.state = {
|
||||||
|
status: 0,
|
||||||
|
type: 0,
|
||||||
|
currency: 0,
|
||||||
|
currencyCode: 'USD',
|
||||||
|
is_participant: false,
|
||||||
|
amount: 1,
|
||||||
|
paymentMethod:"",
|
||||||
|
premium: 0,
|
||||||
|
satoshis: null,
|
||||||
|
makerId: "",
|
||||||
|
// makerNick:"",
|
||||||
|
// takerId: "",
|
||||||
|
// takerNick:"",
|
||||||
|
};
|
||||||
|
this.orderId = this.props.match.params.orderId;
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
get_order_details() {
|
||||||
return <p>This is the single order detail view page</p>;
|
fetch('api/order' + '?order_id' + this.orderId)
|
||||||
|
.then((response) => response.json())
|
||||||
|
.then((data) => {
|
||||||
|
this.setState({
|
||||||
|
status: data.status,
|
||||||
|
type: data.type,
|
||||||
|
currency: data.currency,
|
||||||
|
amount: data.amount,
|
||||||
|
paymentMethod: data.payment_method,
|
||||||
|
premium: data.premium,
|
||||||
|
makerId: maker,
|
||||||
|
// satoshis: satoshis,
|
||||||
|
// isParticipant: is_participant,
|
||||||
|
// makerNick: maker_nick,
|
||||||
|
// takerId: taker,
|
||||||
|
// takerNick: taker_nick,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
render (){
|
||||||
|
return (
|
||||||
|
<div>
|
||||||
|
<p>This is the single order detail view page</p>
|
||||||
|
<p>Order id: {this.orderId}</p>
|
||||||
|
<p>Order status: {this.state.status}</p>
|
||||||
|
<p>Order type: {this.state.type}</p>
|
||||||
|
<p>Currency: {this.state.currencyCode}</p>
|
||||||
|
<p>Amount: {this.state.amount}</p>
|
||||||
|
<p>Payment method: {this.state.paymentMethod}</p>
|
||||||
|
<p>Premium: {this.state.premium}</p>
|
||||||
|
<p>Maker: {this.makerId}</p>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
File diff suppressed because one or more lines are too long
@ -7,6 +7,6 @@ urlpatterns = [
|
|||||||
path('login/', index),
|
path('login/', index),
|
||||||
path('make/', index),
|
path('make/', index),
|
||||||
path('book/', index),
|
path('book/', index),
|
||||||
path('order/', index),
|
path('order/<int:orderId>', index),
|
||||||
path('wait/', index),
|
path('wait/', index),
|
||||||
]
|
]
|
Loading…
Reference in New Issue
Block a user