123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783 |
- <?php
- /* For licensing terms, see /license.txt */
- require_once api_get_path(SYS_CODE_PATH).'exercice/exercise.lib.php';
- require_once api_get_path(SYS_CODE_PATH).'newscorm/learnpathList.class.php';
- /**
- * Class Tracking
- *
- * @author Julio Montoya <gugli100@gmail.com>
- * @package chamilo.library
- */
- class Tracking
- {
- /**
- * @param int $user_id
- * @param array $courseInfo
- * @param int $session_id
- * @param string $origin
- * @param bool $export_csv
- * @param int $lp_id
- * @param int $lp_item_id
- * @param int $extendId
- * @param int $extendAttemptId
- * @param string $extendedAttempt
- * @param string $extendedAll
- * @param string $type classic or simple
- * @return null|string
- */
- public static function getLpStats(
- $user_id,
- $courseInfo,
- $session_id,
- $origin,
- $export_csv,
- $lp_id,
- $lp_item_id = null,
- $extendId = null,
- $extendAttemptId = null,
- $extendedAttempt = null,
- $extendedAll = null,
- $type = 'classic'
- ) {
- if (empty($courseInfo) || empty($lp_id)) {
- return null;
- }
- $lp_id = intval($lp_id);
- $lp_item_id = intval($lp_item_id);
- $user_id = intval($user_id);
- $session_id = intval($session_id);
- $origin = Security::remove_XSS($origin);
- $list = learnpath :: get_flat_ordered_items_list($lp_id, 0, $courseInfo['real_id']);
- $is_allowed_to_edit = api_is_allowed_to_edit(null, true);
- $course_id = $courseInfo['real_id'];
- $courseCode = $courseInfo['code'];
- $session_condition = api_get_session_condition($session_id);
- // Extend all button
- $output = null;
- $extend_all = 0;
- if ($origin == 'tracking') {
- $url_suffix = '&session_id=' . $session_id . '&course=' . $courseCode . '&student_id=' . $user_id . '&lp_id=' . $lp_id . '&origin=' . $origin;
- } else {
- $url_suffix = '&lp_id=' . $lp_id;
- }
- if (!empty($extendedAll)) {
- $extend_all_link = Display::url(
- Display::return_icon('view_less_stats.gif', get_lang('HideAllAttempts')),
- api_get_self() . '?action=stats' . $url_suffix
- );
- $extend_all = 1;
- } else {
- $extend_all_link = Display::url(
- Display::return_icon('view_more_stats.gif', get_lang('ShowAllAttempts')),
- api_get_self() . '?action=stats&extend_all=1' . $url_suffix
- );
- }
- if ($origin != 'tracking') {
- $output .= Display::page_header(get_lang('ScormMystatus'));
- }
- $actionColumn = null;
- if ($type == 'classic') {
- $actionColumn = ' <th>' . get_lang('Actions') . '</th>';
- }
- $output .= '<table class="data_table">
- <tr>
- <th width="16">' . $extend_all_link . '</th>
- <th colspan="4">
- ' . get_lang('ScormLessonTitle') .'
- </th>
- <th colspan="2">
- ' . get_lang('ScormStatus') . '
- </th>
- <th colspan="2">
- ' . get_lang('ScormScore') . '
- </th>
- <th colspan="2">
- ' . get_lang('ScormTime') . '
- </th>
- '.$actionColumn.'
- </tr>';
- // Going through the items using the $items[] array instead of the database order ensures
- // we get them in the same order as in the imsmanifest file, which is rather random when using
- // the database table.
- $TBL_LP_ITEM = Database :: get_course_table(TABLE_LP_ITEM);
- $TBL_LP_ITEM_VIEW = Database :: get_course_table(TABLE_LP_ITEM_VIEW);
- $TBL_LP_VIEW = Database :: get_course_table(TABLE_LP_VIEW);
- $tbl_quiz_questions = Database :: get_course_table(TABLE_QUIZ_QUESTION);
- $TBL_QUIZ = Database :: get_course_table(TABLE_QUIZ_TEST);
- $tbl_stats_exercices = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_EXERCICES);
- $tbl_stats_attempts = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_ATTEMPT);
- $sql = "SELECT max(view_count)
- FROM $TBL_LP_VIEW
- WHERE
- c_id = $course_id AND
- lp_id = $lp_id AND
- user_id = $user_id
- $session_condition";
- $res = Database::query($sql);
- $view = '';
- if (Database :: num_rows($res) > 0) {
- $myrow = Database :: fetch_array($res);
- $view = $myrow[0];
- }
- $counter = 0;
- $total_time = 0;
- $h = get_lang('h');
- if (!empty($export_csv)) {
- $csv_content[] = array(
- get_lang('ScormLessonTitle'),
- get_lang('ScormStatus'),
- get_lang('ScormScore'),
- get_lang('ScormTime'),
- );
- }
- $result_disabled_ext_all = true;
- $chapterTypes = learnpath::getChapterTypes();
- // Show lp items
- if (is_array($list) && count($list) > 0) {
- foreach ($list as $my_item_id) {
- $extend_this = 0;
- $order = 'DESC';
- if ((!empty($extendId) && $extendId == $my_item_id) || $extend_all) {
- $extend_this = 1;
- $order = 'ASC';
- }
- // Prepare statement to go through each attempt.
- $viewCondition = null;
- if (!empty($view)) {
- $viewCondition = " AND v.view_count = $view ";
- }
- $sql = "SELECT
- iv.status as mystatus,
- v.view_count as mycount,
- iv.score as myscore,
- iv.total_time as mytime,
- i.id as myid,
- i.lp_id as mylpid,
- iv.lp_view_id as mylpviewid,
- i.title as mytitle,
- i.max_score as mymaxscore,
- iv.max_score as myviewmaxscore,
- i.item_type as item_type,
- iv.view_count as iv_view_count,
- iv.id as iv_id,
- path
- FROM $TBL_LP_ITEM as i
- INNER JOIN $TBL_LP_ITEM_VIEW as iv
- ON (i.id = iv.lp_item_id AND i.c_id = $course_id AND iv.c_id = $course_id)
- INNER JOIN $TBL_LP_VIEW as v
- ON (iv.lp_view_id = v.id AND v.c_id = $course_id)
- WHERE
- i.id = $my_item_id AND
- i.lp_id = $lp_id AND
- v.user_id = $user_id AND
- v.session_id = $session_id
- $viewCondition
- ORDER BY iv.view_count $order ";
- $result = Database::query($sql);
- $num = Database :: num_rows($result);
- $time_for_total = 'NaN';
- // Extend all
- if (($extend_this || $extend_all) && $num > 0) {
- $row = Database :: fetch_array($result);
- $result_disabled_ext_all = false;
- if ($row['item_type'] == 'quiz') {
- // Check results_disabled in quiz table.
- $my_path = Database::escape_string($row['path']);
- $sql = "SELECT results_disabled
- FROM $TBL_QUIZ
- WHERE
- c_id = $course_id AND
- id ='" . $my_path . "'";
- $res_result_disabled = Database::query($sql);
- $row_result_disabled = Database::fetch_row($res_result_disabled);
- if (Database::num_rows($res_result_disabled) > 0 &&
- (int) $row_result_disabled[0] === 1
- ) {
- $result_disabled_ext_all = true;
- }
- }
- // If there are several attempts, and the link to extend has been clicked, show each attempt...
- if (($counter % 2) == 0) {
- $oddclass = 'row_odd';
- } else {
- $oddclass = 'row_even';
- }
- $extend_link = '';
- if (!empty($inter_num)) {
- $extend_link = Display::url(
- Display::return_icon('visible.gif', get_lang('HideAttemptView')),
- api_get_self() . '?action=stats&fold_id=' . $my_item_id . $url_suffix
- );
- }
- $title = $row['mytitle'];
- if (empty($title)) {
- $title = rl_get_resource_name($courseInfo['code'], $lp_id, $row['myid']);
- }
- if (in_array($row['item_type'], $chapterTypes)) {
- $title = "<h4> $title </h4>";
- }
- $lesson_status = $row['mystatus'];
- $title = Security::remove_XSS($title);
- $counter++;
- $action = null;
- if ($type == 'classic') {
- $action = '<td></td>';
- }
- if (in_array($row['item_type'], $chapterTypes)) {
- $output .= '<tr class="'.$oddclass.'">
- <td>'.$extend_link.'</td>
- <td colspan="4">
- '.$title.'
- </td>
- <td colspan="2">'.learnpathItem::humanize_status($lesson_status, true, $type).'</td>
- <td colspan="2"></td>
- <td colspan="2"></td>
- '.$action.'
- </tr>';
- continue;
- } else {
- $output .= '<tr class="'.$oddclass.'">
- <td>'.$extend_link.'</td>
- <td colspan="4">
- '.$title.'
- </td>
- <td colspan="2"></td>
- <td colspan="2"></td>
- <td colspan="2"></td>
- '.$action.'
- </tr>';
- }
- $attemptCount = 1;
- do {
- // Check if there are interactions below.
- $extend_attempt_link = '';
- $extend_this_attempt = 0;
- if ((learnpath::get_interactions_count_from_db($row['iv_id'], $course_id) > 0 ||
- learnpath::get_objectives_count_from_db($row['iv_id'], $course_id) > 0) &&
- !$extend_all
- ) {
- if ($extendAttemptId == $row['iv_id']) {
- // The extend button for this attempt has been clicked.
- $extend_this_attempt = 1;
- $extend_attempt_link = Display::url(
- Display::return_icon('visible.gif', get_lang('HideAttemptView')),
- api_get_self() . '?action=stats&extend_id=' . $my_item_id . '&fold_attempt_id=' . $row['iv_id'] . $url_suffix
- );
- } else { // Same case if fold_attempt_id is set, so not implemented explicitly.
- // The extend button for this attempt has not been clicked.
- $extend_attempt_link = Display::url(
- Display::return_icon('invisible.gif', get_lang('ExtendAttemptView')),
- api_get_self() . '?action=stats&extend_id=' . $my_item_id . '&extend_attempt_id=' . $row['iv_id'] . $url_suffix
- );
- }
- }
- if (($counter % 2) == 0) {
- $oddclass = 'row_odd';
- } else {
- $oddclass = 'row_even';
- }
- $lesson_status = $row['mystatus'];
- $score = $row['myscore'];
- $time_for_total = $row['mytime'];
- $time = learnpathItem :: getScormTimeFromParameter('js', $row['mytime']);
- if ($score == 0) {
- $maxscore = $row['mymaxscore'];
- } else {
- if ($row['item_type'] == 'sco') {
- if (!empty($row['myviewmaxscore']) && $row['myviewmaxscore'] > 0) {
- $maxscore = $row['myviewmaxscore'];
- } elseif ($row['myviewmaxscore'] === '') {
- $maxscore = 0;
- } else {
- $maxscore = $row['mymaxscore'];
- }
- } else {
- $maxscore = $row['mymaxscore'];
- }
- }
- // Remove "NaN" if any (@todo: locate the source of these NaN)
- $time = str_replace('NaN', '00' . $h . '00\'00"', $time);
- if ($row['item_type'] != 'dokeos_chapter') {
- if (!$is_allowed_to_edit && $result_disabled_ext_all) {
- $view_score = Display::return_icon('invisible.gif', get_lang('ResultsHiddenByExerciseSetting'));
- } else {
- switch ($row['item_type']) {
- case 'sco':
- if ($maxscore == 0) {
- $view_score = $score;
- } else {
- $view_score = show_score($score, $maxscore, false);
- }
- break;
- case 'document':
- $view_score = ($score == 0 ? '/' : show_score($score, $maxscore, false));
- break;
- default:
- $view_score = show_score($score, $maxscore, false);
- break;
- }
- }
- $action = null;
- if ($type == 'classic') {
- $action = '<td></td>';
- }
- $output .= '<tr class="' . $oddclass . '">
- <td></td>
- <td>' . $extend_attempt_link . '</td>
- <td colspan="3">' . get_lang('Attempt') . ' ' . $attemptCount . '</td>
- <td colspan="2">' . learnpathItem::humanize_status($lesson_status, true, $type) . '</td>
- <td colspan="2">' . $view_score . '</td>
- <td colspan="2">' . $time . '</td>
- '.$action.'
- </tr>';
- $attemptCount++;
- if (!empty($export_csv)) {
- $temp = array();
- $temp[] = $title = Security::remove_XSS($title);
- $temp[] = Security::remove_XSS(learnpathItem::humanize_status($lesson_status, false, $type));
- if ($row['item_type'] == 'quiz') {
- if (!$is_allowed_to_edit && $result_disabled_ext_all) {
- $temp[] = '/';
- } else {
- $temp[] = ($score == 0 ? '0/' . $maxscore : ($maxscore == 0 ? $score : $score . '/' . float_format($maxscore, 1)));
- }
- } else {
- $temp[] = ($score == 0 ? '/' : ($maxscore == 0 ? $score : $score . '/' . float_format($maxscore, 1)));
- }
- $temp[] = $time;
- $csv_content[] = $temp;
- }
- }
- $counter++;
- $action = null;
- if ($type == 'classic') {
- $action = '<td></td>';
- }
- if ($extend_this_attempt OR $extend_all) {
- $list1 = learnpath :: get_iv_interactions_array($row['iv_id']);
- foreach ($list1 as $id => $interaction) {
- if (($counter % 2) == 0) {
- $oddclass = 'row_odd';
- } else {
- $oddclass = 'row_even';
- }
- $student_response = urldecode($interaction['student_response']);
- $content_student_response = explode('__|', $student_response);
- if (count($content_student_response) > 0) {
- if (count($content_student_response) >= 3) {
- // Pop the element off the end of array.
- array_pop($content_student_response);
- }
- $student_response = implode(',', $content_student_response);
- }
- $output .= '<tr class="'.$oddclass.'">
- <td></td>
- <td></td>
- <td></td>
- <td>'.$interaction['order_id'] . '</td>
- <td>'.$interaction['id'] . '</td>
- <td colspan="2">' . $interaction['type'].'</td>
- <td>'.$student_response . '</td>
- <td>'.$interaction['result'] . '</td>
- <td>'.$interaction['latency'] . '</td>
- <td>'.$interaction['time'] . '</td>
- '.$action.'
- </tr>';
- $counter++;
- }
- $list2 = learnpath :: get_iv_objectives_array($row['iv_id']);
- foreach ($list2 as $id => $interaction) {
- if (($counter % 2) == 0) {
- $oddclass = 'row_odd';
- } else {
- $oddclass = 'row_even';
- }
- $output .= '<tr class="'.$oddclass.'">
- <td></td>
- <td></td>
- <td></td>
- <td>' . $interaction['order_id'] . '</td>
- <td colspan="2">' . $interaction['objective_id'] . '</td>
- <td colspan="2">' . $interaction['status'] .'</td>
- <td>' . $interaction['score_raw'] . '</td>
- <td>' . $interaction['score_max'] . '</td>
- <td>' . $interaction['score_min'] . '</td>
- '.$action.'
- </tr>';
- $counter++;
- }
- }
- } while ($row = Database :: fetch_array($result));
- } elseif ($num > 0) {
- // Not extended.
- $row = Database :: fetch_array($result, 'ASSOC');
- $my_id = $row['myid'];
- $my_lp_id = $row['mylpid'];
- $my_lp_view_id = $row['mylpviewid'];
- $my_path = $row['path'];
- $result_disabled_ext_all = false;
- if ($row['item_type'] == 'quiz') {
- // Check results_disabled in quiz table.
- $my_path = Database::escape_string($my_path);
- $sql = "SELECT results_disabled
- FROM $TBL_QUIZ
- WHERE c_id = $course_id AND id ='" . $my_path . "'";
- $res_result_disabled = Database::query($sql);
- $row_result_disabled = Database::fetch_row($res_result_disabled);
- if (Database::num_rows($res_result_disabled) > 0 &&
- (int) $row_result_disabled[0] === 1
- ) {
- $result_disabled_ext_all = true;
- }
- }
- // Check if there are interactions below
- $extend_this_attempt = 0;
- $inter_num = learnpath::get_interactions_count_from_db($row['iv_id'], $course_id);
- $objec_num = learnpath::get_objectives_count_from_db($row['iv_id'], $course_id);
- $extend_attempt_link = '';
- if ($inter_num > 0 || $objec_num > 0) {
- if (!empty($extendAttemptId) && $extendAttemptId == $row['iv_id']) {
- // The extend button for this attempt has been clicked.
- $extend_this_attempt = 1;
- $extend_attempt_link = Display::url(
- Display::return_icon('visible.gif', get_lang('HideAttemptView')),
- api_get_self() . '?action=stats&extend_id=' . $my_item_id . '&fold_attempt_id=' . $row['iv_id'] . $url_suffix
- );
- } else {
- // Same case if fold_attempt_id is set, so not implemented explicitly.
- // The extend button for this attempt has not been clicked.
- $extend_attempt_link = Display::url(
- Display::return_icon('invisible.gif', get_lang('ExtendAttemptView')),
- api_get_self() . '?action=stats&extend_id=' . $my_item_id . '&extend_attempt_id=' . $row['iv_id'] . $url_suffix
- );
- }
- }
- if (($counter % 2) == 0) {
- $oddclass = 'row_odd';
- } else {
- $oddclass = 'row_even';
- }
- $extend_link = '';
- if ($inter_num > 1) {
- $extend_link = Display::url(
- Display::return_icon('invisible.gif', get_lang('ExtendAttemptView')),
- api_get_self() . '?action=stats&extend_id=' . $my_item_id . '&extend_attempt_id=' . $row['iv_id'] . $url_suffix
- );
- }
- $lesson_status = $row['mystatus'];
- $score = $row['myscore'];
- $subtotal_time = $row['mytime'];
- while ($tmp_row = Database :: fetch_array($result)) {
- $subtotal_time += $tmp_row['mytime'];
- }
- $title = $row['mytitle'];
- // Selecting the exe_id from stats attempts tables in order to look the max score value.
- $sql = 'SELECT * FROM ' . $tbl_stats_exercices . '
- WHERE
- exe_exo_id="' . $row['path'] . '" AND
- exe_user_id="' . $user_id . '" AND
- orig_lp_id = "' . $lp_id . '" AND
- orig_lp_item_id = "' . $row['myid'] . '" AND
- exe_cours_id="' . $courseCode . '" AND
- status <> "incomplete" AND
- session_id = ' . $session_id . '
- ORDER BY exe_date DESC
- LIMIT 1';
- $resultLastAttempt = Database::query($sql);
- $num = Database :: num_rows($resultLastAttempt);
- $id_last_attempt = null;
- if ($num > 0) {
- while ($rowLA = Database :: fetch_array($resultLastAttempt)) {
- $id_last_attempt = $rowLA['exe_id'];
- }
- }
- if ($score == 0) {
- $maxscore = $row['mymaxscore'];
- } else {
- if ($row['item_type'] == 'sco') {
- if (!empty($row['myviewmaxscore']) and $row['myviewmaxscore'] > 0) {
- $maxscore = $row['myviewmaxscore'];
- } elseif ($row['myviewmaxscore'] === '') {
- $maxscore = 0;
- } else {
- $maxscore = $row['mymaxscore'];
- }
- } else {
- if ($row['item_type'] == 'quiz') {
- // Get score and total time from last attempt of a exercise en lp.
- $sql = "SELECT score
- FROM $TBL_LP_ITEM_VIEW
- WHERE
- c_id = $course_id AND
- lp_item_id = '" . (int) $my_id . "' AND
- lp_view_id = '" . (int) $my_lp_view_id . "'
- ORDER BY view_count DESC limit 1";
- $res_score = Database::query($sql);
- $row_score = Database::fetch_array($res_score);
- $sql = "SELECT SUM(total_time) as total_time
- FROM $TBL_LP_ITEM_VIEW
- WHERE
- c_id = $course_id AND
- lp_item_id = '" . (int) $my_id . "' AND
- lp_view_id = '" . (int) $my_lp_view_id . "'";
- $res_time = Database::query($sql);
- $row_time = Database::fetch_array($res_time);
- if (Database::num_rows($res_score) > 0 &&
- Database::num_rows($res_time) > 0
- ) {
- $score = (float) $row_score['score'];
- $subtotal_time = (int) $row_time['total_time'];
- } else {
- $score = 0;
- $subtotal_time = 0;
- }
- // Selecting the max score from an attempt.
- $sql = "SELECT SUM(t.ponderation) as maxscore
- FROM (
- SELECT DISTINCT
- question_id, marks, ponderation
- FROM $tbl_stats_attempts as at
- INNER JOIN $tbl_quiz_questions as q
- ON (q.id = at.question_id AND q.c_id = $course_id)
- WHERE exe_id ='$id_last_attempt'
- ) as t";
- $result = Database::query($sql);
- $row_max_score = Database :: fetch_array($result);
- $maxscore = $row_max_score['maxscore'];
- } else {
- $maxscore = $row['mymaxscore'];
- }
- }
- }
- $time_for_total = $subtotal_time;
- $time = learnpathItem::getScormTimeFromParameter('js', $subtotal_time);
- if (empty($title)) {
- $title = rl_get_resource_name($courseInfo['code'], $lp_id, $row['myid']);
- }
- $action = null;
- if ($type == 'classic') {
- $action = '<td></td>';
- }
- if (in_array($row['item_type'], $chapterTypes)) {
- $title = Security::remove_XSS($title);
- $output .= '<tr class="'.$oddclass.'">
- <td>'.$extend_link.'</td>
- <td colspan="4">
- <h4>'.$title.'</h4>
- </td>
- <td colspan="2">'.learnpathitem::humanize_status($lesson_status).'</td>
- <td colspan="2"></td>
- <td colspan="2"></td>
- '.$action.'
- </tr>';
- } else {
- $correct_test_link = '-';
- if ($row['item_type'] == 'quiz') {
- $my_url_suffix = '&course=' . $courseCode . '&student_id=' . $user_id . '&lp_id=' . intval($row['mylpid']) . '&origin=' . $origin;
- $sql = 'SELECT * FROM ' . $tbl_stats_exercices . '
- WHERE
- exe_exo_id="' . $row['path'] . '" AND
- exe_user_id="' . $user_id . '" AND
- orig_lp_id = "' . $lp_id . '" AND
- orig_lp_item_id = "' . $row['myid'] . '" AND
- exe_cours_id="' . $courseCode. '" AND
- status <> "incomplete" AND
- session_id = ' . $session_id . '
- ORDER BY exe_date DESC ';
- $resultLastAttempt = Database::query($sql);
- $num = Database :: num_rows($resultLastAttempt);
- if ($num > 0) {
- if ($extendedAttempt == 1 &&
- $lp_id == $my_lp_id &&
- $lp_item_id == $my_id
- ) {
- $correct_test_link = Display::url(
- Display::return_icon('view_less_stats.gif', get_lang('HideAllAttempts')),
- api_get_self() . '?action=stats' . $my_url_suffix . '&session_id=' . $session_id . '&lp_item_id=' . $my_id
- );
- } else {
- $correct_test_link = Display::url(
- Display::return_icon('view_more_stats.gif', get_lang('ShowAllAttemptsByExercise')),
- api_get_self() . '?action=stats&extend_attempt=1' . $my_url_suffix . '&session_id=' . $session_id . '&lp_item_id=' . $my_id
- );
- }
- }
- }
- $title = Security::remove_XSS($title);
- $action = null;
- if ($type == 'classic') {
- $action = '<td>' . $correct_test_link . '</td>';
- }
- if ($lp_id == $my_lp_id && false) {
- $output .= '<tr class =' . $oddclass . '>
- <td>' . $extend_link . '</td>
- <td colspan="4">' . $title . '</td>
- <td colspan="2"> </td>
- <td colspan="2"> </td>
- <td colspan="2"> </td>
- '.$action.'
- </tr>';
- $output .= '</tr>';
- } else {
- if ($lp_id == $my_lp_id && $lp_item_id == $my_id) {
- $output .= "<tr class='$oddclass'>";
- } else {
- $output .= "<tr class='$oddclass'>";
- }
- /*if (($is_allowed_to_edit || api_is_drh()) && isset($_GET['lp_id']) && isset($course_code)) {
- $lp = new learnpath($course_code, $_GET['lp_id'], api_get_user_id());
- $lp->set_course_int_id($course_id);
- $item_path_url = $lp->get_link('http', $my_id, false);
- $item_path_url .= "&width=600";
- $title = Display::url($title, $item_path_url, array('class' => 'ajax'));
- }*/
- $scoreItem = null;
- if ($row['item_type'] == 'quiz') {
- if (!$is_allowed_to_edit && $result_disabled_ext_all) {
- $scoreItem .= Display::return_icon(
- 'invisible.gif',
- get_lang('ResultsHiddenByExerciseSetting')
- );
- } else {
- $scoreItem .= show_score($score, $maxscore, false);
- }
- } else {
- $scoreItem .= $score == 0 ? '/' : ($maxscore == 0 ? $score : $score . '/' . $maxscore);
- }
- $output .= '
- <td>'.$extend_link.'</td>
- <td colspan="4">' . $title . '</td>
- <td colspan="2">' . learnpathitem::humanize_status($lesson_status) .'</td>
- <td colspan="2">'.$scoreItem.'</td>
- <td colspan="2">'.$time.'</td>
- '.$action.'
- ';
- $output .= '</tr>';
- }
- if (!empty($export_csv)) {
- $temp = array();
- $temp[] = api_html_entity_decode($title, ENT_QUOTES);
- $temp[] = api_html_entity_decode($lesson_status, ENT_QUOTES);
- if ($row['item_type'] == 'quiz') {
- if (!$is_allowed_to_edit && $result_disabled_ext_all) {
- $temp[] = '/';
- } else {
- $temp[] = ($score == 0 ? '0/' . $maxscore : ($maxscore == 0 ? $score : $score . '/' . float_format($maxscore, 1)));
- }
- } else {
- $temp[] = ($score == 0 ? '/' : ($maxscore == 0 ? $score : $score . '/' . float_format($maxscore, 1)));
- }
- $temp[] = $time;
- $csv_content[] = $temp;
- }
- }
- $counter++;
- $action = null;
- if ($type == 'classic') {
- $action = '<td></td>';
- }
- if ($extend_this_attempt OR $extend_all) {
- $list1 = learnpath :: get_iv_interactions_array($row['iv_id']);
- foreach ($list1 as $id => $interaction) {
- if (($counter % 2) == 0) {
- $oddclass = 'row_odd';
- } else {
- $oddclass = 'row_even';
- }
- $output .= '<tr class="'.$oddclass.'">
- <td></td>
- <td></td>
- <td></td>
- <td>'.$interaction['order_id'].'</td>
- <td>'.$interaction['id'].'</td>
- <td colspan="2">' . $interaction['type'].'</td>
- <td>'.urldecode($interaction['student_response']).'</td>
- <td>'.$interaction['result'].'</td>
- <td>'.$interaction['latency'].'</td>
- <td>'.$interaction['time'].'</td>
- '.$action.'
- </tr>';
- $counter++;
- }
- $list2 = learnpath :: get_iv_objectives_array($row['iv_id']);
- foreach ($list2 as $id => $interaction) {
- if (($counter % 2) == 0) {
- $oddclass = 'row_odd';
- } else {
- $oddclass = 'row_even';
- }
- $output .= '<tr class="'.$oddclass.'">
- <td></td>
- <td></td>
- <td></td>
- <td>' . $interaction['order_id'] . '</td>
- <td colspan="2">'.$interaction['objective_id'] . '</td>
- <td colspan="2">' . $interaction['status'] . '</td>
- <td>' . $interaction['score_raw'].'</td>
- <td>' . $interaction['score_max'] .'</td>
- <td>' . $interaction['score_min'].'</td>
- '.$action.'
- </tr>';
- $counter++;
- }
- }
- // Attempts listing by exercise.
- if ($lp_id == $my_lp_id && $lp_item_id== $my_id && $extendedAttempt) {
- // Get attempts of a exercise.
- if (!empty($lp_id) &&
- !empty($lp_item_id) &&
- $row['item_type'] === 'quiz'
- ) {
- $sql = "SELECT path FROM $TBL_LP_ITEM
- WHERE
- c_id = $course_id AND
- id = '$lp_item_id' AND
- lp_id = '$lp_id'";
- $res_path = Database::query($sql);
- $row_path = Database::fetch_array($res_path);
- if (Database::num_rows($res_path) > 0) {
- $sql = 'SELECT * FROM ' . $tbl_stats_exercices . '
- WHERE
- exe_exo_id="' . (int) $row_path['path'] . '" AND
- status <> "incomplete" AND
- exe_user_id="' . $user_id . '" AND
- orig_lp_id = "' . (int) $lp_id . '" AND
- orig_lp_item_id = "' . (int) $lp_item_id . '" AND
- exe_cours_id="' . $courseCode . '" AND
- session_id = ' . $session_id . '
- ORDER BY exe_date';
- $res_attempts = Database::query($sql);
- $num_attempts = Database::num_rows($res_attempts);
- if ($num_attempts > 0) {
- $n = 1;
- while ($row_attempts = Database :: fetch_array($res_attempts)) {
- $my_score = $row_attempts['exe_result'];
- $my_maxscore = $row_attempts['exe_weighting'];
- $my_exe_id = $row_attempts['exe_id'];
- $my_orig_lp = $row_attempts['orig_lp_id'];
- $my_orig_lp_item = $row_attempts['orig_lp_item_id'];
- $my_exo_exe_id = $row_attempts['exe_exo_id'];
- $mktime_start_date = api_strtotime($row_attempts['start_date'], 'UTC');
- $mktime_exe_date = api_strtotime($row_attempts['exe_date'], 'UTC');
- if ($mktime_start_date && $mktime_exe_date) {
- $mytime = ((int) $mktime_exe_date - (int) $mktime_start_date);
- $time_attemp = learnpathItem :: getScormTimeFromParameter('js', $mytime);
- $time_attemp = str_replace('NaN', '00' . $h . '00\'00"', $time_attemp);
- } else {
- $time_attemp = ' - ';
- }
- if (!$is_allowed_to_edit && $result_disabled_ext_all) {
- $view_score = Display::return_icon('invisible.gif', get_lang('ResultsHiddenByExerciseSetting'));
- } else {
- // Show only float when need it
- if ($my_score == 0) {
- $view_score = show_score(0, $my_maxscore, false);
- } else {
- if ($my_maxscore == 0) {
- $view_score = $my_score;
- } else {
- $view_score = show_score($my_score, $my_maxscore, false);
- }
- }
- }
- $my_lesson_status = $row_attempts['status'];
- if ($my_lesson_status == '') {
- $my_lesson_status = learnpathitem::humanize_status('completed');
- } elseif ($my_lesson_status == 'incomplete') {
- $my_lesson_status = learnpathitem::humanize_status('incomplete');
- }
- $output .= '<tr class="' . $oddclass . '" >
- <td></td>
- <td>' . $extend_attempt_link . '</td>
- <td colspan="3">' . get_lang('Attempt').' '. $n.'</td>
- <td colspan="2">' . $my_lesson_status . '</td>
- <td colspan="2">'.$view_score . '</td>
- <td colspan="2">'.$time_attemp . '</td>';
- if ($action == 'classic') {
- if ($origin != 'tracking') {
- if (!$is_allowed_to_edit && $result_disabled_ext_all) {
- $output .= '<td>
- <img src="' . api_get_path(WEB_IMG_PATH) . 'quiz_na.gif" alt="' . get_lang('ShowAttempt') . '" title="' . get_lang('ShowAttempt') . '">
- </td>';
- } else {
- $output .= '<td>
- <a href="../exercice/exercise_show.php?origin=' . $origin . '&id=' . $my_exe_id . '&cidReq=' . $courseCode . '" target="_parent">
- <img src="' . api_get_path(WEB_IMG_PATH) . 'quiz.gif" alt="' . get_lang('ShowAttempt') . '" title="' . get_lang('ShowAttempt') . '">
- </a></td>';
- }
- } else {
- if (!$is_allowed_to_edit && $result_disabled_ext_all) {
- $output .= '<td>
- <img src="' . api_get_path(WEB_IMG_PATH) . 'quiz_na.gif" alt="' . get_lang('ShowAndQualifyAttempt') . '" title="' . get_lang('ShowAndQualifyAttempt') . '"></td>';
- } else {
- $output .= '<td>
- <a href="../exercice/exercise_show.php?cidReq=' . $courseCode . '&origin=correct_exercise_in_lp&id=' . $my_exe_id . '" target="_parent">
- <img src="' . api_get_path(WEB_IMG_PATH) . 'quiz.gif" alt="' . get_lang('ShowAndQualifyAttempt') . '" title="' . get_lang('ShowAndQualifyAttempt') . '"></a></td>';
- }
- }
- }
- $output .= '</tr>';
- $n++;
- }
- }
- $output .= '<tr><td colspan="12"> </td></tr>';
- }
- }
- }
- }
- $total_time += $time_for_total;
- // QUIZZ IN LP
- $a_my_id = array();
- if (!empty($my_lp_id)) {
- $a_my_id[] = $my_lp_id;
- }
- }
- }
- // NOT Extend all "left green cross"
- if (!empty($a_my_id)) {
- if ($extendedAttempt) {
- // "Right green cross" extended
- $total_score = self::get_avg_student_score(
- $user_id,
- $course_id,
- $a_my_id,
- $session_id,
- false,
- false
- );
- } else {
- // "Left green cross" extended
- $total_score = self::get_avg_student_score(
- $user_id,
- $course_id,
- $a_my_id,
- $session_id,
- false,
- true
- );
- }
- } else {
- // Extend all "left green cross"
- $total_score = self::get_avg_student_score(
- $user_id,
- $course_id,
- array($lp_id),
- $session_id,
- false,
- false
- );
- }
- $total_time = learnpathItem::getScormTimeFromParameter('js', $total_time);
- $total_time = str_replace('NaN', '00' . $h . '00\'00"', $total_time);
- if (!$is_allowed_to_edit && $result_disabled_ext_all) {
- $final_score = Display::return_icon('invisible.gif', get_lang('ResultsHiddenByExerciseSetting'));
- } else {
- if (is_numeric($total_score)) {
- $final_score = $total_score . '%';
- } else {
- $final_score = $total_score;
- }
- }
- $progress = learnpath::getProgress($lp_id, $user_id, $course_id, $session_id);
- if (($counter % 2) == 0) {
- $oddclass = 'row_odd';
- } else {
- $oddclass = 'row_even';
- }
- $action = null;
- if ($type == 'classic') {
- $action = '<td></td>';
- }
- $output .= '<tr class="'.$oddclass.'">
- <td></td>
- <td colspan="4">
- <i>' . get_lang('AccomplishedStepsTotal') .'</i>
- </td>
- <td colspan="2">'.$progress.'%</td>
- <td colspan="2">
- ' . $final_score.'
- </td>
- <td colspan="2">' . $total_time . '</div>
- '.$action.'
- </tr>';
- $output .= "</table>";
- if (!empty($export_csv)) {
- $temp = array(
- '',
- '',
- '',
- '',
- );
- $csv_content[] = $temp;
- $temp = array(
- get_lang('AccomplishedStepsTotal'),
- '',
- $final_score,
- $total_time,
- );
- $csv_content[] = $temp;
- ob_end_clean();
- Export :: export_table_csv($csv_content, 'reporting_learning_path_details');
- exit;
- }
- return $output;
- }
- /**
- * @param int $userId
- *
- * @return array
- */
- public static function getStats($userId)
- {
- $assignedCourses = array();
- if (api_is_drh() && api_drh_can_access_all_session_content()) {
- $studentList = SessionManager::getAllUsersFromCoursesFromAllSessionFromStatus(
- 'drh_all',
- $userId,
- false,
- null,
- null,
- null,
- null,
- null,
- null,
- null,
- array(),
- array(),
- STUDENT
- );
- $students = array();
- foreach ($studentList as $studentData) {
- $students[] = $studentData['user_id'];
- }
- $teacherList = SessionManager::getAllUsersFromCoursesFromAllSessionFromStatus(
- 'drh_all',
- $userId,
- false,
- null,
- null,
- null,
- null,
- null,
- null,
- null,
- array(),
- array(),
- COURSEMANAGER
- );
- $teachers = array();
- foreach ($teacherList as $teacherData) {
- $teachers[] = $teacherData['user_id'];
- }
- $humanResources = SessionManager::getAllUsersFromCoursesFromAllSessionFromStatus(
- 'drh_all',
- $userId,
- false,
- null,
- null,
- null,
- null,
- null,
- null,
- null,
- array(),
- array(),
- DRH
- );
- $humanResourcesList = array();
- foreach ($humanResources as $item) {
- $humanResourcesList[] = $item['user_id'];
- }
- $platformCourses = SessionManager::getAllCoursesFollowedByUser(
- $userId,
- null,
- null,
- null,
- null,
- null
- );
- $courses = array();
- foreach ($platformCourses as $course) {
- $courses[$course['code']] = $course['code'];
- }
- $sessions = SessionManager::get_sessions_followed_by_drh($userId);
- } else {
- $studentList = UserManager::getUsersFollowedByUser(
- $userId,
- STUDENT,
- false,
- false,
- false,
- null,
- null,
- null,
- null,
- null,
- null,
- COURSEMANAGER
- );
- $students = array();
- foreach ($studentList as $studentData) {
- $students[] = $studentData['user_id'];
- }
- $teacherList = UserManager::getUsersFollowedByUser(
- $userId,
- COURSEMANAGER,
- false,
- false,
- false,
- null,
- null,
- null,
- null,
- null,
- null,
- COURSEMANAGER
- );
- $teachers = array();
- foreach ($teacherList as $teacherData) {
- $teachers[] = $teacherData['user_id'];
- }
- $humanResources = UserManager::getUsersFollowedByUser(
- $userId,
- DRH,
- false,
- false,
- false,
- null,
- null,
- null,
- null,
- null,
- null,
- COURSEMANAGER
- );
- $humanResourcesList = array();
- foreach ($humanResources as $item) {
- $humanResourcesList[] = $item['user_id'];
- }
- $platformCourses = CourseManager::getCoursesFollowedByUser(
- $userId,
- COURSEMANAGER,
- null,
- null,
- null,
- null,
- false,
- null,
- null,
- true
- );
- foreach ($platformCourses as $course) {
- $assignedCourses[$course['code']] = $course['code'];
- }
- $platformCourses = CourseManager::getCoursesFollowedByUser(
- $userId,
- COURSEMANAGER
- );
- foreach ($platformCourses as $course) {
- $courses[$course['code']] = $course['code'];
- }
- $sessions = SessionManager::getSessionsFollowedByUser(
- $userId,
- COURSEMANAGER
- );
- }
- return array(
- 'drh' => $humanResourcesList,
- 'teachers' => $teachers,
- 'students' => $students,
- 'courses' => $courses,
- 'sessions' => $sessions,
- 'assignedCourses' => $assignedCourses,
- );
- }
- /**
- * Calculates the time spent on the platform by a user
- * @param int|array User id
- * @param string type of time filter: 'last_week' or 'custom'
- * @param string start date date('Y-m-d H:i:s')
- * @param string end date date('Y-m-d H:i:s')
- * @return timestamp $nb_seconds
- */
- public static function get_time_spent_on_the_platform(
- $userId,
- $timeFilter = 'last_7_days',
- $start_date = null,
- $end_date = null
- ) {
- $tbl_track_login = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_LOGIN);
- $condition_time = '';
- if (is_array($userId)) {
- $userList = array_map('intval', $userId);
- $userCondition = " login_user_id IN ('".implode("','", $userList)."')";
- } else {
- $userCondition = " login_user_id = ".intval($userId);
- }
- if (empty($timeFilter)) {
- $timeFilter = 'last_week';
- }
- $today = date('Y-m-d H:i:s');
- switch ($timeFilter) {
- case 'last_7_days':
- $new_date = date('Y-m-d H:i:s', strtotime('-7 day'));
- $condition_time = ' AND (login_date >= "'.$new_date.'" AND logout_date <= "'.$today.'") ';
- break;
- case 'last_30_days':
- $new_date = date('Y-m-d H:i:s', strtotime('-30 day'));
- $condition_time = ' AND (login_date >= "'.$new_date.'" AND logout_date <= "'.$today.'") ';
- break;
- case 'custom':
- if (!empty($start_date) && !empty($end_date)) {
- $start_date = Database::escape_string($start_date);
- $end_date = Database::escape_string($end_date);
- $condition_time = ' AND (login_date >= "'.$start_date.'" AND logout_date <= "'.$end_date.'" ) ';
- }
- break;
- }
- $sql = 'SELECT SUM(TIMESTAMPDIFF(SECOND, login_date, logout_date)) diff
- FROM '.$tbl_track_login.'
- WHERE '.$userCondition.$condition_time;
- $rs = Database::query($sql);
- $row = Database::fetch_array($rs, 'ASSOC');
- $diff = $row['diff'];
- if ($diff >= 0) {
- return $diff;
- } else {
- return -1;
- }
- }
- /**
- * Calculates the time spent on the course
- * @param integer $user_id
- * @param string $course_code
- * @param int Session id (optional)
- *
- * @return int Time in seconds
- */
- public static function get_time_spent_on_the_course($user_id, $course_code, $session_id = 0)
- {
- $course_code = Database::escape_string($course_code);
- $session_id = intval($session_id);
- $tbl_track_course = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_COURSE_ACCESS);
- if (is_array($user_id)) {
- $user_id = array_map('intval', $user_id);
- $condition_user = " AND user_id IN (".implode(',',$user_id).") ";
- } else {
- $user_id = intval($user_id);
- $condition_user = " AND user_id = '$user_id' ";
- }
- $sql = "SELECT SUM(UNIX_TIMESTAMP(logout_course_date) - UNIX_TIMESTAMP(login_course_date)) as nb_seconds
- FROM $tbl_track_course
- WHERE
- UNIX_TIMESTAMP(logout_course_date) > UNIX_TIMESTAMP(login_course_date) AND
- course_code='$course_code' AND
- session_id = '$session_id' $condition_user";
- $rs = Database::query($sql);
- $row = Database::fetch_array($rs);
- return $row['nb_seconds'];
- }
- /**
- * Get first connection date for a student
- * @param int $student_id
- *
- * @return string|bool Date format long without day or false if there are no connections
- */
- public static function get_first_connection_date($student_id)
- {
- $tbl_track_login = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_LOGIN);
- $sql = 'SELECT login_date FROM ' . $tbl_track_login . '
- WHERE login_user_id = ' . intval($student_id) . '
- ORDER BY login_date ASC LIMIT 0,1';
- $rs = Database::query($sql);
- if (Database::num_rows($rs)>0) {
- if ($first_login_date = Database::result($rs, 0, 0)) {
- return api_convert_and_format_date($first_login_date, DATE_FORMAT_SHORT, date_default_timezone_get());
- }
- }
- return false;
- }
- /**
- * Get las connection date for a student
- * @param int $student_id
- * @param bool $warning_message Show a warning message (optional)
- * @param bool $return_timestamp True for returning results in timestamp (optional)
- * @return string|int|bool Date format long without day, false if there are no connections or
- * timestamp if parameter $return_timestamp is true
- */
- public static function get_last_connection_date($student_id, $warning_message = false, $return_timestamp = false)
- {
- $tbl_track_login = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_LOGIN);
- $sql = 'SELECT login_date FROM ' . $tbl_track_login . '
- WHERE login_user_id = ' . intval($student_id) . '
- ORDER BY login_date DESC LIMIT 0,1';
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0) {
- if ($last_login_date = Database::result($rs, 0, 0)) {
- $last_login_date = api_get_local_time($last_login_date);
- if ($return_timestamp) {
- return api_strtotime($last_login_date,'UTC');
- } else {
- if (!$warning_message) {
- return api_format_date($last_login_date, DATE_FORMAT_SHORT);
- } else {
- $timestamp = api_strtotime($last_login_date,'UTC');
- $currentTimestamp = time();
- //If the last connection is > than 7 days, the text is red
- //345600 = 7 days in seconds
- if ($currentTimestamp - $timestamp > 604800) {
- return '<span style="color: #F00;">' . api_format_date($last_login_date, DATE_FORMAT_SHORT) . '</span>';
- } else {
- return api_format_date($last_login_date, DATE_FORMAT_SHORT);
- }
- }
- }
- }
- }
- return false;
- }
- /**
- * Get las connection date for a student
- * @param array $studentList Student id array
- * @param int $days
- * @param bool $getCount
- * @return int
- */
- public static function getInactiveUsers($studentList, $days, $getCount = true)
- {
- if (empty($studentList)) {
- return 0;
- }
- $days = intval($days);
- $date = api_get_utc_datetime(strtotime($days.' days ago'));
- $studentList = array_map('intval', $studentList);
- $tbl_track_login = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_LOGIN);
- $select = " SELECT login_user_id ";
- if ($getCount) {
- $select = " SELECT count(DISTINCT login_user_id) as count";
- }
- $sql = "$select
- FROM $tbl_track_login
- WHERE
- login_user_id IN (' ". implode("','", $studentList) . "' ) AND
- login_date < '$date'
- ";
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0) {
- if ($getCount) {
- $count = Database::fetch_array($rs);
- return $count['count'];
- }
- return Database::store_result($rs, 'ASSOC');
- }
- return false;
- }
- /**
- * Get first user's connection date on the course
- * @param int User id
- * @param string Course code
- * @param int Session id (optional, default=0)
- * @return string|bool Date with format long without day or false if there is no date
- */
- public static function get_first_connection_date_on_the_course(
- $student_id,
- $course_code,
- $session_id = 0,
- $convert_date = true
- ) {
- // protect data
- $student_id = intval($student_id);
- $course_code = Database::escape_string($course_code);
- $session_id = intval($session_id);
- $tbl_track_login = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_COURSE_ACCESS);
- $sql = 'SELECT login_course_date FROM '.$tbl_track_login.'
- WHERE user_id = '.$student_id.'
- AND course_code = "'.$course_code.'"
- AND session_id = '.$session_id.'
- ORDER BY login_course_date ASC LIMIT 0,1';
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0) {
- if ($first_login_date = Database::result($rs, 0, 0)) {
- if ($convert_date) {
- return api_convert_and_format_date($first_login_date, DATE_FORMAT_SHORT);
- } else {
- return $first_login_date;
- }
- }
- }
- return false;
- }
- /**
- * Get last user's connection date on the course
- * @param int User id
- * @param string Course code
- * @param int Session id (optional, default=0)
- * @return string|bool Date with format long without day or false if there is no date
- */
- public static function get_last_connection_date_on_the_course(
- $student_id,
- $course_code,
- $session_id = 0,
- $convert_date = true
- ) {
- // protect data
- $student_id = intval($student_id);
- $course_code = Database::escape_string($course_code);
- $session_id = intval($session_id);
- /*$tbl_track_e_access = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_ACCESS);
- $sql = 'SELECT access_date
- FROM '.$tbl_track_e_access.'
- WHERE access_user_id = '.$student_id.' AND
- access_cours_code = "'.$course_code.'" AND
- access_session_id = '.$session_id.'
- ORDER BY access_date DESC
- LIMIT 0,1';*/
- $table = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_COURSE_ACCESS);
- $sql = "SELECT login_course_date
- FROM $table
- WHERE
- user_id = $student_id AND
- course_code = '$course_code' AND
- session_id = $session_id
- ORDER BY login_course_date DESC
- LIMIT 0,1";
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0) {
- if ($last_login_date = Database::result($rs, 0, 0)) {
- if (empty($last_login_date) || $last_login_date == '0000-00-00 00:00:00') {
- return false;
- }
- //$last_login_date_timestamp = api_strtotime($last_login_date, 'UTC');
- //see #5736
- $last_login_date_timestamp = api_strtotime($last_login_date);
- $now = time();
- //If the last connection is > than 7 days, the text is red
- //345600 = 7 days in seconds
- if ($now - $last_login_date_timestamp > 604800) {
- if ($convert_date) {
- $last_login_date = api_convert_and_format_date($last_login_date, DATE_FORMAT_SHORT);
- $icon = api_is_allowed_to_edit() ? '<a href="'.api_get_path(REL_CODE_PATH).'announcements/announcements.php?action=add&remind_inactive='.$student_id.'" title="'.get_lang('RemindInactiveUser').'"><img src="'.api_get_path(WEB_IMG_PATH).'messagebox_warning.gif" /> </a>': null;
- return $icon. Display::label($last_login_date, 'warning');
- } else {
- return $last_login_date;
- }
- } else {
- if ($convert_date) {
- return api_convert_and_format_date($last_login_date, DATE_FORMAT_SHORT);
- } else {
- return $last_login_date;
- }
- }
- }
- }
- return false;
- }
- /**
- * Get count of the connections to the course during a specified period
- * @param string Course code
- * @param int Session id (optional)
- * @param int Datetime from which to collect data (defaults to 0)
- * @param int Datetime to which to collect data (defaults to now)
- * @return int count connections
- */
- public static function get_course_connections_count($course_code, $session_id = 0, $start = 0, $stop = null)
- {
- if ($start < 0) {
- $start = 0;
- }
- if (!isset($stop) or ($stop < 0)) {
- $stop = api_get_utc_datetime();
- }
- $start = Database::escape_string($start);
- $stop = Database::escape_string($stop);
- $month_filter = " AND login_course_date > '$start' AND login_course_date < '$stop' ";
- $course_code = Database::escape_string($course_code);
- $session_id = intval($session_id);
- $count = 0;
- $tbl_track_e_course_access = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_COURSE_ACCESS);
- $sql = "SELECT count(*) as count_connections
- FROM $tbl_track_e_course_access
- WHERE
- course_code = '$course_code' AND
- session_id = $session_id
- $month_filter";
- $rs = Database::query($sql);
- if (Database::num_rows($rs)>0) {
- $row = Database::fetch_object($rs);
- $count = $row->count_connections;
- }
- return $count;
- }
- /**
- * Get count courses per student
- * @param int Student id
- * @param bool Include sessions (optional)
- * @return int count courses
- */
- public static function count_course_per_student($user_id, $include_sessions = true)
- {
- $user_id = intval($user_id);
- $tbl_course_rel_user = Database :: get_main_table(TABLE_MAIN_COURSE_USER);
- $tbl_session_course_rel_user = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $sql = 'SELECT DISTINCT course_code
- FROM ' . $tbl_course_rel_user . '
- WHERE user_id = ' . $user_id.' AND relation_type<>'.COURSE_RELATION_TYPE_RRHH;
- $rs = Database::query($sql);
- $nb_courses = Database::num_rows($rs);
- if ($include_sessions) {
- $sql = 'SELECT DISTINCT course_code
- FROM ' . $tbl_session_course_rel_user . '
- WHERE id_user = ' . $user_id;
- $rs = Database::query($sql);
- $nb_courses += Database::num_rows($rs);
- }
- return $nb_courses;
- }
- /**
- * Gets the score average from all tests in a course by student
- *
- * @param $student_id
- * @param $course_code
- * @param int $exercise_id
- * @param null $session_id
- * @param int $active_filter 2 for consider all tests
- * 1 for active <> -1
- * 0 for active <> 0
- * @param int $into_lp 1 for all exercises
- * 0 for without LP
- * @internal param \Student $mixed id
- * @internal param \Course $string code
- * @internal param \Exercise $int id (optional), filtered by exercise
- * @internal param \Session $int id (optional), if param $session_id is null it'll return results including sessions, 0 = session is not filtered
- * @return string value (number %) Which represents a round integer about the score average.
- */
- public static function get_avg_student_exercise_score(
- $student_id,
- $course_code,
- $exercise_id = 0,
- $session_id = null,
- $active_filter = 1,
- $into_lp = 0
- ) {
- $course_code = Database::escape_string($course_code);
- $course_info = api_get_course_info($course_code);
- if (!empty($course_info)) {
- // table definition
- $tbl_course_quiz = Database::get_course_table(TABLE_QUIZ_TEST);
- $tbl_stats_exercise = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_EXERCICES);
- // Compose a filter based on optional exercise given
- $condition_quiz = "";
- if (!empty($exercise_id)) {
- $exercise_id = intval($exercise_id);
- $condition_quiz =" AND id = $exercise_id ";
- }
- // Compose a filter based on optional session id given
- $condition_session = "";
- if (isset($session_id)) {
- $session_id = intval($session_id);
- $condition_session = " AND session_id = $session_id ";
- }
- if ($active_filter == 1) {
- $condition_active = 'AND active <> -1';
- } elseif ($active_filter == 0) {
- $condition_active = 'AND active <> 0';
- } else {
- $condition_active = '';
- }
- $condition_into_lp = '';
- $select_lp_id = '';
- if ($into_lp == 0) {
- $condition_into_lp = 'AND orig_lp_id = 0 AND orig_lp_item_id = 0';
- } else {
- $select_lp_id = ', orig_lp_id as lp_id ';
- }
- $sql = "SELECT count(id) FROM $tbl_course_quiz
- WHERE c_id = {$course_info['real_id']} $condition_active $condition_quiz ";
- $count_quiz = Database::fetch_row(Database::query($sql));
- if (!empty($count_quiz[0]) && !empty($student_id)) {
- if (is_array($student_id)) {
- $student_id = array_map('intval', $student_id);
- $condition_user = " AND exe_user_id IN (".implode(',', $student_id).") ";
- } else {
- $student_id = intval($student_id);
- $condition_user = " AND exe_user_id = '$student_id' ";
- }
- if (empty($exercise_id)) {
- $sql = "SELECT id FROM $tbl_course_quiz
- WHERE c_id = {$course_info['real_id']} $condition_active $condition_quiz";
- $result = Database::query($sql);
- $exercise_list = array();
- $exercise_id = null;
- if (Database::num_rows($result)) {
- while ($row = Database::fetch_array($result)) {
- $exercise_list[] = $row['id'];
- }
- }
- if (!empty($exercise_list)) {
- $exercise_id = implode("','",$exercise_list);
- }
- }
- $count_quiz = Database::fetch_row(Database::query($sql));
- $sql = "SELECT
- SUM(exe_result/exe_weighting*100) as avg_score,
- COUNT(*) as num_attempts
- $select_lp_id
- FROM $tbl_stats_exercise
- WHERE
- exe_exo_id IN ('".$exercise_id."')
- $condition_user AND
- status = '' AND
- exe_cours_id = '$course_code'
- $condition_session
- $condition_into_lp
- ORDER BY exe_date DESC";
- $res = Database::query($sql);
- $row = Database::fetch_array($res);
- $quiz_avg_score = null;
- if (!empty($row['avg_score'])) {
- $quiz_avg_score = round($row['avg_score'],2);
- }
- if(!empty($row['num_attempts'])) {
- $quiz_avg_score = round($quiz_avg_score / $row['num_attempts'], 2);
- }
- if (is_array($student_id)) {
- $quiz_avg_score = round($quiz_avg_score / count($student_id), 2);
- }
- if ($into_lp == 0) {
- return $quiz_avg_score;
- } else {
- if (!empty($row['lp_id'])) {
- $tbl_lp = Database::get_course_table(TABLE_LP_MAIN);
- $tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
- $sql = "SELECT lp.name
- FROM $tbl_lp as lp, $tbl_course as c
- WHERE
- c.code = '$course_code' AND
- lp.id = ".$row['lp_id']." AND
- lp.c_id = c.id
- LIMIT 1;
- ";
- $result = Database::query($sql);
- $row_lp = Database::fetch_row($result);
- $lp_name = $row_lp[0];
- return array($quiz_avg_score, $lp_name);
- } else {
- return array($quiz_avg_score, null);
- }
- }
- }
- }
- return null;
- }
- /**
- * Get count student's exercise COMPLETED attempts
- * @param $student_id
- * @param $course_code
- * @param $exercise_id
- * @param int $lp_id
- * @param int $lp_item_id
- * @param int $session_id
- * @param int $find_all_lp 0 = just LP specified
- * 1 = LP specified or whitout LP,
- * 2 = all rows
- * @internal param \Student $int id
- * @internal param \Course $string code
- * @internal param \Exercise $int id
- * @internal param \Learning $int path id (optional), for showing attempts inside a learning path $lp_id and $lp_item_id params are required.
- * @internal param \Learning $int path item id (optional), for showing attempts inside a learning path $lp_id and $lp_item_id params are required.
- * @return int count of attempts
- */
- public static function count_student_exercise_attempts(
- $student_id,
- $course_code,
- $exercise_id,
- $lp_id = 0,
- $lp_item_id = 0,
- $session_id = 0,
- $find_all_lp = 0
- ) {
- $course_code = Database::escape_string($course_code);
- $student_id = intval($student_id);
- $exercise_id = intval($exercise_id);
- $session_id = intval($session_id);
- $lp_id = intval($lp_id);
- $lp_item_id = intval($lp_item_id);
- $tbl_stats_exercices = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_EXERCICES);
- $sql = "SELECT COUNT(ex.exe_id) as essais FROM $tbl_stats_exercices AS ex
- WHERE ex.exe_cours_id = '$course_code'
- AND ex.exe_exo_id = $exercise_id
- AND status = ''
- AND exe_user_id= $student_id
- AND session_id = $session_id ";
- if ($find_all_lp == 1) {
- $sql .= "AND (orig_lp_id = $lp_id OR orig_lp_id = 0)
- AND (orig_lp_item_id = $lp_item_id OR orig_lp_item_id = 0)";
- } elseif ($find_all_lp == 0) {
- $sql .= "AND orig_lp_id = $lp_id
- AND orig_lp_item_id = $lp_item_id";
- }
- $rs = Database::query($sql);
- $row = Database::fetch_row($rs);
- $count_attempts = $row[0];
- return $count_attempts;
- }
- /**
- * Get count student's exercise progress
- *
- * @param array $exercise_list
- * @param int $user_id
- * @param string $course_code
- * @param int $session_id
- */
- public static function get_exercise_student_progress($exercise_list, $user_id, $course_code, $session_id)
- {
- $course_code = Database::escape_string($course_code);
- $user_id = intval($user_id);
- $session_id = intval($session_id);
- if (empty($exercise_list)) {
- return '0%';
- }
- $tbl_stats_exercices = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_EXERCICES);
- $exercise_list = array_keys($exercise_list);
- $exercise_list = array_map('intval', $exercise_list);
- $exercise_list_imploded = implode("' ,'", $exercise_list);
- $sql = "SELECT COUNT(DISTINCT ex.exe_exo_id)
- FROM $tbl_stats_exercices AS ex
- WHERE
- ex.exe_cours_id = '$course_code' AND
- ex.session_id = $session_id AND
- ex.exe_user_id = $user_id AND
- ex.exe_exo_id IN ('$exercise_list_imploded') ";
- $rs = Database::query($sql);
- $count = 0;
- if ($rs) {
- $row = Database::fetch_row($rs);
- $count = $row[0];
- }
- $count = ($count != 0 ) ? 100*round(intval($count)/count($exercise_list), 2) .'%' : '0%';
- return $count;
- }
- /**
- * @param array $exercise_list
- * @param int $user_id
- * @param string $course_code
- * @param int $session_id
- * @return string
- */
- public static function get_exercise_student_average_best_attempt($exercise_list, $user_id, $course_code, $session_id)
- {
- $result = 0;
- if (!empty($exercise_list)) {
- foreach ($exercise_list as $exercise_data) {
- $exercise_id = $exercise_data['id'];
- $best_attempt = get_best_attempt_exercise_results_per_user(
- $user_id,
- $exercise_id,
- $course_code,
- $session_id
- );
- if (!empty($best_attempt) && !empty($best_attempt['exe_weighting'])) {
- $result += $best_attempt['exe_result']/$best_attempt['exe_weighting'];
- }
- }
- $result = $result / count($exercise_list);
- $result = round($result, 2) * 100;
- }
- return $result.'%';
- }
- /**
- * get teacher progress by course and session
- * @param int course id
- * @param int session id
- * @return array
- */
- static function get_teachers_progress_by_course($courseId, $sessionId)
- {
- $course = api_get_course_info_by_id($courseId);
- $sessionId = intval($sessionId);
- $courseId = intval($courseId);
- //get teachers
- $sql = "SELECT scu.id_session, scu.id_user, s.name
- FROM session_rel_course_rel_user scu, session s
- WHERE
- scu.id_session = s.id
- AND scu.status = 2
- AND scu.visibility = 1
- AND scu.course_code = '%s'
- AND scu.id_session = %s";
- $query = sprintf($sql,$course['code'], $sessionId);
- $rs = Database::query($query);
- $teachers = array();
- while ($teacher = Database::fetch_array($rs,'ASSOC')) {
- $teachers[] = $teacher;
- }
- $data = array();
- foreach ($teachers as $teacher) {
- //total documents added
- $sql = "SELECT count(*) as total
- FROM c_item_property
- WHERE lastedit_type = 'DocumentAdded'
- AND c_id = %s
- AND insert_user_id = %s
- AND id_session = %s";
- $query = sprintf($sql,
- $courseId,
- $teacher['id_user'],
- $teacher['id_session']
- );
- $rs = Database::query($query);
- $totalDocuments = 0;
- if ($rs) {
- $row = Database::fetch_row($rs);
- $totalDocuments = $row[0];
- }
- //total links added
- $sql = "SELECT count(*) as total
- FROM c_item_property
- WHERE lastedit_type = 'LinkAdded'
- AND c_id = %s
- AND insert_user_id = %s
- AND id_session = %s";
- $query = sprintf($sql,
- $courseId,
- $teacher['id_user'],
- $teacher['id_session']
- );
- $rs = Database::query($query);
- $totalLinks = 0;
- if ($rs) {
- $row = Database::fetch_row($rs);
- $totalLinks = $row[0];
- }
- //total forums added
- $sql = "SELECT count(*) as total
- FROM c_item_property
- WHERE lastedit_type = 'ForumthreadVisible'
- AND c_id = %s
- AND insert_user_id = %s
- AND id_session = %s";
- $query = sprintf($sql,
- $courseId,
- $teacher['id_user'],
- $teacher['id_session']
- );
- $rs = Database::query($query);
- $totalForums = 0;
- if ($rs) {
- $row = Database::fetch_row($rs);
- $totalForums = $row[0];
- }
- //total wikis added
- $sql = "SELECT COUNT(DISTINCT(ref)) as total
- FROM c_item_property
- WHERE lastedit_type = 'WikiAdded'
- AND c_id = %s
- AND insert_user_id = %s
- AND id_session = %s";
- $query = sprintf($sql,
- $courseId,
- $teacher['id_user'],
- $teacher['id_session']
- );
- $rs = Database::query($query);
- $totalWikis = 0;
- if ($rs) {
- $row = Database::fetch_row($rs);
- $totalWikis = $row[0];
- }
- //total works added
- $sql = "SELECT COUNT(*) as total
- FROM c_item_property
- WHERE lastedit_type = 'DirectoryCreated'
- AND tool = 'work'
- AND c_id = %s
- AND insert_user_id = %s
- AND id_session = %s";
- $query = sprintf($sql,
- $courseId,
- $teacher['id_user'],
- $teacher['id_session']
- );
- $rs = Database::query($query);
- $totalWorks = 0;
- if ($rs) {
- $row = Database::fetch_row($rs);
- $totalWorks = $row[0];
- }
- //total announcements added
- $sql = "SELECT COUNT(*) as total
- FROM c_item_property
- WHERE lastedit_type = 'AnnouncementAdded'
- AND c_id = %s
- AND insert_user_id = %s
- AND id_session = %s";
- $query = sprintf($sql,
- $courseId,
- $teacher['id_user'],
- $teacher['id_session']
- );
- $rs = Database::query($query);
- $totalAnnouncements = 0;
- if ($rs) {
- $row = Database::fetch_row($rs);
- $totalAnnouncements = $row[0];
- }
- $tutor = api_get_user_info($teacher['id_user']);
- $data[] = array(
- 'course' => $course['title'],
- 'session' => $teacher['name'],
- 'tutor' => $tutor['username'] . ' - ' . $tutor['lastname'] . ' ' . $tutor['firstname'],
- 'documents' => $totalDocuments,
- 'links' => $totalLinks,
- 'forums' => $totalForums,
- 'works' => $totalWorks,
- 'wikis' => $totalWikis,
- 'announcements' => $totalAnnouncements,
- );
- }
- return $data;
- }
- /**
- * Returns the average student progress in the learning paths of the given
- * course.
- * @param int|array $student_id
- * @param string $course_code
- * @param array $lp_ids Limit average to listed lp ids
- * @param int $session_id Session id (optional),
- * if parameter $session_id is null(default) it'll return results including
- * sessions, 0 = session is not filtered
- * @param bool $return_array Will return an array of the type:
- * [sum_of_progresses, number] if it is set to true
- * @return double Average progress of the user in this course
- */
- public static function get_avg_student_progress(
- $student_id,
- $course_code = null,
- $lp_ids = array(),
- $session_id = null,
- $return_array = false
- ) {
- $conditions = array();
- $session_id = intval($session_id);
- // Get the information of the course.
- $course_info = api_get_course_info($course_code);
- if (!empty($course_info)) {
- $conditions[] = " c_id = {$course_info['real_id']} ";
- }
- // table definition
- $tbl_course_lp_view = Database :: get_course_table(TABLE_LP_VIEW);
- // Compose a filter based on optional learning paths list given
- $condition_lp = null;
- if (!empty($lp_ids)) {
- if (count($lp_ids) > 0) {
- $lp_ids = array_map('intval', $lp_ids);
- $conditions[] = " lp_view.lp_id IN (".implode(',', $lp_ids).") ";
- }
- }
- // If there is at least one learning path and one student.
- if (!empty($student_id)) {
- if (is_array($student_id)) {
- $student_id = array_map('intval', $student_id);
- $conditions[] = " lp_view.user_id IN (".implode(',', $student_id).") ";
- } else {
- $student_id = intval($student_id);
- $conditions[] = " lp_view.user_id = '$student_id' ";
- if (empty($lp_ids)) {
- $lpList = new learnpathList($student_id, $course_code, $session_id);
- $lpList = $lpList->get_flat_list();
- if (!empty($lpList)) {
- /** @var $lp */
- foreach ($lpList as $lpId => $lp) {
- $lp_ids[] = $lpId;
- }
- }
- }
- }
- if (!empty($session_id)) {
- $conditions[] = " session_id = $session_id ";
- }
- $conditionToString = implode('AND', $conditions);
- // Get last view for each student (in case of multi-attempt)
- // Also filter on LPs of this session
- /*$sql = " SELECT
- MAX(view_count),
- AVG(progress) average,
- SUM(progress) sum_progress,
- count(progress) count_progress
- FROM $tbl_course_lp_view lp_view
- WHERE
- $conditionToString
- GROUP BY lp_id";*/
- $sql = " SELECT
- lp_id,
- view_count,
- progress
- FROM $tbl_course_lp_view lp_view
- WHERE
- $conditionToString
- GROUP BY lp_id
- ORDER BY view_count DESC
- ";
- $result = Database::query($sql);
- $progress = array();
- $viewCount = array();
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- if (!isset($viewCount[$row['lp_id']])) {
- $progress[$row['lp_id']] = $row['progress'];
- }
- $viewCount[$row['lp_id']] = $row['view_count'];
- }
- // Fill with lp ids
- if (!empty($lp_ids)) {
- foreach ($lp_ids as $lpId) {
- if (!isset($progress[$lpId])) {
- $progress[$lpId] = 0;
- }
- }
- }
- if (!empty($progress)) {
- $sum = array_sum($progress);
- $average = $sum / count($progress);
- } else {
- $average = 0;
- $sum = 0;
- }
- if (!$return_array) {
- $avg_progress = round($average, 1);
- return $avg_progress;
- } else {
- return array($sum, count($progress));
- }
- }
- }
- /**
- * This function gets:
- * 1. The score average from all SCORM Test items in all LP in a course-> All the answers / All the max scores.
- * 2. The score average from all Tests (quiz) in all LP in a course-> All the answers / All the max scores.
- * 3. And finally it will return the average between 1. and 2.
- * @todo improve performance, when loading 1500 users with 20 lps the script dies
- * This function does not take the results of a Test out of a LP
- *
- * @param mixed $student_id Array of user ids or an user id
- * @param string $course_code
- * @param array $lp_ids List of LP ids
- * @param int $session_id Session id (optional),
- * if param $session_id is null(default) it'll return results
- * including sessions, 0 = session is not filtered
- * @param bool $return_array Returns an array of the
- * type [sum_score, num_score] if set to true
- * @param bool $get_only_latest_attempt_results get only the latest attempts or ALL attempts
- *
- * @return string Value (number %) Which represents a round integer explain in got in 3.
- */
- public static function get_avg_student_score(
- $student_id,
- $course_code,
- $lp_ids = array(),
- $session_id = null,
- $return_array = false,
- $get_only_latest_attempt_results = false
- ) {
- $debug = false;
- if (empty($lp_ids)) {
- $debug = false;
- }
- if ($debug) echo '<h1>Tracking::get_avg_student_score</h1>';
- $tbl_stats_exercices = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_EXERCICES);
- $tbl_stats_attempts = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_ATTEMPT);
- $course = api_get_course_info($course_code);
- if (!empty($course)) {
- // Get course tables names
- $tbl_quiz_questions = Database :: get_course_table(TABLE_QUIZ_QUESTION);
- $lp_table = Database :: get_course_table(TABLE_LP_MAIN);
- $lp_item_table = Database :: get_course_table(TABLE_LP_ITEM);
- $lp_view_table = Database :: get_course_table(TABLE_LP_VIEW);
- $lp_item_view_table = Database :: get_course_table(TABLE_LP_ITEM_VIEW);
- $course_id = $course['real_id'];
- // Compose a filter based on optional learning paths list given
- $condition_lp = "";
- if (count($lp_ids) > 0) {
- $condition_lp =" AND id IN(".implode(',',$lp_ids).") ";
- }
- // Compose a filter based on optional session id
- $session_id = intval($session_id);
- if (count($lp_ids) > 0) {
- $condition_session = " AND session_id = $session_id ";
- } else {
- $condition_session = " WHERE session_id = $session_id ";
- }
- // Check the real number of LPs corresponding to the filter in the
- // database (and if no list was given, get them all)
- if (empty($session_id)) {
- $sql = "SELECT DISTINCT(id), use_max_score FROM $lp_table
- WHERE c_id = $course_id AND session_id = 0 $condition_lp ";
- } else {
- $sql = "SELECT DISTINCT(id), use_max_score FROM $lp_table
- WHERE c_id = $course_id $condition_lp ";
- }
- $res_row_lp = Database::query($sql);
- $count_row_lp = Database::num_rows($res_row_lp);
- $lp_list = $use_max_score = array();
- while ($row_lp = Database::fetch_array($res_row_lp)) {
- $lp_list[] = $row_lp['id'];
- $use_max_score[$row_lp['id']] = $row_lp['use_max_score'];
- }
- if ($debug) {
- echo 'Use max score or not list '; var_dump($use_max_score);
- }
- // prepare filter on users
- if (is_array($student_id)) {
- array_walk($student_id, 'intval');
- $condition_user1 =" AND user_id IN (".implode(',', $student_id).") ";
- } else {
- $condition_user1 =" AND user_id = $student_id ";
- }
- if ($count_row_lp > 0 && !empty($student_id)) {
- // Getting latest LP result for a student
- //@todo problem when a course have more than 1500 users
- $sql = "SELECT MAX(view_count) as vc, id, progress, lp_id, user_id
- FROM $lp_view_table
- WHERE
- c_id = $course_id AND
- lp_id IN (".implode(',', $lp_list).")
- $condition_user1 AND
- session_id = $session_id
- GROUP BY lp_id, user_id";
- if ($debug) echo $sql;
- $rs_last_lp_view_id = Database::query($sql);
- $global_result = 0;
- if (Database::num_rows($rs_last_lp_view_id) > 0) {
- // Cycle through each line of the results (grouped by lp_id, user_id)
- while ($row_lp_view = Database::fetch_array($rs_last_lp_view_id)) {
- $count_items = 0;
- $lp_partial_total = 0;
- $list = array();
- $lp_view_id = $row_lp_view['id'];
- $lp_id = $row_lp_view['lp_id'];
- $user_id = $row_lp_view['user_id'];
- if ($debug) echo '<h2>LP id '.$lp_id.'</h2>';
- if ($get_only_latest_attempt_results) {
- //Getting lp_items done by the user
- $sql = "SELECT DISTINCT lp_item_id
- FROM $lp_item_view_table
- WHERE
- c_id = $course_id AND
- lp_view_id = $lp_view_id
- ORDER BY lp_item_id";
- $res_lp_item = Database::query($sql);
- while ($row_lp_item = Database::fetch_array($res_lp_item,'ASSOC')) {
- $my_lp_item_id = $row_lp_item['lp_item_id'];
- // Getting the most recent attempt
- $sql = "SELECT lp_iv.id as lp_item_view_id,
- lp_iv.score as score,
- lp_i.max_score,
- lp_iv.max_score as max_score_item_view,
- lp_i.path,
- lp_i.item_type,
- lp_i.id as iid
- FROM $lp_item_view_table as lp_iv
- INNER JOIN $lp_item_table as lp_i
- ON lp_i.id = lp_iv.lp_item_id AND
- lp_iv.c_id = $course_id AND
- lp_i.c_id = $course_id AND
- (lp_i.item_type='sco' OR lp_i.item_type='".TOOL_QUIZ."')
- WHERE
- lp_item_id = $my_lp_item_id AND
- lp_view_id = $lp_view_id
- ORDER BY view_count DESC
- LIMIT 1";
- $res_lp_item_result = Database::query($sql);
- while ($row_max_score = Database::fetch_array($res_lp_item_result,'ASSOC')) {
- $list[]= $row_max_score;
- }
- }
- } else {
- // For the currently analysed view, get the score and
- // max_score of each item if it is a sco or a TOOL_QUIZ
- $sql = "SELECT
- lp_iv.id as lp_item_view_id,
- lp_iv.score as score,
- lp_i.max_score,
- lp_iv.max_score as max_score_item_view,
- lp_i.path,
- lp_i.item_type,
- lp_i.id as iid
- FROM $lp_item_view_table as lp_iv
- INNER JOIN $lp_item_table as lp_i
- ON lp_i.id = lp_iv.lp_item_id AND
- lp_iv.c_id = $course_id AND
- lp_i.c_id = $course_id AND
- (lp_i.item_type='sco' OR lp_i.item_type='".TOOL_QUIZ."')
- WHERE lp_view_id = $lp_view_id ";
- if ($debug) echo $sql.'<br />';
- $res_max_score = Database::query($sql);
- while ($row_max_score = Database::fetch_array($res_max_score,'ASSOC')) {
- $list[]= $row_max_score;
- }
- }
- // Go through each scorable element of this view
- $score_of_scorm_calculate = 0;
- foreach ($list as $row_max_score) {
- // Came from the original lp_item
- $max_score = $row_max_score['max_score'];
- // Came from the lp_item_view
- $max_score_item_view = $row_max_score['max_score_item_view'];
- $score = $row_max_score['score'];
- if ($debug) echo '<h3>Item Type: ' .$row_max_score['item_type'].'</h3>';
- if ($row_max_score['item_type'] == 'sco') {
- /* Check if it is sco (easier to get max_score)
- when there's no max score, we assume 100 as the max score,
- as the SCORM 1.2 says that the value should always be between 0 and 100.
- */
- if ($max_score == 0 || is_null($max_score) || $max_score == '') {
- // Chamilo style
- if ($use_max_score[$lp_id]) {
- $max_score = 100;
- } else {
- // Overwrites max score = 100 to use the one that came in the lp_item_view see BT#1613
- $max_score = $max_score_item_view;
- }
- }
- // Avoid division by zero errors
- if (!empty($max_score)) {
- $lp_partial_total += $score/$max_score;
- }
- if ($debug) echo '<b>$lp_partial_total, $score, $max_score '.$lp_partial_total.' '.$score.' '.$max_score.'</b><br />';
- } else {
- // Case of a TOOL_QUIZ element
- $item_id = $row_max_score['iid'];
- $item_path = $row_max_score['path'];
- $lp_item_view_id = $row_max_score['lp_item_view_id'];
- // Get last attempt to this exercise through
- // the current lp for the current user
- $sql = "SELECT exe_id
- FROM $tbl_stats_exercices
- WHERE
- exe_exo_id = '$item_path' AND
- exe_user_id = $user_id AND
- orig_lp_item_id = $item_id AND
- orig_lp_item_view_id = $lp_item_view_id AND
- exe_cours_id = '$course_code' AND
- session_id = $session_id AND
- status = ''
- ORDER BY exe_date DESC
- LIMIT 1";
- if ($debug) echo $sql .'<br />';
- $result_last_attempt = Database::query($sql);
- $num = Database :: num_rows($result_last_attempt);
- if ($num > 0 ) {
- $id_last_attempt = Database :: result($result_last_attempt, 0, 0);
- if ($debug) echo $id_last_attempt.'<br />';
- // Within the last attempt number tracking, get the sum of
- // the max_scores of all questions that it was
- // made of (we need to make this call dynamic because of random questions selection)
- $sql = "SELECT SUM(t.ponderation) as maxscore FROM
- (
- SELECT DISTINCT
- question_id,
- marks,
- ponderation
- FROM $tbl_stats_attempts AS at
- INNER JOIN $tbl_quiz_questions AS q
- ON (q.id = at.question_id)
- WHERE
- exe_id ='$id_last_attempt' AND
- q.c_id = $course_id
- )
- AS t";
- if ($debug) echo '$sql: '.$sql.' <br />';
- $res_max_score_bis = Database::query($sql);
- $row_max_score_bis = Database::fetch_array($res_max_score_bis);
- if (!empty($row_max_score_bis['maxscore'])) {
- $max_score = $row_max_score_bis['maxscore'];
- }
- if (!empty($max_score) && floatval($max_score) > 0) {
- $lp_partial_total += $score/$max_score;
- }
- if ($debug) echo '$lp_partial_total, $score, $max_score <b>'.$lp_partial_total.' '.$score.' '.$max_score.'</b><br />';
- }
- }
- if (in_array($row_max_score['item_type'], array('quiz','sco'))) {
- // Normal way
- if ($use_max_score[$lp_id]) {
- $count_items++;
- } else {
- if ($max_score != '') {
- $count_items++;
- }
- }
- if ($debug) echo '$count_items: '.$count_items;
- }
- } //end for
- $score_of_scorm_calculate += $count_items ? (($lp_partial_total / $count_items) * 100) : 0;
- if ($debug) echo '<h3>$count_items '.$count_items.'</h3>';
- if ($debug) echo '<h3>$score_of_scorm_calculate '.$score_of_scorm_calculate.'</h3>';
- $global_result += $score_of_scorm_calculate;
- if ($debug) echo '<h3>$global_result '.$global_result.'</h3>';
- } // end while
- }
- $lp_with_quiz = 0;
- foreach ($lp_list as $lp_id) {
- // Check if LP have a score we assume that all SCO have an score
- $sql = "SELECT count(id) as count
- FROM $lp_item_table
- WHERE
- c_id = $course_id AND
- (item_type = 'quiz' OR item_type = 'sco') AND
- lp_id = ".$lp_id;
- if ($debug) echo $sql;
- $result_have_quiz = Database::query($sql);
- if (Database::num_rows($result_have_quiz) > 0 ) {
- $row = Database::fetch_array($result_have_quiz,'ASSOC');
- if (is_numeric($row['count']) && $row['count'] != 0) {
- $lp_with_quiz++;
- }
- }
- }
- if ($debug) echo '<h3>$lp_with_quiz '.$lp_with_quiz.' </h3>';
- if ($debug) echo '<h3>Final return</h3>';
- if ($lp_with_quiz != 0) {
- if (!$return_array) {
- $score_of_scorm_calculate = round(($global_result/$lp_with_quiz),2);
- if ($debug) var_dump($score_of_scorm_calculate);
- if (empty($lp_ids)) {
- if ($debug) echo '<h2>All lps fix: '.$score_of_scorm_calculate.'</h2>';
- }
- return $score_of_scorm_calculate;
- } else {
- if ($debug) var_dump($global_result, $lp_with_quiz);
- return array($global_result, $lp_with_quiz);
- }
- } else {
- return '-';
- }
- }
- }
- return null;
- }
- /**
- * This function gets:
- * 1. The score average from all SCORM Test items in all LP in a course-> All the answers / All the max scores.
- * 2. The score average from all Tests (quiz) in all LP in a course-> All the answers / All the max scores.
- * 3. And finally it will return the average between 1. and 2.
- * This function does not take the results of a Test out of a LP
- *
- * @param int|array Array of user ids or an user id
- * @param string Course code
- * @param array List of LP ids
- * @param int Session id (optional), if param $session_id is null(default) it'll return results including sessions, 0 = session is not filtered
- * @param bool Returns an array of the type [sum_score, num_score] if set to true
- * @param bool get only the latest attempts or ALL attempts
- * @return string Value (number %) Which represents a round integer explain in got in 3.
- */
- public static function getAverageStudentScore(
- $student_id,
- $course_code = null,
- $lp_ids = array(),
- $session_id = null
- ) {
- if (empty($student_id)) {
- return 0;
- }
- $conditions = array();
- if (!empty($course_code)) {
- $course = api_get_course_info($course_code);
- $courseId = $course['real_id'];
- $conditions[] = " c_id = $courseId";
- }
- // Get course tables names
- $lp_table = Database :: get_course_table(TABLE_LP_MAIN);
- $lp_item_table = Database :: get_course_table(TABLE_LP_ITEM);
- $lp_view_table = Database :: get_course_table(TABLE_LP_VIEW);
- $lp_item_view_table = Database :: get_course_table(TABLE_LP_ITEM_VIEW);
- // Compose a filter based on optional learning paths list given
- if (!empty($lp_ids) && count($lp_ids) > 0) {
- $conditions[] = " id IN(".implode(',', $lp_ids).") ";
- }
- // Compose a filter based on optional session id
- $session_id = intval($session_id);
- if (!empty($session_id)) {
- $conditions[] = " session_id = $session_id ";
- }
- if (is_array($student_id)) {
- array_walk($student_id, 'intval');
- $conditions[] =" lp_view.user_id IN (".implode(',', $student_id).") ";
- } else {
- $conditions[] =" lp_view.user_id = $student_id ";
- }
- $conditionsToString = implode('AND ', $conditions);
- $sql = "SELECT SUM(lp_iv.score) sum_score,
- SUM(lp_i.max_score) sum_max_score,
- count(*) as count
- FROM $lp_table as lp
- INNER JOIN $lp_item_table as lp_i
- ON lp.id = lp_id AND lp.c_id = lp_i.c_id
- INNER JOIN $lp_view_table as lp_view
- ON lp_view.lp_id = lp_i.lp_id AND lp_view.c_id = lp_i.c_id
- INNER JOIN $lp_item_view_table as lp_iv
- ON lp_i.id = lp_iv.lp_item_id AND lp_view.c_id = lp_iv.c_id AND lp_iv.lp_view_id = lp_view.id
- WHERE (lp_i.item_type='sco' OR lp_i.item_type='".TOOL_QUIZ."') AND
- $conditionsToString
- ";
- $result = Database::query($sql);
- $row = Database::fetch_array($result, 'ASSOC');
- if (empty($row['sum_max_score'])) {
- return 0;
- }
- return ($row['sum_score'] / $row['sum_max_score'])*100;
- }
- /**
- * This function gets time spent in learning path for a student inside a course
- * @param int|array Student id(s)
- * @param string Course code
- * @param array Limit average to listed lp ids
- * @param int Session id (optional), if param $session_id is null(default) it'll return results including sessions, 0 = session is not filtered
- * @return int Total time
- */
- public static function get_time_spent_in_lp($student_id, $course_code, $lp_ids = array(), $session_id = null)
- {
- $course = CourseManager :: get_course_information($course_code);
- $student_id = intval($student_id);
- $total_time = 0;
- if (!empty($course)) {
- $lp_table = Database :: get_course_table(TABLE_LP_MAIN);
- $t_lpv = Database :: get_course_table(TABLE_LP_VIEW);
- $t_lpiv = Database :: get_course_table(TABLE_LP_ITEM_VIEW);
- $course_id = $course['real_id'];
- // Compose a filter based on optional learning paths list given
- $condition_lp = "";
- if(count($lp_ids) > 0) {
- $condition_lp =" AND id IN(".implode(',',$lp_ids).") ";
- }
- // Compose a filter based on optional session id
- $condition_session = "";
- $session_id = intval($session_id);
- if (isset($session_id)) {
- $condition_session = " AND session_id = $session_id ";
- }
- // Check the real number of LPs corresponding to the filter in the
- // database (and if no list was given, get them all)
- //$res_row_lp = Database::query("SELECT DISTINCT(id) FROM $lp_table $condition_lp $condition_session");
- $res_row_lp = Database::query("SELECT DISTINCT(id) FROM $lp_table WHERE c_id = $course_id $condition_lp");
- $count_row_lp = Database::num_rows($res_row_lp);
- // calculates time
- if ($count_row_lp > 0) {
- while ($row_lp = Database::fetch_array($res_row_lp)) {
- $lp_id = intval($row_lp['id']);
- $sql = 'SELECT SUM(total_time)
- FROM '.$t_lpiv.' AS item_view
- INNER JOIN '.$t_lpv.' AS view
- ON item_view.lp_view_id = view.id
- WHERE
- item_view.c_id = '.$course_id.' AND
- view.c_id = '.$course_id.' AND
- view.lp_id = '.$lp_id.'
- AND view.user_id = '.$student_id.' AND
- session_id = '.$session_id;
- $rs = Database::query($sql);
- if (Database :: num_rows($rs) > 0) {
- $total_time += Database :: result($rs, 0, 0);
- }
- }
- }
- }
- return $total_time;
- }
- /**
- * This function gets last connection time to one learning path
- * @param int|array Student id(s)
- * @param string Course code
- * @param int Learning path id
- * @return int Total time
- */
- public static function get_last_connection_time_in_lp($student_id, $course_code, $lp_id, $session_id = 0)
- {
- $course = CourseManager :: get_course_information($course_code);
- $student_id = intval($student_id);
- $lp_id = intval($lp_id);
- $last_time = 0;
- $session_id = intval($session_id);
- if (!empty($course)) {
- $course_id = $course['real_id'];
- $lp_table = Database :: get_course_table(TABLE_LP_MAIN);
- $t_lpv = Database :: get_course_table(TABLE_LP_VIEW);
- $t_lpiv = Database :: get_course_table(TABLE_LP_ITEM_VIEW);
- // Check the real number of LPs corresponding to the filter in the
- // database (and if no list was given, get them all)
- $res_row_lp = Database::query("SELECT id FROM $lp_table WHERE c_id = $course_id AND id = $lp_id ");
- $count_row_lp = Database::num_rows($res_row_lp);
- // calculates last connection time
- if ($count_row_lp > 0) {
- $sql = 'SELECT MAX(start_time)
- FROM ' . $t_lpiv . ' AS item_view
- INNER JOIN ' . $t_lpv . ' AS view
- ON item_view.lp_view_id = view.id
- WHERE
- item_view.c_id = '.$course_id.' AND
- view.c_id = '.$course_id.' AND
- view.lp_id = '.$lp_id.'
- AND view.user_id = '.$student_id.'
- AND view.session_id = '.$session_id;
- $rs = Database::query($sql);
- if (Database :: num_rows($rs) > 0) {
- $last_time = Database :: result($rs, 0, 0);
- }
- }
- }
- return $last_time;
- }
- /**
- * gets the list of students followed by coach
- * @param int Coach id
- * @return array List of students
- */
- public static function get_student_followed_by_coach($coach_id)
- {
- $coach_id = intval($coach_id);
- $tbl_session_course_user = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tbl_session_course = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE);
- $tbl_session_user = Database :: get_main_table(TABLE_MAIN_SESSION_USER);
- $tbl_session = Database :: get_main_table(TABLE_MAIN_SESSION);
- $a_students = array ();
- // At first, courses where $coach_id is coach of the course //
- $sql = 'SELECT id_session, course_code
- FROM ' . $tbl_session_course_user . '
- WHERE id_user=' . $coach_id.' AND status=2';
- if (api_is_multiple_url_enabled()) {
- $tbl_session_rel_access_url= Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $access_url_id = api_get_current_access_url_id();
- if ($access_url_id != -1) {
- $sql = 'SELECT scu.id_session, scu.course_code
- FROM ' . $tbl_session_course_user . ' scu
- INNER JOIN '.$tbl_session_rel_access_url.' sru
- ON (scu.id_session=sru.session_id)
- WHERE
- scu.id_user=' . $coach_id.' AND
- scu.status=2 AND
- sru.access_url_id = '.$access_url_id;
- }
- }
- $result = Database::query($sql);
- while ($a_courses = Database::fetch_array($result)) {
- $course_code = $a_courses["course_code"];
- $id_session = $a_courses["id_session"];
- $sql = "SELECT distinct srcru.id_user
- FROM $tbl_session_course_user AS srcru, $tbl_session_user sru
- WHERE
- srcru.id_user = sru.id_user AND
- sru.relation_type<>".SESSION_RELATION_TYPE_RRHH." AND
- srcru.id_session = sru.id_session AND
- srcru.course_code='$course_code' AND
- srcru.id_session='$id_session'";
- $rs = Database::query($sql);
- while ($row = Database::fetch_array($rs)) {
- $a_students[$row['id_user']] = $row['id_user'];
- }
- }
- // Then, courses where $coach_id is coach of the session //
- $sql = 'SELECT session_course_user.id_user
- FROM ' . $tbl_session_course_user . ' as session_course_user
- INNER JOIN '.$tbl_session_user.' sru ON session_course_user.id_user = sru.id_user AND session_course_user.id_session = sru.id_session
- INNER JOIN ' . $tbl_session_course . ' as session_course
- ON session_course.course_code = session_course_user.course_code
- AND session_course_user.id_session = session_course.id_session
- INNER JOIN ' . $tbl_session . ' as session
- ON session.id = session_course.id_session
- AND session.id_coach = ' . $coach_id;
- if (api_is_multiple_url_enabled()) {
- $tbl_session_rel_access_url= Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $access_url_id = api_get_current_access_url_id();
- if ($access_url_id != -1){
- $sql = 'SELECT session_course_user.id_user
- FROM ' . $tbl_session_course_user . ' as session_course_user
- INNER JOIN '.$tbl_session_user.' sru
- ON session_course_user.id_user = sru.id_user AND
- session_course_user.id_session = sru.id_session
- INNER JOIN ' . $tbl_session_course . ' as session_course
- ON session_course.course_code = session_course_user.course_code AND
- session_course_user.id_session = session_course.id_session
- INNER JOIN ' . $tbl_session . ' as session
- ON session.id = session_course.id_session AND
- session.id_coach = ' . $coach_id.'
- INNER JOIN '.$tbl_session_rel_access_url.' session_rel_url
- ON session.id = session_rel_url.session_id WHERE access_url_id = '.$access_url_id;
- }
- }
- $result = Database::query($sql);
- while ($row = Database::fetch_array($result)) {
- $a_students[$row['id_user']] = $row['id_user'];
- }
- return $a_students;
- }
- /**
- * Get student followed by a coach inside a session
- * @param int Session id
- * @param int Coach id
- * @return array students list
- */
- public static function get_student_followed_by_coach_in_a_session($id_session, $coach_id)
- {
- $coach_id = intval($coach_id);
- $tbl_session_course_user = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tbl_session = Database :: get_main_table(TABLE_MAIN_SESSION);
- $a_students = array ();
- // At first, courses where $coach_id is coach of the course //
- $sql = 'SELECT course_code FROM ' . $tbl_session_course_user . ' WHERE id_session="' . $id_session . '" AND id_user=' . $coach_id.' AND status=2';
- $result = Database::query($sql);
- while ($a_courses = Database::fetch_array($result)) {
- $course_code = $a_courses["course_code"];
- $sql = "SELECT distinct srcru.id_user
- FROM $tbl_session_course_user AS srcru
- WHERE
- course_code='$course_code' AND
- id_session = '" . $id_session . "'";
- $rs = Database::query($sql);
- while ($row = Database::fetch_array($rs)) {
- $a_students[$row['id_user']] = $row['id_user'];
- }
- }
- // Then, courses where $coach_id is coach of the session
- $sql = 'SELECT id_coach FROM ' . $tbl_session . '
- WHERE id="' . $id_session.'" AND id_coach="' . $coach_id . '"';
- $result = Database::query($sql);
- //He is the session_coach so we select all the users in the session
- if (Database::num_rows($result) > 0) {
- $sql = 'SELECT DISTINCT srcru.id_user
- FROM ' . $tbl_session_course_user . ' AS srcru
- WHERE id_session="' . $id_session . '"';
- $result = Database::query($sql);
- while ($row = Database::fetch_array($result)) {
- $a_students[$row['id_user']] = $row['id_user'];
- }
- }
- return $a_students;
- }
- /**
- * Check if a coach is allowed to follow a student
- * @param int Coach id
- * @param int Student id
- * @return bool
- */
- public static function is_allowed_to_coach_student($coach_id, $student_id)
- {
- $coach_id = intval($coach_id);
- $student_id = intval($student_id);
- $tbl_session_course_user = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tbl_session_course = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE);
- $tbl_session = Database :: get_main_table(TABLE_MAIN_SESSION);
- // At first, courses where $coach_id is coach of the course //
- $sql = 'SELECT 1 FROM ' . $tbl_session_course_user . ' WHERE id_user=' . $coach_id .' AND status=2';
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0) {
- return true;
- }
- // Then, courses where $coach_id is coach of the session
- $sql = 'SELECT session_course_user.id_user
- FROM ' . $tbl_session_course_user . ' as session_course_user
- INNER JOIN ' . $tbl_session_course . ' as session_course
- ON session_course.course_code = session_course_user.course_code
- INNER JOIN ' . $tbl_session . ' as session
- ON session.id = session_course.id_session
- AND session.id_coach = ' . $coach_id . '
- WHERE id_user = ' . $student_id;
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0) {
- return true;
- }
- return false;
- }
- /**
- * Get courses followed by coach
- * @param int Coach id
- * @param int Session id (optional)
- * @return array Courses list
- */
- public static function get_courses_followed_by_coach($coach_id, $id_session = null)
- {
- $coach_id = intval($coach_id);
- if (!empty($id_session)) {
- $id_session = intval($id_session);
- }
- $tbl_session_course_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tbl_session_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
- // At first, courses where $coach_id is coach of the course.
- $sql = 'SELECT DISTINCT course_code
- FROM ' . $tbl_session_course_user . '
- WHERE id_user = ' . $coach_id.' AND status = 2';
- if (api_is_multiple_url_enabled()) {
- $tbl_course_rel_access_url= Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $access_url_id = api_get_current_access_url_id();
- if ($access_url_id != -1){
- $sql = 'SELECT DISTINCT scu.course_code
- FROM ' . $tbl_session_course_user . ' scu
- INNER JOIN '.$tbl_course_rel_access_url.' cru
- ON (scu.course_code = cru.course_code)
- WHERE
- scu.id_user=' . $coach_id.' AND
- scu.status=2 AND
- cru.access_url_id = '.$access_url_id;
- }
- }
- if (!empty($id_session)) {
- $sql .= ' AND id_session=' . $id_session;
- }
- $courseList = array();
- $result = Database::query($sql);
- while ($row = Database::fetch_array($result)) {
- $courseList[$row['course_code']] = $row['course_code'];
- }
- // Then, courses where $coach_id is coach of the session
- $sql = 'SELECT DISTINCT session_course.course_code
- FROM ' . $tbl_session_course . ' as session_course
- INNER JOIN ' . $tbl_session . ' as session
- ON session.id = session_course.id_session
- AND session.id_coach = ' . $coach_id . '
- INNER JOIN ' . $tbl_course . ' as course
- ON course.code = session_course.course_code';
- if (api_is_multiple_url_enabled()) {
- $tbl_course_rel_access_url= Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $access_url_id = api_get_current_access_url_id();
- if ($access_url_id != -1){
- $sql = 'SELECT DISTINCT session_course.course_code
- FROM ' . $tbl_session_course . ' as session_course
- INNER JOIN ' . $tbl_session . ' as session
- ON session.id = session_course.id_session
- AND session.id_coach = ' . $coach_id . '
- INNER JOIN ' . $tbl_course . ' as course
- ON course.code = session_course.course_code
- INNER JOIN '.$tbl_course_rel_access_url.' course_rel_url
- ON (session_course.course_code = course_rel_url.course_code)';
- }
- }
- if (!empty ($id_session)) {
- $sql .= ' WHERE session_course.id_session=' . $id_session;
- if (api_is_multiple_url_enabled())
- $sql .= ' AND access_url_id = '.$access_url_id;
- } else {
- if (api_is_multiple_url_enabled())
- $sql .= ' WHERE access_url_id = '.$access_url_id;
- }
- $result = Database::query($sql);
- while ($row = Database::fetch_array($result)) {
- $courseList[$row['course_code']] = $row['course_code'];
- }
- return $courseList;
- }
- /**
- * Get sessions coached by user
- * @param $coach_id
- * @param int $start
- * @param int $limit
- * @param bool $getCount
- * @param string $keyword
- * @param string $description
- * @return mixed
- */
- public static function get_sessions_coached_by_user(
- $coach_id,
- $start = 0,
- $limit = 0,
- $getCount = false,
- $keyword = '',
- $description = ''
- ) {
- // table definition
- $tbl_session = Database :: get_main_table(TABLE_MAIN_SESSION);
- $tbl_session_course_user = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $coach_id = intval($coach_id);
- $select = " SELECT * FROM ";
- if ($getCount) {
- $select = " SELECT count(DISTINCT id) as count FROM ";
- }
- $limitCondition = null;
- if (!empty($start) && !empty($limit)) {
- $limitCondition = " LIMIT ".intval($start).", ".intval($limit);
- }
- $keywordCondition = null;
- if (!empty($keyword)) {
- $keyword = Database::escape_string($keyword);
- $keywordCondition = " AND (name LIKE '%$keyword%' ) ";
- if (!empty($description)) {
- $description = Database::escape_string($description);
- $keywordCondition = " AND (name LIKE '%$keyword%' OR description LIKE '%$description%' ) ";
- }
- }
- $tbl_session_rel_access_url= Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $access_url_id = api_get_current_access_url_id();
- $sql = "
- $select
- (
- SELECT DISTINCT id, name, date_start, date_end
- FROM $tbl_session session INNER JOIN $tbl_session_rel_access_url session_rel_url
- ON (session.id = session_rel_url.session_id)
- WHERE
- id_coach = $coach_id AND
- access_url_id = $access_url_id
- $keywordCondition
- UNION
- SELECT DISTINCT session.id, session.name, session.date_start, session.date_end
- FROM $tbl_session as session
- INNER JOIN $tbl_session_course_user as session_course_user
- ON session.id = session_course_user.id_session AND
- session_course_user.id_user= $coach_id AND
- session_course_user.status=2
- INNER JOIN $tbl_session_rel_access_url session_rel_url
- ON (session.id = session_rel_url.session_id)
- WHERE
- access_url_id = $access_url_id
- $keywordCondition
- ) as sessions $limitCondition
- ";
- $rs = Database::query($sql);
- if ($getCount) {
- $row = Database::fetch_array($rs);
- return $row['count'];
- }
- while ($row = Database::fetch_array($rs)) {
- $a_sessions[$row["id"]] = $row;
- }
- if (is_array($a_sessions)) {
- foreach ($a_sessions as & $session) {
- if ($session['date_start'] == '0000-00-00') {
- $session['status'] = get_lang('SessionActive');
- }
- else {
- $date_start = explode('-', $session['date_start']);
- $time_start = mktime(0, 0, 0, $date_start[1], $date_start[2], $date_start[0]);
- $date_end = explode('-', $session['date_end']);
- $time_end = mktime(0, 0, 0, $date_end[1], $date_end[2], $date_end[0]);
- if ($time_start < time() && time() < $time_end) {
- $session['status'] = get_lang('SessionActive');
- } else {
- if (time() < $time_start) {
- $session['status'] = get_lang('SessionFuture');
- } else {
- if (time() > $time_end) {
- $session['status'] = get_lang('SessionPast');
- }
- }
- }
- }
- }
- }
- return $a_sessions;
- }
- /**
- * Get courses list from a session
- * @param int Session id
- * @return array Courses list
- */
- public static function get_courses_list_from_session($session_id)
- {
- $session_id = intval($session_id);
- // table definition
- $tbl_session_course = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE);
- $sql = 'SELECT DISTINCT course_code
- FROM ' . $tbl_session_course . '
- WHERE id_session=' . $session_id;
- $rs = Database::query($sql);
- $a_courses = array ();
- while ($row = Database::fetch_array($rs)) {
- $a_courses[$row['course_code']] = $row;
- }
- return $a_courses;
- }
- /**
- * Count the number of documents that an user has uploaded to a course
- * @param int|array Student id(s)
- * @param string Course code
- * @param int Session id (optional), if param $session_id is null(default) return count of assignments including sessions, 0 = session is not filtered
- * @return int Number of documents
- */
- public static function count_student_uploaded_documents($student_id, $course_code, $session_id = null)
- {
- // get the information of the course
- $a_course = CourseManager::get_course_information($course_code);
- if (!empty($a_course)) {
- // table definition
- $tbl_item_property = Database :: get_course_table(TABLE_ITEM_PROPERTY);
- $tbl_document = Database :: get_course_table(TABLE_DOCUMENT);
- $course_id = $a_course['real_id'];
- if (is_array($student_id)) {
- $studentList = array_map('intval', $student_id);
- $condition_user = " AND ip.insert_user_id IN ('".implode(',', $studentList)."') ";
- } else {
- $student_id = intval($student_id);
- $condition_user = " AND ip.insert_user_id = '$student_id' ";
- }
- $condition_session = null;
- if (isset($session_id)) {
- $session_id = intval($session_id);
- $condition_session = " AND pub.session_id = $session_id ";
- }
- $sql = "SELECT count(ip.tool) AS count
- FROM $tbl_item_property ip INNER JOIN $tbl_document pub
- ON ip.ref = pub.id
- WHERE ip.c_id = $course_id AND
- pub.c_id = $course_id AND
- pub.filetype ='file' AND
- ip.tool = 'document'
- $condition_user $condition_session ";
- $rs = Database::query($sql);
- $row = Database::fetch_row($rs);
- return $row['count'];
- }
- return null;
- }
- /**
- * Count assignments per student
- * @param int|array Student id(s)
- * @param string Course code
- * @param int Session id (optional), if param $session_id is null(default) return count of assignments including sessions, 0 = session is not filtered
- * @return int Count of assignments
- */
- public static function count_student_assignments($student_id, $course_code = null, $session_id = null)
- {
- if (empty($student_id)) {
- return 0;
- }
- $conditions = array();
- // Get the information of the course
- $a_course = CourseManager::get_course_information($course_code);
- if (!empty($a_course)) {
- $course_id = $a_course['real_id'];
- $conditions[]= " ip.c_id = $course_id AND pub.c_id = $course_id ";
- }
- // table definition
- $tbl_item_property = Database :: get_course_table(TABLE_ITEM_PROPERTY);
- $tbl_student_publication = Database :: get_course_table(TABLE_STUDENT_PUBLICATION);
- if (is_array($student_id)) {
- $studentList = array_map('intval', $student_id);
- $conditions[]= " ip.insert_user_id IN ('".implode("','", $studentList)."') ";
- } else {
- $student_id = intval($student_id);
- $conditions[]= " ip.insert_user_id = '$student_id' ";
- }
- if (isset($session_id)) {
- $session_id = intval($session_id);
- $conditions[]= " pub.session_id = $session_id ";
- }
- $conditionToString = implode('AND', $conditions);
- $sql = "SELECT count(ip.tool) as count
- FROM $tbl_item_property ip
- INNER JOIN $tbl_student_publication pub ON ip.ref = pub.id
- WHERE
- ip.tool='work' AND
- $conditionToString";
- $rs = Database::query($sql);
- $row = Database::fetch_array($rs, 'ASSOC');
- return $row['count'];
- }
- /**
- * Count messages per student inside forum tool
- * @param int|array Student id
- * @param string Course code
- * @param int Session id (optional), if param $session_id is
- * null(default) return count of messages including sessions, 0 = session is not filtered
- * @return int Count of messages
- */
- public static function count_student_messages($student_id, $courseCode = null, $session_id = null)
- {
- if (empty($student_id)) {
- return 0;
- }
- $courseInfo = api_get_course_info($courseCode);
- $courseCondition = null;
- $conditions = array();
- if (!empty($courseInfo)) {
- $course_id = $courseInfo['real_id'];
- $conditions[]= " post.c_id = $course_id AND forum.c_id = $course_id ";
- }
- // Table definition.
- $tbl_forum_post = Database :: get_course_table(TABLE_FORUM_POST);
- $tbl_forum = Database :: get_course_table(TABLE_FORUM);
- if (is_array($student_id)) {
- $studentList = array_map('intval', $student_id);
- $conditions[]= " post.poster_id IN ('".implode("','", $studentList)."') ";
- } else {
- $student_id = intval($student_id);
- $conditions[]= " post.poster_id = '$student_id' ";
- }
- if (isset($session_id)) {
- $session_id = intval($session_id);
- $conditions[]= " forum.session_id = $session_id";
- }
- $conditionsToString = implode('AND ', $conditions);
- $sql = "SELECT count(poster_id) as count
- FROM $tbl_forum_post post INNER JOIN $tbl_forum forum
- ON forum.forum_id = post.forum_id
- WHERE $conditionsToString";
- $rs = Database::query($sql);
- $row = Database::fetch_array($rs, 'ASSOC');
- $count = $row['count'];
- return $count;
- }
- /**
- * This function counts the number of post by course
- * @param string Course code
- * @param int Session id (optional), if param $session_id is null(default) it'll return results including sessions, 0 = session is not filtered
- * @return int The number of post by course
- */
- public static function count_number_of_posts_by_course($course_code, $session_id = null)
- {
- $a_course = CourseManager :: get_course_information($course_code);
- if (!empty($a_course)) {
- $tbl_posts = Database :: get_course_table(TABLE_FORUM_POST);
- $tbl_forums = Database :: get_course_table(TABLE_FORUM);
- $condition_session = '';
- if (isset($session_id)) {
- $session_id = intval($session_id);
- $condition_session = ' AND f.session_id = '. $session_id;
- }
- $course_id = $a_course['real_id'];
- $sql = "SELECT count(*) FROM $tbl_posts p INNER JOIN $tbl_forums f
- ON f.forum_id = p.forum_id
- WHERE p.c_id = $course_id AND
- f.c_id = $course_id
- $condition_session
- ";
- $result = Database::query($sql);
- $row = Database::fetch_row($result);
- $count = $row[0];
- return $count;
- } else {
- return null;
- }
- }
- /**
- * This function counts the number of threads by course
- * @param string Course code
- * @param int Session id (optional), if param $session_id is null(default) it'll return results including sessions, 0 = session is not filtered
- * @return int The number of threads by course
- */
- public static function count_number_of_threads_by_course($course_code, $session_id = null)
- {
- $course_info = api_get_course_info($course_code);
- if (empty($course_info)) {
- return null;
- }
- $course_id = $course_info['real_id'];
- $tbl_threads = Database :: get_course_table(TABLE_FORUM_THREAD);
- $tbl_forums = Database :: get_course_table(TABLE_FORUM);
- $condition_session = '';
- if (isset($session_id)) {
- $session_id = intval($session_id);
- $condition_session = ' AND f.session_id = '. $session_id;
- }
- $sql = "SELECT count(*) FROM $tbl_threads t INNER JOIN $tbl_forums f ON f.forum_id = t.forum_id
- WHERE t.c_id = $course_id AND f.c_id = $course_id $condition_session ";
- $result = Database::query($sql);
- if (Database::num_rows($result)) {
- $row = Database::fetch_row($result);
- $count = $row[0];
- return $count;
- } else {
- return null;
- }
- }
- /**
- * This function counts the number of forums by course
- * @param string Course code
- * @param int Session id (optional), if param $session_id is null(default) it'll return results including sessions, 0 = session is not filtered
- * @return int The number of forums by course
- */
- public static function count_number_of_forums_by_course($course_code, $session_id = null)
- {
- $course_info = api_get_course_info($course_code);
- if (empty($course_info)) {
- return null;
- }
- $course_id = $course_info['real_id'];
- $condition_session = '';
- if (isset($session_id)) {
- $session_id = intval($session_id);
- $condition_session = ' session_id = '. $session_id;
- }
- $tbl_forums = Database :: get_course_table(TABLE_FORUM);
- $sql = "SELECT count(*) FROM $tbl_forums WHERE c_id = $course_id AND $condition_session";
- $result = Database::query($sql);
- if (Database::num_rows($result)) {
- $row = Database::fetch_row($result);
- $count = $row[0];
- return $count;
- } else {
- return null;
- }
- }
- /**
- * This function counts the chat last connections by course in x days
- * @param string Course code
- * @param int Last x days
- * @param int Session id (optional)
- * @return int Chat last connections by course in x days
- */
- public static function chat_connections_during_last_x_days_by_course($course_code, $last_days, $session_id = 0)
- {
- $course_info = api_get_course_info($course_code);
- if (empty($course_info)) {
- return null;
- }
- $course_id = $course_info['real_id'];
- //protect data
- $last_days = intval($last_days);
- $course_code = Database::escape_string($course_code);
- $session_id = intval($session_id);
- $tbl_stats_access = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_ACCESS);
- $sql = "SELECT count(*) FROM $tbl_stats_access WHERE DATE_SUB(NOW(),INTERVAL $last_days DAY) <= access_date
- AND access_cours_code = '$course_code' AND access_tool='".TOOL_CHAT."' AND access_session_id='$session_id' ";
- $result = Database::query($sql);
- if (Database::num_rows($result)) {
- $row = Database::fetch_row($result);
- $count = $row[0];
- return $count;
- } else {
- return null;
- }
- }
- /**
- * This function gets the last student's connection in chat
- * @param int Student id
- * @param string Course code
- * @param int Session id (optional)
- * @return string datetime formatted without day (e.g: February 23, 2010 10:20:50 )
- */
- public static function chat_last_connection($student_id, $course_code, $session_id = 0)
- {
- $student_id = intval($student_id);
- $course_code= Database::escape_string($course_code);
- $session_id = intval($session_id);
- $date_time = '';
- // table definition
- $tbl_stats_access = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_LASTACCESS);
- $sql = "SELECT access_date
- FROM $tbl_stats_access
- WHERE
- access_tool='".TOOL_CHAT."' AND
- access_user_id='$student_id' AND
- access_cours_code = '$course_code' AND
- access_session_id = '$session_id'
- ORDER BY access_date DESC limit 1";
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0) {
- $row = Database::fetch_array($rs);
- $date_time = api_convert_and_format_date($row['access_date'], null, date_default_timezone_get());
- }
- return $date_time;
- }
- /**
- * Get count student's visited links
- * @param int Student id
- * @param string Course code
- * @param int Session id (optional)
- * @return int count of visited links
- */
- public static function count_student_visited_links($student_id, $course_code, $session_id = 0)
- {
- // protect datas
- $student_id = intval($student_id);
- $course_code = Database::escape_string($course_code);
- $session_id = intval($session_id);
- // table definition
- $tbl_stats_links = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_LINKS);
- $sql = 'SELECT 1
- FROM '.$tbl_stats_links.'
- WHERE
- links_user_id= '.$student_id.' AND
- links_cours_id = "'.$course_code.'" AND
- links_session_id = '.$session_id.' ';
- $rs = Database::query($sql);
- return Database::num_rows($rs);
- }
- /**
- * Get count student downloaded documents
- * @param int Student id
- * @param string Course code
- * @param int Session id (optional)
- * @return int Count downloaded documents
- */
- public static function count_student_downloaded_documents($student_id, $course_code, $session_id = 0)
- {
- // protect datas
- $student_id = intval($student_id);
- $course_code = Database::escape_string($course_code);
- $session_id = intval($session_id);
- // table definition
- $tbl_stats_documents = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_DOWNLOADS);
- $sql = 'SELECT 1
- FROM ' . $tbl_stats_documents . '
- WHERE down_user_id = '.$student_id.'
- AND down_cours_id = "'.$course_code.'"
- AND down_session_id = '.$session_id.' ';
- $rs = Database::query($sql);
- return Database::num_rows($rs);
- }
- /**
- * Get course list inside a session from a student
- * @param int Student id
- * @param int Session id (optional)
- * @return array Courses list
- */
- public static function get_course_list_in_session_from_student($user_id, $id_session = 0)
- {
- $user_id = intval($user_id);
- $id_session = intval($id_session);
- $tbl_session_course_user = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $sql = 'SELECT course_code
- FROM ' . $tbl_session_course_user . '
- WHERE
- id_user="' . $user_id . '" AND
- id_session="' . $id_session . '"';
- $result = Database::query($sql);
- $a_courses = array ();
- while ($row = Database::fetch_array($result)) {
- $a_courses[$row['course_code']] = $row['course_code'];
- }
- return $a_courses;
- }
- /**
- * Get inactives students in course
- * @param string Course code
- * @param string Since login course date (optional, default = 'never')
- * @param int Session id (optional)
- * @return array Inactives users
- */
- public static function get_inactives_students_in_course($course_code, $since = 'never', $session_id=0)
- {
- $tbl_track_login = Database :: get_statistic_table(TABLE_STATISTIC_TRACK_E_COURSE_ACCESS);
- $tbl_session_course_user = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $table_course_rel_user = Database :: get_main_table(TABLE_MAIN_COURSE_USER);
- $inner = '';
- if ($session_id!=0) {
- $inner = ' INNER JOIN '.$tbl_session_course_user.' session_course_user
- ON stats_login.course_code = session_course_user.course_code
- AND session_course_user.id_session = '.intval($session_id).'
- AND session_course_user.id_user = stats_login.user_id ';
- }
- $sql = 'SELECT user_id, MAX(login_course_date) max_date FROM'.$tbl_track_login.' stats_login'.$inner.'
- GROUP BY user_id
- HAVING DATE_SUB( NOW(), INTERVAL '.$since.' DAY) > max_date ';
- //HAVING DATE_ADD(max_date, INTERVAL '.$since.' DAY) < NOW() ';
- if ($since == 'never') {
- $sql = 'SELECT course_user.user_id FROM '.$table_course_rel_user.' course_user
- LEFT JOIN '. $tbl_track_login.' stats_login
- ON course_user.user_id = stats_login.user_id AND relation_type<>'.COURSE_RELATION_TYPE_RRHH.' '.
- $inner.'
- WHERE course_user.course_code = \''.Database::escape_string($course_code).'\'
- AND stats_login.login_course_date IS NULL
- GROUP BY course_user.user_id';
- }
- $rs = Database::query($sql);
- $inactive_users = array();
- while($user = Database::fetch_array($rs)) {
- $inactive_users[] = $user['user_id'];
- }
- return $inactive_users;
- }
- /**
- * Get count login per student
- * @param int Student id
- * @param string Course code
- * @param int Session id (optional)
- * @return int count login
- */
- public static function count_login_per_student($student_id, $course_code, $session_id = 0)
- {
- $student_id = intval($student_id);
- $course_code = Database::escape_string($course_code);
- $session_id = intval($session_id);
- $tbl_course_rel_user = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_ACCESS);
- $sql = 'SELECT '.$student_id.'
- FROM ' . $tbl_course_rel_user . '
- WHERE access_user_id=' . $student_id . '
- AND access_cours_code="' . $course_code . '" AND access_session_id = "'.$session_id.'" ';
- $rs = Database::query($sql);
- $nb_login = Database::num_rows($rs);
- return $nb_login;
- }
- /**
- * Get students followed by a human resources manager
- * @param int Drh id
- * @return array Student list
- */
- public static function get_student_followed_by_drh($hr_dept_id)
- {
- $hr_dept_id = intval($hr_dept_id);
- $a_students = array();
- $tbl_user = Database :: get_main_table(TABLE_MAIN_USER);
- $sql = 'SELECT DISTINCT user_id FROM '.$tbl_user.' as user
- WHERE hr_dept_id='.$hr_dept_id;
- $rs = Database::query($sql);
- while($user = Database :: fetch_array($rs)) {
- $a_students[$user['user_id']] = $user['user_id'];
- }
- return $a_students;
- }
- /**
- * Gets the average of test and scorm inside a learning path
- * @param int User id
- * @param string Course id
- * @return float average of test
- * @author isaac flores paz
- * @deprecated get_avg_student_score should be use
- */
- public static function get_average_test_scorm_and_lp($user_id, $course_id)
- {
- //the score inside the Reporting table
- $course_info = api_get_course_info($course_id);
- $course_id = $course_info['real_id'];
- $lp_table = Database :: get_course_table(TABLE_LP_MAIN);
- $lp_view_table = Database :: get_course_table(TABLE_LP_VIEW);
- $lp_item_view_table = Database :: get_course_table(TABLE_LP_ITEM_VIEW);
- $lp_item_table = Database :: get_course_table(TABLE_LP_ITEM);
- $sql_type = "SELECT id, lp_type FROM $lp_table WHERE c_id = $course_id";
- $rs_type=Database::query($sql_type);
- $average_data=0;
- $count_loop=0;
- $average_data_sum = 0;
- $lp_list = array();
- while ($row_type = Database::fetch_array($rs_type)) {
- $lp_list[] = $row_type['id'];
- if ($row_type['lp_type']==1) {
- //lp chamilo
- $sql = "SELECT id FROM $lp_view_table WHERE c_id = $course_id AND user_id = '".intval($user_id)."' and lp_id='".$row_type['id']."'";
- $rs_last_lp_view_id = Database::query($sql);
- $lp_view_id = intval(Database::result($rs_last_lp_view_id,0,'id'));
- $sql_list_view="SELECT li.max_score,lv.user_id,liw.score,(liw.score/li.max_score) as sum_data
- FROM $lp_item_table li
- INNER JOIN $lp_view_table lv
- ON li.lp_id=lv.lp_id
- INNER JOIN $lp_item_view_table liw
- ON liw.lp_item_id=li.id
- WHERE li.c_id = $course_id AND
- liw.c_id = $course_id AND
- lv.c_id = $course_id AND
- lv.user_id= $user_id AND
- li.item_type = 'quiz' AND
- liw.lp_view_id= $lp_view_id";
- $sum=0;
- $tot=0;
- $rs_list_view1=Database::query($sql_list_view);
- while ($row_list_view=Database::fetch_array($rs_list_view1)) {
- $sum=$sum+$row_list_view['sum_data'];
- $tot++;
- }
- if ($tot==0) {
- $tot=1;
- }
- $average_data1=$sum/$tot;
- } elseif ($row_type['lp_type']==2) {
- //lp scorm
- $sql = "SELECT id FROM $lp_view_table
- WHERE c_id = $course_id AND user_id = '".intval($user_id)."' and lp_id='".$row_type['id']."'";
- $rs_last_lp_view_id = Database::query($sql);
- $lp_view_id = intval(Database::result($rs_last_lp_view_id,0,'id'));
- $sql_list_view = "SELECT li.max_score,lv.user_id,liw.score,((liw.score/li.max_score)*100) as sum_data
- FROM $lp_item_table li
- INNER JOIN $lp_view_table lv
- ON li.lp_id=lv.lp_id
- INNER JOIN $lp_item_view_table liw ON liw.lp_item_id=li.id
- WHERE li.c_id = $course_id AND
- liw.c_id = $course_id AND
- lv.c_id = $course_id AND
- lv.user_id= $user_id AND
- (li.item_type = 'sco' OR li.item_type='quiz') AND
- liw.lp_view_id = $lp_view_id";
- $tot=0;
- $sum=0;
- $rs_list_view2=Database::query($sql_list_view);
- while ($row_list_view=Database::fetch_array($rs_list_view2)) {
- $sum=$sum+$row_list_view['sum_data'];
- $tot++;
- }
- if ($tot==0) {
- $tot=1;
- }
- $average_data2=$sum/$tot;
- }
- $average_data_sum = $average_data_sum+$average_data1+$average_data2;
- $average_data2=0;
- $average_data1=0;
- $count_loop++;
- }
- //We only count the LP that have an exercise to get the average
- $lp_with_quiz = 0;
- foreach ($lp_list as $lp_id) {
- //check if LP have a score
- $sql = "SELECT count(id) as count FROM $lp_item_table
- WHERE c_id = $course_id AND item_type = 'quiz' AND lp_id = ".$lp_id." ";
- $result_have_quiz = Database::query($sql);
- if (Database::num_rows($result_have_quiz) > 0 ) {
- $row = Database::fetch_array($result_have_quiz,'ASSOC');
- if (is_numeric($row['count']) && $row['count'] != 0) {
- $lp_with_quiz++;
- }
- }
- }
- if ($lp_with_quiz > 0) {
- $avg_student_score = round(($average_data_sum / $lp_with_quiz * 100), 2);
- }
- return $avg_student_score;
- }
- /**
- * get count clicks about tools most used by course
- * @param string Course code
- * @param int Session id (optional), if param $session_id is null(default) it'll return results including sessions, 0 = session is not filtered
- * @return array tools data
- */
- public static function get_tools_most_used_by_course($course_code, $session_id = null)
- {
- //protect data
- $course_code = Database::escape_string($course_code);
- $data = array();
- $TABLETRACK_ACCESS = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_LASTACCESS);
- $condition_session = '';
- if (isset($session_id)) {
- $session_id = intval($session_id);
- $condition_session = ' AND access_session_id = '. $session_id;
- }
- $sql = "SELECT access_tool, COUNT(DISTINCT access_user_id),count( access_tool ) as count_access_tool
- FROM $TABLETRACK_ACCESS
- WHERE
- access_tool IS NOT NULL AND
- access_tool != '' AND
- access_cours_code = '$course_code'
- $condition_session
- GROUP BY access_tool
- ORDER BY count_access_tool DESC
- LIMIT 0, 3";
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0) {
- while ($row = Database::fetch_array($rs)) {
- $data[] = $row;
- }
- }
- return $data;
- }
- /**
- * Get total clicks
- * THIS FUNCTION IS NOT BEEN USED, IT WAS MEANT TO BE USE WITH track_e_course_access.date_from and track_e_course_access.date_to,
- * BUT NO ROW MATCH THE CONDITION, IT SHOULD BE FINE TO USE IT WHEN YOU USE USER DEFINED DATES AND NO CHAMILO DATES
- * @param int User Id
- * @param int Course Id
- * @param int Session Id (optional), if param $session_id is null(default) it'll return results including sessions, 0 = session is not filtered
- * @param string Date from
- * @param string Date to
- * @return array Data
- * @author César Perales cesar.perales@beeznest.com 2014-01-16
- */
- public static function get_total_clicks($userId, $courseId, $sessionId = 0, $date_from = '', $date_to = '')
- {
- $course = api_get_course_info_by_id($courseId);
- $tables = array(
- TABLE_STATISTIC_TRACK_E_LASTACCESS => array(
- 'course' => 'access_cours_code',
- 'session' => 'access_session_id',
- 'user' => 'access_user_id',
- 'start_date'=> 'access_date',
- ),
- TABLE_STATISTIC_TRACK_E_ACCESS => array(
- 'course' => 'access_cours_code',
- 'session' => 'access_session_id',
- 'user' => 'access_user_id',
- 'start_date'=> 'access_date',
- ),
- #TABLE_STATISTIC_TRACK_E_LOGIN, array(,, 'login_date', 'logout_date');
- TABLE_STATISTIC_TRACK_E_DOWNLOADS => array(
- 'course' => 'down_cours_id',
- 'session' => 'down_session_id',
- 'user' => 'down_user_id',
- 'start_date'=> 'down_date',
- ),
- TABLE_STATISTIC_TRACK_E_LINKS => array(
- 'course' => 'links_cours_id',
- 'session' => 'links_session_id',
- 'user' => 'links_user_id',
- 'start_date'=> 'links_date',
- ),
- TABLE_STATISTIC_TRACK_E_ONLINE => array(
- 'course' => 'course',
- 'session' => 'session_id',
- 'user' => 'login_user_id',
- 'start_date'=> 'login_date',
- ),
- #TABLE_STATISTIC_TRACK_E_HOTPOTATOES,
- /*TABLE_STATISTIC_TRACK_E_COURSE_ACCESS => array(
- 'course' => 'course_code',
- 'session' => 'session_id',
- 'user' => 'user_id',
- 'start_date'=> 'login_course_date',
- 'end_date' => 'logout_course_date',
- ),*/
- TABLE_STATISTIC_TRACK_E_EXERCICES => array(
- 'course' => 'exe_cours_id',
- 'session' => 'session_id',
- 'user' => 'exe_user_id',
- 'start_date'=> 'exe_date',
- ),
- TABLE_STATISTIC_TRACK_E_ATTEMPT => array(
- 'course' => 'course_code',
- 'session' => 'session_id',
- 'user' => 'user_id',
- 'start_date'=> 'tms',
- ),
- #TABLE_STATISTIC_TRACK_E_ATTEMPT_RECORDING,
- #TABLE_STATISTIC_TRACK_E_DEFAULT,
- TABLE_STATISTIC_TRACK_E_UPLOADS => array(
- 'course' => 'upload_cours_id',
- 'session' => 'upload_session_id',
- 'user' => 'upload_user_id',
- 'start_date'=> 'upload_date',
- ),
- #TABLE_STATISTIC_TRACK_E_HOTSPOT,
- #TABLE_STATISTIC_TRACK_E_ITEM_PROPERTY,
- #TABLE_STATISTIC_TRACK_E_OPEN,
- );
- $error_sql = '';
- foreach ($tables as $tableName => $fields) {
- //If session is defined, add it to query
- $where = '';
- if (isset($sessionId) && !empty($sessionId)) {
- $sessionField = $fields['session'];
- $where .= " AND $sessionField = $sessionId";
- }
- //filter by date
- if (!empty($date_from) && !empty($date_to)) {
- $fieldStartDate = $fields['start_date'];
- if (!isset($fields['end_date'])) {
- $where .= sprintf(" AND ($fieldStartDate BETWEEN '%s' AND '%s' )", $date_from, $date_to) ;
- } else {
- $fieldEndDate = $fields['end_date'];
- $where .= sprintf(" AND fieldStartDate >= '%s'
- AND $fieldEndDate <= '%s'", $date_from, $date_to);
- }
- }
- //query
- $sql = "SELECT %s as user, count(*) as total
- FROM %s
- WHERE %s = '%s'
- AND %s = %s
- $where
- GROUP BY %s";
- $sql = sprintf($sql,
- $fields['user'], //user field
- $tableName, //FROM
- $fields['course'], //course condition
- $course['code'], //course condition
- $fields['user'], //user condition
- $userId, //user condition
- $fields['user'] //GROUP BY
- );
- $rs = Database::query($sql);
- //iterate query
- if (Database::num_rows($rs) > 0) {
- while ($row = Database::fetch_array($rs)) {
- $data[$row['user']] = (isset($data[$row['user']])) ? $data[$row['user']] + $row[total]: $row['total'];
- }
- }
- }
- return $data;
- }
- /**
- * get documents most downloaded by course
- * @param string Course code
- * @param int Session id (optional), if param $session_id is null(default) it'll return results including sessions, 0 = session is not filtered
- * @param int Limit (optional, default = 0, 0 = without limit)
- * @return array documents downloaded
- */
- public static function get_documents_most_downloaded_by_course($course_code, $session_id = null, $limit = 0)
- {
- //protect data
- $course_code = Database::escape_string($course_code);
- $data = array();
- $TABLETRACK_DOWNLOADS = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_DOWNLOADS);
- $condition_session = '';
- if (isset($session_id)) {
- $session_id = intval($session_id);
- $condition_session = ' AND down_session_id = '. $session_id;
- }
- $sql = "SELECT down_doc_path, COUNT(DISTINCT down_user_id), COUNT(down_doc_path) as count_down
- FROM $TABLETRACK_DOWNLOADS
- WHERE down_cours_id = '$course_code'
- $condition_session
- GROUP BY down_doc_path
- ORDER BY count_down DESC
- LIMIT 0, $limit";
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0) {
- while ($row = Database::fetch_array($rs)) {
- $data[] = $row;
- }
- }
- return $data;
- }
- /**
- * get links most visited by course
- * @param string Course code
- * @param int Session id (optional), if param $session_id is null(default) it'll return results including sessions, 0 = session is not filtered
- * @return array links most visited
- */
- public static function get_links_most_visited_by_course($course_code, $session_id = null)
- {
- $course_code = Database::escape_string($course_code);
- $course_info = api_get_course_info($course_code);
- $course_id = $course_info['real_id'];
- $data = array();
- $TABLETRACK_LINKS = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_LINKS);
- $TABLECOURSE_LINKS = Database::get_course_table(TABLE_LINK);
- $condition_session = '';
- if (isset($session_id)) {
- $session_id = intval($session_id);
- $condition_session = ' AND cl.session_id = '.$session_id;
- }
- $sql = "SELECT cl.title, cl.url,count(DISTINCT sl.links_user_id), count(cl.title) as count_visits
- FROM $TABLETRACK_LINKS AS sl, $TABLECOURSE_LINKS AS cl
- WHERE cl.c_id = $course_id AND
- sl.links_link_id = cl.id
- AND sl.links_cours_id = '$course_code'
- $condition_session
- GROUP BY cl.title, cl.url
- ORDER BY count_visits DESC
- LIMIT 0, 3";
- $rs = Database::query($sql);
- if (Database::num_rows($rs) > 0) {
- while ($row = Database::fetch_array($rs)) {
- $data[] = $row;
- }
- }
- return $data;
- }
- /**
- * Shows the user progress (when clicking in the Progress tab)
- *
- * @param int $user_id
- * @param int $session_id
- * @param string $extra_params
- * @param bool $show_courses
- * @param bool $showAllSessions
- * @param bool $isSessionIndex Optional. If not comming from session index page then use api_get_self when show a link
- * @return string
- */
- public static function show_user_progress(
- $user_id,
- $session_id = 0,
- $extra_params = '',
- $show_courses = true,
- $showAllSessions = true,
- $isSessionIndex = true
- ) {
- $tbl_course = Database :: get_main_table(TABLE_MAIN_COURSE);
- $tbl_session = Database :: get_main_table(TABLE_MAIN_SESSION);
- $tbl_course_user = Database :: get_main_table(TABLE_MAIN_COURSE_USER);
- $tbl_access_rel_course = Database :: get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $tbl_session_course_user = Database :: get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tbl_access_rel_session = Database :: get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $user_id = intval($user_id);
- $session_id = intval($session_id);
- if (api_is_multiple_url_enabled()) {
- $sql = "SELECT cu.course_code as code, title
- FROM $tbl_course_user cu INNER JOIN $tbl_access_rel_course a
- ON (a.course_code = cu.course_code)
- INNER JOIN $tbl_course c ON (cu.course_code = c.code)
- WHERE
- user_id = $user_id AND
- relation_type<> ".COURSE_RELATION_TYPE_RRHH." AND
- access_url_id = ".api_get_current_access_url_id()."
- ORDER BY title";
- } else {
- $sql = "SELECT course_code as code, title
- FROM $tbl_course_user u
- INNER JOIN $tbl_course c ON (course_code = c.code)
- WHERE
- u.user_id= $user_id AND
- relation_type<>".COURSE_RELATION_TYPE_RRHH."
- ORDER BY title";
- }
- $rs = Database::query($sql);
- $courses = $course_in_session = $temp_course_in_session = array();
- while($row = Database :: fetch_array($rs, 'ASSOC')) {
- $courses[$row['code']] = $row['title'];
- }
- $orderBy = " ORDER BY name ";
- $extraInnerJoin = null;
- if (SessionManager::orderCourseIsEnabled() && !empty($session_id)) {
- $orderBy = " ORDER BY s.id, position ";
- $tableSessionRelCourse = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $extraInnerJoin = " INNER JOIN $tableSessionRelCourse src
- ON (cu.course_code = src.course_code AND src.id_session = $session_id) ";
- }
- $sessionCondition = '';
- if (!empty($session_id)) {
- $sessionCondition = " AND s.id = $session_id";
- }
- // Get the list of sessions where the user is subscribed as student
- if (api_is_multiple_url_enabled()) {
- $sql = "SELECT DISTINCT cu.course_code, s.id as session_id, name
- FROM $tbl_session_course_user cu
- INNER JOIN $tbl_access_rel_session a
- ON (a.session_id = cu.id_session)
- INNER JOIN $tbl_session s ON (s.id = a.session_id)
- $extraInnerJoin
- WHERE
- id_user = $user_id AND
- access_url_id = ".api_get_current_access_url_id()."
- $sessionCondition
- $orderBy ";
- } else {
- $sql = "SELECT DISTINCT cu.course_code, s.id as session_id, name
- FROM $tbl_session_course_user cu
- INNER JOIN $tbl_session s ON (s.id = cu.id_session)
- $extraInnerJoin
- WHERE id_user = $user_id
- $sessionCondition
- $orderBy ";
- }
- $rs = Database::query($sql);
- $simple_session_array = array();
- while ($row = Database :: fetch_array($rs)) {
- $course_info = CourseManager::get_course_information($row['course_code']);
- $temp_course_in_session[$row['session_id']]['course_list'][$course_info['id']] = $course_info;
- $temp_course_in_session[$row['session_id']]['name'] = $row['name'];
- $simple_session_array[$row['session_id']] = $row['name'];
- }
- foreach ($simple_session_array as $my_session_id => $session_name) {
- $course_list = $temp_course_in_session[$my_session_id]['course_list'];
- $my_course_data = array();
- foreach ($course_list as $course_data) {
- $my_course_data[$course_data['id']] = $course_data['title'];
- }
- if (!SessionManager::orderCourseIsEnabled() && empty($session_id)) {
- $my_course_data = utf8_sort($my_course_data);
- }
- $final_course_data = array();
- foreach($my_course_data as $course_id => $value) {
- $final_course_data[$course_id] = $course_list[$course_id];
- }
- $course_in_session[$my_session_id]['course_list'] = $final_course_data;
- $course_in_session[$my_session_id]['name'] = $session_name;
- }
- $html = '';
- // Course list
- if ($show_courses) {
- if (!empty($courses)) {
- $html .= Display::page_subheader(
- Display::return_icon(
- 'course.png',
- get_lang('MyCourses'),
- array(),
- ICON_SIZE_SMALL
- ).' '.get_lang('MyCourses')
- );
- $html .= '<table class="data_table" width="100%">';
- $html .= '<tr>
- '.Display::tag('th', get_lang('Course'), array('width'=>'300px')).'
- '.Display::tag('th', get_lang('TimeSpentInTheCourse'), array('class'=>'head')).'
- '.Display::tag('th', get_lang('Progress'), array('class'=>'head')).'
- '.Display::tag('th', get_lang('Score').Display::return_icon('info3.gif', get_lang('ScormAndLPTestTotalAverage'), array('align' => 'absmiddle', 'hspace' => '3px')),array('class'=>'head')).'
- '.Display::tag('th', get_lang('LastConnexion'), array('class'=>'head')).'
- '.Display::tag('th', get_lang('Details'), array('class'=>'head')).'
- </tr>';
- foreach ($courses as $course_code => $course_title) {
- $total_time_login = Tracking :: get_time_spent_on_the_course(
- $user_id,
- $course_code
- );
- $time = api_time_to_hms($total_time_login);
- $progress = Tracking :: get_avg_student_progress(
- $user_id,
- $course_code
- );
- $percentage_score = Tracking :: get_avg_student_score(
- $user_id,
- $course_code,
- array()
- );
- $last_connection = Tracking :: get_last_connection_date_on_the_course(
- $user_id,
- $course_code
- );
- if (is_null($progress)) {
- $progress = '0%';
- } else {
- $progress = $progress.'%';
- }
- if ($course_code == $_GET['course'] && empty($_GET['session_id'])) {
- $html .= '<tr class="row_odd" style="background-color:#FBF09D">';
- } else {
- $html .= '<tr class="row_even">';
- }
- $url = api_get_course_url($course_code, $session_id);
- $course_url = Display::url($course_title, $url, array('target'=>SESSION_LINK_TARGET));
- $html .= '<td>'.$course_url.'</td>';
- $html .= '<td align="center">'.$time.'</td>';
- $html .= '<td align="center">'.$progress.'</td>';
- $html .= '<td align="center">';
- if (is_numeric($percentage_score)) {
- $html .= $percentage_score.'%';
- } else {
- $html .= '0%';
- }
- $html .= '</td>';
- $html .= '<td align="center">'.$last_connection.'</td>';
- $html .= '<td align="center">';
- if ($course_code == $_GET['course'] && empty($_GET['session_id'])) {
- $html .= '<a href="#">';
- $html .= Display::return_icon('2rightarrow_na.gif', get_lang('Details'));
- } else {
- $html .= '<a href="'.api_get_self().'?course='.$course_code.$extra_params.'">';
- $html .= Display::return_icon('2rightarrow.gif', get_lang('Details'));
- }
- $html .= '</a>';
- $html .= '</td></tr>';
- }
- $html .= '</table>';
- }
- }
- // Session list
- if (!empty($course_in_session)) {
- $main_session_graph = '';
- //Load graphics only when calling to an specific session
- $session_graph = array();
- $all_exercise_graph_name_list = array();
- $my_results = array();
- $all_exercise_graph_list = array();
- $all_exercise_start_time = array();
- foreach ($course_in_session as $my_session_id => $session_data) {
- $course_list = $session_data['course_list'];
- $session_name = $session_data['name'];
- $user_count = count(SessionManager::get_users_by_session($my_session_id));
- $exercise_graph_name_list = array();
- //$user_results = array();
- $exercise_graph_list = array();
- foreach ($course_list as $course_data) {
- $exercise_list = get_all_exercises(
- $course_data,
- $my_session_id,
- false,
- null,
- false,
- 1
- );
- foreach ($exercise_list as $exercise_data) {
- $exercise_obj = new Exercise($course_data['id']);
- $exercise_obj->read($exercise_data['id']);
- //Exercise is not necessary to be visible to show results check the result_disable configuration instead
- //$visible_return = $exercise_obj->is_visible();
- if ($exercise_data['results_disabled'] == 0 ||
- $exercise_data['results_disabled'] == 2
- ) {
- $best_average = intval(
- get_best_average_score_by_exercise(
- $exercise_data['id'],
- $course_data['code'],
- $my_session_id,
- $user_count
- )
- );
- $exercise_graph_list[] = $best_average;
- $all_exercise_graph_list[] = $best_average;
- $user_result_data = get_best_attempt_by_user(
- api_get_user_id(),
- $exercise_data['id'],
- $course_data['code'],
- $my_session_id
- );
- $score = 0;
- if (!empty($user_result_data['exe_weighting']) &&
- intval($user_result_data['exe_weighting']) != 0
- ) {
- $score = intval($user_result_data['exe_result']/$user_result_data['exe_weighting'] * 100);
- }
- $time = api_strtotime($exercise_data['start_time']) ? api_strtotime($exercise_data['start_time'], 'UTC') : 0;
- $all_exercise_start_time[] = $time;
- $my_results[] = $score;
- if (count($exercise_list)<=10) {
- $title = cut($course_data['title'], 30)." \n ".cut($exercise_data['title'], 30);
- $exercise_graph_name_list[]= $title;
- $all_exercise_graph_name_list[] = $title;
- } else {
- // if there are more than 10 results, space becomes
- // difficult to find, so only show the title of the exercise, not the tool
- $title = cut($exercise_data['title'], 30);
- $exercise_graph_name_list[]= $title;
- $all_exercise_graph_name_list[]= $title;
- }
- }
- }
- }
- }
- // Complete graph
- if (!empty($my_results) && !empty($all_exercise_graph_list)) {
- asort($all_exercise_start_time);
- //Fix exams order
- $final_all_exercise_graph_name_list = array();
- $my_results_final = array();
- $final_all_exercise_graph_list = array();
- foreach ($all_exercise_start_time as $key => $time) {
- $label_time = '';
- if (!empty($time)) {
- $label_time = date('d-m-y', $time);
- }
- $final_all_exercise_graph_name_list[] = $all_exercise_graph_name_list[$key].' '.$label_time;
- $my_results_final[] = $my_results[$key];
- $final_all_exercise_graph_list[] = $all_exercise_graph_list[$key];
- }
- $main_session_graph = self::generate_session_exercise_graph(
- $final_all_exercise_graph_name_list,
- $my_results_final,
- $final_all_exercise_graph_list
- );
- }
- $html .= Display::page_subheader(
- Display::return_icon(
- 'session.png',
- get_lang('Sessions'),
- array(),
- ICON_SIZE_SMALL
- ).' '.get_lang('Sessions')
- );
- $html .= '<table class="data_table" width="100%">';
- $html .= '<tr>
- '.Display::tag('th', get_lang('Session'), array('width'=>'300px')).'
- '.Display::tag('th', get_lang('PublishedExercises'), array('width'=>'300px')).'
- '.Display::tag('th', get_lang('NewExercises'), array('class'=>'head')).'
- '.Display::tag('th', get_lang('AverageExerciseResult'), array('class'=>'head')).'
- '.Display::tag('th', get_lang('Details'), array('class'=>'head')).'
- </tr>';
- foreach ($course_in_session as $my_session_id => $session_data) {
- $course_list = $session_data['course_list'];
- $session_name = $session_data['name'];
- if ($showAllSessions == false) {
- if (isset($session_id) && !empty($session_id)) {
- if ($session_id != $my_session_id) {
- continue;
- }
- }
- }
- $all_exercises = 0;
- $all_unanswered_exercises_by_user = 0;
- $all_average = 0;
- $stats_array = array();
- foreach ($course_list as $course_data) {
- //All exercises in the course @todo change for a real count
- $exercises = get_all_exercises($course_data, $my_session_id);
- $count_exercises = 0;
- if (is_array($exercises) && !empty($exercises)) {
- $count_exercises = count($exercises);
- }
- //Count of user results
- //$done_exercises = get_count_exercises_attempted_by_course($course_data['code'], $my_session_id);
- $done_exercises = null;
- $answered_exercises = 0;
- if (!empty($exercises)) {
- foreach($exercises as $exercise_item) {
- $attempts = count_exercise_attempts_by_user(
- api_get_user_id(),
- $exercise_item['id'],
- $course_data['code'],
- $my_session_id
- );
- if ($attempts > 1) {
- $answered_exercises++;
- }
- }
- }
- // Average
- $average = get_average_score_by_course($course_data['code'], $my_session_id);
- $all_exercises += $count_exercises;
- $all_unanswered_exercises_by_user += $count_exercises - $answered_exercises;
- //$all_done_exercise += $done_exercises;
- $all_average += $average;
- }
- $all_average = $all_average / count($course_list);
- if (isset($_GET['session_id']) && $my_session_id == $_GET['session_id']) {
- $html .= '<tr style="background-color:#FBF09D">';
- } else {
- $html .= '<tr>';
- }
- $url = api_get_path(WEB_CODE_PATH)."session/index.php?session_id={$my_session_id}";
- $html .= Display::tag('td', Display::url($session_name, $url, array('target'=>SESSION_LINK_TARGET)));
- $html .= Display::tag('td', $all_exercises);
- $html .= Display::tag('td', $all_unanswered_exercises_by_user);
- //$html .= Display::tag('td', $all_done_exercise);
- $html .= Display::tag('td', convert_to_percentage($all_average));
- if (isset($_GET['session_id']) && $my_session_id == $_GET['session_id']) {
- $icon = Display::url(Display::return_icon('2rightarrow_na.gif', get_lang('Details')), '?session_id='.$my_session_id);
- } else {
- $icon = Display::url(Display::return_icon('2rightarrow.gif', get_lang('Details')), '?session_id='.$my_session_id);
- }
- $html .= Display::tag('td', $icon);
- $html .= '</tr>';
- }
- $html .= '</table><br />';
- $html .= Display::div(
- $main_session_graph,
- array(
- 'id' => 'session_graph',
- 'class' => 'chart-session',
- 'style' => 'position:relative; text-align: center;',
- )
- );
- // Checking selected session.
- if (isset($_GET['session_id'])) {
- $session_id_from_get = intval($_GET['session_id']);
- $session_data = $course_in_session[$session_id_from_get];
- $course_list = $session_data['course_list'];
- $html .= Display::tag('h3',$session_data['name'].' - '.get_lang('CourseList'));
- $html .= '<table class="data_table" width="100%">';
- //'.Display::tag('th', get_lang('DoneExercises'), array('class'=>'head')).'
- $html .= '
- <tr>
- <th width="300px">'.get_lang('Course').'</th>
- '.Display::tag('th', get_lang('PublishedExercises'), array('class'=>'head')).'
- '.Display::tag('th', get_lang('NewExercises'), array('class'=>'head')).'
- '.Display::tag('th', get_lang('MyAverage'), array('class'=>'head')).'
- '.Display::tag('th', get_lang('AverageExerciseResult'), array('class'=>'head')).'
- '.Display::tag('th', get_lang('TimeSpentInTheCourse'), array('class'=>'head')).'
- '.Display::tag('th', get_lang('LPProgress') , array('class'=>'head')).'
- '.Display::tag('th', get_lang('Score').Display::return_icon('info3.gif', get_lang('ScormAndLPTestTotalAverage'), array ('align' => 'absmiddle', 'hspace' => '3px')), array('class'=>'head')).'
- '.Display::tag('th', get_lang('LastConnexion'), array('class'=>'head')).'
- '.Display::tag('th', get_lang('Details'), array('class'=>'head')).'
- </tr>';
- foreach ($course_list as $course_data) {
- $course_code = $course_data['code'];
- $course_title = $course_data['title'];
- //All exercises in the course @todo change for a real count
- $exercises = get_all_exercises($course_data, $session_id_from_get);
- $count_exercises = 0;
- if (!empty($exercises)) {
- $count_exercises = count($exercises);
- }
- //Count of user results
- //$done_exercises = get_best_exercise_results_by_course($course_code, $session_id_from_get);
- //From course exercises NOT from LP exercises!!!
- //$done_exercises = get_count_exercises_attempted_by_course($course_code, $session_id_from_get);
- $answered_exercises = 0;
- foreach ($exercises as $exercise_item) {
- $attempts = count_exercise_attempts_by_user(
- api_get_user_id(),
- $exercise_item['id'],
- $course_code,
- $session_id_from_get
- );
- if ($attempts > 1) {
- $answered_exercises++;
- }
- }
- $unanswered_exercises = $count_exercises - $answered_exercises;
- // Average
- $average = get_average_score_by_course(
- $course_code,
- $session_id_from_get
- );
- $my_average = get_average_score_by_course_by_user(
- api_get_user_id(),
- $course_code,
- $session_id_from_get
- );
- $stats_array[$course_code] = array(
- 'exercises' => $count_exercises,
- 'unanswered_exercises_by_user' => $unanswered_exercises,
- 'done_exercises' => $done_exercises,
- 'average' => $average,
- 'my_average' => $my_average,
- );
- $weighting = 0;
- $last_connection = Tracking :: get_last_connection_date_on_the_course($user_id, $course_code, $session_id_from_get);
- $progress = Tracking :: get_avg_student_progress($user_id, $course_code,array(), $session_id_from_get);
- $total_time_login = Tracking :: get_time_spent_on_the_course($user_id, $course_code, $session_id_from_get);
- $time = api_time_to_hms($total_time_login);
- $percentage_score = Tracking :: get_avg_student_score($user_id, $course_code, array(), $session_id_from_get);
- $courseCodeFromGet = isset($_GET['course']) ? $_GET['course'] : null;
- if ($course_code == $courseCodeFromGet && $_GET['session_id'] == $session_id_from_get) {
- $html .= '<tr class="row_odd" style="background-color:#FBF09D" >';
- } else {
- $html .= '<tr class="row_even">';
- }
- $url = api_get_course_url($course_code, $session_id_from_get);
- $course_url = Display::url($course_title, $url, array('target'=>SESSION_LINK_TARGET));
- $html .= Display::tag('td', $course_url);
- $html .= Display::tag('td', $stats_array[$course_code]['exercises']);
- $html .= Display::tag('td', $stats_array[$course_code]['unanswered_exercises_by_user']);
- //$html .= Display::tag('td', $stats_array[$course_code]['done_exercises']);
- $html .= Display::tag('td', convert_to_percentage($stats_array[$course_code]['my_average']));
- $html .= Display::tag('td', $stats_array[$course_code]['average'] == 0 ? '-' : '('.convert_to_percentage($stats_array[$course_code]['average']).')');
- $html .= Display::tag('td', $time, array('align'=>'center'));
- if (is_numeric($progress)) {
- $progress = $progress.'%';
- } else {
- $progress = '0%';
- }
- //Progress
- $html .= Display::tag('td', $progress, array('align'=>'center'));
- if (is_numeric($percentage_score)) {
- $percentage_score = $percentage_score.'%';
- } else {
- $percentage_score = '0%';
- }
- //Score
- $html .= Display::tag('td', $percentage_score, array('align'=>'center'));
- $html .= Display::tag('td', $last_connection, array('align'=>'center'));
- if ($course_code == $courseCodeFromGet && $_GET['session_id'] == $session_id_from_get) {
- $details = '<a href="#">';
- $details .=Display::return_icon('2rightarrow_na.gif', get_lang('Details'));
- } else {
- $url = !$isSessionIndex ? api_get_self() : api_get_path(WEB_CODE_PATH) . 'session/index.php';
- $details = '<a href="' . $url . '?course='.$course_code.'&session_id='.$session_id_from_get.$extra_params.'">';
- $details .= Display::return_icon('2rightarrow.gif', get_lang('Details'));
- }
- $details .= '</a>';
- $html .= Display::tag('td', $details, array('align'=>'center'));
- $html .= '</tr>';
- }
- $html .= '</table>';
- }
- }
- return $html;
- }
- /**
- * Shows the user detail progress (when clicking in the details link)
- * @param int user id
- * @param string course code
- * @param int session id
- * @return string html code
- */
- static function show_course_detail($user_id, $course_code, $session_id)
- {
- $html = '';
- if (isset($course_code)) {
- $user_id = intval($user_id);
- $session_id = intval($session_id);
- $course = Database::escape_string($course_code);
- $course_info = CourseManager::get_course_information($course);
- //$course_id = $course_info['real_id'];
- //$session_name = api_get_session_name($session_id);
- $html .= Display::page_subheader($course_info['title']);
- $html .= '<table class="data_table" width="100%">';
- //Course details
- $html .= '
- <tr>
- <th class="head" style="color:#000">'.get_lang('Exercices').'</th>
- <th class="head" style="color:#000">'.get_lang('Attempts').'</th>
- <th class="head" style="color:#000">'.get_lang('BestAttempt').'</th>
- <th class="head" style="color:#000">'.get_lang('Ranking').'</th>
- <th class="head" style="color:#000">'.get_lang('BestResultInCourse').'</th>
- <th class="head" style="color:#000">'.get_lang('Statistics').' '.Display :: return_icon('info3.gif', get_lang('OnlyBestResultsPerStudent'), array('align' => 'absmiddle', 'hspace' => '3px')).'</th>
- </tr>';
- if (empty($session_id)) {
- $user_list = CourseManager::get_user_list_from_course_code($course, $session_id, null, null, STUDENT);
- } else {
- $user_list = CourseManager::get_user_list_from_course_code($course, $session_id, null, null, 0);
- }
- //$exercise_list = get_all_exercises($course_info, $session_id, true);
- // Show exercise results of invisible exercises? see BT#4091
- $exercise_list = get_all_exercises(
- $course_info,
- $session_id,
- false,
- null,
- false,
- 1
- );
- $to_graph_exercise_result = array();
- if (!empty($exercise_list)) {
- $score = $weighting = $exe_id = 0;
- foreach ($exercise_list as $exercices) {
- $exercise_obj = new Exercise($course_info['real_id']);
- $exercise_obj->read($exercices['id']);
- $visible_return = $exercise_obj->is_visible();
- $score = $weighting = $attempts = 0;
- //Getting count of attempts by user
- $attempts = count_exercise_attempts_by_user(api_get_user_id(), $exercices['id'], $course_info['code'], $session_id);
- $html .= '<tr class="row_even">';
- $url = api_get_path(WEB_CODE_PATH)."exercice/overview.php?cidReq={$course_info['code']}&id_session=$session_id&exerciseId={$exercices['id']}";
- if ($visible_return['value'] == true) {
- $exercices['title'] = Display::url($exercices['title'], $url, array('target'=>SESSION_LINK_TARGET));
- }
- $html .= Display::tag('td', $exercices['title']);
- //Exercise configuration show results or show only score
- if ($exercices['results_disabled'] == 0 || $exercices['results_disabled'] == 2) {
- //For graphics
- $best_exercise_stats = get_best_exercise_results_by_user($exercices['id'], $course_info['code'], $session_id);
- $to_graph_exercise_result[$exercices['id']] = array('title'=>$exercices['title'], 'data'=>$best_exercise_stats);
- $latest_attempt_url = '';
- $best_score = $position = $percentage_score_result = '-';
- $graph = $normal_graph = null;
- //Getting best results
- $best_score_data = get_best_attempt_in_course($exercices['id'], $course_info['code'], $session_id);
- $best_score = show_score($best_score_data['exe_result'], $best_score_data['exe_weighting']);
- if ($attempts > 0) {
- $exercise_stat = get_best_attempt_by_user(api_get_user_id(), $exercices['id'], $course_info['code'], $session_id);
- if (!empty($exercise_stat)) {
- //Always getting the BEST attempt
- $score = $exercise_stat['exe_result'];
- $weighting = $exercise_stat['exe_weighting'];
- $exe_id = $exercise_stat['exe_id'];
- $latest_attempt_url .= api_get_path(WEB_CODE_PATH).'exercice/result.php?id='.$exe_id.'&cidReq='.$course_info['code'].'&show_headers=1&id_session='.$session_id;
- $percentage_score_result = Display::url(show_score($score, $weighting), $latest_attempt_url);
- $my_score = 0;
- if (!empty($weighting) && intval($weighting) != 0) {
- $my_score = $score/$weighting;
- }
- //@todo this function slows the page
- $position = get_exercise_result_ranking($my_score, $exe_id, $exercices['id'], $course_info['code'], $session_id, $user_list);
- $graph = self::generate_exercise_result_thumbnail_graph($to_graph_exercise_result[$exercices['id']]);
- $normal_graph = self::generate_exercise_result_graph($to_graph_exercise_result[$exercices['id']]);
- }
- }
- $html .= Display::div($normal_graph, array('id'=>'main_graph_'.$exercices['id'],'class'=>'dialog', 'style'=>'display:none') );
- if (empty($graph)) {
- $graph = '-';
- } else {
- $graph = Display::url($graph, '#', array('id'=>$exercices['id'], 'class'=>'opener'));
- }
- $html .= Display::tag('td', $attempts, array('align'=>'center'));
- $html .= Display::tag('td', $percentage_score_result, array('align'=>'center'));
- $html .= Display::tag('td', $position, array('align'=>'center'));
- $html .= Display::tag('td', $best_score, array('align'=>'center'));
- $html .= Display::tag('td', $graph, array('align'=>'center'));
- //$html .= Display::tag('td', $latest_attempt_url, array('align'=>'center', 'width'=>'25'));
- } else {
- // Exercise configuration NO results
- $html .= Display::tag('td', $attempts, array('align'=>'center'));
- $html .= Display::tag('td', '-', array('align'=>'center'));
- $html .= Display::tag('td', '-', array('align'=>'center'));
- $html .= Display::tag('td', '-', array('align'=>'center'));
- $html .= Display::tag('td', '-', array('align'=>'center'));
- }
- $html .= '</tr>';
- }
- } else {
- $html .= '<tr><td colspan="5" align="center">'.get_lang('NoEx').'</td></tr>';
- }
- $html .= '</table>';
- //LP table results
- $html .='<table class="data_table">';
- $html .= Display::tag('th', get_lang('Learnpaths'), array('class'=>'head', 'style'=>'color:#000'));
- $html .= Display::tag('th', get_lang('LatencyTimeSpent'), array('class'=>'head', 'style'=>'color:#000'));
- $html .= Display::tag('th', get_lang('Progress'), array('class'=>'head', 'style'=>'color:#000'));
- $html .= Display::tag('th', get_lang('Score'), array('class'=>'head', 'style'=>'color:#000'));
- $html .= Display::tag('th', get_lang('LastConnexion'), array('class'=>'head', 'style'=>'color:#000'));
- $html .= '</tr>';
- $list = new LearnpathList(api_get_user_id(), $course_info['code'], $session_id, 'publicated_on ASC', true);
- $lp_list = $list->get_flat_list();
- if (!empty($lp_list) > 0) {
- foreach($lp_list as $lp_id => $learnpath) {
- $progress = Tracking::get_avg_student_progress($user_id, $course, array($lp_id), $session_id);
- $last_connection_in_lp = Tracking::get_last_connection_time_in_lp($user_id, $course, $lp_id, $session_id);
- $time_spent_in_lp = Tracking::get_time_spent_in_lp($user_id, $course, array($lp_id), $session_id);
- $percentage_score = Tracking::get_avg_student_score($user_id, $course, array($lp_id), $session_id);
- if (is_numeric($percentage_score)) {
- $percentage_score = $percentage_score.'%';
- } else {
- $percentage_score = '0%';
- }
- $time_spent_in_lp = api_time_to_hms($time_spent_in_lp);
- $html .= '<tr class="row_even">';
- $url = api_get_path(WEB_CODE_PATH)."newscorm/lp_controller.php?cidReq={$course_code}&id_session=$session_id&lp_id=$lp_id&action=view";
- $html .= Display::tag('td', Display::url($learnpath['lp_name'], $url, array('target'=>SESSION_LINK_TARGET)));
- $html .= Display::tag('td', $time_spent_in_lp, array('align'=>'center'));
- if (is_numeric($progress)) {
- $progress = $progress.'%';
- }
- $html .= Display::tag('td', $progress, array('align'=>'center'));
- $html .= Display::tag('td', $percentage_score);
- $last_connection = '-';
- if (!empty($last_connection_in_lp)) {
- $last_connection = api_convert_and_format_date($last_connection_in_lp, DATE_TIME_FORMAT_LONG);
- }
- $html .= Display::tag('td', $last_connection, array('align'=>'center','width'=>'180px'));
- $html .= "</tr>";
- }
- } else {
- $html .= '<tr>
- <td colspan="4" align="center">
- '.get_lang('NoLearnpath').'
- </td>
- </tr>';
- }
- $html .='</table>';
- }
- return $html;
- }
- /**
- * Generates an histogram
- *
- * @param array list of exercise names
- * @param array my results 0 to 100
- * @param array average scores 0-100
- */
- static function generate_session_exercise_graph($names, $my_results, $average)
- {
- require_once api_get_path(LIBRARY_PATH).'pchart/pData.class.php';
- require_once api_get_path(LIBRARY_PATH).'pchart/pChart.class.php';
- require_once api_get_path(LIBRARY_PATH).'pchart/pCache.class.php';
- $cache = new pCache();
- // Dataset definition
- $data_set = new pData();
- // Dataset definition
- $data_set->AddPoint($average, "Serie1");
- $data_set->AddPoint($my_results, "Serie2");
- $data_set->AddPoint($names, "Serie3");
- $data_set->AddAllSeries();
- $data_set->SetAbsciseLabelSerie('Serie3');
- $data_set->SetSerieName(get_lang('AverageScore'),"Serie1");
- $data_set->SetSerieName(get_lang('MyResults'), "Serie2");
- //$data_set->SetYAxisName(get_lang("Percentage"));
- $data_set->SetYAxisUnit("%");
- // Initialise the graph
- $main_width = 860;
- $main_height = 500;
- $y_label_angle = 50;
- $data_set->RemoveSerie("Serie3");
- $graph = new pChart($main_width, $main_height);
- //See 3.2 BT#2797
- $graph->setFixedScale(0,100);
- $graph->setFontProperties(api_get_path(LIBRARY_PATH).'pchart/fonts/tahoma.ttf',8);
- $graph->setGraphArea(65,50,$main_width-20, $main_height-140);
- $graph->drawFilledRoundedRectangle(7,7,$main_width-7,$main_height-7,5,240,240,240);
- $graph->drawRoundedRectangle(5,5,$main_width-5,$main_height -5,5,230,230,230);
- $graph->drawGraphArea(255,255,255,TRUE);
- //SCALE_NORMAL, SCALE_START0, SCALE_ADDALLSTART0, SCALE_ADDALL
- $graph->drawScale($data_set->GetData(),$data_set->GetDataDescription(),SCALE_NORMAL ,150,150,150,TRUE,$y_label_angle,1, TRUE);
- $graph->drawGrid(4,TRUE,230,230,230,70);
- // Draw the 0 line
- $graph->setFontProperties(api_get_path(LIBRARY_PATH).'pchart/fonts/tahoma.ttf',6);
- $graph->drawTreshold(0,143,55,72,TRUE,TRUE);
- // Draw the cubic curve graph
- $graph->drawLineGraph($data_set->GetData(),$data_set->GetDataDescription());
- $graph->drawPlotGraph($data_set->GetData(),$data_set->GetDataDescription(),1,1,230,255,255);
- // Finish the graph
- $graph->setFontProperties(api_get_path(LIBRARY_PATH).'pchart/fonts/tahoma.ttf',10);
- $graph->drawLegend($main_width - 150,70,$data_set->GetDataDescription(),255,255,255);
- $graph->setFontProperties(api_get_path(LIBRARY_PATH).'pchart/fonts/tahoma.ttf',11);
- $graph->drawTitle(50, 30, get_lang('ExercisesInTimeProgressChart'), 50,50,50,$main_width-110, true);
- // $main_graph = new pChart($main_width,$main_height);
- $courseCode = isset($_GET['course']) ? Security::remove_XSS($_GET['course']) : null;
- $graph_id = 'generate_session_exercise_graph'.$courseCode.'-'.intval($_GET['session_id']).'-'.api_get_user_id();
- if ($cache->IsInCache($graph_id, $data_set->GetData())) {
- //if (0) {
- //if we already created the img
- //echo 'in cache';
- $img_file = $cache->GetHash($graph_id,$data_set->GetData());
- } else {
- $cache->WriteToCache($graph_id, $data_set->GetData(), $graph);
- ob_start();
- $graph->Stroke();
- ob_end_clean();
- $img_file = $cache->GetHash($graph_id, $data_set->GetData());
- }
- $html = '<img src="'.api_get_path(WEB_ARCHIVE_PATH).$img_file.'">';
- return $html;
- }
- /**
- *
- * Returns a thumbnail of the function generate_exercise_result_graph
- * @param array attempts
- */
- static function generate_exercise_result_thumbnail_graph($attempts)
- {
- require_once api_get_path(LIBRARY_PATH).'pchart/pData.class.php';
- require_once api_get_path(LIBRARY_PATH).'pchart/pChart.class.php';
- require_once api_get_path(LIBRARY_PATH).'pchart/pCache.class.php';
- $exercise_title = $attempts['title'];
- $attempts = $attempts['data'];
- $my_exercise_result_array = $exercise_result = array();
- if (empty($attempts)) {
- return null;
- }
- foreach ($attempts as $attempt) {
- if (api_get_user_id() == $attempt['exe_user_id']) {
- if ($attempt['exe_weighting'] != 0 ) {
- $my_exercise_result_array[]= $attempt['exe_result']/$attempt['exe_weighting'];
- }
- } else {
- if ($attempt['exe_weighting'] != 0 ) {
- $exercise_result[]= $attempt['exe_result']/$attempt['exe_weighting'];
- }
- }
- }
- //Getting best result
- rsort($my_exercise_result_array);
- $my_exercise_result = 0;
- if (isset($my_exercise_result_array[0])) {
- $my_exercise_result = $my_exercise_result_array[0] *100;
- }
- $max = 100;
- $pieces = 5 ;
- $part = round($max / $pieces);
- $x_axis = array();
- $final_array = array();
- $my_final_array = array();
- for ($i=1; $i <=$pieces; $i++) {
- $sum = 1;
- if ($i == 1) {
- $sum = 0;
- }
- $min = ($i-1)*$part + $sum;
- $max = ($i)*$part;
- $x_axis[]= $min." - ".$max;
- $count = 0;
- foreach($exercise_result as $result) {
- $percentage = $result*100;
- //echo $percentage.' - '.$min.' - '.$max."<br />";
- if ($percentage >= $min && $percentage <= $max) {
- //echo ' is > ';
- $count++;
- }
- }
- //echo '<br />';
- $final_array[]= $count;
- if ($my_exercise_result >= $min && $my_exercise_result <= $max) {
- $my_final_array[] = 1;
- } else {
- $my_final_array[] = 0;
- }
- }
- //Fix to remove the data of the user with my data
- for($i = 0; $i<=count($my_final_array); $i++) {
- if (!empty($my_final_array[$i])) {
- $my_final_array[$i] = $final_array[$i] + 1; //Add my result
- $final_array[$i] = 0;
- }
- }
- $cache = new pCache();
- // Dataset definition
- $data_set = new pData();
- $data_set->AddPoint($final_array,"Serie1");
- $data_set->AddPoint($my_final_array,"Serie2");
- //$data_set->AddPoint($x_axis,"Serie3");
- $data_set->AddAllSeries();
- // Initialise the graph
- $main_width = 80;
- $main_height = 35;
- $thumbnail_graph = new pChart($main_width, $main_height);
- $thumbnail_graph->setFontProperties(api_get_path(LIBRARY_PATH).'pchart/fonts/tahoma.ttf',8);
- //$thumbnail_graph->setGraphArea(50,30,680,200);
- $thumbnail_graph->drawFilledRoundedRectangle(2,2,$main_width-2,$main_height-2,2,230,230,230);
- $thumbnail_graph->setGraphArea(5,5,$main_width-5,$main_height-5);
- $thumbnail_graph->drawGraphArea(255,255,255);
- //SCALE_NORMAL, SCALE_START0, SCALE_ADDALLSTART0
- $thumbnail_graph->drawScale($data_set->GetData(),$data_set->GetDataDescription(),SCALE_ADDALLSTART0, 150,150,150,FALSE,0,1,TRUE);
- $thumbnail_graph->drawOverlayBarGraph($data_set->GetData(),$data_set->GetDataDescription(), 100);
- // Finish the graph
- $graph_id = 'thumbnail_exercise_result_graph_'.Security::remove_XSS($_GET['course']).'-'.intval($_GET['session_id']).'-'.api_get_user_id();
- if ($cache->IsInCache($graph_id, $data_set->GetData())) {
- //if (0) {
- //if we already created the img
- //echo 'in cache';
- $img_file = $cache->GetHash($graph_id,$data_set->GetData());
- } else {
- $cache->WriteToCache($graph_id, $data_set->GetData(), $thumbnail_graph);
- ob_start();
- $thumbnail_graph->Stroke();
- ob_end_clean();
- $img_file = $cache->GetHash($graph_id, $data_set->GetData());
- }
- $html = '<img src="'.api_get_path(WEB_ARCHIVE_PATH).$img_file.'">';
- return $html;
- }
- /**
- * Generates a big graph with the number of best results
- * @param array
- */
- static function generate_exercise_result_graph($attempts)
- {
- require_once api_get_path(LIBRARY_PATH).'pchart/pData.class.php';
- require_once api_get_path(LIBRARY_PATH).'pchart/pChart.class.php';
- require_once api_get_path(LIBRARY_PATH).'pchart/pCache.class.php';
- $exercise_title = strip_tags($attempts['title']);
- $attempts = $attempts['data'];
- $my_exercise_result_array = $exercise_result = array();
- if (empty($attempts)) {
- return null;
- }
- foreach ($attempts as $attempt) {
- if (api_get_user_id() == $attempt['exe_user_id']) {
- if ($attempt['exe_weighting'] != 0 ) {
- $my_exercise_result_array[]= $attempt['exe_result']/$attempt['exe_weighting'];
- }
- } else {
- if ($attempt['exe_weighting'] != 0 ) {
- $exercise_result[]= $attempt['exe_result']/$attempt['exe_weighting'];
- }
- }
- }
- //Getting best result
- rsort($my_exercise_result_array);
- $my_exercise_result = 0;
- if (isset($my_exercise_result_array[0])) {
- $my_exercise_result = $my_exercise_result_array[0] *100;
- }
- $max = 100;
- $pieces = 5 ;
- $part = round($max / $pieces);
- $x_axis = array();
- $final_array = array();
- $my_final_array = array();
- for ($i=1; $i <=$pieces; $i++) {
- $sum = 1;
- if ($i == 1) {
- $sum = 0;
- }
- $min = ($i-1)*$part + $sum;
- $max = ($i)*$part;
- $x_axis[]= $min." - ".$max;
- $count = 0;
- foreach($exercise_result as $result) {
- $percentage = $result*100;
- //echo $percentage.' - '.$min.' - '.$max."<br />";
- if ($percentage >= $min && $percentage <= $max) {
- //echo ' is > ';
- $count++;
- }
- }
- //echo '<br />';
- $final_array[]= $count;
- if ($my_exercise_result >= $min && $my_exercise_result <= $max) {
- $my_final_array[] = 1;
- } else {
- $my_final_array[] = 0;
- }
- }
- //Fix to remove the data of the user with my data
- for($i = 0; $i<=count($my_final_array); $i++) {
- if (!empty($my_final_array[$i])) {
- $my_final_array[$i] = $final_array[$i] + 1; //Add my result
- $final_array[$i] = 0;
- }
- }
- $cache = new pCache();
- // Dataset definition
- $data_set = new pData();
- $data_set->AddPoint($final_array,"Serie1");
- $data_set->AddPoint($my_final_array,"Serie2");
- $data_set->AddPoint($x_axis,"Serie3");
- $data_set->AddAllSeries();
- $data_set->SetAbsciseLabelSerie('Serie3');
- $data_set->SetSerieName(get_lang('Score'),"Serie1");
- $data_set->SetSerieName(get_lang('MyResults'),"Serie2");
- $data_set->SetXAxisName(get_lang("Score"));
- // Initialise the graph
- $main_width = 500;
- $main_height = 250;
- $main_graph = new pChart($main_width,$main_height);
- $main_graph->setFontProperties(api_get_path(LIBRARY_PATH).'pchart/fonts/tahoma.ttf',8);
- $main_graph->setGraphArea(50,30, $main_width -20,$main_height -50);
- $main_graph->drawFilledRoundedRectangle(10,10, $main_width- 10,$main_height -10,5,240,240,240);
- $main_graph->drawRoundedRectangle(7,7,$main_width - 7,$main_height - 7,5,230,230,230);
- $main_graph->drawGraphArea(255,255,255,TRUE);
- //SCALE_NORMAL, SCALE_START0, SCALE_ADDALLSTART0
- $main_graph->drawScale($data_set->GetData(),$data_set->GetDataDescription(),SCALE_ADDALLSTART0, 150,150,150,TRUE,0,1,TRUE);
- $main_graph->drawGrid(4,TRUE,230,230,230,50);
- // Draw the 0 line
- $main_graph->setFontProperties(api_get_path(LIBRARY_PATH).'pchart/fonts/tahoma.ttf',6);
- // $main_graph->drawTreshold(0,143,55,72,TRUE,TRUE);
- // Draw the bar graph
- $data_set->RemoveSerie("Serie3");
- //$main_graph->drawBarGraph($data_set->GetData(),$data_set->GetDataDescription(),TRUE);
- //$main_graph->drawStackedBarGraph($data_set->GetData(),$data_set->GetDataDescription(),TRUE);
- $main_graph->drawOverlayBarGraph($data_set->GetData(),$data_set->GetDataDescription(), 100);
- // Finish the graph
- $main_graph->setFontProperties(api_get_path(LIBRARY_PATH).'pchart/fonts/tahoma.ttf',8);
- $main_graph->drawLegend($main_width - 120,$main_height -100,$data_set->GetDataDescription(),255,255,255);
- $main_graph->setFontProperties(api_get_path(LIBRARY_PATH).'pchart/fonts/tahoma.ttf',8);
- $main_graph->drawTitle(180,22,$exercise_title,50,50,50);
- $graph_id = 'exercise_result_graph'.Security::remove_XSS($_GET['course']).'-'.intval($_GET['session_id']).'-'.api_get_user_id();
- if ($cache->IsInCache($graph_id, $data_set->GetData())) {
- //if (0) {
- //if we already created the img
- //echo 'in cache';
- $img_file = $cache->GetHash($graph_id,$data_set->GetData());
- } else {
- $cache->WriteToCache($graph_id, $data_set->GetData(), $main_graph);
- ob_start();
- $main_graph->Stroke();
- ob_end_clean();
- $img_file = $cache->GetHash($graph_id, $data_set->GetData());
- }
- $html = '<img src="'.api_get_path(WEB_ARCHIVE_PATH).$img_file.'">';
- return $html;
- }
- /**
- * @param FormValidator $form
- * @return mixed
- */
- public static function setUserSearchForm($form)
- {
- global $_configuration;
- $form->addElement('text', 'keyword', get_lang('Keyword'));
- $form->addElement('select', 'active', get_lang('Status'), array(1 => get_lang('Active'), 0 => get_lang('Inactive')));
- if (isset($_configuration['save_user_last_login']) &&
- $_configuration['save_user_last_login']
- ) {
- $form->addElement(
- 'select',
- 'sleeping_days',
- get_lang('InactiveDays'),
- array('', 1 => 1, 5 => 5, 15 => 15, 30 => 30, 60 => 60, 90 => 90, 120 => 120)
- );
- }
- $form->addElement('button', 'submit', get_lang('Search'));
- return $form;
- }
- /**
- * Get the progress of a exercise
- * @param int $sessionId The session ID (session.id)
- * @param int $courseId The course ID (course.id)
- * @param int $exerciseId The quiz ID (c_quiz.id)
- * @param int $answer The answer status (0 = incorrect, 1 = correct, 2 = both)
- * @param array $options An array of options you can pass to the query (limit, where and order)
- * @return array An array with the data of exercise(s) progress
- */
- public static function get_exercise_progress(
- $sessionId = 0,
- $courseId = 0,
- $exerciseId = 0,
- $date_from = null,
- $date_to = null,
- $options = array()
- ) {
- $sessionId = intval($sessionId);
- $courseId = intval($courseId);
- $exerciseId = intval($exerciseId);
- $date_from = Database::escape_string($date_from);
- $date_to = Database::escape_string($date_to);
- /*
- * This method gets the data by blocks, as previous attempts at one single
- * query made it take ages. The logic of query division is described below
- */
- // Get tables names
- $tuser = Database::get_main_table(TABLE_MAIN_USER);
- $tquiz = Database::get_course_table(TABLE_QUIZ_TEST);
- $tquiz_answer = Database::get_course_table(TABLE_QUIZ_ANSWER);
- $tquiz_question = Database::get_course_table(TABLE_QUIZ_QUESTION);
- $tquiz_rel_question = Database::get_course_table(TABLE_QUIZ_TEST_QUESTION);
- $ttrack_exercises = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_EXERCICES);
- $ttrack_attempt = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_ATTEMPT);
- require_once api_get_path(SYS_CODE_PATH).'exercice/exercise.lib.php';
- $sessions = array();
- $courses = array();
- // if session ID is defined but course ID is empty, get all the courses
- // from that session
- if (!empty($sessionId) && empty($courseId)) {
- // $courses is an array of course int id as index and course details hash as value
- $courses = SessionManager::get_course_list_by_session_id($sessionId);
- $sessions[$sessionId] = api_get_session_info($sessionId);
- } elseif (empty($sessionId) && !empty($courseId)) {
- // if, to the contrary, course is defined but not sessions, get the sessions that include this course
- // $sessions is an array like: [0] => ('id' => 3, 'name' => 'Session 35'), [1] => () etc;
- $course = api_get_course_info_by_id($courseId);
- $sessionsTemp = SessionManager::get_session_by_course($course['code']);
- $courses[$courseId] = $course;
- foreach ($sessionsTemp as $sessionItem) {
- $sessions[$sessionItem['id']] = $sessionItem;
- }
- } elseif (!empty($courseId) && !empty($sessionId)) {
- //none is empty
- $course = api_get_course_info_by_id($courseId);
- $courses[$courseId] = array($course['code']);
- $courses[$courseId]['code'] = $course['code'];
- $sessions[$sessionId] = api_get_session_info($sessionId);
- } else {
- //both are empty, not enough data, return an empty array
- return array();
- }
- // Now we have two arrays of courses and sessions with enough data to proceed
- // If no course could be found, we shouldn't return anything. Sessions can be empty (then we only return the pure-course-context results)
- if (count($courses) < 1) {
- return array();
- }
- $data = array();
- // The following loop is less expensive than what it seems:
- // - if a course was defined, then we only loop through sessions
- // - if a session was defined, then we only loop through courses
- // - if a session and a course were defined, then we only loop once
- foreach ($courses as $courseIdx => $courseData) {
- $where = '';
- $whereParams = array();
- $whereCourseCode = $courseData['code'];
- $whereSessionParams = '';
- if (count($sessions > 0)) {
- foreach ($sessions as $sessionIdx => $sessionData) {
- if (!empty($sessionIdx)) {
- $whereSessionParams .= $sessionIdx.',';
- }
- }
- $whereSessionParams = substr($whereSessionParams,0,-1);
- }
- if (!empty($exerciseId)) {
- $exerciseId = intval($exerciseId);
- $where .= ' AND q.id = %d ';
- $whereParams[] = $exerciseId;
- }
- /*
- * This feature has been disabled for now, to avoid having to
- * join two very large tables
- //2 = show all questions (wrong and correct answered)
- if ($answer != 2) {
- $answer = intval($answer);
- //$where .= ' AND qa.correct = %d';
- //$whereParams[] = $answer;
- }
- */
- $limit = '';
- if (!empty($options['limit'])) {
- $limit = " LIMIT ".$options['limit'];
- }
- if (!empty($options['where'])) {
- $where .= ' AND '.Database::escape_string($options['where']);
- }
- $order = '';
- if (!empty($options['order'])) {
- $order = " ORDER BY ".$options['order'];
- }
- if (!empty($date_to) && !empty($date_from)) {
- $where .= sprintf(" AND (te.start_date BETWEEN '%s 00:00:00' AND '%s 23:59:59')", $date_from, $date_to);
- }
- $sql = "SELECT
- te.session_id,
- ta.id as attempt_id,
- te.exe_user_id as user_id,
- te.exe_id as exercise_attempt_id,
- ta.question_id,
- ta.answer as answer_id,
- ta.tms as time,
- te.exe_exo_id as quiz_id,
- CONCAT ('c', q.c_id, '_e', q.id) as exercise_id,
- q.title as quiz_title,
- qq.description as description
- FROM $ttrack_exercises te
- INNER JOIN $ttrack_attempt ta ON ta.exe_id = te.exe_id
- INNER JOIN $tquiz q ON q.id = te.exe_exo_id
- INNER JOIN $tquiz_rel_question rq ON rq.exercice_id = q.id AND rq.c_id = q.c_id
- INNER JOIN $tquiz_question qq
- ON
- qq.id = rq.question_id AND
- qq.c_id = rq.c_id AND
- qq.position = rq.question_order AND
- ta.question_id = rq.question_id
- WHERE
- te.exe_cours_id = '$whereCourseCode' ".(empty($whereSessionParams)?'':"AND te.session_id IN ($whereSessionParams)")."
- AND q.c_id = $courseIdx
- $where $order $limit";
- $sql_query = vsprintf($sql, $whereParams);
- // Now browse through the results and get the data
- $rs = Database::query($sql_query);
- $userIds = array();
- $questionIds = array();
- $answerIds = array();
- while ($row = Database::fetch_array($rs)) {
- //only show if exercise is visible
- if (api_get_item_visibility($courseData, 'quiz', $row['exercise_id'])) {
- $userIds[$row['user_id']] = $row['user_id'];
- $questionIds[$row['question_id']] = $row['question_id'];
- $answerIds[$row['question_id']][$row['answer_id']] = $row['answer_id'];
- $row['session'] = $sessions[$row['session_id']];
- $data[] = $row;
- }
- }
- // Now fill questions data. Query all questions and answers for this test to avoid
- $sqlQuestions = "SELECT tq.c_id, tq.id as question_id, tq.question, tqa.id_auto,
- tqa.answer, tqa.correct, tq.position, tqa.id_auto as answer_id
- FROM $tquiz_question tq, $tquiz_answer tqa
- WHERE
- tqa.question_id = tq.id AND
- tqa.c_id = tq.c_id AND
- tq.c_id = $courseIdx AND
- tq.id IN (".implode(',', $questionIds).")";
- $resQuestions = Database::query($sqlQuestions);
- $answer = array();
- $question = array();
- while ($rowQuestion = Database::fetch_assoc($resQuestions)) {
- $questionId = $rowQuestion['question_id'];
- $answerId = $rowQuestion['answer_id'];
- $answer[$questionId][$answerId] = array(
- 'position' => $rowQuestion['position'],
- 'question' => $rowQuestion['question'],
- 'answer' => $rowQuestion['answer'],
- 'correct' => $rowQuestion['correct'],
- );
- $question[$questionId]['question'] = $rowQuestion['question'];
- }
- // Now fill users data
- $sqlUsers = "SELECT user_id, username, lastname, firstname
- FROM $tuser
- WHERE user_id IN (".implode(',',$userIds).")";
- $resUsers = Database::query($sqlUsers);
- while ($rowUser = Database::fetch_assoc($resUsers)) {
- $users[$rowUser['user_id']] = $rowUser;
- }
- foreach ($data as $id => $row) {
- $rowQuestId = $row['question_id'];
- $rowAnsId = $row['answer_id'];
- $data[$id]['session'] = $sessions[$row['session_id']]['name'];
- $data[$id]['firstname'] = $users[$row['user_id']]['firstname'];
- $data[$id]['lastname'] = $users[$row['user_id']]['lastname'];
- $data[$id]['username'] = $users[$row['user_id']]['username'];
- $data[$id]['answer'] = $answer[$rowQuestId][$rowAnsId]['answer'];
- $data[$id]['correct'] = ($answer[$rowQuestId][$rowAnsId]['correct'] == 0 ? get_lang('No') : get_lang('Yes'));
- $data[$id]['question'] = $question[$rowQuestId]['question'];
- $data[$id]['question_id'] = $rowQuestId;
- $data[$id]['description'] = $row['description'];
- }
- /*
- The minimum expected array structure at the end is:
- attempt_id,
- session name,
- exercise_id,
- quiz_title,
- username,
- lastname,
- firstname,
- time,
- question_id,
- question,
- answer,
- */
- }
- return $data;
- }
- }
- /**
- * @todo move into a proper file
- * @package chamilo.tracking
- */
- class TrackingCourseLog
- {
- /**
- * @return mixed
- */
- public static function count_item_resources()
- {
- $session_id = api_get_session_id();
- $course_id = api_get_course_int_id();
- $table_item_property = Database :: get_course_table(TABLE_ITEM_PROPERTY);
- $table_user = Database :: get_main_table(TABLE_MAIN_USER);
- $sql = "SELECT count(tool) AS total_number_of_items
- FROM $table_item_property track_resource, $table_user user
- WHERE
- track_resource.c_id = $course_id AND
- track_resource.insert_user_id = user.user_id AND
- id_session = $session_id ";
- if (isset($_GET['keyword'])) {
- $keyword = Database::escape_string(trim($_GET['keyword']));
- $sql .= " AND (
- user.username LIKE '%".$keyword."%' OR
- lastedit_type LIKE '%".$keyword."%' OR
- tool LIKE '%".$keyword."%'
- )";
- }
- $sql .= " AND tool IN (
- 'document',
- 'learnpath',
- 'quiz',
- 'glossary',
- 'link',
- 'course_description',
- 'announcement',
- 'thematic',
- 'thematic_advance',
- 'thematic_plan'
- )";
- $res = Database::query($sql);
- $obj = Database::fetch_object($res);
- return $obj->total_number_of_items;
- }
- /**
- * @param $from
- * @param $number_of_items
- * @param $column
- * @param $direction
- * @return array
- */
- public static function get_item_resources_data($from, $number_of_items, $column, $direction)
- {
- $session_id = api_get_session_id();
- $course_id = api_get_course_int_id();
- $table_item_property = Database :: get_course_table(TABLE_ITEM_PROPERTY);
- $table_user = Database :: get_main_table(TABLE_MAIN_USER);
- $table_session = Database :: get_main_table(TABLE_MAIN_SESSION);
- $session_id = intval($session_id);
- $sql = "SELECT
- tool as col0,
- lastedit_type as col1,
- ref as ref,
- user.username as col3,
- insert_date as col5,
- visibility as col6,
- user.user_id as user_id
- FROM $table_item_property track_resource, $table_user user
- WHERE
- track_resource.c_id = $course_id AND
- track_resource.insert_user_id = user.user_id AND
- id_session = $session_id ";
- if (isset($_GET['keyword'])) {
- $keyword = Database::escape_string(trim($_GET['keyword']));
- $sql .= " AND (
- user.username LIKE '%".$keyword."%' OR
- lastedit_type LIKE '%".$keyword."%' OR
- tool LIKE '%".$keyword."%'
- ) ";
- }
- $sql .= " AND tool IN (
- 'document',
- 'learnpath',
- 'quiz',
- 'glossary',
- 'link',
- 'course_description',
- 'announcement',
- 'thematic',
- 'thematic_advance',
- 'thematic_plan'
- )";
- if ($column == 0) {
- $column = '0';
- }
- if ($column != '' && $direction != '') {
- if ($column != 2 && $column != 4) {
- $sql .= " ORDER BY col$column $direction";
- }
- } else {
- $sql .= " ORDER BY col5 DESC ";
- }
- $from = intval($from);
- $number_of_items = intval($number_of_items);
- $sql .= " LIMIT $from, $number_of_items ";
- $res = Database::query($sql);
- $resources = array();
- $thematic_tools = array('thematic', 'thematic_advance', 'thematic_plan');
- while ($row = Database::fetch_array($res)) {
- $ref = $row['ref'];
- $table_name = TrackingCourseLog::get_tool_name_table($row['col0']);
- $table_tool = Database :: get_course_table($table_name['table_name']);
- $id = $table_name['id_tool'];
- $recorset = false;
- if (in_array($row['col0'], array('thematic_plan', 'thematic_advance'))) {
- $tbl_thematic = Database :: get_course_table(TABLE_THEMATIC);
- $sql = "SELECT thematic_id FROM $table_tool WHERE c_id = $course_id AND id = $ref";
- $rs_thematic = Database::query($sql);
- if (Database::num_rows($rs_thematic)) {
- $row_thematic = Database::fetch_array($rs_thematic);
- $thematic_id = $row_thematic['thematic_id'];
- $sql = "SELECT session.id, session.name, user.username
- FROM $tbl_thematic t, $table_session session, $table_user user
- WHERE
- t.c_id = $course_id AND
- t.session_id = session.id AND
- session.id_coach = user.user_id AND
- t.id = $thematic_id";
- $recorset = Database::query($sql);
- }
- } else {
- $sql = "SELECT session.id, session.name, user.username
- FROM $table_tool tool, $table_session session, $table_user user
- WHERE
- tool.c_id = $course_id AND
- tool.session_id = session.id AND
- session.id_coach = user.user_id AND
- tool.$id = $ref";
- $recorset = Database::query($sql);
- }
- if (!empty($recorset)) {
- $obj = Database::fetch_object($recorset);
- $name_session = '';
- $coach_name = '';
- if (!empty($obj)) {
- $name_session = $obj->name;
- $coach_name = $obj->username;
- }
- $url_tool = api_get_path(WEB_CODE_PATH).$table_name['link_tool'];
- $row[0] = '';
- if ($row['col6'] != 2) {
- if (in_array($row['col0'], $thematic_tools)) {
- $exp_thematic_tool = explode('_', $row['col0']);
- $thematic_tool_title = '';
- if (is_array($exp_thematic_tool)) {
- foreach ($exp_thematic_tool as $exp) {
- $thematic_tool_title .= api_ucfirst($exp);
- }
- } else {
- $thematic_tool_title = api_ucfirst($row['col0']);
- }
- $row[0] = '<a href="'.$url_tool.'?'.api_get_cidreq().'&action=thematic_details">'.get_lang($thematic_tool_title).'</a>';
- } else {
- $row[0] = '<a href="'.$url_tool.'?'.api_get_cidreq().'">'.get_lang('Tool'.api_ucfirst($row['col0'])).'</a>';
- }
- } else {
- $row[0] = api_ucfirst($row['col0']);
- }
- $row[1] = get_lang($row[1]);
- $row[6] = api_convert_and_format_date($row['col5'], null, date_default_timezone_get());
- $row[5] = '';
- //@todo Improve this code please
- switch ($table_name['table_name']) {
- case 'document' :
- $sql = "SELECT tool.title as title FROM $table_tool tool
- WHERE c_id = $course_id AND id = $ref";
- $rs_document = Database::query($sql);
- $obj_document = Database::fetch_object($rs_document);
- $row[5] = $obj_document->title;
- break;
- case 'announcement':
- $sql = "SELECT title FROM $table_tool
- WHERE c_id = $course_id AND id = $ref";
- $rs_document = Database::query($sql);
- $obj_document = Database::fetch_object($rs_document);
- $row[5] = $obj_document->title;
- break;
- case 'glossary':
- $sql = "SELECT name FROM $table_tool
- WHERE c_id = $course_id AND glossary_id = $ref";
- $rs_document = Database::query($sql);
- $obj_document = Database::fetch_object($rs_document);
- $row[5] = $obj_document->name;
- break;
- case 'lp':
- $sql = "SELECT name
- FROM $table_tool WHERE c_id = $course_id AND id = $ref";
- $rs_document = Database::query($sql);
- $obj_document = Database::fetch_object($rs_document);
- $row[5] = $obj_document->name;
- break;
- case 'quiz':
- $sql = "SELECT title FROM $table_tool
- WHERE c_id = $course_id AND id = $ref";
- $rs_document = Database::query($sql);
- $obj_document = Database::fetch_object($rs_document);
- $row[5] = $obj_document->title;
- break;
- case 'course_description':
- $sql = "SELECT title FROM $table_tool
- WHERE c_id = $course_id AND id = $ref";
- $rs_document = Database::query($sql);
- $obj_document = Database::fetch_object($rs_document);
- $row[5] = $obj_document->title;
- break;
- case 'thematic':
- $rs = Database::query("SELECT title FROM $table_tool WHERE c_id = $course_id AND id = $ref");
- if (Database::num_rows($rs) > 0) {
- $obj = Database::fetch_object($rs);
- $row[5] = $obj->title;
- }
- break;
- case 'thematic_advance':
- $rs = Database::query("SELECT content FROM $table_tool WHERE c_id = $course_id AND id = $ref");
- if (Database::num_rows($rs) > 0) {
- $obj = Database::fetch_object($rs);
- $row[5] = $obj->content;
- }
- break;
- case 'thematic_plan':
- $rs = Database::query("SELECT title FROM $table_tool WHERE c_id = $course_id AND id = $ref");
- if (Database::num_rows($rs) > 0) {
- $obj = Database::fetch_object($rs);
- $row[5] = $obj->title;
- }
- break;
- default:
- break;
- }
- $row2 = $name_session;
- if (!empty($coach_name)) {
- $row2 .= '<br />'.get_lang('Coach').': '.$coach_name;
- }
- $row[2] = $row2;
- if (!empty($row['col3'])) {
- $row['col3'] = Display::url(
- $row['col3'],
- api_get_path(WEB_CODE_PATH).'user/userInfo.php?'.api_get_cidreq().'&origin=tracking&uInfo='.$row['user_id']
- );
- $row[3] = $row['col3'];
- $ip = TrackingUserLog::get_ip_from_user_event($row['user_id'], $row['col5'], true);
- if (empty($ip)) {
- $ip = get_lang('Unknown');
- }
- $row[4] = $ip;
- }
- $resources[] = $row;
- }
- }
- return $resources;
- }
- /**
- * @param string $tool
- *
- * @return array
- */
- public static function get_tool_name_table($tool)
- {
- switch ($tool) {
- case 'document':
- $table_name = TABLE_DOCUMENT;
- $link_tool = 'document/document.php';
- $id_tool = 'id';
- break;
- case 'learnpath':
- $table_name = TABLE_LP_MAIN;
- $link_tool = 'newscorm/lp_controller.php';
- $id_tool = 'id';
- break;
- case 'quiz':
- $table_name = TABLE_QUIZ_TEST;
- $link_tool = 'exercice/exercice.php';
- $id_tool = 'id';
- break;
- case 'glossary':
- $table_name = TABLE_GLOSSARY;
- $link_tool = 'glossary/index.php';
- $id_tool = 'glossary_id';
- break;
- case 'link':
- $table_name = TABLE_LINK;
- $link_tool = 'link/link.php';
- $id_tool = 'id';
- break;
- case 'course_description':
- $table_name = TABLE_COURSE_DESCRIPTION;
- $link_tool = 'course_description/';
- $id_tool = 'id';
- break;
- case 'announcement':
- $table_name = TABLE_ANNOUNCEMENT;
- $link_tool = 'announcements/announcements.php';
- $id_tool = 'id';
- break;
- case 'thematic':
- $table_name = TABLE_THEMATIC;
- $link_tool = 'course_progress/index.php';
- $id_tool = 'id';
- break;
- case 'thematic_advance':
- $table_name = TABLE_THEMATIC_ADVANCE;
- $link_tool = 'course_progress/index.php';
- $id_tool = 'id';
- break;
- case 'thematic_plan':
- $table_name = TABLE_THEMATIC_PLAN;
- $link_tool = 'course_progress/index.php';
- $id_tool = 'id';
- break;
- default:
- $table_name = $tool;
- break;
- }
- return array(
- 'table_name' => $table_name,
- 'link_tool' => $link_tool,
- 'id_tool' => $id_tool,
- );
- }
- public static function display_additional_profile_fields()
- {
- // getting all the extra profile fields that are defined by the platform administrator
- $extra_fields = UserManager :: get_extra_fields(0,50,5,'ASC');
- // creating the form
- $return = '<form action="courseLog.php" method="get" name="additional_profile_field_form" id="additional_profile_field_form">';
- // the select field with the additional user profile fields (= this is where we select the field of which we want to see
- // the information the users have entered or selected.
- $return .= '<select name="additional_profile_field">';
- $return .= '<option value="-">'.get_lang('SelectFieldToAdd').'</option>';
- $extra_fields_to_show = 0;
- foreach ($extra_fields as $key=>$field) {
- // show only extra fields that are visible + and can be filtered, added by J.Montoya
- if ($field[6]==1 && $field[8] == 1) {
- if (isset($_GET['additional_profile_field']) && $field[0] == $_GET['additional_profile_field'] ) {
- $selected = 'selected="selected"';
- } else {
- $selected = '';
- }
- $extra_fields_to_show++;
- $return .= '<option value="'.$field[0].'" '.$selected.'>'.$field[3].'</option>';
- }
- }
- $return .= '</select>';
- // the form elements for the $_GET parameters (because the form is passed through GET
- foreach ($_GET as $key=>$value){
- if ($key <> 'additional_profile_field') {
- $return .= '<input type="hidden" name="'.Security::remove_XSS($key).'" value="'.Security::remove_XSS($value).'" />';
- }
- }
- // the submit button
- $return .= '<button class="save" type="submit">'.get_lang('AddAdditionalProfileField').'</button>';
- $return .= '</form>';
- if ($extra_fields_to_show > 0) {
- return $return;
- } else {
- return '';
- }
- }
- /**
- * This function gets all the information of a certrain ($field_id) additional profile field.
- * It gets the information of all the users so that it can be displayed in the sortable table or in the csv or xls export
- *
- * @author Patrick Cool <patrick.cool@UGent.be>, Ghent University, Belgium
- * @since October 2009
- * @version 1.8.7
- */
- public function get_addtional_profile_information_of_field($field_id)
- {
- // Database table definition
- $table_user = Database::get_main_table(TABLE_MAIN_USER);
- $table_user_field_values = Database::get_main_table(TABLE_MAIN_USER_FIELD_VALUES);
- $sql = "SELECT user.user_id, field.field_value
- FROM $table_user user, $table_user_field_values field
- WHERE
- user.user_id = field.user_id AND
- field.field_id='".intval($field_id)."'";
- $result = Database::query($sql);
- while($row = Database::fetch_array($result)) {
- $return[$row['user_id']][] = $row['field_value'];
- }
- return $return;
- }
- /**
- * This function gets all the information of a certrain ($field_id)
- * additional profile field for a specific list of users is more efficent
- * than get_addtional_profile_information_of_field() function
- * It gets the information of all the users so that it can be displayed
- * in the sortable table or in the csv or xls export
- *
- * @author Julio Montoya <gugli100@gmail.com>
- * @param int field id
- * @param array list of user ids
- * @return array
- * @since Nov 2009
- * @version 1.8.6.2
- */
- public static function get_addtional_profile_information_of_field_by_user($field_id, $users)
- {
- // Database table definition
- $table_user = Database::get_main_table(TABLE_MAIN_USER);
- $table_user_field_values = Database::get_main_table(TABLE_MAIN_USER_FIELD_VALUES);
- $result_extra_field = UserManager::get_extra_field_information($field_id);
- if (!empty($users)) {
- if ($result_extra_field['field_type'] == UserManager::USER_FIELD_TYPE_TAG ) {
- foreach($users as $user_id) {
- $user_result = UserManager::get_user_tags($user_id, $field_id);
- $tag_list = array();
- foreach($user_result as $item) {
- $tag_list[] = $item['tag'];
- }
- $return[$user_id][] = implode(', ',$tag_list);
- }
- } else {
- $new_user_array = array();
- foreach($users as $user_id) {
- $new_user_array[]= "'".$user_id."'";
- }
- $users = implode(',',$new_user_array);
- //selecting only the necessary information NOT ALL the user list
- $sql = "SELECT user.user_id, field.field_value FROM $table_user user INNER JOIN $table_user_field_values field
- ON (user.user_id = field.user_id)
- WHERE field.field_id=".intval($field_id)." AND user.user_id IN ($users)";
- $result = Database::query($sql);
- while($row = Database::fetch_array($result)) {
- // get option value for field type double select by id
- if (!empty($row['field_value'])) {
- if ($result_extra_field['field_type'] == USER_FIELD_TYPE_DOUBLE_SELECT) {
- $id_double_select = explode(';',$row['field_value']);
- if (is_array($id_double_select)) {
- $value1 = $result_extra_field['options'][$id_double_select[0]]['option_value'];
- $value2 = $result_extra_field['options'][$id_double_select[1]]['option_value'];
- $row['field_value'] = ($value1.';'.$value2);
- }
- }
- }
- // get other value from extra field
- $return[$row['user_id']][] = $row['field_value'];
- }
- }
- }
- return $return;
- }
- /**
- * count the number of students in this course (used for SortableTable)
- * Deprecated
- */
- public function count_student_in_course()
- {
- global $nbStudents;
- return $nbStudents;
- }
- public function sort_users($a, $b)
- {
- return strcmp(trim(api_strtolower($a[$_SESSION['tracking_column']])), trim(api_strtolower($b[$_SESSION['tracking_column']])));
- }
- public function sort_users_desc($a, $b)
- {
- return strcmp( trim(api_strtolower($b[$_SESSION['tracking_column']])), trim(api_strtolower($a[$_SESSION['tracking_column']])));
- }
- /**
- * Get number of users for sortable with pagination
- * @return int
- */
- public static function get_number_of_users()
- {
- global $user_ids;
- return count($user_ids);
- }
- /**
- * Get data for users list in sortable with pagination
- * @param $from
- * @param $number_of_items
- * @param $column
- * @param $direction
- * @return array
- */
- public static function get_user_data($from, $number_of_items, $column, $direction)
- {
- global $user_ids, $course_code, $additional_user_profile_info, $export_csv, $is_western_name_order, $csv_content, $session_id;
- $course_code = Database::escape_string($course_code);
- $tbl_user = Database::get_main_table(TABLE_MAIN_USER);
- $tbl_url_rel_user = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER);
- $access_url_id = api_get_current_access_url_id();
- // get all users data from a course for sortable with limit
- if (is_array($user_ids)) {
- $user_ids = array_map('intval', $user_ids);
- $condition_user = " WHERE user.user_id IN (".implode(',',$user_ids).") ";
- } else {
- $user_ids = intval($user_ids);
- $condition_user = " WHERE user.user_id = $user_ids ";
- }
- if (!empty($_GET['user_keyword'])) {
- $keyword = trim(Database::escape_string($_GET['user_keyword']));
- $condition_user .= " AND (
- user.firstname LIKE '%".$keyword."%' OR
- user.lastname LIKE '%".$keyword."%' OR
- user.username LIKE '%".$keyword."%' OR
- user.email LIKE '%".$keyword."%'
- ) ";
- }
- $url_table = null;
- $url_condition = null;
- if (api_is_multiple_url_enabled()) {
- $url_table = ", ".$tbl_url_rel_user."as url_users";
- $url_condition = " AND user.user_id = url_users.user_id AND access_url_id='$access_url_id'";
- }
- $sql = "SELECT user.user_id as user_id,
- user.official_code as col0,
- user.lastname as col1,
- user.firstname as col2,
- user.username as col3
- FROM $tbl_user as user $url_table
- $condition_user $url_condition";
- if (!in_array($direction, array('ASC','DESC'))) {
- $direction = 'ASC';
- }
- $column = intval($column);
- $from = intval($from);
- $number_of_items = intval($number_of_items);
- $sql .= " ORDER BY col$column $direction ";
- $sql .= " LIMIT $from,$number_of_items";
- $res = Database::query($sql);
- $users = array();
- $course_info = api_get_course_info($course_code);
- $total_surveys = 0;
- $total_exercises = get_all_exercises(
- $course_info,
- $session_id,
- false,
- null,
- false,
- 3
- );
- if (empty($session_id)) {
- $survey_user_list = array();
- $survey_list = survey_manager::get_surveys($course_code, $session_id);
- $total_surveys = count($survey_list);
- foreach ($survey_list as $survey) {
- $user_list = survey_manager::get_people_who_filled_survey(
- $survey['survey_id'],
- false,
- $course_info['real_id']
- );
- foreach ($user_list as $user_id) {
- isset($survey_user_list[$user_id]) ? $survey_user_list[$user_id]++ : $survey_user_list[$user_id] = 1;
- }
- }
- }
- while ($user = Database::fetch_array($res, 'ASSOC')) {
- $user['official_code'] = $user['col0'];
- $user['lastname'] = $user['col1'];
- $user['firstname'] = $user['col2'];
- $user['username'] = $user['col3'];
- $user['time'] = api_time_to_hms(Tracking::get_time_spent_on_the_course($user['user_id'], $course_code, $session_id));
- $avg_student_score = Tracking::get_avg_student_score(
- $user['user_id'],
- $course_code,
- array(),
- $session_id
- );
- $avg_student_progress = Tracking::get_avg_student_progress(
- $user['user_id'],
- $course_code,
- array(),
- $session_id
- );
- if (empty($avg_student_progress)) {
- $avg_student_progress=0;
- }
- $user['average_progress'] = $avg_student_progress.'%';
- $total_user_exercise = Tracking::get_exercise_student_progress(
- $total_exercises,
- $user['user_id'],
- $course_code,
- $session_id
- );
- $user['exercise_progress'] = $total_user_exercise;
- $total_user_exercise = Tracking::get_exercise_student_average_best_attempt(
- $total_exercises,
- $user['user_id'],
- $course_code,
- $session_id
- );
- $user['exercise_average_best_attempt'] = $total_user_exercise;
- if (is_numeric($avg_student_score)) {
- $user['student_score'] = $avg_student_score.'%';
- } else {
- $user['student_score'] = $avg_student_score;
- }
- $user['count_assignments'] = Tracking::count_student_assignments($user['user_id'], $course_code, $session_id);
- $user['count_messages'] = Tracking::count_student_messages($user['user_id'], $course_code, $session_id);
- $user['first_connection'] = Tracking::get_first_connection_date_on_the_course($user['user_id'], $course_code, $session_id);
- $user['last_connection'] = Tracking::get_last_connection_date_on_the_course($user['user_id'], $course_code, $session_id);
- // we need to display an additional profile field
- $user['additional'] = '';
- if (isset($_GET['additional_profile_field']) AND is_numeric($_GET['additional_profile_field'])) {
- if (isset($additional_user_profile_info[$user['user_id']]) &&
- is_array($additional_user_profile_info[$user['user_id']])
- ) {
- $user['additional'] = implode(', ', $additional_user_profile_info[$user['user_id']]);
- }
- }
- if (empty($session_id)) {
- $user['survey'] = (isset($survey_user_list[$user['user_id']]) ? $survey_user_list[$user['user_id']] : 0) .' / '.$total_surveys;
- }
- $user['link'] = '<center><a href="../mySpace/myStudents.php?student='.$user['user_id'].'&details=true&course='.$course_code.'&origin=tracking_course&id_session='.$session_id.'"><img src="'.api_get_path(WEB_IMG_PATH).'2rightarrow.gif" border="0" /></a></center>';
- // store columns in array $users
- $is_western_name_order = api_is_western_name_order();
- $user_row = array();
- $user_row[]= $user['official_code']; //0
- if ($is_western_name_order) {
- $user_row[]= $user['firstname'];
- $user_row[]= $user['lastname'];
- } else {
- $user_row[]= $user['lastname'];
- $user_row[]= $user['firstname'];
- }
- $user_row[]= $user['username'];
- $user_row[]= $user['time'];
- $user_row[]= $user['average_progress'];
- $user_row[]= $user['exercise_progress'];
- $user_row[]= $user['exercise_average_best_attempt'];
- $user_row[]= $user['student_score'];
- $user_row[]= $user['count_assignments'];
- $user_row[]= $user['count_messages'];
- if (empty($session_id)) {
- $user_row[]= $user['survey'];
- }
- $user_row[]= $user['first_connection'];
- $user_row[]= $user['last_connection'];
- if (isset($_GET['additional_profile_field']) AND is_numeric($_GET['additional_profile_field'])) {
- $user_row[]= $user['additional'];
- }
- $user_row[]= $user['link'];
- $users[] = $user_row;
- if ($export_csv) {
- if (empty($session_id)) {
- $user_row = array_map('strip_tags', $user_row);
- unset($user_row[14]);
- unset($user_row[15]);
- } else {
- $user_row = array_map('strip_tags', $user_row);
- unset($user_row[13]);
- unset($user_row[14]);
- }
- $csv_content[] = $user_row;
- }
- }
- return $users;
- }
- }
- /**
- * @package chamilo.tracking
- */
- class TrackingUserLog
- {
- /**
- * Displays the number of logins every month for a specific user in a specific course.
- */
- public function display_login_tracking_info($view, $user_id, $course_id, $session_id = 0)
- {
- $MonthsLong = $GLOBALS['MonthsLong'];
- // protected data
- $user_id = intval($user_id);
- $session_id = intval($session_id);
- $course_id = Database::escape_string($course_id);
- $track_access_table = Database::get_main_table(TABLE_STATISTIC_TRACK_E_ACCESS);
- $tempView = $view;
- if(substr($view,0,1) == '1') {
- $new_view = substr_replace($view,'0',0,1);
- echo "
- <tr>
- <td valign='top'>
- <font color='#0000FF'>- </font>" .
- "<b>".get_lang('LoginsAndAccessTools')."</b> [<a href='".api_get_self()."?uInfo=".$user_id."&view=".Security::remove_XSS($new_view)."'>".get_lang('Close')."</a>] [<a href='userLogCSV.php?".api_get_cidreq()."&uInfo=".Security::remove_XSS($_GET['uInfo'])."&view=10000'>".get_lang('ExportAsCSV')."</a>]
- </td>
- </tr>
- ";
- echo "<tr><td style='padding-left : 40px;' valign='top'>".get_lang('LoginsDetails')."<br>";
- $sql = "SELECT UNIX_TIMESTAMP(access_date), count(access_date)
- FROM $track_access_table
- WHERE access_user_id = '$user_id'
- AND access_cours_code = '$course_id'
- AND access_session_id = '$session_id'
- GROUP BY YEAR(access_date),MONTH(access_date)
- ORDER BY YEAR(access_date),MONTH(access_date) ASC";
- echo "<tr><td style='padding-left : 40px;padding-right : 40px;'>";
- //$results = getManyResults2Col($sql);
- $results = getManyResults3Col($sql);
- echo "<table cellpadding='2' cellspacing='1' border='0' align=center>";
- echo "<tr>
- <td class='secLine'>
- ".get_lang('LoginsTitleMonthColumn')."
- </td>
- <td class='secLine'>
- ".get_lang('LoginsTitleCountColumn')."
- </td>
- </tr>";
- $total = 0;
- if (is_array($results)) {
- for($j = 0 ; $j < count($results) ; $j++) {
- echo "<tr>";
- echo "<td class='content'><a href='logins_details.php?uInfo=".$user_id."&reqdate=".$results[$j][0]."&view=".Security::remove_XSS($view)."'>".$MonthsLong[date('n', $results[$j][0])-1].' '.date('Y', $results[$j][0])."</a></td>";
- echo "<td valign='top' align='right' class='content'>".$results[$j][1]."</td>";
- echo"</tr>";
- $total = $total + $results[$j][1];
- }
- echo "<tr>";
- echo "<td>".get_lang('Total')."</td>";
- echo "<td align='right' class='content'>".$total."</td>";
- echo"</tr>";
- } else {
- echo "<tr>";
- echo "<td colspan='2'><center>".get_lang('NoResult')."</center></td>";
- echo"</tr>";
- }
- echo "</table>";
- echo "</td></tr>";
- } else {
- $new_view = substr_replace($view,'1',0,1);
- echo "
- <tr>
- <td valign='top'>
- +<font color='#0000FF'> </font><a href='".api_get_self()."?uInfo=".$user_id."&view=".Security::remove_XSS($new_view)."' class='specialLink'>".get_lang('LoginsAndAccessTools')."</a>
- </td>
- </tr>
- ";
- }
- }
- /**
- * Displays the exercise results for a specific user in a specific course.
- * @todo remove globals
- */
- public function display_exercise_tracking_info($view, $user_id, $course_id)
- {
- global $TBL_TRACK_HOTPOTATOES, $TABLECOURSE_EXERCICES, $TABLETRACK_EXERCICES, $dateTimeFormatLong;
- if(substr($view,1,1) == '1') {
- $new_view = substr_replace($view,'0',1,1);
- echo "<tr>
- <td valign='top'>
- <font color='#0000FF'>- </font><b>".get_lang('ExercicesResults')."</b> [<a href='".api_get_self()."?uInfo=".Security::remove_XSS($user_id)."&view=".Security::remove_XSS($new_view)."'>".get_lang('Close')."</a>] [<a href='userLogCSV.php?".api_get_cidreq()."&uInfo=".Security::remove_XSS($_GET['uInfo'])."&view=01000'>".get_lang('ExportAsCSV')."</a>]
- </td>
- </tr>";
- echo "<tr><td style='padding-left : 40px;' valign='top'>".get_lang('ExercicesDetails')."<br />";
- $sql = "SELECT ce.title, te.exe_result , te.exe_weighting, UNIX_TIMESTAMP(te.exe_date)
- FROM $TABLECOURSE_EXERCICES AS ce , $TABLETRACK_EXERCICES AS te
- WHERE te.exe_cours_id = '".Database::escape_string($course_id)."'
- AND te.exe_user_id = '".intval($user_id)."'
- AND te.exe_exo_id = ce.id
- ORDER BY ce.title ASC, te.exe_date ASC";
- $hpsql = "SELECT te.exe_name, te.exe_result , te.exe_weighting, UNIX_TIMESTAMP(te.exe_date)
- FROM $TBL_TRACK_HOTPOTATOES AS te
- WHERE te.exe_user_id = '".intval($user_id)."' AND te.exe_cours_id = '".Database::escape_string($course_id)."'
- ORDER BY te.exe_cours_id ASC, te.exe_date ASC";
- $hpresults = getManyResultsXCol($hpsql, 4);
- $NoTestRes = 0;
- $NoHPTestRes = 0;
- echo "<tr>\n<td style='padding-left : 40px;padding-right : 40px;'>\n";
- $results = getManyResultsXCol($sql, 4);
- echo "<table cellpadding='2' cellspacing='1' border='0' align='center'>\n";
- echo "
- <tr bgcolor='#E6E6E6'>
- <td>
- ".get_lang('ExercicesTitleExerciceColumn')."
- </td>
- <td>
- ".get_lang('Date')."
- </td>
- <td>
- ".get_lang('ExercicesTitleScoreColumn')."
- </td>
- </tr>";
- if (is_array($results)) {
- for($i = 0; $i < sizeof($results); $i++) {
- $display_date = api_convert_and_format_date($results[$i][3], null, date_default_timezone_get());
- echo "<tr>\n";
- echo "<td class='content'>".$results[$i][0]."</td>\n";
- echo "<td class='content'>".$display_date."</td>\n";
- echo "<td valign='top' align='right' class='content'>".$results[$i][1]." / ".$results[$i][2]."</td>\n";
- echo "</tr>\n";
- }
- } else {
- // istvan begin
- $NoTestRes = 1;
- }
- // The Result of Tests
- if(is_array($hpresults)) {
- for($i = 0; $i < sizeof($hpresults); $i++) {
- $title = GetQuizName($hpresults[$i][0],'');
- if ($title == '')
- $title = basename($hpresults[$i][0]);
- $display_date = api_convert_and_format_date($hpresults[$i][3], null, date_default_timezone_get());
- ?>
- <tr>
- <td class="content"><?php echo $title; ?></td>
- <td class="content" align="center"><?php echo $display_date; ?></td>
- <td class="content" align="center"><?php echo $hpresults[$i][1]; ?> / <?php echo $hpresults[$i][2]; ?>
- </td>
- </tr>
- <?php }
- } else {
- $NoHPTestRes = 1;
- }
- if ($NoTestRes == 1 && $NoHPTestRes == 1) {
- echo "<tr>\n";
- echo "<td colspan='3'><center>".get_lang('NoResult')."</center></td>\n";
- echo "</tr>\n";
- }
- echo "</table>";
- echo "</td>\n</tr>\n";
- } else {
- $new_view = substr_replace($view,'1',1,1);
- echo "
- <tr>
- <td valign='top'>
- +<font color='#0000FF'> </font><a href='".api_get_self()."?uInfo=$user_id&view=".$new_view."' class='specialLink'>".get_lang('ExercicesResults')."</a>
- </td>
- </tr>";
- }
- }
- /**
- * Displays the student publications for a specific user in a specific course.
- * @todo remove globals
- */
- public function display_student_publications_tracking_info($view, $user_id, $course_id)
- {
- global $TABLETRACK_UPLOADS, $TABLECOURSE_WORK, $dateTimeFormatLong, $_course;
- if (substr($view,2,1) == '1') {
- $new_view = substr_replace($view,'0',2,1);
- echo "<tr>
- <td valign='top'>
- <font color='#0000FF'>- </font><b>".get_lang('WorkUploads')."</b> [<a href='".api_get_self()."?uInfo=".Security::remove_XSS($user_id)."&view=".Security::remove_XSS($new_view)."'>".get_lang('Close')."</a>] [<a href='userLogCSV.php?".api_get_cidreq()."&uInfo=".Security::remove_XSS($_GET['uInfo'])."&view=00100'>".get_lang('ExportAsCSV')."</a>]
- </td>
- </tr>";
- echo "<tr><td style='padding-left : 40px;' valign='top'>".get_lang('WorksDetails')."<br>";
- $sql = "SELECT u.upload_date, w.title, w.author,w.url
- FROM $TABLETRACK_UPLOADS u , $TABLECOURSE_WORK w
- WHERE u.upload_work_id = w.id
- AND u.upload_user_id = '".intval($user_id)."'
- AND u.upload_cours_id = '".Database::escape_string($course_id)."'
- ORDER BY u.upload_date DESC";
- echo "<tr><td style='padding-left : 40px;padding-right : 40px;'>";
- $results = getManyResultsXCol($sql,4);
- echo "<table cellpadding='2' cellspacing='1' border='0' align=center>";
- echo "<tr>
- <td class='secLine' width='40%'>
- ".get_lang('WorkTitle')."
- </td>
- <td class='secLine' width='30%'>
- ".get_lang('WorkAuthors')."
- </td>
- <td class='secLine' width='30%'>
- ".get_lang('Date')."
- </td>
- </tr>";
- if (is_array($results)) {
- for($j = 0 ; $j < count($results) ; $j++) {
- $pathToFile = api_get_path(WEB_COURSE_PATH).$_course['path']."/".$results[$j][3];
- $beautifulDate = api_convert_and_format_date($results[$j][0], null, date_default_timezone_get());
- echo "<tr>";
- echo "<td class='content'>"
- ."<a href ='".$pathToFile."'>".$results[$j][1]."</a>"
- ."</td>";
- echo "<td class='content'>".$results[$j][2]."</td>";
- echo "<td class='content'>".$beautifulDate."</td>";
- echo"</tr>";
- }
- } else {
- echo "<tr>";
- echo "<td colspan='3'><center>".get_lang('NoResult')."</center></td>";
- echo"</tr>";
- }
- echo "</table>";
- echo "</td></tr>";
- } else {
- $new_view = substr_replace($view,'1',2,1);
- echo "
- <tr>
- <td valign='top'>
- +<font color='#0000FF'> </font><a href='".api_get_self()."?uInfo=".Security::remove_XSS($user_id)."&view=".Security::remove_XSS($new_view)."' class='specialLink'>".get_lang('WorkUploads')."</a>
- </td>
- </tr>
- ";
- }
- }
- /**
- * Displays the links followed for a specific user in a specific course.
- * @todo remove globals
- */
- public function display_links_tracking_info($view, $user_id, $course_id)
- {
- global $TABLETRACK_LINKS, $TABLECOURSE_LINKS;
- if (substr($view,3,1) == '1') {
- $new_view = substr_replace($view,'0',3,1);
- echo "
- <tr>
- <td valign='top'>
- <font color='#0000FF'>- </font><b>".get_lang('LinksAccess')."</b> [<a href='".api_get_self()."?uInfo=".Security::remove_XSS($user_id)."&view=".Security::remove_XSS($new_view)."'>".get_lang('Close')."</a>] [<a href='userLogCSV.php?".api_get_cidreq()."&uInfo=".Security::remove_XSS($_GET['uInfo'])."&view=00010'>".get_lang('ExportAsCSV')."</a>]
- </td>
- </tr>
- ";
- echo "<tr><td style='padding-left : 40px;' valign='top'>".get_lang('LinksDetails')."<br>";
- $sql = "SELECT cl.title, cl.url
- FROM $TABLETRACK_LINKS AS sl, $TABLECOURSE_LINKS AS cl
- WHERE sl.links_link_id = cl.id
- AND sl.links_cours_id = '".Database::escape_string($course_id)."'
- AND sl.links_user_id = '".intval($user_id)."'
- GROUP BY cl.title, cl.url";
- echo "<tr><td style='padding-left : 40px;padding-right : 40px;'>";
- $results = getManyResults2Col($sql);
- echo "<table cellpadding='2' cellspacing='1' border='0' align=center>";
- echo "<tr>
- <td class='secLine'>
- ".get_lang('LinksTitleLinkColumn')."
- </td>
- </tr>";
- if (is_array($results)) {
- for($j = 0 ; $j < count($results) ; $j++) {
- echo "<tr>";
- echo "<td class='content'><a href='".$results[$j][1]."'>".$results[$j][0]."</a></td>";
- echo"</tr>";
- }
- } else {
- echo "<tr>";
- echo "<td ><center>".get_lang('NoResult')."</center></td>";
- echo"</tr>";
- }
- echo "</table>";
- echo "</td></tr>";
- } else {
- $new_view = substr_replace($view,'1',3,1);
- echo "
- <tr>
- <td valign='top'>
- +<font color='#0000FF'> </font><a href='".api_get_self()."?uInfo=".Security::remove_XSS($user_id)."&view=".Security::remove_XSS($new_view)."' class='specialLink'>".get_lang('LinksAccess')."</a>
- </td>
- </tr>
- ";
- }
- }
- /**
- * Displays the documents downloaded for a specific user in a specific course.
- * @param string kind of view inside tracking info
- * @param int User id
- * @param string Course code
- * @param int Session id (optional, default = 0)
- * @return void
- */
- public static function display_document_tracking_info($view, $user_id, $course_id, $session_id = 0) {
- // protect data
- $user_id = intval($user_id);
- $course_id = Database::escape_string($course_id);
- $session_id = intval($session_id);
- $downloads_table = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_DOWNLOADS);
- if(substr($view,4,1) == '1') {
- $new_view = substr_replace($view,'0',4,1);
- echo "
- <tr>
- <td valign='top'>
- <font color='#0000FF'>- </font><b>".get_lang('DocumentsAccess')."</b> [<a href='".api_get_self()."?uInfo=".Security::remove_XSS($user_id)."&view=".Security::remove_XSS($new_view)."'>".get_lang('Close')."</a>] [<a href='userLogCSV.php?".api_get_cidreq()."&uInfo=".Security::remove_XSS($_GET['uInfo'])."&view=00001'>".get_lang('ExportAsCSV')."</a>]
- </td>
- </tr>
- ";
- echo "<tr><td style='padding-left : 40px;' valign='top'>".get_lang('DocumentsDetails')."<br>";
- $sql = "SELECT down_doc_path
- FROM $downloads_table
- WHERE down_cours_id = '".$course_id."'
- AND down_user_id = '$user_id'
- AND down_session_id = '$session_id'
- GROUP BY down_doc_path";
- echo "<tr><td style='padding-left : 40px;padding-right : 40px;'>";
- $results = getManyResults1Col($sql);
- echo "<table cellpadding='2' cellspacing='1' border='0' align='center'>";
- echo "<tr>
- <td class='secLine'>
- ".get_lang('DocumentsTitleDocumentColumn')."
- </td>
- </tr>";
- if (is_array($results)) {
- for($j = 0 ; $j < count($results) ; $j++) {
- echo "<tr>";
- echo "<td class='content'>".$results[$j]."</td>";
- echo"</tr>";
- }
- } else {
- echo "<tr>";
- echo "<td><center>".get_lang('NoResult')."</center></td>";
- echo"</tr>";
- }
- echo "</table>";
- echo "</td></tr>";
- } else {
- $new_view = substr_replace($view,'1',4,1);
- echo "
- <tr>
- <td valign='top'>
- +<font color='#0000FF'> </font><a href='".api_get_self()."?uInfo=".Security::remove_XSS($user_id)."&view=".Security::remove_XSS($new_view)."' class='specialLink'>".get_lang('DocumentsAccess')."</a>
- </td>
- </tr>
- ";
- }
- }
- /**
- * Gets the IP of a given user, using the last login before the given date
- * @param int User ID
- * @param string Datetime
- * @param bool Whether to return the IP as a link or just as an IP
- * @param string If defined and return_as_link if true, will be used as the text to be shown as the link
- * @return string IP address (or false on error)
- * @assert (0,0) === false
- */
- public static function get_ip_from_user_event($user_id, $event_date, $return_as_link = false, $body_replace = null) {
- if (empty($user_id) or empty($event_date)) {
- return false;
- }
- $table_login = Database :: get_main_table(TABLE_STATISTIC_TRACK_E_LOGIN);
- $sql_ip = "SELECT login_date, login_ip FROM $table_login WHERE login_user_id = $user_id AND login_date < '$event_date' ORDER BY login_date DESC LIMIT 1";
- $ip = '';
- $res_ip = Database::query($sql_ip);
- if ($res_ip !== false && Database::num_rows($res_ip)>0) {
- $row_ip = Database::fetch_row($res_ip);
- if ($return_as_link) {
- $ip = Display::url((empty($body_replace)?$row_ip[1]:$body_replace), 'http://www.whatsmyip.org/ip-geo-location/?ip='.$row_ip[1], array('title'=>get_lang('TraceIP'), 'target'=>'_blank'));
- } else {
- $ip = $row_ip[1];
- }
- }
- return $ip;
- }
- }
- /**
- * @package chamilo.tracking
- */
- class TrackingUserLogCSV
- {
- /**
- * Displays the number of logins every month for a specific user in a specific course.
- */
- public function display_login_tracking_info($view, $user_id, $course_id, $session_id = 0)
- {
- $MonthsLong = $GLOBALS['MonthsLong'];
- $track_access_table = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_ACCESS);
- // protected data
- $user_id = intval($user_id);
- $session_id = intval($session_id);
- $course_id = Database::escape_string($course_id);
- $tempView = $view;
- if(substr($view,0,1) == '1')
- {
- $new_view = substr_replace($view,'0',0,1);
- $title[1]= get_lang('LoginsAndAccessTools').get_lang('LoginsDetails');
- $sql = "SELECT UNIX_TIMESTAMP(access_date), count(access_date)
- FROM $track_access_table
- WHERE access_user_id = '$user_id'
- AND access_cours_code = '".$course_id."'
- AND access_session_id = '$session_id'
- GROUP BY YEAR(access_date),MONTH(access_date)
- ORDER BY YEAR(access_date),MONTH(access_date) ASC";
- //$results = getManyResults2Col($sql);
- $results = getManyResults3Col($sql);
- $title_line= get_lang('LoginsTitleMonthColumn').';'.get_lang('LoginsTitleCountColumn')."\n";
- $line='';
- $total = 0;
- if (is_array($results)) {
- for($j = 0 ; $j < count($results) ; $j++) {
- $line .= $results[$j][0].';'.$results[$j][1]."\n";
- $total = $total + $results[$j][1];
- }
- $line .= get_lang('Total').";".$total."\n";
- } else {
- $line= get_lang('NoResult')."</center></td>";
- }
- } else {
- $new_view = substr_replace($view,'1',0,1);
- }
- return array($title_line, $line);
- }
- /**
- * Displays the exercise results for a specific user in a specific course.
- * @todo remove globals
- */
- public function display_exercise_tracking_info($view, $user_id, $course_id)
- {
- global $TABLECOURSE_EXERCICES, $TABLETRACK_EXERCICES, $TABLETRACK_HOTPOTATOES, $dateTimeFormatLong;
- if (substr($view,1,1) == '1') {
- $new_view = substr_replace($view,'0',1,1);
- $title[1]= get_lang('ExercicesDetails');
- $line='';
- $sql = "SELECT ce.title, te.exe_result , te.exe_weighting, UNIX_TIMESTAMP(te.exe_date)
- FROM $TABLECOURSE_EXERCICES AS ce , $TABLETRACK_EXERCICES AS te
- WHERE te.exe_cours_id = '$course_id'
- AND te.exe_user_id = '$user_id'
- AND te.exe_exo_id = ce.id
- ORDER BY ce.title ASC, te.exe_date ASC";
- $hpsql = "SELECT te.exe_name, te.exe_result , te.exe_weighting, UNIX_TIMESTAMP(te.exe_date)
- FROM $TABLETRACK_HOTPOTATOES AS te
- WHERE te.exe_user_id = '$user_id' AND te.exe_cours_id = '$course_id'
- ORDER BY te.exe_cours_id ASC, te.exe_date ASC";
- $hpresults = getManyResultsXCol($hpsql, 4);
- $NoTestRes = 0;
- $NoHPTestRes = 0;
- $results = getManyResultsXCol($sql, 4);
- $title_line=get_lang('ExercicesTitleExerciceColumn').";".get_lang('Date').';'.get_lang('ExercicesTitleScoreColumn')."\n";
- if (is_array($results)) {
- for($i = 0; $i < sizeof($results); $i++)
- {
- $display_date = api_convert_and_format_date($results[$i][3], null, date_default_timezone_get());
- $line .= $results[$i][0].";".$display_date.";".$results[$i][1]." / ".$results[$i][2]."\n";
- }
- } else {
- // istvan begin
- $NoTestRes = 1;
- }
- // The Result of Tests
- if (is_array($hpresults)) {
- for($i = 0; $i < sizeof($hpresults); $i++) {
- $title = GetQuizName($hpresults[$i][0],'');
- if ($title == '')
- $title = basename($hpresults[$i][0]);
- $display_date = api_convert_and_format_date($hpresults[$i][3], null, date_default_timezone_get());
- $line .= $title.';'.$display_date.';'.$hpresults[$i][1].'/'.$hpresults[$i][2]."\n";
- }
- } else {
- $NoHPTestRes = 1;
- }
- if ($NoTestRes == 1 && $NoHPTestRes == 1) {
- $line=get_lang('NoResult');
- }
- } else {
- $new_view = substr_replace($view,'1',1,1);
- }
- return array($title_line, $line);
- }
- /**
- * Displays the student publications for a specific user in a specific course.
- * @todo remove globals
- */
- public function display_student_publications_tracking_info($view, $user_id, $course_id)
- {
- global $TABLETRACK_UPLOADS, $TABLECOURSE_WORK, $dateTimeFormatLong, $_course;
- if (substr($view,2,1) == '1') {
- $new_view = substr_replace($view,'0',2,1);
- $sql = "SELECT u.upload_date, w.title, w.author, w.url
- FROM $TABLETRACK_UPLOADS u , $TABLECOURSE_WORK w
- WHERE u.upload_work_id = w.id
- AND u.upload_user_id = '$user_id'
- AND u.upload_cours_id = '$course_id'
- ORDER BY u.upload_date DESC";
- $results = getManyResultsXCol($sql,4);
- $title[1]=get_lang('WorksDetails');
- $line='';
- $title_line=get_lang('WorkTitle').";".get_lang('WorkAuthors').";".get_lang('Date')."\n";
- if (is_array($results)) {
- for($j = 0 ; $j < count($results) ; $j++) {
- $pathToFile = api_get_path(WEB_COURSE_PATH).$_course['path']."/".$results[$j][3];
- $beautifulDate = api_convert_and_format_date($results[$j][0], null, date_default_timezone_get());
- $line .= $results[$j][1].";".$results[$j][2].";".$beautifulDate."\n";
- }
- } else {
- $line= get_lang('NoResult');
- }
- } else {
- $new_view = substr_replace($view,'1',2,1);
- }
- return array($title_line, $line);
- }
- /**
- * Displays the links followed for a specific user in a specific course.
- * @todo remove globals
- */
- public function display_links_tracking_info($view, $user_id, $course_id)
- {
- global $TABLETRACK_LINKS, $TABLECOURSE_LINKS;
- $line = null;
- if (substr($view,3,1) == '1') {
- $new_view = substr_replace($view,'0',3,1);
- $title[1]=get_lang('LinksDetails');
- $sql = "SELECT cl.title, cl.url
- FROM $TABLETRACK_LINKS AS sl, $TABLECOURSE_LINKS AS cl
- WHERE sl.links_link_id = cl.id
- AND sl.links_cours_id = '$course_id'
- AND sl.links_user_id = '$user_id'
- GROUP BY cl.title, cl.url";
- $results = getManyResults2Col($sql);
- $title_line= get_lang('LinksTitleLinkColumn')."\n";
- if (is_array($results)) {
- for ($j = 0 ; $j < count($results) ; $j++) {
- $line .= $results[$j][0]."\n";
- }
- } else {
- $line=get_lang('NoResult');
- }
- } else {
- $new_view = substr_replace($view,'1',3,1);
- }
- return array($title_line, $line);
- }
- /**
- * Displays the documents downloaded for a specific user in a specific course.
- * @param string kind of view inside tracking info
- * @param int User id
- * @param string Course code
- * @param int Session id (optional, default = 0)
- * @return void
- */
- public function display_document_tracking_info($view, $user_id, $course_id, $session_id = 0)
- {
- // protect data
- $user_id = intval($user_id);
- $course_id = Database::escape_string($course_id);
- $session_id = intval($session_id);
- $downloads_table = Database::get_statistic_table(TABLE_STATISTIC_TRACK_E_DOWNLOADS);
- if (substr($view,4,1) == '1') {
- $new_view = substr_replace($view,'0',4,1);
- $title[1]= get_lang('DocumentsDetails');
- $sql = "SELECT down_doc_path
- FROM $downloads_table
- WHERE down_cours_id = '$course_id'
- AND down_user_id = '$user_id'
- AND down_session_id = '$session_id'
- GROUP BY down_doc_path";
- $results = getManyResults1Col($sql);
- $title_line = get_lang('DocumentsTitleDocumentColumn')."\n";
- $line = null;
- if (is_array($results)) {
- for ($j = 0 ; $j < count($results) ; $j++) {
- $line .= $results[$j]."\n";
- }
- } else {
- $line = get_lang('NoResult');
- }
- } else {
- $new_view = substr_replace($view,'1',4,1);
- }
- return array($title_line, $line);
- }
- /**
- * @param $userId
- * @param $courseInfo
- * @param int $sessionId
- * @return array
- */
- public static function getToolInformation(
- $userId,
- $courseInfo,
- $sessionId = 0
- ) {
- $csvContent = array();
- $courseToolInformation = null;
- $headerTool = array(
- array(get_lang('Title')),
- array(get_lang('CreatedAt')),
- array(get_lang('UpdatedAt')),
- );
- $headerListForCSV = array();
- foreach ($headerTool as $item) {
- $headerListForCSV[] = $item[0];
- }
- $courseForumInformationArray = getForumCreatedByUser(
- $userId,
- $courseInfo['real_id'],
- $sessionId
- );
- if (!empty($courseForumInformationArray)) {
- $csvContent[] = array();
- $csvContent[] = get_lang('Forums');
- $csvContent[] = $headerListForCSV;
- foreach ($courseForumInformationArray as $row) {
- $csvContent[] = $row;
- }
- $courseToolInformation .= Display::page_subheader2(
- get_lang('Forums')
- );
- $courseToolInformation .= Display::return_sortable_table(
- $headerTool,
- $courseForumInformationArray
- );
- }
- $courseWorkInformationArray = getWorkCreatedByUser(
- $userId,
- $courseInfo['real_id'],
- $sessionId
- );
- if (!empty($courseWorkInformationArray)) {
- $csvContent[] = null;
- $csvContent[] = get_lang('Works');
- $csvContent[] = $headerListForCSV;
- foreach ($courseWorkInformationArray as $row) {
- $csvContent[] = $row;
- }
- $csvContent[] = null;
- $courseToolInformation .= Display::page_subheader2(
- get_lang('Works')
- );
- $courseToolInformation .= Display::return_sortable_table(
- $headerTool,
- $courseWorkInformationArray
- );
- }
- $courseToolInformationTotal = null;
- if (!empty($courseToolInformation)) {
- $sessionTitle = null;
- if (!empty($sessionId)) {
- $sessionTitle = ' ('.api_get_session_name($sessionId).')';
- }
- $courseToolInformationTotal .= Display::page_subheader(
- $courseInfo['title'].$sessionTitle
- );
- $courseToolInformationTotal .= $courseToolInformation;
- }
- return array(
- 'array' => $csvContent,
- 'html' => $courseToolInformationTotal,
- );
- }
- }
|