Place Limit Order
1. placeLimitOrder.cs
We will first import these four packages as they are required to run the solution.
Step 1. Create class file to store content of the web response.
2. PlaceLimitOrder.aspx.cs
We will first import these 16 packages as they are required to run the solution.
Code in Common
Step 1. We would first have to check if the user id and password are already stored inside the session. If the user id and password are stored, the solution will automatically populate into the user id and pin textbox. This is to provide convenience for the users as they do not need to manually type their user id and password repeatedly. Else, if the user id and password are not stored yet, we would then store them inside the session.
Step 2. The next step would be to store the details entered by the user. If the user id, password, and OTP already exist in session, users would not need to enter them again (refer to common stuff).
Step 3. Create the URL which would be posted to the server. User inputs need to be stored in the class created, and serialize into JSON format. In this function, both the header and content are needed.
Step 4. After creating the URL, we would post the URL to the server, and store response. The URL is being sent using a web request function, and a response will be send back from the server. The response need to be deserialized first into the ‘placeLimitOrder’ class.
Step 5. Next step would be to obtain the error code. If error code is ‘010000’ which means invocation successful, the solution would populate the attributes of the ‘placeLimitOrder’ class into the label(s). If error code is '010041', it means that the OTP has expired, and we will use the newOTP() function to prompt the user for their OTP again. Else, we will display the ErrorText and ErrorDetails.
The newOTP() function can be referred to under Common Stuff Section
Overview of placeLimitOrder.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
namespace Demo
{
public class placeLimitOrderServiceRespHeader
{
public string ErrorText { get; set; }
public object ErrorDetails { get; set; }
public string GlobalErrorID { get; set; }
}
public class placeLimitOrderStockOrder
{
public string orderID { get; set; }
}
public class placeLimitOrderServiceResponse
{
public placeLimitOrderServiceRespHeader ServiceRespHeader { get; set; }
public placeLimitOrderStockOrder StockOrder { get; set; }
}
public class placeLimitOrderContent
{
public placeLimitOrderServiceResponse ServiceResponse { get; set; }
}
public class placeLimitOrderRootObject
{
public placeLimitOrderContent Content { get; set; }
}
}
Overview of PlaceLimitOrder.aspx.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using DotNetOpenAuth.OAuth2;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
using System.Collections.Specialized;
using System.Configuration;
using System.Net;
using System.IO;
using System.Windows.Forms;
using System.Data;
using Microsoft.VisualBasic;
namespace Demo
{
public partial class PlaceLimitOrder : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (Page.IsPostBack == false)
{
if (Session["userid"] != null)
{
txtUserID.Text = (string)Session["userid"];
txtPassword.Text = (string)Session["pin"];
}
}
}
protected void btnSend_Click(object sender, EventArgs e)
{
if (Page.IsValid)
{
try
{
string userID = txtUserID.Text;
Session["userid"] = userID;
string pin = txtPassword.Text;
Session["pin"] = pin;
string settlementAccount = txtsettlementAccount.Text;
string symbol = txtsymbol.Text;
string buyOrSell = txtbuyOrSell.Text;
string quantity = txtquantity.Text;
string limitPrice = txtlimitPrice.Text;
string expirationType = txtexpirationType.Text;
string maturityDate = txtmaturityDate.Text;
string otp;
if (Session["otp"] == null)
{
otp = "";
}
else
{
otp = Session["otp"].ToString();
}
var header = new HeaderJson();
header.userID = userID;
header.PIN = pin;
header.serviceName = "placeLimitOrder";
header.OTP = otp;
var headerJson = new HeaderJsonObject();
headerJson.Header = header;
string strHeader = JsonConvert.SerializeObject(headerJson);
var content = new ContentJson();
content.settlementAccount = settlementAccount;
content.symbol = symbol;
content.buyOrSell = buyOrSell;
content.quantity = quantity;
content.limitPrice = limitPrice;
content.expirationType = expirationType;
content.maturityDate = maturityDate;
var contentObj = new ContentJsonObject();
contentObj.Content = content;
string strContent = JsonConvert.SerializeObject(contentObj);
string url = "http://tbankonline.com/SMUtBank_API/Gateway?Header=" + strHeader + "&Content=" + strContent;
var webRequest = (HttpWebRequest)WebRequest.Create(url);
webRequest.ContentType = "application/json";
webRequest.Method = "POST";
var result = "";
var httpResponse = (HttpWebResponse)webRequest.GetResponse();
using (var streamReader = new StreamReader(httpResponse.GetResponseStream()))
{
result = streamReader.ReadToEnd();
}
placeLimitOrderRootObject LO = new placeLimitOrderRootObject();
LO = JsonConvert.DeserializeObject<placeLimitOrderRootObject>(result);
string globalErrorID = LO.Content.ServiceResponse.ServiceRespHeader.GlobalErrorID.ToString();
if (globalErrorID == "010000")
{
lblOrderID.Text = LO.Content.ServiceResponse.StockOrder.orderID.ToString();
}
else if (globalErrorID == "010041")
{
otp = utilities.newOTP();
Session["otp"] = otp;
}
else
{
lblTest.Text = LO.Content.ServiceResponse.ServiceRespHeader.ErrorText.ToString();
string errorMessage = LO.Content.ServiceResponse.ServiceRespHeader.ErrorDetails.ToString();
lblErrorMessage.Text = errorMessage;
}
}
catch (Exception ex)
{
lblExceptionMsg.Text = ex.ToString();
}
}
}
}
}
Created with the Personal Edition of HelpNDoc: Easily create Help documents