private static void CreditUser(string username, decimal points, string offerwallname, string trackingID = "?") { Money Sent = new Money(points); Money Calculated = new Money(0); Member User = new Member(username); CrowdflowerCrediter Crediter = new CrowdflowerCrediter(User); OfferwallsLogStatus Status = OfferwallsLogStatus.CreditedByOfferwall; if (Sent < new Money(0)) { //Reversal Status = OfferwallsLogStatus.ReversedByOfferwall; Calculated = Crediter.Reverse(Sent, AppSettings.Offerwalls.ConvertCrowdflowerToMainBalance ? CreditAs.MainBalance : CreditAs.Points, offerwallname, AppSettings.Offerwalls.ConvertCrowdflowerToMainBalance); } else { //Credit Calculated = Crediter.Credit(Sent, AppSettings.Offerwalls.ConvertCrowdflowerToMainBalance ? CreditAs.MainBalance : CreditAs.Points, offerwallname, AppSettings.Offerwalls.ConvertCrowdflowerToMainBalance); } //Add OfferwallsLog OfferwallsLog.CreateCrowdflower(username, Sent, Calculated, trackingID, Status); }
/// <summary> /// Provides human readable, short description for each status. /// </summary> public static string ShortDescription(this OfferwallsLogStatus status) { if (status == OfferwallsLogStatus.Null) { return("Unknown"); } return(Enum.GetName(typeof(OfferwallsLogStatus), status)); }
public static OfferwallsLog Create(Offerwall Wall, string Username, Money SentBalance, Money CalculatedBalance, string TrackingInfo, OfferwallsLogStatus Status) { if (TrackingInfo == null) { TrackingInfo = "?"; } string sent = "-"; string credited = "-"; if (Wall.CreditAs == CreditAs.Points) { sent = SentBalance.GetRealTotals().ToString(); if (CalculatedBalance != null) { credited = CalculatedBalance.GetRealTotals().ToString() + " " + AppSettings.PointsName; } } if (Wall.CreditAs == CreditAs.MainBalance) { sent = SentBalance.ToClearString(); if (CalculatedBalance != null) { credited = CalculatedBalance.ToString(); } } OfferwallsLog ol = new OfferwallsLog(); ol.Date = DateTime.Now; ol.NetworkName = Wall.DisplayName; ol.SentBalance = sent; ol.Status = Status; ol.SentBalanceMoney = SentBalance; ol.TrackingID = TrackingInfo; ol.Username = Username; ol.CalculatedBalance = credited; ol.Save(); return(ol); }
public static void CreateCrowdflower(string Username, Money SentBalance, Money CalculatedBalance, string TrackingInfo, OfferwallsLogStatus Status) { Offerwall Temp = new Offerwall(); Temp.DisplayName = "CrowdFlower"; Temp.CreditAs = CreditAs.Points; if (AppSettings.Offerwalls.ConvertCrowdflowerToMainBalance) { Temp.CreditAs = CreditAs.MainBalance; } Create(Temp, Username, SentBalance, CalculatedBalance, TrackingInfo, Status); //TODO Crowdflower Points Locking }
public static void ProcessRequest(HttpContext context) { try { string RequestIP = IP.Current; string LogMessage = context.Request.Params.ToRawString(); ErrorLogger.Log(LogMessage, LogType.OfferWalls); //Force refresh AppSettings.Offerwalls.Reload(); AppSettings.Points.Reload(); //Get proper Offerwall string Hash = OfferwallFileManager.GetHashFromClientHandlerHit(context); Offerwall Wall = TableHelper.SelectRows <Offerwall>(TableHelper.MakeDictionary("Hash", Hash))[0]; //All OK string Username = GetFromRequest(context, Wall.VariableNameOfUsername); string _Balance = GetFromRequest(context, Wall.VariableNameOfBalance); string TrackingInfo = GetFromRequest(context, Wall.VariableNameOfTrackingInfo); //Can be null string _CreditVal = GetFromRequest(context, Wall.VariableNameOfType); //Can be null string Signature = GetFromRequest(context, Wall.VariableNameOfSignature); //Can be null Money Balance = Money.Parse(_Balance); Member member = null; //Check Status and IP restrictions bool ActiveRestriction = Wall.Status == OfferwallStatus.Active; bool IPRestriction = !Wall.HasRestrictedIPs || (Wall.HasRestrictedIPs && IpRangeHelper.isOK(Wall.RestrictedIPs, RequestIP)); if (ActiveRestriction && IPRestriction) { //Check condition if (Signature == null || Signature.Trim() == OfferwallParser.ParseSignatureCondition(Wall.SIgnatureCondition, context).Trim()) { //All OK, Verified OfferwallsLogStatus Status = OfferwallsLogStatus.Null; Money Calculated = new Money(0); //Check if member exists try { member = new Member(Username); if ((_CreditVal != null && _CreditVal == Wall.VariableValueOfTypeReversed) || (_CreditVal == null && Balance < Money.Zero)) { //Reverse OfferwallsLog oldLog = PointsLockingHelper.FindSimilarLog(member.Name, Wall.DisplayName, TrackingInfo); if (oldLog == null) { OfferwallCrediter Crediter = new OfferwallCrediter(member, Wall); Calculated = Crediter.ReverseCredit(Balance, Wall.CreditAs, Wall.DisplayName, Wall.RequiresConversion); History.AddOfferwalRevereseCompleted(Username, Wall.DisplayName, Calculated, Wall.CreditAs); Status = OfferwallsLogStatus.ReversedByOfferwall; } //change old log status else { Status = OfferwallsLogStatus.ReversedByOfferwall; oldLog.Status = Status; } } if ((_CreditVal != null && _CreditVal == Wall.VariableValueOfTypeCredited) || (_CreditVal == null && Balance >= Money.Zero)) { //Credit if (PointsLockingManager.OfferwallShouldBeLocked(Balance, member, Wall)) { Calculated = OfferwallCrediter.CalculatedAndConversion(Balance, member, Wall); History.AddOfferLocked(Username, Wall.DisplayName, null, Calculated, Wall.CreditAs); Status = OfferwallsLogStatus.CreditedAndPointsLocked; } else { OfferwallCrediter Crediter = new OfferwallCrediter(member, Wall); Calculated = Crediter.CreditMember(Balance, Wall); History.AddOfferwalCompleted(Username, Wall.DisplayName, Calculated, Wall.CreditAs); Status = OfferwallsLogStatus.CreditedByOfferwall; } } if ((_CreditVal != null && (_CreditVal != Wall.VariableValueOfTypeCredited && _CreditVal != Wall.VariableValueOfTypeReversed))) { Status = OfferwallsLogStatus.WrongCreditVariable; } //Add OfferwallsLog OfferwallsLog.Create(Wall, member.Name, Balance, Calculated, TrackingInfo, Status); //If All was handled OK, than succResponse context.Response.Write(Wall.ValueOfSuccessfulResponse); } catch (MsgException ex) { Status = OfferwallsLogStatus.MemberNotFoundByUsername; OfferwallsLog.Create(Wall, Username, Balance, Calculated, TrackingInfo, Status); } } else { OfferwallsLog.Create(Wall, Username, Balance, null, TrackingInfo, OfferwallsLogStatus.WrongSignature); } } else if (IPRestriction) { OfferwallsLog.Create(Wall, Username, Balance, null, TrackingInfo, OfferwallsLogStatus.OfferwallInactive); } else if (ActiveRestriction) { OfferwallsLog.Create(Wall, Username, Balance, null, TrackingInfo, OfferwallsLogStatus.SentFromUnallowedIP); } } catch (Exception ex) { Prem.PTC.ErrorLogger.Log(ex); } }