controls.py 108 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965
  1. #coding=utf-8
  2. '''
  3. '''
  4. import os,re,random
  5. import json,time,datetime
  6. import shutil
  7. import tempfile
  8. import zipfile
  9. from docxtpl import DocxTemplate,InlineImage
  10. from docx.shared import Mm
  11. from django.db import transaction
  12. from django.conf import settings
  13. import common.models as cm
  14. import common.error_info as ce
  15. import common.common_functions as ccf
  16. import common.common_control as ccc
  17. import account.password_handle as ph
  18. from utils.exceltool import ExcelTool
  19. from utils.jgpush import send_notification_by_registration_ids
  20. import wzhifuSDK as wxpay
  21. from utils.exceltool import ExcelTool
  22. from utils.qrcodetool import gen_general_qrcode
  23. from django.db.models import Q,Sum,Count,F
  24. from PIL import Image
  25. from PIL import Image,ImageDraw,ImageFont
  26. from django.db import transaction
  27. from threading import Thread
  28. #from django.core.cache import cache
  29. from django.db import connection
  30. import calendar
  31. import xlrd
  32. import xlwt
  33. from xlutils.copy import copy
  34. from xltpl.writer import BookWriter
  35. from django_redis import get_redis_connection
  36. from constants import *
  37. from utils.aliyun_sms import send_verify_code,send_signup_success
  38. from utils.wxSubscribeMessage import send_consult_reply_message
  39. from utils.aliyunpush import aliyunpush
  40. #import logging
  41. #log = logging.getLogger("myerror")
  42. def async(f):
  43. def wrapper(*args, **kwargs):
  44. thr = Thread(target=f, args=args, kwargs=kwargs)
  45. thr.start()
  46. return wrapper
  47. def get_today_date(match_id=None,user_id=None):
  48. if not match_id:
  49. match_id = ccc.get_cur_match().id
  50. #if datetime.datetime.now().strftime("%H:%M") < "15:00":
  51. # if datetime.datetime.now().weekday() in [5,6] or datetime.datetime.now().strftime("%Y-%m-%d") in MISS_DATES:
  52. # today = cm.PlayerRecord.get_db_model(match_id).objects.all().order_by("-stock_date").first().stock_date
  53. # else:
  54. # if datetime.datetime.now().weekday()==0:
  55. # today = (datetime.datetime.now()-datetime.timedelta(days=3)).strftime("%Y-%m-%d")
  56. # else:
  57. # today = (datetime.datetime.now()-datetime.timedelta(days=1)).strftime("%Y-%m-%d")
  58. #else:
  59. # if datetime.datetime.now().weekday() in [5,6] or datetime.datetime.now().strftime("%Y-%m-%d") in MISS_DATES:
  60. # today = cm.PlayerRecord.get_db_model(match_id).objects.all().order_by("-stock_date").first().stock_date
  61. # else:
  62. # today = datetime.datetime.now().strftime("%Y-%m-%d")
  63. try:
  64. if user_id:
  65. today = cm.PlayerRecord.get_db_model(match_id).objects.filter(user_id=user_id).order_by("-stock_date").first().stock_date
  66. else:
  67. today = cm.PlayerRecord.get_db_model(match_id).objects.all().order_by("-stock_date").first().stock_date
  68. except:
  69. today = datetime.datetime.now().strftime("%Y-%m-%d")
  70. return today
  71. #@async
  72. def update_group_rank(match_id,match_group,stock_date):
  73. #return
  74. prset = cm.PlayerRecord.get_db_model(match_id).objects.filter(match_id=match_id,match_group=match_group,stock_date=stock_date).order_by("-total_income")
  75. records = prset.values()
  76. case_id = " case id "
  77. cases = []
  78. where = []
  79. for index,pr in enumerate(prset):
  80. key = "%s_%s_%s_%s" % (pr.player_id,match_id,match_group,stock_date)
  81. record = records[index]
  82. record.update({"group_rank":index+1})
  83. ccc.cache.delete(key)
  84. ccc.pl.set(key,json.dumps(record,cls=ccc.CusJSONEncoder))
  85. ccc.pl.execute()
  86. #@ccc.cache_data()
  87. def get_notices():
  88. """
  89. """
  90. notices = list(cm.Article.objects.filter(status=2,type="notice").values())
  91. return notices
  92. def get_index_data(request):
  93. """首页数据
  94. """
  95. player = request.player
  96. if not player:
  97. raise ce.TipException(u"该账号未参加任何赛事!")
  98. player_id = player.id
  99. match_id = player.match_id
  100. match_group = player.match_group
  101. #if datetime.datetime.now().hour < 15:
  102. # today = (datetime.datetime.now()-datetime.timedelta(days=1)).strftime("%Y-%m-%d")
  103. #else:
  104. # today = datetime.datetime.now().strftime("%Y-%m-%d")
  105. today = get_today_date()
  106. match_name = get_match_info(match_id).get("name")
  107. records_set = cm.PlayerRecord.get_db_model(match_id).objects.filter(player_id=player_id,match_id=match_id)
  108. if records_set:
  109. try:
  110. cur_rank = get_today_record(player_id,match_id,match_group,today).get("group_rank","")
  111. records = list(records_set.order_by("-stock_date").values())
  112. except:
  113. cur_rank = 0
  114. records = []
  115. else:
  116. cur_rank = 0
  117. records = []
  118. for item in records:
  119. today_stock = json.loads(item["today_stock"]) if item["today_stock"] else []
  120. today_stock = filter(lambda x:x["name"],today_stock)
  121. item["today_stock"] = today_stock
  122. item["today_stock_img"] = json.loads(item["today_stock_img"]) if item["today_stock_img"] else []
  123. yesterday_stock = json.loads(item["yesterday_stock"]) if item["yesterday_stock"] else []
  124. yesterday_stock = filter(lambda x:x["name"],yesterday_stock)
  125. item["yesterday_stock"] = yesterday_stock
  126. item["yesterday_stock_img"] = json.loads(item["yesterday_stock_img"]) if item["yesterday_stock_img"] else []
  127. item["today_income"] = "{}%".format(item["today_income"]*100)
  128. item["total_income"] = "{}%".format(item["total_income"]*100)
  129. #通知
  130. notices = get_notices()
  131. ret = {"match_name":match_name,"cur_rank":cur_rank,"records":records,"notices":notices}
  132. return ret
  133. def get_player_match_list(request):
  134. """选手参赛列表数据
  135. """
  136. uid = request.user.get("id",0)
  137. now_str = datetime.datetime.now().strftime("%Y-%m-%d")
  138. cur_match_id = ccc.get_cur_match().id
  139. match_ids = list(cm.Player.objects.filter(user_id=uid).values_list("match_id",flat=True))
  140. matchs = list(cm.Match.objects.filter(id__in=match_ids).values())
  141. for item in matchs:
  142. player = cm.Player.objects.filter(user_id=uid,match_id=item["id"]).first()
  143. item["player_id"] = player.id if player else 0
  144. return matchs
  145. def get_group_income(match_id,match_group):
  146. """
  147. """
  148. data = []
  149. today = datetime.datetime.now().strftime("%Y-%m-%d")
  150. player_ids = list(cm.Player.objects.filter(match_id=match_id,match_group=match_group).values_list("id",flat=True))
  151. for player_id in player_ids:
  152. today_record = cm.PlayerRecord.get_db_model(match_id).objects.filter(match_id=match_id,match_group=match_group,player_id=player_id,stock_date=today).first()
  153. if today_record:
  154. data.append(today_record.total_income)
  155. data = list(set(data))
  156. data = sorted(data,key=lambda x:x,reverse=True)
  157. return data
  158. def get_player_match_detail(request):
  159. """选手参赛详情数据
  160. """
  161. qdata = request.json
  162. user_id = request.user.get("id",0)
  163. match_id = qdata.get("id")
  164. record_id = qdata.get("record_id")
  165. userinfo = {}
  166. cur_user_id = user_id
  167. if qdata.get("user_id"):
  168. cur_user_id = qdata.get("user_id")
  169. today = get_today_date()
  170. ismine = True if int(cur_user_id) == user_id else False
  171. if not match_id:
  172. player = cm.Player.objects.filter(user_id=cur_user_id,match_id=match_id).first()
  173. match_id =player.match_id
  174. cur_user_id = player.user_id
  175. if record_id:
  176. records_set = cm.PlayerRecord.get_db_model(match_id).objects.filter(id=record_id)
  177. if records_set:
  178. match_id = records_set.first().match_id
  179. else:
  180. records_set = cm.PlayerRecord.get_db_model(match_id).objects.filter(user_id=cur_user_id,match_id=match_id).order_by("-stock_date")
  181. match = cm.Match.objects.filter(id=match_id).values().first()
  182. groups = list(cm.MatchGroup.objects.filter(match_id=match_id).values_list("name",flat=True))
  183. match["groups"] = groups
  184. all_records_set = cm.PlayerRecord.get_db_model(match_id).objects.filter(user_id=cur_user_id,match_id=match_id).order_by("-stock_date")
  185. if all_records_set:
  186. records = list(all_records_set.values())
  187. else:
  188. records = []
  189. for item in records:
  190. item["today_stock"] = json.loads(item["today_stock"]) if item["today_stock"] else []
  191. item["today_stock_img"] = json.loads(item["today_stock_img"]) if item["today_stock_img"] else []
  192. item["yesterday_stock"] = json.loads(item["yesterday_stock"]) if item["yesterday_stock"] else []
  193. item["yesterday_stock_img"] = json.loads(item["yesterday_stock_img"]) if item["yesterday_stock_img"] else []
  194. item["today_income"] = "{}%".format(item["today_income"]*100)
  195. item["total_income"] = "{}%".format(item["total_income"]*100)
  196. item["avatar"] = get_user_info(item["user_id"])["avatar"]
  197. today_record = {}
  198. if records_set:
  199. today = records_set.first().stock_date
  200. if record_id:
  201. today_record = records_set.values().first()
  202. today_record = format_today_record(today_record)
  203. else:
  204. match_group = records_set.first().match_group
  205. today_record = ccc.get_today_record(cur_user_id,int(match_id),match_group,today)
  206. if today_record:
  207. today_record["today_stock_img"] = json.loads(today_record["today_stock_img"]) if today_record["today_stock_img"] else []
  208. today_record["today_stock"] = json.loads(today_record["today_stock"]) if today_record["today_stock"] else []
  209. today_record["today_income"] = "{}%".format(today_record["today_income"]*100)
  210. today_record["total_income"] = "{}%".format(today_record["total_income"]*100)
  211. today_record["match_group_name"] = cm.MatchGroup.objects.filter(id=today_record["match_group"]).first().name
  212. today_record["players_num"] = cm.Player.objects.filter(match_group=today_record["match_group"]).count()
  213. today_record["win_rate"] = calc_win_rate(cur_user_id,today_record["match_id"])
  214. badest = cm.PlayerRecord.get_db_model(match_id).objects.filter(user_id=cur_user_id,match_id=match_id).order_by("today_income").first()
  215. if badest:
  216. today_record["badest_income"] = "{}%".format(badest.today_income*100)
  217. today_record["today_stock_total"] = round(today_record.get("today_stock_total",0.0),4)
  218. userinfo = get_user_info(today_record["user_id"])
  219. today_record["style"] = userinfo.get("style")
  220. else:
  221. player_info = get_user_info(cur_user_id)
  222. today_record = {}
  223. today_record["stock_date"] = today
  224. today_record.update(player_info)
  225. today_record["player_id"] = player_info["id"]
  226. today_record["avatar"] = get_user_info(cur_user_id)["avatar"]
  227. userinfo = get_user_info(cur_user_id)
  228. today_record["style"] = userinfo.get("style")
  229. today_record["user_id"] = player_info["id"]
  230. match["groups"] = [today_record.get("match_group_name","")] if today_record else []
  231. records = sorted(records,key=lambda x:x["stock_date"],reverse=True)
  232. if cm.UserFollows.objects.filter(user_id=request.user.get("id"),follow_id=cur_user_id).exists():
  233. is_follow = 1
  234. else:
  235. is_follow = 0
  236. if today_record and today_record.get("today_fund"):
  237. today_record["today_income_fund"] = round((today_record["today_fund"] - today_record["yesterday_fund"])*10000,2) if today_record["yesterday_fund"] else 0.00
  238. today_record["zan_count"] = today_record.get("zans",0)
  239. ret = {
  240. "match":match,
  241. "today_record":today_record,
  242. "match_group_info":get_group_info(today_record.get("match_group")) if today_record.get("match_group") else {},
  243. "userinfo":get_user_info(cur_user_id),
  244. "records":records,
  245. "is_follow":is_follow,
  246. "fans":cm.UserFollows.objects.filter(follow_id=cur_user_id).count(),
  247. "followers":cm.UserFollows.objects.filter(user_id=cur_user_id).count(),
  248. "stock_age":datetime.datetime.now().year - int(userinfo.get("join_time")) if userinfo.get("join_time") else 0,
  249. "stock_follow":list(cm.UserChoice.objects.filter(user_id=cur_user_id).values_list("stock_name",flat=True))
  250. }
  251. return ret
  252. def get_today_record(player_id,match_id,match_group,today):
  253. """
  254. """
  255. key = "%s_%s_%s_%s" % (player_id,match_id,match_group,today)
  256. #key = "%s_%s_%s" % (player_id,match_id,today)
  257. today_record = ccc.cache.get(key)
  258. today_record = json.loads(today_record) if today_record else {}
  259. #if match_id:
  260. # #记得这里上线后要注释掉
  261. # today_record = cm.PlayerRecord.get_db_model(match_id).objects.filter(user_id=player_id,match_id=match_id,stock_date=today)
  262. # today_record = today_record.values().first()
  263. try:
  264. if today_record:
  265. user_info = get_user_info(today_record["user_id"])
  266. if user_info:
  267. user_info.pop("id")
  268. today_record.update(user_info)
  269. #仓位
  270. today_stock_total = 0
  271. today_stock = json.loads(today_record["today_stock"])
  272. for ts in today_stock:
  273. if ts["fund"]:
  274. try:
  275. today_stock_total += float(ts["fund"])
  276. except Exception as e:
  277. print e
  278. today_record["cangwei"] = "{}%".format(round(today_stock_total/today_record["today_fund"],4)*100)
  279. today_record["today_stock_total"] = today_stock_total
  280. except Exception as e:
  281. import traceback
  282. traceback.print_exc()
  283. return today_record
  284. def format_today_record(today_record):
  285. try:
  286. if today_record:
  287. user_info = get_user_info(today_record["user_id"])
  288. if user_info:
  289. #user_info.pop("id")
  290. today_record.update(user_info)
  291. #仓位
  292. today_stock_total = 0
  293. today_stock = json.loads(today_record["today_stock"])
  294. for ts in today_stock:
  295. if ts["fund"]:
  296. try:
  297. today_stock_total += float(ts["fund"])
  298. except Exception as e:
  299. print e
  300. today_record["cangwei"] = "{}%".format(round(today_stock_total/today_record["today_fund"],4)*100)
  301. today_record["today_stock_total"] = today_stock_total
  302. #win_rate = ccc.cache.hget("PLAYER_LATEST_%d" % today_record["user_id"],"win_rate")
  303. #if win_rate:
  304. # today_record["win_rate"] = str(float(win_rate)*100)+"%"
  305. #else:
  306. # today_record["win_rate"] = "0.0%"
  307. #
  308. win_rate = calc_win_rate(today_record["user_id"],today_record["match_id"])
  309. today_record["win_rate"] = win_rate
  310. except Exception as e:
  311. import traceback
  312. traceback.print_exc()
  313. today_record = today_record if today_record else {}
  314. return today_record
  315. def get_today_record_actual(player_id,match_id,match_group,today=None):
  316. """
  317. """
  318. if today:
  319. qset = cm.PlayerRecord.get_db_model(match_id).objects.filter(match_id=match_id,match_group=match_group,player_id=player_id,stock_date=today)
  320. else:
  321. qset = cm.PlayerRecord.get_db_model(match_id).objects.filter(match_id=match_id,match_group=match_group,player_id=player_id).order_by("-stock_date")
  322. today_record = qset.values().first()
  323. if today_record:
  324. user_info = get_user_info(today_record["user_id"])
  325. if user_info:
  326. user_info.pop("id")
  327. today_record.update(user_info)
  328. #仓位
  329. today_stock_total = 0
  330. today_stock = json.loads(today_record["today_stock"])
  331. for ts in today_stock:
  332. if ts["fund"]:
  333. try:
  334. today_stock_total += float(ts["fund"])
  335. except Exception as e:
  336. print e
  337. today_record["cangwei"] = "{}%".format(round(today_stock_total/today_record["today_fund"],4)*100)
  338. today_record["today_stock_total"] = today_stock_total
  339. return today_record
  340. @ccc.cache_data()
  341. def get_match_group_players(match_id,match_group):
  342. players = list(cm.Player.objects.filter(match_id=match_id,match_group=match_group).values())
  343. return players
  344. #@ccc.cache_data()
  345. def get_match_group_users(match_id,match_group):
  346. #users = list(cm.UserMatch.objects.filter(match_id=match_id,match_group=match_group).values())
  347. users = list(cm.Player.objects.filter(match_id=match_id,match_group=match_group).values())
  348. return users
  349. @ccc.cache_data()
  350. def get_match_groups(match_id):
  351. """
  352. """
  353. match = cm.Match.objects.filter(id=match_id).values().first()
  354. groups = list(cm.MatchGroup.objects.filter(match_id=match_id,is_active=1).order_by("order").values())
  355. return match,groups
  356. def get_cache_rank_list(match_id,today):
  357. """
  358. """
  359. match,groups = get_match_groups(match_id)
  360. data = []
  361. for item in groups:
  362. new_players = []
  363. players = get_match_group_users(match_id,item["id"])
  364. win_count = 0
  365. loss_count = 0
  366. for player in players:
  367. user_id = player["user_id"]
  368. #username = player["signup_name"]
  369. username = player["username"]
  370. match_group = player["match_group"]
  371. today_record = ccc.get_today_record(user_id,match_id,match_group,today)
  372. if today_record:
  373. player.update(today_record)
  374. player["username"] = username
  375. player["org_today_income"] = player["today_income"]
  376. player["org_total_income"] = player["total_income"]
  377. player["total_income"] = "{}%".format(today_record["total_income"]*100)
  378. player["today_income"] = "{}%".format(today_record["today_income"]*100)
  379. if player["org_today_income"] >= 0.05:
  380. win_count += 1
  381. if player["org_today_income"] <= -0.05:
  382. loss_count += 1
  383. try:
  384. player["fund"] = round(player["fund"],4) if player["fund"] else 0.0
  385. player["init_fund"] = round(player["init_fund"],4)
  386. player["fund"] = round(player["init_fund"],4)
  387. player["today_fund"] = round(player["today_fund"],4)
  388. new_players.append(player)
  389. except Exception as e:
  390. print player
  391. pass
  392. new_players_sort = list(sorted(new_players,key=lambda x:x["org_total_income"],reverse=True))
  393. item["players_num"] = len(players)
  394. item["win_count"] = win_count
  395. item["loss_count"] = loss_count
  396. item["players"] = new_players_sort[:3]
  397. data.append(item)
  398. return match,data
  399. def get_rank_list(request):
  400. """排名列表
  401. """
  402. qdata = request.json
  403. user_id = request.user.get("id",0)
  404. match_id = qdata.get("match_id")
  405. today = qdata.get("stock_date")
  406. if not today:
  407. today = get_today_date()
  408. match,groups = get_cache_rank_list(match_id,today)
  409. ret = {"match":match,"groups":groups}
  410. return ret
  411. @ccc.cache_data()
  412. def get_user_info(uid):
  413. user = cm.UserInfo.objects.filter(id=uid).values().first()
  414. if user:
  415. user["style"] = []
  416. if user["zq"]:
  417. user["style"].append(user["zq"])
  418. if user["cw"]:
  419. user["style"].append(user["cw"])
  420. if user["df"]:
  421. user["style"].append(user["df"])
  422. return user
  423. def get_user_info_actual(uid):
  424. user = cm.UserInfo.objects.filter(id=uid).values().first()
  425. if user:
  426. user["style"] = []
  427. if user["zq"]:
  428. user["style"].append(user["zq"])
  429. if user["cw"]:
  430. user["style"].append(user["cw"])
  431. if user["df"]:
  432. user["style"].append(user["df"])
  433. return user
  434. #@ccc.cache_data()
  435. def get_player_info(player_id):
  436. player = cm.Player.objects.filter(id=player_id).values().first()
  437. return player
  438. @ccc.cache_data()
  439. def get_match_info(match_id):
  440. match = cm.Match.objects.filter(id=match_id).values().first()
  441. return match
  442. @ccc.cache_data()
  443. def get_group_info(group_id):
  444. group = cm.MatchGroup.objects.filter(id=group_id).values().first()
  445. if group:
  446. group["players_num"] = cm.Player.objects.filter(match_group=group["id"]).count()
  447. return group
  448. else:
  449. return {}
  450. def get_group_rank_list(request):
  451. """排名列表
  452. """
  453. qdata = request.json
  454. kwargs = qdata
  455. group_id = qdata.get("id")
  456. match_id = qdata.get("match_id")
  457. match_id = cm.MatchGroup.objects.filter(id=group_id).first().match_id
  458. today = qdata.get("stock_date")
  459. if not today:
  460. today = get_today_date()
  461. match = get_match_info(match_id)
  462. group = get_group_info(group_id)
  463. players = get_match_group_users(match_id,group_id)
  464. new_players = []
  465. for player in players:
  466. user_id = player["user_id"]
  467. #user = get_user_info(user_id)
  468. #username = user["username"] if user else ""
  469. #username = player["signup_name"]
  470. username = player["username"]
  471. match_group = group_id
  472. today_record = ccc.get_today_record(user_id,match_id,match_group,today)
  473. if today_record:
  474. player.update(today_record)
  475. player["username"] = username
  476. player["org_today_income"] = player["today_income"]
  477. player["org_total_income"] = player["total_income"]
  478. player["total_income"] = "{}%".format(player["total_income"]*100)
  479. player["today_income"] = "{}%".format(player["today_income"]*100)
  480. player["fund"] = round(player["fund"],4)
  481. player["init_fund"] = round(player["init_fund"],4)
  482. player["today_fund"] = round(player["today_fund"],4)
  483. new_players.append(player)
  484. if kwargs.get("order_by") == "today_income__asc":
  485. new_players = sorted(new_players,key=lambda x:x["org_today_income"])
  486. elif kwargs.get("order_by") == "today_income__desc" :
  487. new_players = sorted(new_players,key=lambda x:x["org_today_income"],reverse=True)
  488. elif kwargs.get("order_by") == "total_income__asc":
  489. new_players = sorted(new_players,key=lambda x:x["org_total_income"])
  490. elif kwargs.get("order_by") == "total_income__desc":
  491. new_players = sorted(new_players,key=lambda x:x["org_total_income"],reverse=True)
  492. else:
  493. new_players = sorted(new_players,key=lambda x:x["org_total_income"],reverse=True)
  494. #分页
  495. page = int(kwargs.get("page",0))
  496. page_size = int(kwargs.get("page_size",50))
  497. #page_size = 50
  498. if page and page_size:
  499. total,new_players = ccf.get_page_list(new_players,page,page_size)
  500. else:
  501. total = len(new_players)
  502. #应到、实到、请假人数
  503. total_person = cm.Player.objects.filter(match_group=group_id,match_status=1).count()
  504. actual_person = cm.PlayerRecord.get_db_model(match_id).objects.filter(match_group=group_id,stock_date=today).count()
  505. leave_person = total_person - actual_person
  506. win_person = cm.PlayerRecord.get_db_model(match_id).objects.filter(match_group=group_id,stock_date=today,total_income__gte=0).count()
  507. loss_person = cm.PlayerRecord.get_db_model(match_id).objects.filter(match_group=group_id,stock_date=today,total_income__lt=0).count()
  508. ret = {"group":group,"players":new_players,"total":total,"total_person":total_person,
  509. "actual_person":actual_person,"leave_person":leave_person,"win_person":win_person,"loss_person":loss_person}
  510. return ret
  511. def get_player_match_records(request):
  512. """选手参赛每日持股
  513. """
  514. qdata = request.json
  515. match_id = qdata.get("id")
  516. user_id = qdata.get("user_id")
  517. page = int(qdata.get("page",0))
  518. page_size = int(qdata.get("page_size",20))
  519. records_set = cm.PlayerRecord.get_db_model(match_id).objects.filter(user_id=user_id,match_id=match_id).order_by("-stock_date")
  520. data = list(records_set.values())
  521. for item in data:
  522. today_stock = json.loads(item["today_stock"]) if item["today_stock"] else []
  523. today_stock = filter(lambda x:x["name"],today_stock if today_stock else [])
  524. item["today_stock"] = today_stock
  525. item["today_stock_img"] = json.loads(item["today_stock_img"]) if item["today_stock_img"] else []
  526. yesterday_stock = json.loads(item["yesterday_stock"]) if item["yesterday_stock"] else []
  527. yesterday_stock = filter(lambda x:x["name"],yesterday_stock if yesterday_stock else [])
  528. item["yesterday_stock"] = yesterday_stock
  529. item["yesterday_stock_img"] = json.loads(item["yesterday_stock_img"]) if item["yesterday_stock_img"] else []
  530. item["today_income"] = "{}%".format(item["today_income"]*100)
  531. item["total_income"] = "{}%".format(item["total_income"]*100)
  532. item["zans_count"] = item.get("zans",0)
  533. item["comments_count"] = cm.Comments.objects.filter(record_id=item.get("id",0)).count()
  534. if page and page_size:
  535. total,data = ccf.get_page_list(data,page,page_size)
  536. return total,data
  537. else:
  538. return len(data),data
  539. def add_model(cls,**kwargs):
  540. """
  541. """
  542. model_name = re.search(r'.*\.(\w+)View',str(cls.__class__)).groups()[0]
  543. model = getattr(cm,model_name)
  544. if model_name == "PlayerRecord":
  545. user_id = kwargs.get("user_id")
  546. match_id = kwargs.get("match_id")
  547. stock_date = kwargs.get("stock_date")
  548. now = datetime.datetime.now()
  549. if not cm.Player.objects.filter(user_id=user_id,match_id=match_id).exists():
  550. raise ce.TipException(u"请先完成报名再提交数据!")
  551. if now.weekday() in [5,6] or not now.strftime("%Y-%m-%d") in get_match_validdates(match_id):
  552. raise ce.TipException(u"今日不能提交数据!")
  553. now_time = datetime.datetime.now().strftime("%H:%S")
  554. if not user_id in [9600,6209,5709,25953]:
  555. if now_time<"15:00" or now_time > "23:50":
  556. raise ce.TipException(u"当日数据请在当日15:00以后23:50以前提交数据!")
  557. stock_date = datetime.datetime.now().strftime("%Y-%m-%d")
  558. today_stock = json.dumps(kwargs.get("today_stock"))
  559. today_stock_img = json.dumps(kwargs.get("today_stock_img"))
  560. today_fund = float(kwargs.get("today_fund",0))
  561. is_markt = int(kwargs.get("is_markt",0))
  562. experience = kwargs.get("experience")
  563. if not ccc.get_cur_match().id == match_id:
  564. raise ce.TipException(u"非当前赛事参赛选手不能提交作业!")
  565. #计算今日和昨日盈亏
  566. if float(today_fund)>9999 or float(today_fund)<=0:
  567. raise ce.TipException(u"数据错误,今日净资产不能超过9999万元,不能低于0万元,请仔细核对数据!")
  568. player = cm.Player.objects.filter(user_id=user_id,match_id=match_id).first()
  569. user_id = player.user_id
  570. init_fund = player.fund
  571. user = cm.UserInfo.objects.filter(id=user_id).first()
  572. username = user.username
  573. usercode = user.usercode
  574. match_group = player.match_group
  575. zq = user.zq
  576. cw = user.cw
  577. df = user.df
  578. match = cm.Match.objects.filter(id=match_id).first()
  579. if player.match_status < 1:
  580. raise ce.TipException(u"该账号已暂停/退出比赛,如有疑问请联系管理员获取详情信息!")
  581. now_date = datetime.datetime.now().strftime("%Y-%m-%d")
  582. if not user_id in [9600,6209,5709]:
  583. if match.end_time < now_date:
  584. raise ce.TipException(u"该比赛已结束或您未参加此次比赛不能提交数据!")
  585. validdates = get_match_validdates(match_id)
  586. today_index = validdates.index(stock_date)
  587. yesterday_index = today_index -1 if today_index >=1 else 0
  588. yesterday_date = validdates[yesterday_index]
  589. yesterday = cm.PlayerRecord.get_db_model(match_id).objects.filter(
  590. match_id=match_id,user_id=user_id,stock_date=yesterday_date).exclude(stock_date=stock_date).first()
  591. if yesterday:
  592. yesterday_fund = yesterday.today_fund
  593. yesterday_stock = yesterday.today_stock
  594. yesterday_stock_img = yesterday.today_stock_img
  595. yesterday_is_markt = yesterday.is_markt
  596. else:
  597. yesterday_fund = today_fund
  598. yesterday_stock = ""
  599. yesterday_stock_img = ""
  600. yesterday_is_markt = 0
  601. if kwargs.get("id"):
  602. if cm.PlayerRecord.get_db_model(match_id).objects.filter(match_id=match_id,user_id=user_id).count()==1:
  603. init_fund = today_fund
  604. cm.Player.objects.filter(user_id=user_id,match_id=match_id).update(fund=today_fund)
  605. else:
  606. if not cm.PlayerRecord.get_db_model(match_id).objects.filter(match_id=match_id,user_id=user_id).exists():
  607. init_fund = today_fund
  608. cm.Player.objects.filter(user_id=user_id,match_id=match_id).update(fund=today_fund)
  609. with transaction.atomic():
  610. #记录持股情况
  611. new_stock_list = []
  612. today_stock_list = json.loads(today_stock)
  613. for ts in today_stock_list:
  614. if ts["name"]:
  615. try:
  616. stock,flag = cm.Stock.objects.get_or_create(
  617. name = ts["name"]
  618. )
  619. stock_id = stock.id
  620. usobj,flag = cm.UserStock.objects.get_or_create(
  621. user_id = user_id,
  622. stock_id = stock_id,
  623. stock_name = ts["name"],
  624. player_id = player.id,
  625. stock_date = stock_date
  626. )
  627. if ts.get("fund"):
  628. usobj.fund = ts["fund"]
  629. usobj.save()
  630. ts["stock_id"] = stock_id
  631. new_stock_list.append(ts)
  632. except Exception as e:
  633. print(e)
  634. today_stock = json.dumps(new_stock_list)
  635. obj,flag = cm.PlayerRecord.get_db_model(match_id).objects.get_or_create(
  636. user_id=user_id,
  637. match_id=match_id,
  638. stock_date=stock_date)
  639. obj.init_fund = init_fund
  640. obj.yesterday_fund = yesterday_fund
  641. obj.yesterday_stock = yesterday_stock
  642. obj.yesterday_stock_img = yesterday_stock_img
  643. obj.today_fund = today_fund
  644. obj.today_stock = today_stock
  645. obj.today_stock_img = today_stock_img
  646. obj.username = username
  647. obj.usercode = usercode
  648. obj.match_group = match_group
  649. obj.is_markt = is_markt
  650. obj.yesterday_is_markt = yesterday_is_markt
  651. obj.zq = zq
  652. obj.cw = cw
  653. obj.df = df
  654. obj.experience = experience
  655. #计算今日收益和总收益
  656. if float(today_fund)>9999 or float(today_fund)<=0:
  657. raise ce.TipException(u"数据错误,今日净资产不能超过9999万元,不能低于0万元,请仔细核对数据!")
  658. #有资金出入
  659. if cm.FundInOut.objects.filter(user_id=user_id,stock_date=stock_date).exists() and flag:
  660. fundinout = cm.FundInOut.objects.filter(user_id=user_id,stock_date=stock_date).first()
  661. fundin = fundinout.fundin
  662. fundout = fundinout.fundout
  663. #入资金
  664. if fundin > fundout:
  665. fundin = fundin - fundout
  666. if yesterday:
  667. today_income = (today_fund-(yesterday_fund+fundin))/(float(yesterday_fund) + fundin)
  668. obj.yesterday_fund = obj.yesterday_fund + fundin
  669. else:
  670. today_income = 0.0
  671. total_income = (today_fund-init_fund-fundin)/(init_fund+fundin)
  672. cm.Player.objects.filter(user_id=user_id,match_id=match_id).update(fund=init_fund+fundin)
  673. obj.init_fund = init_fund + fundin
  674. #出资金
  675. else:
  676. fundout = fundout - fundin
  677. if yesterday:
  678. today_income = (today_fund-(yesterday_fund-fundout))/float(yesterday_fund)
  679. obj.yesterday_fund = round(today_fund/(1+today_income),4)
  680. else:
  681. today_income = 0.0
  682. total_income = (today_fund+fundout-init_fund)/init_fund
  683. cm.Player.objects.filter(user_id=user_id,match_id=match_id).update(fund=round(today_fund/(1+total_income),4))
  684. obj.init_fund = round(today_fund/(1+total_income),4)
  685. if float(today_income)>0.6:
  686. raise ce.TipException(u"今日盈利已超过60%,请仔细核对数据或直接联系顽主!")
  687. if float(total_income)>8:
  688. raise ce.TipException(u"请仔细核对数据或直接联系顽主!")
  689. obj.today_income = round(today_income,4)
  690. obj.total_income = round(total_income,4)
  691. else:
  692. today_income = (today_fund - yesterday_fund)/float(yesterday_fund) if yesterday_fund else 0.0
  693. total_income = (today_fund - init_fund)/float(init_fund) if init_fund else 0.0
  694. if float(today_income)>0.4:
  695. raise ce.TipException(u"今日盈利已超过40%,请仔细核对数据或直接联系顽主!")
  696. if float(total_income)>8:
  697. raise ce.TipException(u"请仔细核对数据或直接联系顽主!")
  698. obj.today_income = round(today_income,4)
  699. obj.total_income = round(total_income,4)
  700. if not flag:
  701. obj.ctime = datetime.datetime.now()
  702. obj.save()
  703. #更新group_rank
  704. #ccc.cache.lpush(settings.RANK_LIST,obj.id)
  705. ccc.cache.lpush(settings.RANK_LIST,"%s_%s" %(obj.match_id,obj.id))
  706. return obj.id
  707. obj = model.objects.create(**kwargs)
  708. return obj.id
  709. def update_model(cls,**kwargs):
  710. """
  711. """
  712. model_name = re.search(r'.*\.(\w+)View',str(cls.__class__)).groups()[0]
  713. model = getattr(cm,model_name)
  714. id = kwargs.pop("id")
  715. rst = model.objects.filter(id=id).update(**kwargs)
  716. if model_name == "Match":
  717. for item in kwargs.get("groups").split(","):
  718. cm.MatchGroup.objects.get_or_create(match_id=obj.id,name=item)
  719. return rst
  720. def delete_model(cls,**kwargs):
  721. """
  722. """
  723. model_name = re.search(r'.*\.(\w+)View',str(cls.__class__)).groups()[0]
  724. model = getattr(cm,model_name)
  725. ids = str(kwargs.get("id")).split(",")
  726. rst = model.objects.filter(id__in=ids).delete()
  727. if model_name == "Comments":
  728. cm.Comments.objects.filter(pid__in=ids).delete()
  729. return ids
  730. def get_search_list(cls,**kwargs):
  731. """
  732. """
  733. model_name = re.search(r'.*\.(\w+)SearchView',str(cls.__class__)).groups()[0]
  734. model = getattr(cm,model_name)
  735. qset = model.objects.all()
  736. if model_name == "Stock":
  737. if kwargs.get("name"):
  738. qset = qset.filter(Q(name__icontains=kwargs.get("name"))|Q(code__icontains=kwargs.get("name")))
  739. else:
  740. if kwargs.get("name"):
  741. qset = qset.filter(name__icontains=kwargs.get("name"))
  742. if model_name == "Player":
  743. data = list(qset.values("id","username"))
  744. if model_name == "Stock":
  745. qset = qset.filter(code__isnull=False)
  746. data = list(qset.values("id","name","code"))
  747. for item in data:
  748. if item["code"]:
  749. item["label"] = "%s(%s)" % (item["name"],item["code"])
  750. else:
  751. item["label"] = "%s" % item["name"]
  752. else:
  753. data = list(qset.values("id","name"))
  754. return data
  755. def get_detail_info(cls,**kwargs):
  756. """
  757. """
  758. model_name = re.search(r'.*\.(\w+)View',str(cls.__class__)).groups()[0]
  759. model = getattr(cm,model_name)
  760. id = kwargs.get("id")
  761. rst = list(model.objects.filter(id=id).values())
  762. rst = rst[0] if rst else {}
  763. if model_name == "Article":
  764. rst["ctime"] = ccf.datetime_to_str(rst["ctime"],"%Y-%m-%d")
  765. if model_name == "Stock":
  766. rst["choiced"] = ccc.cache.get("%s_choices" % id)
  767. rst["user_num"] = ccc.cache.get("%s_choices" % id)
  768. return rst
  769. #@ccc.cache_data()
  770. def get_record_info(rcid):
  771. """
  772. """
  773. rst = cm.PlayerRecord.objects.filter(id=rcid).values().first()
  774. if rst:
  775. rst["match_group"] = cm.MatchGroup.objects.filter(id=rst["match_group"]).first().name
  776. today_stock = json.loads(rst["today_stock"]) if rst["today_stock"] else []
  777. today_stock = filter(lambda x:x["fund"] and x["name"],today_stock if today_stock else [])
  778. rst["today_stock"] = today_stock
  779. today_stock_img = json.loads(rst["today_stock_img"]) if rst["today_stock_img"] else []
  780. rst["today_stock_img"] = today_stock_img
  781. yesterday_stock = json.loads(rst["yesterday_stock"]) if rst["yesterday_stock"] else []
  782. yesterday_stock = filter(lambda x:x["fund"] and x["name"],yesterday_stock if yesterday_stock else [])
  783. rst["yesterday_stock"] = yesterday_stock
  784. yesterday_stock_img = json.loads(rst["yesterday_stock_img"]) if rst["yesterday_stock_img"] else []
  785. rst["yesterday_stock_img"] = yesterday_stock_img
  786. rst["today_income"] = "{}%".format(rst["today_income"]*100)
  787. rst["total_income"] = "{}%".format(rst["total_income"]*100)
  788. return rst
  789. def get_list_info(cls,**kwargs):
  790. """
  791. """
  792. model_name = re.search(r'.*\.(\w+)ListView',str(cls.__class__)).groups()[0]
  793. model = getattr(cm,model_name)
  794. qset = model.objects.all()
  795. if kwargs.get("name"):
  796. qset = qset.filter(name__icontains=kwargs.get("name"))
  797. if model_name == "UserInfo":
  798. if kwargs.get("username"):
  799. qset = qset.filter(username__icontains=kwargs.get("username"))
  800. if kwargs.get("usercode"):
  801. qset = qset.filter(usercode=kwargs.get("usercode"))
  802. data = list(qset.order_by("-id").values())
  803. page = int(kwargs.get("page",0))
  804. page_size = int(kwargs.get("page_size",20))
  805. if page and page_size:
  806. total,data = ccf.get_page_list(data,page,page_size)
  807. if model_name == "Player":
  808. for item in data:
  809. user = cm.UserInfo.objects.filter(id=item["user_id"]).first()
  810. match = cm.Match.objects.filter(id=item["match_id"]).first()
  811. item["username"] = user.username
  812. item["usercode"] = user.usercode
  813. item["match_name"] = match.name if match else ""
  814. return (total,data)
  815. else:
  816. return len(data),data
  817. return rst
  818. def add_player_record_single(**kwargs):
  819. """用户单独上传数据
  820. """
  821. return None
  822. now = datetime.datetime.now()
  823. if now.weekday() in [5,6] or now.strftime("%Y-%m-%d") in MISS_DATES:
  824. raise ce.TipException(u"今日不能提交数据!")
  825. now_time = datetime.datetime.now().strftime("%H:%S")
  826. if now_time<"15:00" or now_time > "23:50":
  827. raise ce.TipException(u"当日数据请在当日15:00以后23:50以前提交数据!")
  828. usercode = kwargs.get("usercode")
  829. match_id = kwargs.get("match_id")
  830. if not cm.Player.objects.filter(usercode=usercode,match_id=match_id).exists():
  831. raise ce.TipException(u"用户代码错误")
  832. stock_date = kwargs.get("stock_date")
  833. #stock_date = "2022-04-26"
  834. stock_date = datetime.datetime.now().strftime("%Y-%m-%d")
  835. today_stock = json.dumps(kwargs.get("today_stock"))
  836. today_stock_img = json.dumps(kwargs.get("today_stock_img"))
  837. today_fund = float(kwargs.get("today_fund"))
  838. is_markt = int(kwargs.get("is_markt",0))
  839. if int(today_fund)>9999 or int(today_fund)<0:
  840. raise ce.TipException(u"数据错误,今日净资产不能超过9999万元,不能低于0万元,请仔细核对数据!")
  841. player = cm.Player.objects.filter(usercode=usercode,match_id=match_id).first()
  842. #if player.fund <=0 :
  843. # raise ce.TipException(u"请先输入您的初始资金后再提交数据!")
  844. player_id = player.id
  845. user_id = player.user_id
  846. init_fund = player.fund
  847. user = cm.UserInfo.objects.filter(id=user_id).first()
  848. username = user.username
  849. usercode = user.usercode
  850. match_group = player.match_group
  851. match = cm.Match.objects.filter(id=match_id).first()
  852. if player.match_status < 1:
  853. raise ce.TipException(u"该账号已暂停/退出比赛,如有疑问请联系管理员获取详情信息!")
  854. now_date = datetime.datetime.now().strftime("%Y-%m-%d")
  855. if match.end_time < now_date:
  856. raise ce.TipException(u"该比赛已结束!")
  857. #yesterday = cm.PlayerRecord.objects.filter(
  858. # match_id=match_id,player_id=player_id).order_by("-id").first()
  859. yesterday = cm.PlayerRecord.get_db_model(match_id).objects.filter(
  860. match_id=match_id,player_id=player_id).order_by("-stock_date").first()
  861. if yesterday:
  862. yesterday_fund = yesterday.today_fund
  863. yesterday_stock = yesterday.today_stock
  864. yesterday_stock_img = yesterday.today_stock_img
  865. else:
  866. #yesterday_fund = init_fund
  867. yesterday_fund = today_fund
  868. init_fund = today_fund
  869. yesterday_stock = ""
  870. yesterday_stock_img = ""
  871. cm.Player.objects.filter(id=player_id).update(fund=today_fund)
  872. #记录持股情况
  873. new_stock_list = []
  874. today_stock_list = json.loads(today_stock)
  875. for ts in today_stock_list:
  876. if ts["name"]:
  877. stock,flag = cm.Stock.objects.get_or_create(
  878. name = ts["stock"]
  879. )
  880. stock_id = stock.id
  881. usobj,flag = cm.UserStock.objects.get_or_create(
  882. player_id = player_id,
  883. stock_id = stock_id,
  884. stock_name = ts["name"],
  885. stock_date = stock_date
  886. )
  887. ts["stock_id"] = stock_id
  888. new_stock_list.append(ts)
  889. today_stock = json.dumps(new_stock_list)
  890. obj,flag = cm.PlayerRecord.get_db_model(match_id).objects.get_or_create(
  891. player_id=player_id,
  892. match_id=match_id,
  893. stock_date=stock_date)
  894. obj.init_fund = init_fund
  895. obj.yesterday_fund = yesterday_fund
  896. obj.yesterday_stock = yesterday_stock
  897. obj.yesterday_stock_img = yesterday_stock_img
  898. obj.today_fund = today_fund
  899. obj.today_stock = today_stock
  900. obj.today_stock_img = today_stock_img
  901. obj.user_id = user_id
  902. obj.username = username
  903. obj.usercode = usercode
  904. obj.match_group = match_group
  905. obj.is_markt = is_markt
  906. #计算今日和昨日盈亏
  907. today_income = (today_fund - yesterday_fund)/float(yesterday_fund)
  908. total_income = (today_fund - init_fund)/float(init_fund)
  909. #if int(today_fund)>9999 or int(today_fund)<0:
  910. # raise ce.TipException(u"数据错误,今日净资产不能超过9999万元,不能低于0万元,请仔细核对数据!")
  911. if int(today_income)>2:
  912. raise ce.TipException(u"数据错误,今日盈利已超过2倍,请仔细核对数据!")
  913. obj.today_income = round(today_income,4)
  914. obj.total_income = round(total_income,4)
  915. if not flag:
  916. obj.ctime = datetime.datetime.now()
  917. obj.save()
  918. #更新股票持股人数
  919. for stock in new_stock_list:
  920. cm.Stock.objects.filter(id=stock["id"]).update(user_num=F("user_num")+1)
  921. #更新group_rank
  922. #update_group_rank(match_id,match_group,obj.stock_date)
  923. ccc.cache.lpush(settings.RANK_LIST,obj.id)
  924. return obj.id
  925. def get_single_match_info(match_id):
  926. """
  927. """
  928. if not match_id:
  929. match = cm.Match.objects.all().order_by("-id").values().first()
  930. else:
  931. match = cm.Match.objects.filter(id=match_id).values().first()
  932. now_date = datetime.datetime.now().strftime("%Y-%m-%d")
  933. return now_date,match
  934. def get_cur_record(request):
  935. """
  936. """
  937. user_id = request.user.get("id")
  938. match_id = ccc.get_cur_match().id
  939. stock_date = datetime.datetime.now().strftime("%Y-%m-%d")
  940. qset = cm.PlayerRecord.get_db_model(match_id).objects.filter(match_id=match_id,user_id=user_id,stock_date=stock_date).order_by("-stock_date")
  941. data = qset.values().first() if qset else {}
  942. if data:
  943. data["today_stock_img"] = json.loads(data["today_stock_img"]) if data["today_stock_img"] else []
  944. data["today_stock"] = json.loads(data["today_stock"]) if data["today_stock"] else []
  945. return data
  946. def follow_player(**kwargs):
  947. """
  948. """
  949. user_id = kwargs.get("user_id")
  950. follow_id = kwargs.get("follow_id")
  951. if kwargs.get("action") == "cancel":
  952. cm.UserFollows.objects.filter(user_id=user_id,follow_id=follow_id).delete()
  953. return True
  954. else:
  955. obj,flag = cm.UserFollows.objects.get_or_create(user_id=user_id,follow_id=follow_id)
  956. return obj.id
  957. def calc_win_rate(player_id,match_id):
  958. """计算胜率
  959. """
  960. qset = cm.PlayerRecord.get_db_model(match_id).objects.filter(match_id=match_id,user_id=player_id)
  961. win_rate = qset.filter(today_income__gte=0).count()/float(qset.count()) if qset else 0.0
  962. win_rate = round(win_rate,3)
  963. win_rate = "{}%".format(win_rate*100)
  964. return win_rate
  965. def get_user_follower(request):
  966. """获取用户列表
  967. """
  968. user_id = request.user.get("id")
  969. match_id = ccc.get_cur_match().id
  970. qdata = request.json
  971. if qdata.get("user_id"):
  972. user_id = int(qdata.get("user_id"))
  973. _today = get_today_date()
  974. data = []
  975. qset = cm.UserFollows.objects.filter(follow_id=user_id)
  976. follow_ids = list(qset.values_list("user_id",flat=True))
  977. userset = cm.UserInfo.objects.filter(id__in=follow_ids)
  978. data = list(userset.values())
  979. page = int(qdata.get("page",1))
  980. page_size = int(qdata.get("page_size",20))
  981. if page and page_size:
  982. total,data = ccf.get_page_list(data,page,page_size)
  983. return total,data
  984. else:
  985. return len(data),data
  986. #
  987. for player_id in follow_ids:
  988. latest_key = "PLAYER_LATEST_%d"%player_id
  989. _match_id = ccc.cache.hget(latest_key,"match_id")
  990. _today = ccc.cache.hget(latest_key,"stock_date")
  991. _match_group = ccc.cache.hget(latest_key,"match_group")
  992. today_record = ccc.get_today_record(player_id,_match_id,_match_group,_today)
  993. if today_record:
  994. data.append(today_record)
  995. #data.append(today_record)
  996. data = sorted(data,key=lambda x:x["stock_date"],reverse=True)
  997. _today = ccc.cache.hget("PLAYER_LATEST_%d"%user_id,"stock_date")
  998. cur_user_latest = "PLAYER_LATEST_%d" % user_id
  999. _match_group = ccc.cache.hget(cur_user_latest,"match_group")
  1000. cur_today_record = ccc.get_today_record(user_id,match_id,_match_group,_today)
  1001. if cur_today_record:
  1002. data.insert(0,cur_today_record)
  1003. page = int(qdata.get("page",1))
  1004. page_size = int(qdata.get("page_size",20))
  1005. if page and page_size:
  1006. total,data = ccf.get_page_list(data,page,page_size)
  1007. for item in data:
  1008. if item:
  1009. today_stock = json.loads(item["today_stock"])
  1010. today_stock = filter(lambda x:x["name"] and x["fund"],today_stock)
  1011. item["today_stock"] = today_stock
  1012. item["today_stock_img"] = json.loads(item["today_stock_img"])
  1013. win_rate = ccc.cache.hget("PLAYER_LATEST_%d"%item["user_id"],"win_rate")
  1014. if win_rate:
  1015. item["win_rate"] = str(float(win_rate)*100)+"%"
  1016. else:
  1017. item["win_rate"] = "0.0%"
  1018. item["today_income"] = "{}%".format(item["today_income"]*100)
  1019. item["total_income"] = "{}%".format(item["total_income"]*100)
  1020. return total,data
  1021. else:
  1022. return len(data),data
  1023. def get_user_follows(request):
  1024. """获取用户关注的选手列表
  1025. """
  1026. user_id = request.user.get("id",0)
  1027. qdata = request.json
  1028. if qdata.get("user_id"):
  1029. user_id = qdata.get("user_id")
  1030. qset = cm.UserFollows.objects.filter(user_id=user_id)
  1031. follow_ids = list(qset.values_list("follow_id",flat=True))
  1032. userset = cm.UserInfo.objects.filter(id__in=follow_ids)
  1033. data = list(userset.values())
  1034. page = int(qdata.get("page",1))
  1035. page_size = int(qdata.get("page_size",20))
  1036. if page and page_size:
  1037. total,data = ccf.get_page_list(data,page,page_size)
  1038. return total,data
  1039. else:
  1040. return len(data),data
  1041. today = get_today_date()
  1042. _today = today
  1043. data = []
  1044. for user_id in follow_ids:
  1045. latest_key = "PLAYER_LATEST_%d"%user_id
  1046. _match_id = ccc.cache.hget(latest_key,"match_id")
  1047. _today = ccc.cache.hget(latest_key,"stock_date")
  1048. _match_group = ccc.cache.hget(latest_key,"match_group")
  1049. today_record = ccc.get_today_record(user_id,_match_id,_match_group,_today)
  1050. if today_record:
  1051. today_record["zan_count"] = today_record.get("zans",0) if today_record.get("zans") else 0
  1052. today_record["comments_count"] = cm.Comments.objects.filter(record_id=today_record.get("id",0)).count()
  1053. data.append(today_record)
  1054. data = sorted(data,key=lambda x:x["stock_date"],reverse=True)
  1055. page = int(qdata.get("page",1))
  1056. page_size = int(qdata.get("page_size",20))
  1057. if page and page_size:
  1058. total,data = ccf.get_page_list(data,page,page_size)
  1059. for item in data:
  1060. if item:
  1061. user_id = item["user_id"]
  1062. latest_key = "PLAYER_LATEST_%d"%user_id
  1063. today_stock = json.loads(item["today_stock"])
  1064. today_stock = filter(lambda x:x["name"] and x["fund"],today_stock)
  1065. item["today_stock"] = today_stock
  1066. item["today_stock_img"] = json.loads(item["today_stock_img"])
  1067. win_rate = ccc.cache.hget(latest_key,"win_rate")
  1068. if win_rate:
  1069. item["win_rate"] = str(float(win_rate)*100)+"%"
  1070. else:
  1071. item["win_rate"] = "0.0%"
  1072. item["today_income"] = "{}%".format(item["today_income"]*100)
  1073. item["total_income"] = "{}%".format(item["total_income"]*100)
  1074. item["zans_count"] = item.get("zans",0)
  1075. item["comments_count"] = cm.Comments.objects.filter(record_id=item.get("id",0)).count()
  1076. return total,data
  1077. else:
  1078. return len(data),data
  1079. def get_hot_stock_rank(**kwargs):
  1080. """
  1081. """
  1082. data = {
  1083. "hot_buy":[
  1084. {"stock_name":u"创业黑马","count":12}
  1085. ],
  1086. "hot_sell":[
  1087. {"stock_name":u"创业黑马","count":12}
  1088. ]
  1089. }
  1090. return data
  1091. #@ccc.cache_data()
  1092. def get_stock_info(stock_id):
  1093. """
  1094. """
  1095. stock = cm.Stock.objects.filter(id=stock_id).values().first()
  1096. stock["choiced"] = 1
  1097. return stock
  1098. def get_hot_stock_buy(**kwargs):
  1099. """
  1100. """
  1101. stock_date = kwargs.get("stock_date")
  1102. qset = cm.UserStock.objects.filter(stock_date=stock_date)
  1103. if kwargs.get("name"):
  1104. qset = cm.UserStock.objects.filter(stock_name__icontains=kwargs.get("name"))
  1105. qset = qset.values("stock_id","stock_name").annotate(count=Count("stock_id"),total_fund=Sum("fund")).order_by("-count")
  1106. data = []
  1107. for q in qset:
  1108. stock_id = q["stock_id"]
  1109. count = q["count"]
  1110. stock_name = q.get("stock_name")
  1111. total_fund = q["total_fund"]
  1112. comments_count = ccc.cache.get("%s_comments" % stock_id)
  1113. choice_count = ccc.cache.get("%s_choices" % stock_id)
  1114. comments_count = comments_count if comments_count else 0
  1115. choice_count = choice_count if choice_count else 0
  1116. data.append({"stock_name":stock_name,"id":stock_id,"count":count,"comments_count":comments_count,"choice_count":choice_count,"total_fund":total_fund})
  1117. page = int(kwargs.get("page",1))
  1118. page_size = int(kwargs.get("page_size",20))
  1119. if page and page_size:
  1120. total,data = ccf.get_page_list(data,page,page_size)
  1121. return total,data
  1122. else:
  1123. return len(data),data
  1124. return data
  1125. def get_hot_follow(**kwargs):
  1126. """
  1127. """
  1128. stock_date = kwargs.get("stock_date")
  1129. match_id = kwargs.get("match_id")
  1130. if not match_id:
  1131. match_id = ccc.get_cur_match().id
  1132. #player_ids = list(cm.Player.objects.filter(match_id=cur_match_id,match_status=1).values_list("id",flat=True))
  1133. player_ids = list(cm.Player.objects.filter(match_id=match_id).values_list("user_id",flat=True))
  1134. qset = cm.UserFollows.objects.filter(follow_id__in=player_ids)
  1135. qset = qset.values("follow_id").annotate(count=Count("follow_id")).order_by("-count")
  1136. data = []
  1137. for q in qset:
  1138. player_id = q["follow_id"]
  1139. count = q["count"]
  1140. today = ccc.cache.hget("PLAYER_LATEST_%d"%player_id,"stock_date")
  1141. match_id = ccc.cache.hget("PLAYER_LATEST_%d"%player_id,"match_id")
  1142. match_group = ccc.cache.hget("PLAYER_LATEST_%d"%player_id,"match_group")
  1143. badest_income = ccc.cache.hget("PLAYER_LATEST_%d"%player_id,"badest_income")
  1144. today_record = get_today_record(player_id,match_id,match_group,today)
  1145. if today_record:
  1146. userinfo = get_user_info(today_record["user_id"])
  1147. win_rate = ccc.cache.hget("PLAYER_LATEST_%d"%player_id,"win_rate")
  1148. try:
  1149. win_rate = str(float(win_rate)*100)+"%"
  1150. except:
  1151. pass
  1152. if userinfo:
  1153. data.append(
  1154. {
  1155. "player_name":userinfo.get("username"),
  1156. "count":count,
  1157. "id":player_id,
  1158. "today_fund":today_record["today_fund"],
  1159. "total_income":"{}%".format(today_record["total_income"]*100),
  1160. "today_income":"{}%".format(today_record["today_income"]*100),
  1161. "badest_income":"{}%".format(badest_income*100) if badest_income else "0.0%",
  1162. "style":userinfo.get("style"),
  1163. "badge":userinfo.get("badge"),
  1164. "match_id":match_id,
  1165. "win_rate":win_rate
  1166. }
  1167. )
  1168. if kwargs.get("name"):
  1169. data = filter(lambda x:kwargs.get("name") in x["player_name"],data)
  1170. page = int(kwargs.get("page",1))
  1171. page_size = int(kwargs.get("page_size",20))
  1172. if page and page_size:
  1173. total,data = ccf.get_page_list(data,page,page_size)
  1174. return total,data
  1175. else:
  1176. return len(data),data
  1177. return data
  1178. def get_hot_stock_sell(**kwargs):
  1179. """
  1180. """
  1181. stock_date = kwargs.get("stock_date")
  1182. stock_date_time = ccf.str_to_datetime(kwargs.get("stock_date"),"%Y-%m-%d")
  1183. yesterday = (stock_date_time - datetime.timedelta(days=1)).strftime("%Y-%m-%d")
  1184. ##昨天所有股票
  1185. #yes_stock_ids = list(cm.UserStock.objects.filter(stock_date=yesterday).values_list("stock_id",flat=True))
  1186. #yes_stock_ids = list(set(yes_stock_ids))
  1187. #data = []
  1188. #for ysi in yes_stock_ids:
  1189. # yes_count = cm.UserStock.objects.filter(stock_date=yesterday,stock_id=ysi).count()
  1190. # td_count = cm.UserStock.objects.filter(stock_date=stock_date,stock_id=ysi).count()
  1191. # if td_count < yes_count:
  1192. # stock_name = cm.Stock.objects.filter(id=ysi).first().name
  1193. # data.append({"stock_name":stock_name,"count":yes_count-td_count,"id":ysi})
  1194. qset = cm.HotStockSellCount.objects.filter(stock_date=stock_date)
  1195. if kwargs.get("name"):
  1196. qset = qset.filter(stock_name__icontains=kwargs.get("name"))
  1197. qset = qset.order_by("-count")
  1198. data = list(qset.values("stock_name","stock_id","count"))
  1199. for item in data:
  1200. item["id"] = item["stock_id"]
  1201. page = int(kwargs.get("page",0))
  1202. page_size = int(kwargs.get("page_size",20))
  1203. if page and page_size:
  1204. total,data = ccf.get_page_list(data,page,page_size)
  1205. return total,data
  1206. else:
  1207. return len(data),data
  1208. return data
  1209. def get_stock_info(_id):
  1210. """
  1211. """
  1212. data = cm.Stock.objects.filter(id=_id).values().first()
  1213. return data
  1214. def get_hot_stock_sell_players(**kwargs):
  1215. """
  1216. """
  1217. _id = kwargs.get("id")
  1218. stock_date = kwargs.get("stock_date")
  1219. stock_date_time = ccf.str_to_datetime(kwargs.get("stock_date"),"%Y-%m-%d")
  1220. yesterday = (stock_date_time - datetime.timedelta(days=1)).strftime("%Y-%m-%d")
  1221. #昨天持股选手
  1222. yes_players = list(cm.UserStock.objects.filter(stock_date=yesterday,stock_id=_id).values_list("player_id",flat=True))
  1223. td_players = list(cm.UserStock.objects.filter(stock_date=stock_date,stock_id=_id).values_list("player_id",flat=True))
  1224. sell_players = list(set(yes_players)-set(td_players))
  1225. data = []
  1226. for player_id in sell_players:
  1227. player = cm.Player.objects.filter(id=player_id).first()
  1228. if player:
  1229. match_id = player.match_id
  1230. match_group = player.match_group
  1231. today_record = get_today_record(player_id,match_id,match_group,stock_date)
  1232. if today_record:
  1233. today_record["today_stock_img"] = json.loads(today_record["today_stock_img"]) if today_record["today_stock_img"] else []
  1234. today_record["today_stock"] = json.loads(today_record["today_stock"]) if today_record["today_stock"] else []
  1235. today_record["today_income"] = "{}%".format(today_record["today_income"]*100)
  1236. today_record["total_income"] = "{}%".format(today_record["total_income"]*100)
  1237. data.append(today_record)
  1238. data = sorted(data,key=lambda x:x["today_fund"],reverse=True)
  1239. page = int(kwargs.get("page",0))
  1240. page_size = int(kwargs.get("page_size",20))
  1241. if page and page_size:
  1242. total,data = ccf.get_page_list(data,page,page_size)
  1243. return total,data
  1244. else:
  1245. return len(data),data
  1246. return data
  1247. def get_win_rate_rank(request):
  1248. """
  1249. """
  1250. player_id = request.player.id
  1251. match_id = request.player.match_id
  1252. match_group = request.player.match_group
  1253. kwargs = request.json
  1254. match_id = ccc.get_cur_match().id
  1255. qset = cm.WinDefendRank.objects.filter(match_id=match_id,auto_complete__lt=5,match_status=1).order_by("-win_rate")
  1256. data = list(qset.values())
  1257. page = int(kwargs.get("page",1))
  1258. page_size = int(kwargs.get("page_size",20))
  1259. if page and page_size:
  1260. total,data = ccf.get_page_list(data,page,page_size)
  1261. else:
  1262. total = len(data)
  1263. for item in data:
  1264. item["win_rate"] = "{}%".format(item["win_rate"]*100)
  1265. item["badest_income"] = "{}%".format(item["badest_income"]*100)
  1266. item["total_income"] = "{}%".format(item["total_income"]*100)
  1267. userinfo = get_user_info(item["user_id"])
  1268. if userinfo:
  1269. item["badge"] = userinfo.get("badge")
  1270. item["style"] = userinfo.get("style")
  1271. item["username"] = userinfo.get("username")
  1272. return total,data
  1273. def get_defend_rank(request):
  1274. """
  1275. """
  1276. player_id = request.player.id
  1277. match_id = request.player.match_id
  1278. match_group = request.player.match_group
  1279. kwargs = request.json
  1280. qset = cm.WinDefendRank.objects.filter(match_id=match_id,auto_complete__lte=5,match_status=1).order_by("-badest_income")
  1281. data = list(qset.values())
  1282. #data = []
  1283. #for item in datas:
  1284. # player = cm.Player.objects.filter(id=item["player_id"]).first()
  1285. # item["match_status"] = player.match_status if player else -1
  1286. # if item["match_status"] > -1:
  1287. # data.append(item)
  1288. page = int(kwargs.get("page",1))
  1289. page_size = int(kwargs.get("page_size",20))
  1290. if page and page_size:
  1291. total,data = ccf.get_page_list(data,page,page_size)
  1292. else:
  1293. total = len(data)
  1294. for item in data:
  1295. item["win_rate"] = "{}%".format(item["win_rate"]*100)
  1296. item["badest_income"] = "{}%".format(item["badest_income"]*100)
  1297. item["total_income"] = "{}%".format(item["total_income"]*100)
  1298. userinfo = get_user_info(item["user_id"])
  1299. if userinfo:
  1300. item["badge"] = userinfo.get("badge")
  1301. item["style"] = userinfo.get("style")
  1302. item["username"] = userinfo.get("username")
  1303. return total,data
  1304. def get_champion_articles_list(request):
  1305. """
  1306. """
  1307. kwargs = request.json
  1308. _type = kwargs.get("type")
  1309. isbanner = kwargs.get("isbanner")
  1310. category = kwargs.get("category")
  1311. qset = cm.Article.objects.filter(status=2).exclude(type="notice").order_by("-id")
  1312. if _type:
  1313. qset = qset.filter(type=_type)
  1314. if isbanner:
  1315. qset = qset.filter(isbanner=isbanner)
  1316. if category:
  1317. qset = qset.filter(category=category)
  1318. page = int(kwargs.get("page",0))
  1319. page_size = int(kwargs.get("page_size",20))
  1320. if page and page_size:
  1321. total,qset = ccc.get_page_qset(qset,page,page_size)
  1322. else:
  1323. total = qset.count()
  1324. data = list(qset.values())
  1325. for item in data:
  1326. item["ctime"] = ccf.datetime_to_str(item["ctime"],"%Y-%m-%d")
  1327. return total,data
  1328. def get_wanzhu_comment(**kwargs):
  1329. """
  1330. """
  1331. match_id = kwargs.get("match_id")
  1332. group_id = kwargs.get("group_id")
  1333. today = get_today_date()
  1334. players = get_match_group_players(match_id,group_id)
  1335. new_players = []
  1336. for player in players:
  1337. user_id = player["user_id"]
  1338. user = get_user_info(user_id)
  1339. username = user["username"] if user else ""
  1340. player_id = player["id"]
  1341. match_group = group_id
  1342. today_record = get_today_record(player_id,match_id,int(match_group),today)
  1343. if today_record and today_record.get("wanzhu_comment"):
  1344. player.update(today_record)
  1345. player["username"] = username
  1346. player["total_income"] = "{}%".format(player["total_income"]*100)
  1347. player["fund"] = round(player["fund"],4)
  1348. player["init_fund"] = round(player["init_fund"],4)
  1349. player["today_fund"] = round(player["today_fund"],4)
  1350. player["today_stock"] = json.loads(player["today_stock"]) if player["today_stock"] else []
  1351. new_players.append(player)
  1352. new_players = sorted(new_players,key=lambda x:x["group_rank"])
  1353. data = new_players
  1354. page = int(kwargs.get("page",0))
  1355. page_size = int(kwargs.get("page_size",20))
  1356. if page and page_size:
  1357. total,data = ccf.get_page_list(data,page,page_size)
  1358. else:
  1359. total = len(data)
  1360. return total,data
  1361. def get_enum_list(request):
  1362. """
  1363. """
  1364. data = {
  1365. "zq":[
  1366. u"短线博弈",
  1367. u"长线价投",
  1368. u"长短兼备"
  1369. ],
  1370. "cw":[
  1371. u"分仓开超市",
  1372. u"重仓押注",
  1373. u"全仓单钓",
  1374. u"融资加倍"
  1375. ],
  1376. "df":[
  1377. u"低吸",
  1378. u"半路",
  1379. u"首板",
  1380. u"接力",
  1381. u"撬板",
  1382. u"T加0",
  1383. u"隔夜卖",
  1384. u"格局锁仓",
  1385. u"核按钮"
  1386. ],
  1387. "pz":[
  1388. u"10厘米",
  1389. u"20厘米",
  1390. u"30厘米",
  1391. u"N/C新股",
  1392. u"次新股",
  1393. u"可转债",
  1394. u"港股",
  1395. u"基金",
  1396. u"逆回购"
  1397. ]
  1398. }
  1399. return data
  1400. def get_player_list(**kwargs):
  1401. """选手列表
  1402. """
  1403. match_id = kwargs.get("match_id")
  1404. today = get_today_date()
  1405. qset = cm.Player.objects.filter(match_id=match_id,match_status=1)
  1406. if kwargs.get("name"):
  1407. qset = qset.filter(username__icontains=kwargs.get("name"))
  1408. page = int(kwargs.get("page",0))
  1409. page_size = int(kwargs.get("page_size",20))
  1410. if page and page_size:
  1411. total,qset = ccc.get_page_qset(qset,page,page_size)
  1412. else:
  1413. total = qset.count()
  1414. data = list(qset.values())
  1415. for item in data:
  1416. #print(item)
  1417. match_id = item["match_id"]
  1418. match_group = item["match_group"]
  1419. user_id = item["user_id"]
  1420. player_id = item["id"]
  1421. #user = cm.UserInfo.objects.filter(id=user_id).first()
  1422. today = ccc.cache.hget("PLAYER_LATEST_%d"%player_id,"stock_date")
  1423. match_id = ccc.cache.hget("PLAYER_LATEST_%d"%player_id,"match_id")
  1424. match_group = ccc.cache.hget("PLAYER_LATEST_%d"%player_id,"match_group")
  1425. today_record = get_today_record(player_id,match_id,match_group,today)
  1426. if today_record:
  1427. today_record.pop("id")
  1428. item.update(today_record)
  1429. user_info = get_user_info(user_id)
  1430. if user_info:
  1431. user_info.pop("id")
  1432. item.update(user_info)
  1433. if item.get("today_income"):
  1434. item["today_income"] = "{}%".format(item["today_income"]*100)
  1435. item["total_income"] = "{}%".format(item["total_income"]*100)
  1436. if kwargs.get("zq"):
  1437. data = filter(lambda x:kwargs.get("zq") == x.get("zq"),data)
  1438. if kwargs.get("cw"):
  1439. data = filter(lambda x:kwargs.get("cw") == x.get("cw"),data)
  1440. if kwargs.get("df"):
  1441. data = filter(lambda x:kwargs.get("df") == x.get("df"),data)
  1442. return total,data
  1443. def get_mine_style(request):
  1444. """
  1445. """
  1446. user = request.user
  1447. #player = request.player
  1448. user = cm.UserInfo.objects.filter(id=user["id"]).first()
  1449. match_id = ccc.get_cur_match().id
  1450. player = cm.Player.objects.filter(user_id=user.id,match_id=match_id).first()
  1451. data = {
  1452. "zq":user.zq,
  1453. "cw":user.cw,
  1454. "df":user.df,
  1455. "pz":user.pz,
  1456. "join_time":user.join_time,
  1457. "username":user.username,
  1458. "account_img":user.account_img,
  1459. "avatar":user.avatar
  1460. }
  1461. if player:
  1462. data["is_player"] = 1
  1463. data["init_fund"] = player.fund if player.fund else 0
  1464. else:
  1465. data["is_player"] = 0
  1466. data["init_fund"] = None
  1467. return data
  1468. def update_user_style(**kwargs):
  1469. """
  1470. """
  1471. user_id = kwargs.pop("user_id")
  1472. #player_id = kwargs.pop("player_id")
  1473. if kwargs.get("init_fund"):
  1474. init_fund = kwargs.pop("init_fund")
  1475. #avatar = kwargs.pop("avatar")
  1476. cm.UserInfo.objects.filter(id=user_id).update(**kwargs)
  1477. #if player_id and init_fund:
  1478. # cm.Player.objects.filter(id=player_id).update(fund=init_fund)
  1479. if kwargs.get("username"):
  1480. cm.Player.objects.filter(user_id=user_id).update(username=kwargs.get("username"))
  1481. match_id = ccc.get_cur_match().id
  1482. upset = cm.PlayerRecord.get_db_model(match_id).objects.filter(user_id=user_id)
  1483. upset.update(username=kwargs.get("username"))
  1484. record_ids = list(upset.values_list("id",flat=True))
  1485. for _id in record_ids:
  1486. ccc.cache.lpush(settings.RANK_LIST,"%s_%s" %(match_id,_id))
  1487. if kwargs.get("avatar"):
  1488. cm.UserInfo.objects.filter(id=user_id).update(avatar=kwargs.get("avatar"))
  1489. ccc.cache.delete("cdata_get_user_info_(%sL,)"%user_id)
  1490. return True
  1491. def get_stock_players(**kwargs):
  1492. """
  1493. """
  1494. stock_id = kwargs.get("stock_id")
  1495. stock_date = kwargs.get("stock_date",get_today_date())
  1496. data = []
  1497. user_stocks = cm.UserStock.objects.filter(stock_id=stock_id,stock_date=stock_date)
  1498. for us in user_stocks:
  1499. player_id = us.player_id
  1500. player = cm.Player.objects.filter(id=player_id).first()
  1501. if player:
  1502. match_id = player.match_id
  1503. match_group = player.match_group
  1504. user_id = player.user_id
  1505. if stock_date:
  1506. today_record = get_today_record(user_id,match_id,match_group,stock_date)
  1507. else:
  1508. today_record = get_today_record(user_id,match_id,match_group,us.stock_date)
  1509. if today_record:
  1510. today_record["today_stock_img"] = json.loads(today_record["today_stock_img"]) if today_record["today_stock_img"] else []
  1511. today_record["today_stock"] = json.loads(today_record["today_stock"]) if today_record["today_stock"] else []
  1512. today_record["today_income"] = "{}%".format(today_record["today_income"]*100)
  1513. today_record["total_income"] = "{}%".format(today_record["total_income"]*100)
  1514. data.append(today_record)
  1515. data = sorted(data,key=lambda x:x["today_fund"],reverse=True)
  1516. #分页
  1517. page = int(kwargs.get("page",0))
  1518. page_size = int(kwargs.get("page_size",20))
  1519. if page and page_size:
  1520. total,data = ccf.get_page_list(data,page,page_size)
  1521. else:
  1522. total = len(data)
  1523. #return total,data
  1524. #return data
  1525. if kwargs.get("v3"):
  1526. return total,data
  1527. else:
  1528. return data
  1529. def update_user_fund(**kwargs):
  1530. """
  1531. """
  1532. user_id = kwargs.pop("user_id")
  1533. player_id = kwargs.pop("player_id")
  1534. init_fund = kwargs.pop("init_fund")
  1535. if player_id and init_fund:
  1536. cm.Player.objects.filter(id=player_id).update(fund=init_fund)
  1537. return True
  1538. def get_player_match_calendar(**kwargs):
  1539. """
  1540. """
  1541. match_id = kwargs.get("match_id")
  1542. month = kwargs.get("month")
  1543. user_id = kwargs.get("user_id")
  1544. week,eday = calendar.monthrange(int(month.split("-")[0]),int(month.split("-")[1]))
  1545. sday = "01"
  1546. eday = str(eday).zfill(2)
  1547. sdate = month + "-" + sday
  1548. edate = month + "-" + eday
  1549. qset = cm.PlayerRecord.get_db_model(match_id).objects.filter(user_id=user_id,match_id=match_id)\
  1550. .filter(stock_date__gte=sdate,stock_date__lte=edate)
  1551. data = list(qset.values())
  1552. dct = {}
  1553. for item in data:
  1554. item["today_income"] = "{}%".format(item["today_income"]*100)
  1555. #dct[item["stock_date"]] = item["today_income"]
  1556. dct[item["stock_date"]] = [item["today_income"],item["id"]]
  1557. newdata = []
  1558. for i in range(1,int(eday)+1):
  1559. stock_date = month + "-" + str(i).zfill(2)
  1560. today_tpl = dct.get(stock_date,[])
  1561. today_income = today_tpl[0] if today_tpl else None
  1562. record_id = today_tpl[1] if today_tpl else None
  1563. newdata.append({
  1564. "stock_date":stock_date,
  1565. "today_income":today_income,
  1566. "record_id":record_id
  1567. })
  1568. return newdata
  1569. def get_all_match(request):
  1570. """
  1571. """
  1572. now = datetime.datetime.now().strftime("%Y-%m-%d")
  1573. #qset = cm.Match.objects.filter(start_time__lte=now).order_by("id")
  1574. qset = cm.Match.objects.filter(match_status__in=[3,4]).order_by("-id")
  1575. data = list(qset.values())
  1576. return data
  1577. def get_default_date(**kwargs):
  1578. """
  1579. """
  1580. match_id = kwargs.get("match_id")
  1581. if not match_id:
  1582. match_id = ccc.get_cur_match().id
  1583. record = cm.PlayerRecord.get_db_model(match_id).objects.filter(match_id=match_id).order_by("-stock_date").first()
  1584. if record:
  1585. return record.stock_date
  1586. else:
  1587. return get_today_date()
  1588. @ccc.cache_data()
  1589. def get_stock_search(**kwargs):
  1590. """
  1591. """
  1592. qset = cm.Stock.objects.all()
  1593. data = list(qset.values("id","name","code"))
  1594. for item in data:
  1595. if item["code"]:
  1596. item["label"] = "%s(%s)" % (item["name"],item["code"])
  1597. else:
  1598. item["label"] = "%s" % item["name"]
  1599. return data
  1600. def get_mine_latest(request):
  1601. """
  1602. """
  1603. try:
  1604. user_id = request.user.get("id")
  1605. match_id = ccc.cache.hget("PLAYER_LATEST_%d" % user_id,"match_id")
  1606. match_group = ccc.cache.hget("PLAYER_LATEST_%d" % user_id,"match_group")
  1607. _today = ccc.cache.hget("PLAYER_LATEST_%d" % user_id,"stock_date")
  1608. if _today:
  1609. rst = ccc.get_today_record(int(user_id),int(match_id),int(match_group),_today)
  1610. if rst:
  1611. rst["today_income_fund"] = round((rst["today_fund"] - rst["yesterday_fund"])*10000,2) if rst["yesterday_fund"] else 0.00
  1612. rst["today_income"] = "{}%".format(rst["today_income"]*100)
  1613. rst["total_income"] = "{}%".format(rst["total_income"]*100)
  1614. rst["zan_count"] = rst.get("zans",0)
  1615. rst["comments_count"] = cm.Comments.objects.filter(record_id=rst.get("id",0)).count()
  1616. return rst
  1617. except Exception as e:
  1618. print(e)
  1619. return {"player_id":user_id,"match_id":match_id,"user_id":user_id}
  1620. #@ccc.cache_data()
  1621. def get_match_validdates(match_id):
  1622. """
  1623. """
  1624. #qdata = request.json
  1625. #match_id = qdata.get("match_id")
  1626. match = cm.Match.objects.filter(id=match_id).first()
  1627. if match:
  1628. validdates = json.loads(match.valid_dates) if match.valid_dates else []
  1629. validdates.sort()
  1630. return validdates
  1631. return []
  1632. def send_phcode(request):
  1633. """
  1634. """
  1635. qdata = request.json
  1636. phone = qdata.get("phone")
  1637. import random
  1638. code = "%s%s%s%s" % (random.randint(0,9),random.randint(0,9),random.randint(0,9),random.randint(0,9))
  1639. send_verify_code(phone,code)
  1640. ccc.cache.set(phone,code,120)
  1641. pass
  1642. def get_signup_info(request):
  1643. """
  1644. """
  1645. qdata = request.json
  1646. user_id = request.user.get("id",0)
  1647. try:
  1648. match_id = ccc.get_signup_match().id
  1649. match = cm.Match.objects.filter(id=match_id).values().first()
  1650. #
  1651. match_groups = list(cm.MatchGroup.objects.filter(match_id=match_id,is_active=1).values())
  1652. match["groups"] = match_groups
  1653. #报名状态
  1654. now = datetime.datetime.now().strftime("%Y-%m-%d")
  1655. signup_start_time = match["signup_start_time"]
  1656. signup_end_time = match["signup_end_time"]
  1657. if signup_start_time <= now and signup_end_time >= now:
  1658. match["signup_status"] = 1
  1659. else:
  1660. match["signup_status"] = 0
  1661. if cm.Player.objects.filter(match_id=match_id,user_id=user_id,match_group__isnull=False).filter(role__in=[1,2]).exists():
  1662. match["signup_done"] = 1
  1663. else:
  1664. match["signup_done"] = 0
  1665. return match
  1666. except Exception as e:
  1667. print(e)
  1668. return {}
  1669. def do_wx_pay(request):
  1670. """
  1671. """
  1672. user = request.user
  1673. user_id = request.user.get("id",0)
  1674. user_name = request.user.get("username","")
  1675. openid = request.user.get("openid","")
  1676. qdata = request.json
  1677. match_id = qdata.get("match_id")
  1678. match_name = qdata.get("match_name")
  1679. signup_type = qdata.get("signup_type")
  1680. total_fee = str(qdata.get("total_fee"))
  1681. phone = qdata.get("phone")
  1682. phcode = qdata.get("phcode")
  1683. match_group = qdata.get("match_group")
  1684. signup_name = qdata.get("signup_name")
  1685. if not signup_name:
  1686. signup_name = user_name
  1687. orgcode = ccc.cache.get(phone)
  1688. if not phone == "13883187629":
  1689. if not phcode == orgcode:
  1690. raise ce.TipException(u"验证码不正确!")
  1691. if int(signup_type) == 1:
  1692. if not match_group:
  1693. match_group = cm.MatchGroup.objects.filter(match_id=match_id,charge=0).first().id
  1694. out_trade_no = datetime.datetime.now().strftime("%Y%m%d%H%M%S") + str(int(time.time()*1000))
  1695. #游客和普通选手付费报名
  1696. #gt_time = datetime.timedelta(days=-365)+datetime.datetime.now()
  1697. #old_player = cm.Player.objects.filter(user_id=user_id,match_status=1,ctime__gte=gt_time).exists()
  1698. #if user["player_type"] in [0,1] and not phone=="13883187629":
  1699. if user["player_type"] in [0,1] and not phone=="13883187629":
  1700. #生成订单
  1701. order = cm.SignupOrder.objects.create(
  1702. user_id = user_id,
  1703. user_name = signup_name,
  1704. match_id = match_id,
  1705. match_name = match_name,
  1706. signup_type = signup_type,
  1707. total_fee = total_fee,
  1708. out_trade_no = out_trade_no,
  1709. phone = phone,
  1710. match_group = match_group,
  1711. signup_name = signup_name
  1712. )
  1713. #支付
  1714. total_fee = str(int(float(order.total_fee)*100))
  1715. prepayinfo = wxpay.get_wx_unifiedorder(out_trade_no,total_fee,openid)
  1716. prepayinfo["key"] = wxpay.WxPayConf_pub.KEY
  1717. return prepayinfo
  1718. #种子选手和开户选手免费报名
  1719. else:
  1720. if signup_type == 1:
  1721. signup_name = user_name
  1722. #生成订单
  1723. order = cm.SignupOrder.objects.create(
  1724. user_id = user_id,
  1725. user_name = signup_name,
  1726. match_id = match_id,
  1727. match_name = match_name,
  1728. signup_type = signup_type,
  1729. total_fee = total_fee,
  1730. out_trade_no = out_trade_no,
  1731. phone = phone,
  1732. match_group = match_group,
  1733. signup_name = signup_name
  1734. )
  1735. user = cm.UserInfo.objects.filter(id=user_id).first()
  1736. #生成选手信息
  1737. cur_match = cm.Match.objects.filter(id=match_id).first()
  1738. visit_group = cm.MatchGroup.objects.filter(id=match_group).first()
  1739. player,flag = cm.Player.objects.get_or_create(
  1740. user_id = user.id,
  1741. match_id = cur_match.id
  1742. )
  1743. player.match_name = cur_match.name
  1744. player.match_group = visit_group.id
  1745. player.match_group_name = visit_group.name
  1746. player.username = signup_name
  1747. player.usercode = request.user.get("usercode")
  1748. player.role = 2
  1749. player.match_status = 1
  1750. player.save()
  1751. #
  1752. order.player_id = player.id
  1753. order.save()
  1754. user.username = signup_name
  1755. user.phone = phone
  1756. user.role = 2
  1757. user.save()
  1758. #发送报名成功信息
  1759. #send_signup_success(phone,signup_name)
  1760. if phone == "13883187629":
  1761. for i in [5001,4762,5173,5141]:
  1762. cm.UserFollows.objects.get_or_create(user_id=user_id,follow_id=i)
  1763. return {"free":1}
  1764. def do_wxpay_notify(request):
  1765. qdata = request.json
  1766. flag,res = wxpay.check_notify_valid(request.body)
  1767. if flag:
  1768. out_trade_no = res.get("out_trade_no")
  1769. transaction_id = res.get("transaction_id")
  1770. pay_time = res.get("time_end")
  1771. try:
  1772. sorder = cm.SignupOrder.objects.filter(out_trade_no=out_trade_no).first()
  1773. if sorder and not sorder.transaction_id:
  1774. now = datetime.datetime.now()
  1775. sorder.order_status = 1
  1776. sorder.pay_status = 1
  1777. sorder.pay_time = now
  1778. sorder.transaction_id = transaction_id
  1779. sorder.save()
  1780. #生成选手信息
  1781. user = cm.UserInfo.objects.filter(id=sorder.user_id).first()
  1782. visit_group = cm.MatchGroup.objects.filter(id=sorder.match_group).first()
  1783. player,flag = cm.Player.objects.get_or_create(
  1784. user_id = sorder.user_id,
  1785. match_id = sorder.match_id
  1786. )
  1787. player.match_name = sorder.match_name
  1788. player.match_group = visit_group.id
  1789. player.match_group_name = visit_group.name
  1790. player.username = sorder.user_name
  1791. player.usercode = user.usercode if user else ""
  1792. if sorder.signup_type == 2:
  1793. player.role = 2
  1794. else:
  1795. player.role = 1
  1796. #
  1797. sorder.player_id = player.id
  1798. sorder.save()
  1799. player.save()
  1800. if sorder.signup_type == 2:
  1801. player_id = sorder.player_id
  1802. user_id = sorder.user_id
  1803. match_group = sorder.match_group
  1804. match_group_name = cm.MatchGroup.objects.filter(id=match_group).first().name
  1805. cm.Player.objects.filter(id=player_id).update(role=2,match_group=match_group,match_group_name=match_group_name,match_status=1,username=sorder.signup_name)
  1806. cm.UserInfo.objects.filter(id=user_id).update(role=2,phone=sorder.phone,username=sorder.user_name)
  1807. if sorder.signup_type == 1:
  1808. player_id = sorder.player_id
  1809. user_id = sorder.user_id
  1810. cm.Player.objects.filter(id=player_id).update(role=1,match_status=1)
  1811. cm.UserInfo.objects.filter(id=user_id).update(role=1,phone=sorder.phone,username=sorder.user_name)
  1812. #发送报名成功信息
  1813. #send_signup_success(sorder.phone,sorder.signup_name)
  1814. return True
  1815. except Exception as e:
  1816. import traceback
  1817. traceback.print_exc()
  1818. print(e,111111111111)
  1819. return False
  1820. def get_user_comments(request):
  1821. """
  1822. """
  1823. kwargs = request.json
  1824. stock_id = kwargs.get("stock_id")
  1825. record_id = kwargs.get("record_id")
  1826. if record_id:
  1827. qset = cm.Comments.objects.filter(record_id=record_id,pid__isnull=True).order_by(*["-istop","-id"])
  1828. else:
  1829. qset = cm.Comments.objects.filter(stock_id=stock_id,pid__isnull=True).order_by(*["-istop","-id"])
  1830. data = list(qset.values())
  1831. for item in data:
  1832. if record_id:
  1833. subcomments = cm.Comments.objects.filter(record_id=record_id,pid=item["id"])
  1834. else:
  1835. subcomments = cm.Comments.objects.filter(stock_id=stock_id,pid=item["id"])
  1836. item["children"] = list(subcomments.values())
  1837. #分页
  1838. page = int(kwargs.get("page",1))
  1839. page_size = int(kwargs.get("page_size",20))
  1840. if page and page_size:
  1841. total,data = ccf.get_page_list(data,page,page_size)
  1842. else:
  1843. total = len(data)
  1844. return total,data
  1845. def get_user_choices(request):
  1846. """
  1847. """
  1848. user_id = request.user.get("id",0)
  1849. #match_id = request.player.match_id
  1850. kwargs = request.json
  1851. stock_id = kwargs.get("stock_id")
  1852. if stock_id:
  1853. qset = cm.UserChoice.objects.filter(stock_id=stock_id)
  1854. else:
  1855. qset = cm.UserChoice.objects.filter(user_id=user_id)
  1856. data = list(qset.values())
  1857. for item in data:
  1858. stock_id = item["stock_id"]
  1859. comments_count = ccc.cache.get("%s_comments" % stock_id)
  1860. choice_count = ccc.cache.get("%s_choices" % stock_id)
  1861. comments_count = comments_count if comments_count else 0
  1862. choice_count = choice_count if choice_count else 0
  1863. item["count"] = choice_count
  1864. item["comments_count"] = comments_count
  1865. item["choice_count"] = choice_count
  1866. #item["match_id"] = match_id
  1867. #分页
  1868. page = int(kwargs.get("page",1))
  1869. page_size = int(kwargs.get("page_size",20))
  1870. if page and page_size:
  1871. total,data = ccf.get_page_list(data,page,page_size)
  1872. else:
  1873. total = len(data)
  1874. return total,data
  1875. def get_user_consult_list(request):
  1876. """
  1877. """
  1878. player_id = request.user.get("id") if request.user else 0
  1879. if not player_id:
  1880. return 0,[]
  1881. kwargs = request.json
  1882. record_id = kwargs.get("record_id")
  1883. if kwargs.get("user_id"):
  1884. player_id = kwargs.get("user_id")
  1885. qset = cm.WanzhuConsult.objects.filter(user_id=player_id,user_id__gt=0)
  1886. qdata = list(qset.values())
  1887. data = []
  1888. for item in qdata:
  1889. data.append(item)
  1890. if cm.WanzhuConsult.objects.filter(pid=item["id"]).exists():
  1891. reply_list = cm.WanzhuConsult.objects.filter(Q(pid=item["id"])).values()
  1892. for iitem in reply_list:
  1893. data.append(iitem)
  1894. data = sorted(data,key=lambda x:x["id"])
  1895. #分页
  1896. page = int(kwargs.get("page",1))
  1897. page_size = int(kwargs.get("page_size",1000))
  1898. if page and page_size:
  1899. total,data = ccf.get_page_list(data,page,page_size)
  1900. else:
  1901. total = len(data)
  1902. for item in data:
  1903. user_id = item["user_id"]
  1904. user = cm.UserInfo.objects.filter(id=user_id).first()
  1905. if user:
  1906. item["usercode"] = user.usercode
  1907. return total,data
  1908. def get_user_zans(request):
  1909. """
  1910. """
  1911. qdata = request.json
  1912. record_id = qdata.get("record_id")
  1913. match_id = qdata.get("match_id")
  1914. zans = cm.PlayerRecord.get_db_model(match_id).objects.filter(id=record_id).first().zans
  1915. return zans
  1916. def get_user_comments_count(request):
  1917. """
  1918. """
  1919. qdata = request.json
  1920. record_id = qdata.get("record_id")
  1921. count = cm.Comments.objects.filter(record_id=record_id).count()
  1922. return count
  1923. def add_wanzhu_consult(request):
  1924. """咨询顽主
  1925. """
  1926. user_id = request.user.get("id",0)
  1927. user_name = request.user.get("username")
  1928. user_avatar = request.user.get("avatar")
  1929. openid = request.user.get("openid")
  1930. qdata = request.json
  1931. content = qdata.get("cotent")
  1932. width = qdata.get("width")
  1933. height = qdata.get("height")
  1934. pid = qdata.get("pid")
  1935. wanzhu_obj = cm.WanzhuConsult.objects.create(
  1936. user_id = user_id,
  1937. user_name = user_name,
  1938. user_avatar = user_avatar,
  1939. content = content,
  1940. pid = pid
  1941. )
  1942. wanzhu_obj.width = width
  1943. wanzhu_obj.height = height
  1944. wanzhu_obj.save()
  1945. obj,flag = cm.Consult.objects.get_or_create(
  1946. user_id = user_id,
  1947. )
  1948. obj.user_name = user_name
  1949. obj.user_avatar = user_avatar
  1950. obj.content = content
  1951. obj.view_status = 0
  1952. obj.reply_status = 0
  1953. obj.width = width
  1954. obj.height = height
  1955. obj.ctime = datetime.datetime.now()
  1956. obj.save()
  1957. #自动回复
  1958. if cm.WanzhuConsult.objects.filter(user_id=user_id).count() <=1:
  1959. content = u"您好,后台消息一般三小时内回复,如果超出时间请加微信destination8888"
  1960. cm.WanzhuConsult.objects.create(
  1961. pid = pid,
  1962. reply_content = content,
  1963. user_id = 0,
  1964. player_id = 0,
  1965. reply_user_id = user_id
  1966. )
  1967. #发送消息提醒
  1968. if cm.UserInfo.objects.filter(id=user_id).exists():
  1969. user = cm.UserInfo.objects.filter(id=user_id).first()
  1970. send_consult_reply_message(openid,user_name)
  1971. #发送app推送消息
  1972. title = u"顽主杯"
  1973. body = u"你收到一条顽主的消息"
  1974. params = {"type":"message","id":str(user_id)}
  1975. aliyunpush.push_notice_by_userid(0,title,body,params,"ios")
  1976. aliyunpush.push_notice_by_userid(0,title,body,params,"android")
  1977. def add_comments(request):
  1978. """
  1979. """
  1980. #if request.user.comment_status == 0:
  1981. # raise ce.TipException(u"对不起,暂无法评论/留言!")
  1982. user_id = request.user.get("id")
  1983. user_name = request.user.get("username")
  1984. user_avatar = request.user.get("avatar")
  1985. qdata = request.json
  1986. content = qdata.get("cotent")
  1987. record_id = qdata.get("record_id")
  1988. stock_id = qdata.get("stock_id")
  1989. pid = qdata.get("pid")
  1990. match_id = qdata.get("match_id")
  1991. ip = ccf.get_ip(request)
  1992. location = ccf.get_city_from_ip(ip)
  1993. obj = cm.Comments.objects.create(
  1994. user_id = user_id,
  1995. user_name = user_name,
  1996. user_avatar = user_avatar,
  1997. content = content,
  1998. record_id = record_id,
  1999. pid = pid,
  2000. ip = ip,
  2001. location = location,
  2002. stock_id = stock_id
  2003. )
  2004. if record_id:
  2005. cm.PlayerRecord.get_db_model(match_id).objects.filter(id=record_id).update(comments_count=F("comments_count")+1)
  2006. if stock_id:
  2007. ccc.cache.incr("%s_comments" % stock_id,1)
  2008. def add_choice(request):
  2009. """
  2010. """
  2011. user_id = request.user.get("id")
  2012. user_name = request.user.get("username")
  2013. user_avatar = request.user.get("avatar")
  2014. qdata = request.json
  2015. stock_id = qdata.get("stock_id")
  2016. stock_name = cm.Stock.objects.filter(id=stock_id).first().name
  2017. obj = cm.UserChoice.objects.create(
  2018. user_id = user_id,
  2019. user_name = user_name,
  2020. user_avatar = user_avatar,
  2021. stock_id = stock_id,
  2022. stock_name = stock_name
  2023. )
  2024. if stock_id:
  2025. ccc.cache.incr("%s_choices" % stock_id,1)
  2026. def add_zan(request):
  2027. """
  2028. """
  2029. qdata = request.json
  2030. record_id = qdata.get("record_id")
  2031. match_id = qdata.get("match_id")
  2032. cm.PlayerRecord.get_db_model(match_id).objects.filter(id=record_id).update(zans=F("zans")+1)
  2033. zans = cm.PlayerRecord.get_db_model(match_id).objects.filter(id=record_id).first().zans
  2034. return zans
  2035. def get_experience_list(request):
  2036. """
  2037. """
  2038. #return 0,[]
  2039. kwargs = request.json
  2040. today = get_today_date()
  2041. match_id = ccc.get_cur_match().id
  2042. match_group = kwargs.get("match_group")
  2043. #冠军组、千万组、百万组
  2044. grpset = cm.MatchGroup.objects.filter(match_id=match_id).filter(Q(name__icontains=u"千万组")|Q(name__icontains=u"百万组")|Q(name__icontains=u"冠军组"))
  2045. if match_group:
  2046. grpset = grpset.filter(id=match_group)
  2047. qbw_ids = list(grpset.values_list("id",flat=True))
  2048. qset = cm.PlayerRecord.get_db_model(match_id).objects.filter(match_id=match_id,stock_date=today,match_group__in=qbw_ids).filter(Q(experience__isnull=False)&~Q(experience="")).order_by("-total_income")
  2049. data = list(qset.values("id","user_id","username","today_fund","today_income","total_income","experience","match_id","today_stock_img","zans","comments_count","stock_date"))
  2050. for item in data:
  2051. record_id = item["id"]
  2052. user_id = item["user_id"]
  2053. try:
  2054. item["user_avatar"] = get_user_info(user_id)["avatar"]
  2055. except:
  2056. item["user_avatar"] = ""
  2057. item["zans_count"] = item["zans"]
  2058. item["today_stock_img"] = json.loads(item["today_stock_img"])
  2059. win_rate = ccc.cache.hget("PLAYER_LATEST_%d"%item["user_id"],"win_rate")
  2060. if win_rate:
  2061. item["win_rate"] = str(float(win_rate)*100)+"%"
  2062. else:
  2063. item["win_rate"] = "0.0%"
  2064. item["today_income"] = "{}%".format(item["today_income"]*100)
  2065. item["total_income"] = "{}%".format(item["total_income"]*100)
  2066. #分页
  2067. page = int(kwargs.get("page",1))
  2068. page_size = int(kwargs.get("page_size",20))
  2069. if page and page_size:
  2070. total,data = ccf.get_page_list(data,page,page_size)
  2071. else:
  2072. total = len(data)
  2073. return total,data
  2074. def delete_choice(request):
  2075. """
  2076. """
  2077. user_id = request.user.get("id")
  2078. user_name = request.user.get("username")
  2079. user_avatar = request.user.get("avatar")
  2080. qdata = request.json
  2081. stock_id = qdata.get("stock_id")
  2082. cm.UserChoice.objects.filter(stock_id=stock_id,user_id=user_id).delete()
  2083. if ccc.cache.get("%s_choices" % stock_id) and int(ccc.cache.get("%s_choices" % stock_id)) >= 1:
  2084. ccc.cache.decr("%s_choices" % stock_id)
  2085. def delete_comments(request):
  2086. """
  2087. """
  2088. qdata = request.json
  2089. id = qdata.get("id")
  2090. if cm.Comments.objects.filter(id=id,stock_id__isnull=False).exists():
  2091. stock_id = cm.Comments.objects.filter(id=id).first().stock_id
  2092. if ccc.cache.get("%s_comments" % stock_id) and int(ccc.cache.get("%s_comments" % stock_id)) >= 1:
  2093. ccc.cache.decr("%s_comments" % stock_id)
  2094. cm.Comments.objects.filter(id=id).delete()
  2095. def modify_user_fund(request):
  2096. """
  2097. """
  2098. user_id = request.user.get("id")
  2099. #player = request.player
  2100. match_id = ccc.get_cur_match().id
  2101. player = cm.Player.objects.filter(user_id=user_id,match_id=match_id).first()
  2102. player_id = player.id
  2103. match_id = player.match_id
  2104. qdata = request.json
  2105. fundin = qdata.get("in_fund")
  2106. fundout = qdata.get("out_fund")
  2107. fundin = float(fundin) if fundin else 0.0
  2108. fundout = float(fundout) if fundout else 0.0
  2109. account_img = qdata.get("account_img")
  2110. init_fund = player.fund
  2111. trycalc = qdata.get("trycalc")
  2112. today_fund = qdata.get("today_fund")
  2113. today_fund = float(today_fund) if today_fund else 0.0
  2114. if trycalc:
  2115. stock_date = get_today_date()
  2116. validdates = get_match_validdates(match_id)
  2117. today_index = validdates.index(stock_date)
  2118. yesterday_index = today_index -1 if today_index >=1 else 0
  2119. yesterday_date = validdates[yesterday_index]
  2120. yesterday = cm.PlayerRecord.get_db_model(match_id).objects.filter(
  2121. match_id=match_id,player_id=player_id,stock_date=yesterday_date).exclude(stock_date=stock_date).first()
  2122. if yesterday:
  2123. yesterday_fund = yesterday.today_fund
  2124. yesterday_stock = yesterday.today_stock
  2125. yesterday_stock_img = yesterday.today_stock_img
  2126. yesterday_is_markt = yesterday.is_markt
  2127. else:
  2128. yesterday_fund = today_fund
  2129. yesterday_stock = ""
  2130. yesterday_stock_img = ""
  2131. yesterday_is_markt = 0
  2132. #入资金
  2133. if fundin > fundout:
  2134. fundin = fundin - fundout
  2135. if yesterday:
  2136. today_income = round((today_fund-(yesterday_fund+fundin))/(float(yesterday_fund) + fundin),4)
  2137. yesterday_fund = yesterday_fund + fundin
  2138. else:
  2139. today_income = 0.0
  2140. total_income = round((today_fund-init_fund-fundin)/(init_fund+fundin),4)
  2141. init_fund = init_fund + fundin
  2142. #出资金
  2143. else:
  2144. fundout = fundout - fundin
  2145. if yesterday:
  2146. today_income = round((today_fund-(yesterday_fund-fundout))/float(yesterday_fund),4)
  2147. yesterday_fund = round(today_fund/(1+today_income),4)
  2148. else:
  2149. today_income = 0.0
  2150. total_income = round((today_fund+fundout-init_fund)/init_fund,4)
  2151. init_fund = round(today_fund/(1+total_income),4)
  2152. today_income = "{}%".format(today_income*100)
  2153. total_income = "{}%".format(total_income*100)
  2154. return {"yesterday_fund":yesterday_fund,
  2155. "today_fund":today_fund,
  2156. "today_income":today_income,
  2157. "total_income":total_income,
  2158. "init_fund":init_fund}
  2159. stock_date = datetime.datetime.now().strftime("%Y-%m-%d")
  2160. if cm.PlayerRecord.get_db_model(match_id).objects.filter(user_id=user_id,stock_date=stock_date).exists():
  2161. raise ce.TipException(u"资金出入须在提交作业之前提交,今日作业已提交,不能提交资金出入!")
  2162. if cm.FundInOut.objects.filter(user_id=user_id,stock_date=stock_date).exists():
  2163. raise ce.TipException(u"今日已有资金出入,一天只能提交一次资金出入!")
  2164. fundinout,flag = cm.FundInOut.objects.get_or_create(
  2165. user_id = user_id,
  2166. fundin = fundin,
  2167. fundout = fundout,
  2168. stock_date = stock_date,
  2169. account_img = account_img
  2170. )
  2171. def get_user_match_list(request):
  2172. kwargs = request.json
  2173. user_id = kwargs.get("user_id")
  2174. if not user_id:
  2175. user_id = request.user.get("id")
  2176. qset = cm.Player.objects.filter(user_id=user_id).filter(match_group__isnull=False).order_by("-id")
  2177. qset = qset.values("user_id","match_id","match_group").annotate(cnt=Count("match_id"))
  2178. page = int(kwargs.get("page",0))
  2179. page_size = int(kwargs.get("page_size",20))
  2180. if page and page_size:
  2181. total,qset = ccc.get_page_qset(qset,page,page_size)
  2182. else:
  2183. total = qset.count()
  2184. #today = get_today_date(user_id=user_id)
  2185. data = list(qset.values("user_id","match_id","match_group"))
  2186. new_data = []
  2187. for item in data:
  2188. match_id = item["match_id"]
  2189. match_group = item["match_group"]
  2190. user_id = item["user_id"]
  2191. today = get_today_date(match_id=match_id,user_id=user_id)
  2192. item["match_info"] = get_match_info(match_id)
  2193. item["match_group_info"] = get_group_info(match_group)
  2194. if match_id and match_group:
  2195. today_record = ccc.get_today_record(user_id,int(match_id),int(match_group),today)
  2196. today_record = format_today_record(today_record)
  2197. if today_record:
  2198. if today_record.get("today_income"):
  2199. today_record["today_income"] = "{}%".format(today_record["today_income"]*100)
  2200. if today_record.get("total_income"):
  2201. today_record["total_income"] = "{}%".format(today_record["total_income"]*100)
  2202. item["today_record"] = today_record
  2203. new_data.append(item)
  2204. #return total,data
  2205. return total,new_data
  2206. def get_format_user_info(request):
  2207. user_id = request.user.get("id")
  2208. cur_user_id = request.user.get("id")
  2209. kwargs = request.json
  2210. q_user_id = kwargs.get("user_id")
  2211. if q_user_id:
  2212. user_id = q_user_id
  2213. userinfo = get_user_info_actual(q_user_id)
  2214. userinfo["fans"] = cm.UserFollows.objects.filter(follow_id=user_id).count()
  2215. userinfo["followers"] = cm.UserFollows.objects.filter(user_id=user_id).count()
  2216. del userinfo["phone"]
  2217. if cm.UserFollows.objects.filter(user_id=cur_user_id,follow_id=user_id).exists():
  2218. userinfo["is_follow"] = 1
  2219. else:
  2220. userinfo["is_follow"] = 0
  2221. return userinfo
  2222. def get_day_inout_rank_list(request):
  2223. """
  2224. """
  2225. kwargs = request.json
  2226. stock_date = kwargs.get("stock_date")
  2227. match_id = kwargs.get("match_id")
  2228. _type = kwargs.get("type")
  2229. qset = cm.PlayerRecord.get_db_model(match_id).objects.filter(match_id=match_id,stock_date=stock_date)
  2230. if _type == "in":
  2231. qset = qset.order_by("-today_income")
  2232. else:
  2233. qset = qset.order_by("today_income")
  2234. page = int(kwargs.get("page",0))
  2235. page_size = int(kwargs.get("page_size",20))
  2236. if page and page_size:
  2237. total,qset = ccc.get_page_qset(qset,page,page_size)
  2238. else:
  2239. total = qset.count()
  2240. data = list(qset.values())
  2241. return total,data
  2242. def get_user_follows_v3(request):
  2243. """获取用户关注的选手列表
  2244. """
  2245. user_id = request.user.get("id",0)
  2246. qdata = request.json
  2247. if qdata.get("user_id"):
  2248. user_id = qdata.get("user_id")
  2249. qset = cm.UserFollows.objects.filter(user_id=user_id)
  2250. follow_ids = list(qset.values_list("follow_id",flat=True))
  2251. today = get_today_date()
  2252. _today = today
  2253. data = []
  2254. for user_id in follow_ids:
  2255. latest_key = "PLAYER_LATEST_%d"%user_id
  2256. _match_id = ccc.cache.hget(latest_key,"match_id")
  2257. _today = ccc.cache.hget(latest_key,"stock_date")
  2258. _match_group = ccc.cache.hget(latest_key,"match_group")
  2259. today_record = ccc.get_today_record(user_id,_match_id,_match_group,_today)
  2260. if today_record:
  2261. today_record["zan_count"] = today_record.get("zans",0) if today_record.get("zans") else 0
  2262. today_record["comments_count"] = cm.Comments.objects.filter(record_id=today_record.get("id",0)).count()
  2263. data.append(today_record)
  2264. data = sorted(data,key=lambda x:x["stock_date"],reverse=True)
  2265. page = int(qdata.get("page",1))
  2266. page_size = int(qdata.get("page_size",20))
  2267. if page and page_size:
  2268. total,data = ccf.get_page_list(data,page,page_size)
  2269. for item in data:
  2270. if item:
  2271. user_id = item["user_id"]
  2272. latest_key = "PLAYER_LATEST_%d"%user_id
  2273. today_stock = json.loads(item["today_stock"])
  2274. today_stock = filter(lambda x:x["name"] and x["fund"],today_stock)
  2275. item["today_stock"] = today_stock
  2276. item["today_stock_img"] = json.loads(item["today_stock_img"])
  2277. win_rate = ccc.cache.hget(latest_key,"win_rate")
  2278. if win_rate:
  2279. item["win_rate"] = str(float(win_rate)*100)+"%"
  2280. else:
  2281. item["win_rate"] = "0.0%"
  2282. item["today_income"] = "{}%".format(item["today_income"]*100)
  2283. item["total_income"] = "{}%".format(item["total_income"]*100)
  2284. item["zans_count"] = item.get("zans",0)
  2285. item["comments_count"] = cm.Comments.objects.filter(record_id=item.get("id",0)).count()
  2286. return total,data
  2287. else:
  2288. return len(data),data
  2289. def get_latest_match_info(request):
  2290. """
  2291. """
  2292. cur_match = cm.Match.objects.filter(match_status=3).order_by("-id").values().first()
  2293. cur_match_id = cur_match.get("id")
  2294. groups = list(cm.MatchGroup.objects.filter(match_id=cur_match_id,is_active=1).order_by("order").values())
  2295. cur_match["groups"] = groups
  2296. return cur_match
  2297. def get_article_info(**kwargs):
  2298. """
  2299. """
  2300. _id = kwargs.get("id")
  2301. rst = cm.Article.objects.filter(id=_id).values().first()
  2302. rst["url"] = "https://www.hunanwanzhu.com/topic/article.html?id="+str(_id)
  2303. return rst
  2304. def get_profit_list(**kwargs):
  2305. """盈亏列表
  2306. """
  2307. stock_date = kwargs.get("stock_date")
  2308. match_id = kwargs.get("match_id")
  2309. _type = kwargs.get("type")
  2310. if not stock_date:
  2311. stock_date = get_today_date()
  2312. qset = cm.PlayerRecord.get_db_model(match_id).objects.filter(stock_date=stock_date)
  2313. #if _type == "win":
  2314. # qset = qset.filter(today_income__gte=0).order_by("-today_income")
  2315. #if _type == "loss":
  2316. # qset = qset.filter(today_income__lt=0).order_by("today_income")
  2317. data = list(qset.values())
  2318. for item in data:
  2319. item["win_loss"] = item["today_fund"] - item["yesterday_fund"]
  2320. item["total_win_loss"] = item["today_fund"] - item["init_fund"]
  2321. item["win_loss"] = round(item["win_loss"],4)
  2322. item["total_win_loss"] = round(item["total_win_loss"],4)
  2323. if _type == "win":
  2324. data = sorted(data,key=lambda x:x["win_loss"],reverse=True)
  2325. if _type == "loss":
  2326. data = sorted(data,key=lambda x:x["win_loss"])
  2327. if _type == "total_win":
  2328. data = sorted(data,key=lambda x:x["total_win_loss"],reverse=True)
  2329. if _type == "total_loss":
  2330. data = sorted(data,key=lambda x:x["total_win_loss"])
  2331. page = int(kwargs.get("page",0))
  2332. page_size = int(kwargs.get("page_size",20))
  2333. if page and page_size:
  2334. total,data = ccf.get_page_list(data,page,page_size)
  2335. else:
  2336. total = len(data)
  2337. #data = list(qset.values())
  2338. return total,data
  2339. def get_group_rank_list_v3(request):
  2340. """排名列表
  2341. """
  2342. qdata = request.json
  2343. kwargs = qdata
  2344. group_id = qdata.get("id")
  2345. match_id = qdata.get("match_id")
  2346. match_id = cm.MatchGroup.objects.filter(id=group_id).first().match_id
  2347. today = qdata.get("stock_date")
  2348. if not today:
  2349. today = get_today_date()
  2350. match = get_match_info(match_id)
  2351. group = get_group_info(group_id)
  2352. players = get_match_group_users(match_id,group_id)
  2353. new_players = []
  2354. for player in players:
  2355. user_id = player["user_id"]
  2356. username = player["username"]
  2357. match_group = group_id
  2358. today_record = ccc.get_today_record(user_id,match_id,match_group,today)
  2359. if today_record:
  2360. player.update(today_record)
  2361. player["username"] = username
  2362. player["org_today_income"] = player["today_income"]
  2363. player["org_total_income"] = player["total_income"]
  2364. player["total_income"] = "{}%".format(player["total_income"]*100)
  2365. player["today_income"] = "{}%".format(player["today_income"]*100)
  2366. player["fund"] = round(player["fund"],4)
  2367. player["init_fund"] = round(player["init_fund"],4)
  2368. player["today_fund"] = round(player["today_fund"],4)
  2369. player["today_stock_img"] = json.loads(player["today_stock_img"]) if player["today_stock_img"] else []
  2370. #player["win_rate"] = calc_win_rate(user_id,match_id)
  2371. player["zan_count"] = player["zans"]
  2372. new_players.append(player)
  2373. if kwargs.get("order_by") == "today_income__asc":
  2374. new_players = sorted(new_players,key=lambda x:x["org_today_income"])
  2375. elif kwargs.get("order_by") == "today_income__desc" :
  2376. new_players = sorted(new_players,key=lambda x:x["org_today_income"],reverse=True)
  2377. elif kwargs.get("order_by") == "total_income__asc":
  2378. new_players = sorted(new_players,key=lambda x:x["org_total_income"])
  2379. elif kwargs.get("order_by") == "total_income__desc":
  2380. new_players = sorted(new_players,key=lambda x:x["org_total_income"],reverse=True)
  2381. else:
  2382. new_players = sorted(new_players,key=lambda x:x["org_total_income"],reverse=True)
  2383. #分页
  2384. page = int(kwargs.get("page",0))
  2385. page_size = int(kwargs.get("page_size",50))
  2386. if page and page_size:
  2387. total,new_players = ccf.get_page_list(new_players,page,page_size)
  2388. else:
  2389. total = len(new_players)
  2390. return total,new_players
  2391. def get_article_type_list(**kwargs):
  2392. rst = [u"腰斩专场",u"冠军交割",u"牛人专场",u"游资列传",u"妖股列传"]
  2393. return rst
  2394. def get_wanzhu_consult_list(**kwargs):
  2395. """
  2396. """
  2397. qset = cm.Consult.objects.filter(user_id__gt=0).order_by("-ctime")
  2398. if kwargs.get("username"):
  2399. qset = qset.filter(user_name__icontains=kwargs.get("username"))
  2400. if kwargs.get("reply_status"):
  2401. qset = qset.filter(reply_status=kwargs.get("reply_status"))
  2402. if kwargs.get("content"):
  2403. qset = qset.filter(Q(content__icontains=kwargs.get("content"))|Q(reply_content__icontains=kwargs.get("content")))
  2404. data = list(qset.values())
  2405. #分页
  2406. page = int(kwargs.get("page",1))
  2407. page_size = int(kwargs.get("page_size",20))
  2408. if page and page_size:
  2409. total,data = ccf.get_page_list(data,page,page_size)
  2410. else:
  2411. total = len(data)
  2412. for item in data:
  2413. user_id = item["user_id"]
  2414. userinfo = get_user_info(user_id)
  2415. if userinfo:
  2416. item["user_code"] = userinfo.get("usercode")
  2417. return total,data
  2418. def get_sub_category(pid):
  2419. """
  2420. """
  2421. qset = cm.BaikeCategory.objects.filter(parent_id=pid)
  2422. qdata = list(qset.values())
  2423. if qdata:
  2424. for subitem in qdata:
  2425. subitem["type"] = "ent"
  2426. subitem["children"] = get_sub_category(subitem["id"])
  2427. return qdata
  2428. def get_baike_category_tree(**kwargs):
  2429. """
  2430. """
  2431. parents = list(cm.BaikeCategory.objects.filter(parent_id__isnull=True).values())
  2432. for item in parents:
  2433. item["children"] = get_sub_category(item["id"])
  2434. return parents
  2435. def get_baike_list_by_category(**kwargs):
  2436. category_id = kwargs.get("category_id")
  2437. qset = cm.BaikeDetail.objects.filter(category_id=category_id)
  2438. data = list(qset.values("id","name"))
  2439. return data
  2440. def get_baike_detail(**kwargs):
  2441. #_id = kwargs.get("id")
  2442. category_id = kwargs.get("category_id")
  2443. data = list(cm.BaikeDetail.objects.filter(category_id=category_id).values())
  2444. return data
  2445. def get_app_version(request):
  2446. rst = cm.APPVersion.objects.all().order_by("-id").values().first()
  2447. return rst
  2448. def reply_wanzhu_consult(**kwargs):
  2449. """
  2450. """
  2451. pid = kwargs.get("pid")
  2452. content = kwargs.get("reply_content")
  2453. user_id = kwargs.get("user_id")
  2454. action = kwargs.get("action")
  2455. width = kwargs.get("width")
  2456. height = kwargs.get("height")
  2457. if action == "send":
  2458. user = cm.UserInfo.objects.filter(id=user_id).first()
  2459. user_name = user.username
  2460. user_avatar = user.avatar
  2461. obj,flag = cm.Consult.objects.get_or_create(
  2462. user_id = user_id,
  2463. )
  2464. obj.user_name = user_name
  2465. obj.user_avatar = user_avatar
  2466. #obj.reply_content = content
  2467. obj.view_status = 1
  2468. obj.reply_status = 0
  2469. obj.ctime = datetime.datetime.now()
  2470. obj.save()
  2471. wanzhu_obj = cm.WanzhuConsult.objects.create(
  2472. user_id = user_id,
  2473. user_name = user_name,
  2474. user_avatar = user_avatar
  2475. )
  2476. wanzhu_obj.width = width
  2477. wanzhu_obj.height = height
  2478. wanzhu_obj.save()
  2479. wanzhu_obj_1 = cm.WanzhuConsult.objects.create(
  2480. reply_content = content,
  2481. user_id = 0,
  2482. player_id = 0,
  2483. reply_user_id = user_id,
  2484. pid = wanzhu_obj.id
  2485. )
  2486. wanzhu_obj_1.width = width
  2487. wanzhu_obj_1.height = height
  2488. wanzhu_obj_1.save()
  2489. cm.Consult.objects.filter(user_id=user_id).update(reply_status=1,view_status=1,reply_content=content,ctime=datetime.datetime.now())
  2490. else:
  2491. wanzhu_obj = cm.WanzhuConsult.objects.create(
  2492. pid = pid,
  2493. reply_content = content,
  2494. user_id = 0,
  2495. player_id = 0,
  2496. reply_user_id = user_id
  2497. )
  2498. wanzhu_obj.width = width
  2499. wanzhu_obj.height = height
  2500. wanzhu_obj.save()
  2501. cm.Consult.objects.filter(user_id=user_id).update(reply_status=1,view_status=1,reply_content=content,ctime=datetime.datetime.now())
  2502. #发送消息提醒
  2503. if cm.UserInfo.objects.filter(id=user_id).exists():
  2504. user = cm.UserInfo.objects.filter(id=user_id).first()
  2505. openid = user.openid
  2506. username = user.username
  2507. try:
  2508. send_consult_reply_message(openid,username)
  2509. except Exception as e:
  2510. print(e)
  2511. #发送app推送消息
  2512. title = u"顽主杯"
  2513. body = u"你收到一条顽主的消息"
  2514. params = {"type":"message","id":str(user_id)}
  2515. aliyunpush.push_notice_by_userid(user_id,title,body,params,"ios")
  2516. aliyunpush.push_notice_by_userid(user_id,title,body,params,"android")