123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846684768486849685068516852685368546855685668576858685968606861686268636864686568666867686868696870687168726873687468756876687768786879688068816882688368846885688668876888688968906891689268936894689568966897689868996900690169026903690469056906690769086909691069116912691369146915691669176918691969206921692269236924692569266927692869296930693169326933693469356936693769386939694069416942694369446945694669476948694969506951695269536954695569566957695869596960696169626963696469656966696769686969697069716972697369746975697669776978697969806981698269836984698569866987698869896990699169926993699469956996699769986999700070017002700370047005700670077008700970107011701270137014701570167017701870197020702170227023702470257026702770287029703070317032703370347035703670377038703970407041704270437044704570467047704870497050705170527053705470557056705770587059706070617062706370647065706670677068706970707071707270737074707570767077707870797080708170827083708470857086708770887089709070917092709370947095709670977098709971007101710271037104710571067107710871097110711171127113711471157116711771187119712071217122712371247125712671277128712971307131713271337134713571367137713871397140714171427143714471457146714771487149715071517152715371547155715671577158715971607161716271637164716571667167716871697170717171727173717471757176717771787179718071817182718371847185718671877188718971907191719271937194719571967197719871997200720172027203720472057206720772087209721072117212721372147215721672177218721972207221722272237224722572267227722872297230723172327233723472357236723772387239724072417242724372447245724672477248724972507251725272537254725572567257725872597260726172627263726472657266726772687269727072717272727372747275727672777278727972807281728272837284728572867287728872897290729172927293729472957296729772987299730073017302730373047305730673077308730973107311731273137314731573167317731873197320732173227323732473257326732773287329733073317332733373347335733673377338733973407341734273437344734573467347734873497350735173527353735473557356735773587359736073617362736373647365736673677368736973707371737273737374737573767377737873797380738173827383738473857386738773887389739073917392739373947395739673977398739974007401740274037404740574067407740874097410741174127413741474157416741774187419742074217422742374247425742674277428742974307431743274337434743574367437743874397440744174427443744474457446744774487449745074517452745374547455745674577458745974607461746274637464746574667467746874697470747174727473747474757476747774787479748074817482748374847485748674877488748974907491749274937494749574967497749874997500750175027503750475057506750775087509751075117512751375147515751675177518751975207521752275237524752575267527752875297530753175327533753475357536753775387539754075417542754375447545754675477548754975507551755275537554755575567557755875597560756175627563756475657566756775687569757075717572757375747575757675777578757975807581758275837584758575867587758875897590759175927593759475957596759775987599760076017602760376047605760676077608760976107611761276137614761576167617761876197620762176227623762476257626762776287629763076317632763376347635763676377638763976407641764276437644764576467647764876497650765176527653765476557656765776587659766076617662766376647665766676677668766976707671767276737674767576767677767876797680768176827683768476857686768776887689769076917692769376947695769676977698769977007701770277037704770577067707770877097710771177127713771477157716771777187719772077217722772377247725772677277728772977307731773277337734773577367737773877397740774177427743774477457746774777487749775077517752775377547755775677577758775977607761776277637764776577667767776877697770777177727773777477757776777777787779778077817782778377847785778677877788778977907791779277937794779577967797779877997800780178027803780478057806780778087809781078117812781378147815781678177818781978207821782278237824782578267827782878297830783178327833783478357836783778387839784078417842784378447845784678477848784978507851785278537854785578567857785878597860786178627863786478657866786778687869787078717872787378747875787678777878787978807881788278837884788578867887788878897890789178927893789478957896789778987899790079017902790379047905790679077908790979107911791279137914791579167917791879197920792179227923792479257926792779287929793079317932793379347935793679377938793979407941794279437944794579467947794879497950795179527953795479557956795779587959796079617962796379647965796679677968796979707971797279737974797579767977797879797980798179827983798479857986798779887989799079917992799379947995799679977998799980008001800280038004800580068007800880098010801180128013801480158016801780188019802080218022802380248025802680278028802980308031803280338034803580368037803880398040804180428043804480458046804780488049805080518052805380548055805680578058805980608061806280638064806580668067806880698070807180728073807480758076807780788079808080818082808380848085808680878088808980908091809280938094809580968097809880998100810181028103810481058106810781088109811081118112811381148115811681178118811981208121812281238124812581268127812881298130813181328133813481358136813781388139814081418142814381448145814681478148814981508151815281538154815581568157815881598160816181628163816481658166816781688169817081718172817381748175817681778178817981808181818281838184818581868187818881898190819181928193819481958196819781988199820082018202820382048205820682078208820982108211821282138214821582168217821882198220822182228223822482258226822782288229823082318232823382348235823682378238823982408241824282438244824582468247824882498250825182528253825482558256825782588259826082618262826382648265826682678268826982708271827282738274827582768277827882798280828182828283828482858286828782888289829082918292829382948295829682978298829983008301830283038304830583068307830883098310831183128313831483158316831783188319832083218322832383248325832683278328832983308331833283338334833583368337833883398340834183428343834483458346834783488349835083518352835383548355835683578358835983608361836283638364836583668367836883698370837183728373837483758376837783788379838083818382838383848385838683878388838983908391839283938394839583968397839883998400840184028403840484058406840784088409841084118412841384148415841684178418841984208421842284238424842584268427842884298430843184328433843484358436843784388439844084418442844384448445844684478448844984508451845284538454845584568457845884598460846184628463846484658466846784688469847084718472847384748475847684778478847984808481848284838484848584868487848884898490849184928493849484958496849784988499850085018502850385048505850685078508850985108511851285138514851585168517851885198520852185228523852485258526852785288529853085318532853385348535853685378538853985408541854285438544854585468547854885498550855185528553855485558556855785588559856085618562856385648565856685678568856985708571857285738574857585768577857885798580858185828583858485858586858785888589859085918592859385948595859685978598859986008601860286038604860586068607860886098610861186128613861486158616861786188619862086218622862386248625862686278628862986308631863286338634863586368637863886398640864186428643864486458646864786488649865086518652865386548655865686578658865986608661866286638664866586668667866886698670867186728673867486758676867786788679868086818682868386848685868686878688868986908691869286938694869586968697869886998700870187028703870487058706870787088709871087118712871387148715871687178718871987208721872287238724872587268727872887298730873187328733873487358736873787388739874087418742874387448745874687478748874987508751875287538754875587568757875887598760876187628763876487658766876787688769877087718772877387748775877687778778877987808781878287838784878587868787878887898790879187928793879487958796879787988799880088018802880388048805880688078808880988108811881288138814881588168817881888198820882188228823882488258826882788288829883088318832883388348835883688378838883988408841884288438844884588468847884888498850885188528853885488558856885788588859886088618862886388648865886688678868886988708871887288738874887588768877887888798880888188828883888488858886888788888889889088918892889388948895889688978898889989008901890289038904890589068907890889098910891189128913891489158916891789188919892089218922892389248925892689278928892989308931893289338934893589368937893889398940894189428943894489458946894789488949895089518952895389548955895689578958895989608961896289638964896589668967896889698970897189728973897489758976897789788979898089818982898389848985898689878988898989908991899289938994899589968997899889999000900190029003900490059006900790089009901090119012901390149015901690179018901990209021902290239024902590269027902890299030903190329033903490359036903790389039904090419042904390449045904690479048904990509051905290539054905590569057905890599060906190629063906490659066906790689069907090719072907390749075907690779078907990809081908290839084908590869087908890899090909190929093909490959096909790989099910091019102910391049105910691079108910991109111911291139114911591169117911891199120912191229123912491259126912791289129913091319132913391349135913691379138913991409141914291439144914591469147914891499150915191529153915491559156915791589159916091619162916391649165916691679168916991709171917291739174917591769177917891799180918191829183918491859186918791889189919091919192919391949195919691979198919992009201920292039204920592069207920892099210921192129213921492159216921792189219922092219222922392249225922692279228922992309231923292339234923592369237923892399240924192429243924492459246924792489249925092519252925392549255925692579258925992609261926292639264926592669267926892699270927192729273927492759276927792789279928092819282928392849285928692879288928992909291929292939294929592969297929892999300 |
- <?php
- /* For licensing terms, see /license.txt */
- use Chamilo\CoreBundle\Entity\Course;
- use Chamilo\CoreBundle\Entity\ExtraField;
- use Chamilo\CoreBundle\Entity\SequenceResource;
- use Chamilo\CoreBundle\Entity\Session;
- use Chamilo\CoreBundle\Entity\SessionRelCourse;
- use Chamilo\CoreBundle\Entity\SessionRelCourseRelUser;
- use Chamilo\CoreBundle\Entity\SessionRelUser;
- use Chamilo\CoreBundle\Repository\SequenceRepository;
- use Chamilo\UserBundle\Entity\User;
- use ExtraField as ExtraFieldModel;
- use Monolog\Logger;
- /**
- * Class SessionManager.
- *
- * This is the session library for Chamilo
- * (as in courses>session, not as in PHP session)
- * All main sessions functions should be placed here.
- * This class provides methods for sessions management.
- * Include/require it in your code to use its features.
- */
- class SessionManager
- {
- // See BT#4871
- public const SESSION_CHANGE_USER_REASON_SCHEDULE = 1;
- public const SESSION_CHANGE_USER_REASON_CLASSROOM = 2;
- public const SESSION_CHANGE_USER_REASON_LOCATION = 3;
- public const SESSION_CHANGE_USER_REASON_ENROLLMENT_ANNULATION = 4;
- public const DEFAULT_VISIBILITY = 4; //SESSION_AVAILABLE
- public static $_debug = false;
- /**
- * Constructor.
- */
- public function __construct()
- {
- }
- /**
- * Fetches a session from the database.
- *
- * @param int $id Session Id
- *
- * @return array Session details
- */
- public static function fetch($id)
- {
- $em = Database::getManager();
- if (empty($id)) {
- return [];
- }
- /** @var Session $session */
- $session = $em->find('ChamiloCoreBundle:Session', $id);
- if (!$session) {
- return [];
- }
- $result = [
- 'id' => $session->getId(),
- 'id_coach' => $session->getGeneralCoach() ? $session->getGeneralCoach()->getId() : null,
- 'session_category_id' => $session->getCategory() ? $session->getCategory()->getId() : null,
- 'name' => $session->getName(),
- 'description' => $session->getDescription(),
- 'show_description' => $session->getShowDescription(),
- 'duration' => $session->getDuration(),
- 'nbr_courses' => $session->getNbrCourses(),
- 'nbr_users' => $session->getNbrUsers(),
- 'nbr_classes' => $session->getNbrClasses(),
- 'session_admin_id' => $session->getSessionAdminId(),
- 'visibility' => $session->getVisibility(),
- 'promotion_id' => $session->getPromotionId(),
- 'display_start_date' => $session->getDisplayStartDate()
- ? $session->getDisplayStartDate()->format('Y-m-d H:i:s')
- : null,
- 'display_end_date' => $session->getDisplayEndDate()
- ? $session->getDisplayEndDate()->format('Y-m-d H:i:s')
- : null,
- 'access_start_date' => $session->getAccessStartDate()
- ? $session->getAccessStartDate()->format('Y-m-d H:i:s')
- : null,
- 'access_end_date' => $session->getAccessEndDate()
- ? $session->getAccessEndDate()->format('Y-m-d H:i:s')
- : null,
- 'coach_access_start_date' => $session->getCoachAccessStartDate()
- ? $session->getCoachAccessStartDate()->format('Y-m-d H:i:s')
- : null,
- 'coach_access_end_date' => $session->getCoachAccessEndDate()
- ? $session->getCoachAccessEndDate()->format('Y-m-d H:i:s')
- : null,
- 'send_subscription_notification' => $session->getSendSubscriptionNotification(),
- ];
- // Converted to local values
- $variables = [
- 'display_start_date',
- 'display_end_date',
- 'access_start_date',
- 'access_end_date',
- 'coach_access_start_date',
- 'coach_access_end_date',
- ];
- foreach ($variables as $value) {
- $result[$value.'_to_local_time'] = null;
- if (!empty($result[$value])) {
- $result[$value.'_to_local_time'] = api_get_local_time($result[$value]);
- }
- }
- return $result;
- }
- /**
- * Create a session.
- *
- * @author Carlos Vargas <carlos.vargas@beeznest.com>, from existing code
- *
- * @param string $name
- * @param string $startDate (YYYY-MM-DD hh:mm:ss)
- * @param string $endDate (YYYY-MM-DD hh:mm:ss)
- * @param string $displayStartDate (YYYY-MM-DD hh:mm:ss)
- * @param string $displayEndDate (YYYY-MM-DD hh:mm:ss)
- * @param string $coachStartDate (YYYY-MM-DD hh:mm:ss)
- * @param string $coachEndDate (YYYY-MM-DD hh:mm:ss)
- * @param mixed $coachId If int, this is the session coach id,
- * if string, the coach ID will be looked for from the user table
- * @param int $sessionCategoryId ID of the session category in which this session is registered
- * @param int $visibility Visibility after end date (0 = read-only, 1 = invisible, 2 = accessible)
- * @param bool $fixSessionNameIfExists
- * @param string $duration
- * @param string $description Optional. The session description
- * @param int $showDescription Optional. Whether show the session description
- * @param array $extraFields
- * @param int $sessionAdminId Optional. If this sessions was created by a session admin, assign it to him
- * @param bool $sendSubscriptionNotification Optional.
- * Whether send a mail notification to users being subscribed
- * @param int|null $accessUrlId Optional.
- *
- * @return mixed Session ID on success, error message otherwise
- *
- * @todo use an array to replace all this parameters or use the model.lib.php ...
- */
- public static function create_session(
- $name,
- $startDate,
- $endDate,
- $displayStartDate,
- $displayEndDate,
- $coachStartDate,
- $coachEndDate,
- $coachId,
- $sessionCategoryId,
- $visibility = 1,
- $fixSessionNameIfExists = false,
- $duration = null,
- $description = null,
- $showDescription = 0,
- $extraFields = [],
- $sessionAdminId = 0,
- $sendSubscriptionNotification = false,
- $accessUrlId = null
- ) {
- global $_configuration;
- // Check portal limits
- $accessUrlId = api_is_multiple_url_enabled()
- ? (empty($accessUrlId) ? api_get_current_access_url_id() : (int) $accessUrlId)
- : 1;
- if (isset($_configuration[$accessUrlId]) &&
- is_array($_configuration[$accessUrlId]) &&
- isset($_configuration[$accessUrlId]['hosting_limit_sessions']) &&
- $_configuration[$accessUrlId]['hosting_limit_sessions'] > 0
- ) {
- $num = self::count_sessions();
- if ($num >= $_configuration[$accessUrlId]['hosting_limit_sessions']) {
- api_warn_hosting_contact('hosting_limit_sessions');
- return get_lang('The number of sessions limit for this portal has been reached');
- }
- }
- $name = Database::escape_string(trim($name));
- $sessionCategoryId = (int) $sessionCategoryId;
- $visibility = (int) $visibility;
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $startDate = Database::escape_string($startDate);
- $endDate = Database::escape_string($endDate);
- if (empty($name)) {
- $msg = get_lang('A name is required for the session');
- return $msg;
- } elseif (!empty($startDate) && !api_is_valid_date($startDate, 'Y-m-d H:i') &&
- !api_is_valid_date($startDate, 'Y-m-d H:i:s')
- ) {
- $msg = get_lang('Invalid start date was given.');
- return $msg;
- } elseif (!empty($endDate) && !api_is_valid_date($endDate, 'Y-m-d H:i') &&
- !api_is_valid_date($endDate, 'Y-m-d H:i:s')
- ) {
- $msg = get_lang('Invalid end date was given.');
- return $msg;
- } elseif (!empty($startDate) && !empty($endDate) && $startDate >= $endDate) {
- $msg = get_lang('The first date should be before the end date');
- return $msg;
- } else {
- $ready_to_create = false;
- if ($fixSessionNameIfExists) {
- $name = self::generateNextSessionName($name);
- if ($name) {
- $ready_to_create = true;
- } else {
- $msg = get_lang('Session name already exists');
- return $msg;
- }
- } else {
- $rs = Database::query("SELECT 1 FROM $tbl_session WHERE name='".$name."'");
- if (Database::num_rows($rs)) {
- $msg = get_lang('Session name already exists');
- return $msg;
- }
- $ready_to_create = true;
- }
- if ($ready_to_create) {
- $sessionAdminId = !empty($sessionAdminId) ? $sessionAdminId : api_get_user_id();
- $values = [
- 'name' => $name,
- 'id_coach' => $coachId,
- 'session_admin_id' => $sessionAdminId,
- 'visibility' => $visibility,
- 'description' => $description,
- 'show_description' => $showDescription,
- 'send_subscription_notification' => (int) $sendSubscriptionNotification,
- ];
- if (!empty($startDate)) {
- $values['access_start_date'] = api_get_utc_datetime($startDate);
- }
- if (!empty($endDate)) {
- $values['access_end_date'] = api_get_utc_datetime($endDate);
- }
- if (!empty($displayStartDate)) {
- $values['display_start_date'] = api_get_utc_datetime($displayStartDate);
- }
- if (!empty($displayEndDate)) {
- $values['display_end_date'] = api_get_utc_datetime($displayEndDate);
- }
- if (!empty($coachStartDate)) {
- $values['coach_access_start_date'] = api_get_utc_datetime($coachStartDate);
- }
- if (!empty($coachEndDate)) {
- $values['coach_access_end_date'] = api_get_utc_datetime($coachEndDate);
- }
- if (!empty($sessionCategoryId)) {
- $values['session_category_id'] = $sessionCategoryId;
- }
- $values['position'] = 0;
- $session_id = Database::insert($tbl_session, $values);
- $duration = (int) $duration;
- if (!empty($duration)) {
- $sql = "UPDATE $tbl_session SET
- access_start_date = NULL,
- access_end_date = NULL,
- display_start_date = NULL,
- display_end_date = NULL,
- coach_access_start_date = NULL,
- coach_access_end_date = NULL,
- duration = $duration
- WHERE id = $session_id";
- Database::query($sql);
- } else {
- $sql = "UPDATE $tbl_session
- SET duration = 0
- WHERE id = $session_id";
- Database::query($sql);
- }
- if (!empty($session_id)) {
- $extraFields['item_id'] = $session_id;
- $sessionFieldValue = new ExtraFieldValue('session');
- $sessionFieldValue->saveFieldValues($extraFields);
- /*
- Sends a message to the user_id = 1
- $user_info = api_get_user_info(1);
- $complete_name = $user_info['firstname'].' '.$user_info['lastname'];
- $subject = api_get_setting('siteName').' - '.get_lang('A new session has been created');
- $message = get_lang('A new session has been created')." <br /> ".get_lang('Session name').' : '.$name;
- api_mail_html($complete_name, $user_info['email'], $subject, $message);
- *
- */
- // Adding to the correct URL
- UrlManager::add_session_to_url($session_id, $accessUrlId);
- // add event to system log
- $user_id = api_get_user_id();
- Event::addEvent(
- LOG_SESSION_CREATE,
- LOG_SESSION_ID,
- $session_id,
- api_get_utc_datetime(),
- $user_id
- );
- }
- return $session_id;
- }
- }
- }
- /**
- * @param string $name
- *
- * @return bool
- */
- public static function sessionNameExists($name)
- {
- $name = Database::escape_string($name);
- $sql = "SELECT COUNT(*) as count FROM ".Database::get_main_table(TABLE_MAIN_SESSION)."
- WHERE name = '$name'";
- $result = Database::fetch_array(Database::query($sql));
- return $result['count'] > 0;
- }
- /**
- * @param string $where_condition
- *
- * @return mixed
- */
- public static function get_count_admin($where_condition = '')
- {
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $tbl_session_category = Database::get_main_table(TABLE_MAIN_SESSION_CATEGORY);
- $tbl_user = Database::get_main_table(TABLE_MAIN_USER);
- $table_access_url_rel_session = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $tbl_session_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $where = 'WHERE 1=1 ';
- $user_id = api_get_user_id();
- $extraJoin = '';
- if (api_is_session_admin() &&
- api_get_setting('allow_session_admins_to_manage_all_sessions') == 'false'
- ) {
- $where .= " AND (
- s.session_admin_id = $user_id OR
- sru.user_id = '$user_id' AND
- sru.relation_type = '".SESSION_RELATION_TYPE_RRHH."'
- )
- ";
- $extraJoin = " INNER JOIN $tbl_session_rel_user sru
- ON sru.session_id = s.id ";
- }
- $today = api_get_utc_datetime();
- $today = api_strtotime($today, 'UTC');
- $today = date('Y-m-d', $today);
- if (!empty($where_condition)) {
- $where_condition = str_replace("( session_active = ':' )", '1=1', $where_condition);
- $where_condition = str_replace('category_name', 'sc.name', $where_condition);
- $where_condition = str_replace(
- ["AND session_active = '1' )", " AND ( session_active = '1' )"],
- [') GROUP BY s.name HAVING session_active = 1 ', " GROUP BY s.name HAVING session_active = 1 "],
- $where_condition
- );
- $where_condition = str_replace(
- ["AND session_active = '0' )", " AND ( session_active = '0' )"],
- [') GROUP BY s.name HAVING session_active = 0 ', " GROUP BY s.name HAVING session_active = '0' "],
- $where_condition
- );
- } else {
- $where_condition = " AND 1 = 1";
- }
- $courseCondition = null;
- if (strpos($where_condition, 'c.id')) {
- $table = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $tableCourse = Database::get_main_table(TABLE_MAIN_COURSE);
- $courseCondition = " INNER JOIN $table course_rel_session
- ON (s.id = course_rel_session.session_id)
- INNER JOIN $tableCourse c
- ON (course_rel_session.c_id = c.id)
- ";
- }
- $sql = "SELECT COUNT(id) as total_rows FROM (
- SELECT DISTINCT
- IF (
- (s.access_start_date <= '$today' AND '$today' <= s.access_end_date) OR
- (s.access_start_date IS NULL AND s.access_end_date = IS NULL ) OR
- (s.access_start_date <= '$today' AND s.access_end_date IS NULL) OR
- ('$today' <= s.access_end_date AND s.access_start_date IS NULL)
- , 1, 0) as session_active,
- s.id
- FROM $tbl_session s
- LEFT JOIN $tbl_session_category sc
- ON s.session_category_id = sc.id
- INNER JOIN $tbl_user u
- ON s.id_coach = u.user_id
- $courseCondition
- $extraJoin
- $where $where_condition ) as session_table";
- if (api_is_multiple_url_enabled()) {
- $access_url_id = api_get_current_access_url_id();
- if ($access_url_id != -1) {
- $where .= " AND ar.access_url_id = $access_url_id ";
- $sql = "SELECT count(id) as total_rows FROM (
- SELECT DISTINCT
- IF (
- (s.access_start_date <= '$today' AND '$today' <= s.access_end_date) OR
- (s.access_start_date IS NULL AND s.access_end_date IS NULL) OR
- (s.access_start_date <= '$today' AND s.access_end_date IS NULL) OR
- ('$today' <= s.access_end_date AND s.access_start_date IS NULL)
- , 1, 0)
- as session_active,
- s.id
- FROM $tbl_session s
- LEFT JOIN $tbl_session_category sc
- ON s.session_category_id = sc.id
- INNER JOIN $tbl_user u ON s.id_coach = u.user_id
- INNER JOIN $table_access_url_rel_session ar
- ON ar.session_id = s.id
- $courseCondition
- $extraJoin
- $where $where_condition) as session_table";
- }
- }
- $result_rows = Database::query($sql);
- $row = Database::fetch_array($result_rows);
- $num = $row['total_rows'];
- return $num;
- }
- /**
- * Get session list for a session admin or platform admin.
- *
- * @param int $userId User Id for the session admin.
- * @param array $options Optional. Order and limit keys.
- * @param bool $getCount Optional. Whether to get all the results or only the count.
- * @param array $columns Optional. Columns from jqGrid.
- *
- * @return array
- */
- public static function getSessionsForAdmin(
- $userId,
- $options = [],
- $getCount = false,
- $columns = []
- ) {
- $tblSession = Database::get_main_table(TABLE_MAIN_SESSION);
- $sessionCategoryTable = Database::get_main_table(TABLE_MAIN_SESSION_CATEGORY);
- $where = 'WHERE 1 = 1 ';
- $userId = (int) $userId;
- if (!api_is_platform_admin()) {
- if (api_is_session_admin() &&
- api_get_setting('allow_session_admins_to_manage_all_sessions') === 'false'
- ) {
- $where .= " AND s.session_admin_id = $userId ";
- }
- }
- if (!api_is_platform_admin() &&
- api_is_teacher() &&
- api_get_setting('allow_teachers_to_create_sessions') === 'true'
- ) {
- $where .= " AND s.id_coach = $userId ";
- }
- $extraFieldModel = new ExtraFieldModel('session');
- $conditions = $extraFieldModel->parseConditions($options);
- $sqlInjectJoins = $conditions['inject_joins'];
- $where .= $conditions['where'];
- $sqlInjectWhere = $conditions['inject_where'];
- $inject_extra_fields = $conditions['inject_extra_fields'];
- $order = $conditions['order'];
- $limit = $conditions['limit'];
- $isMakingOrder = false;
- $showCountUsers = false;
- if ($getCount === true) {
- $select = ' SELECT count(DISTINCT s.id) as total_rows ';
- } else {
- if (!empty($columns['column_model'])) {
- foreach ($columns['column_model'] as $column) {
- if ($column['name'] == 'users') {
- $showCountUsers = true;
- }
- }
- }
- $select =
- "SELECT DISTINCT
- s.name,
- s.display_start_date,
- s.display_end_date,
- access_start_date,
- access_end_date,
- s.visibility,
- s.session_category_id,
- $inject_extra_fields
- s.id
- ";
- if ($showCountUsers) {
- $select .= ', count(su.user_id) users';
- }
- if (isset($options['order'])) {
- $isMakingOrder = strpos($options['order'], 'category_name') === 0;
- }
- }
- $isFilteringSessionCategory = strpos($where, 'category_name') !== false;
- $isFilteringSessionCategoryWithName = strpos($where, 'sc.name') !== false;
- if ($isMakingOrder || $isFilteringSessionCategory || $isFilteringSessionCategoryWithName) {
- $sqlInjectJoins .= " LEFT JOIN $sessionCategoryTable sc ON s.session_category_id = sc.id ";
- if ($isFilteringSessionCategory) {
- $where = str_replace('category_name', 'sc.name', $where);
- }
- if ($isMakingOrder) {
- $order = str_replace('category_name', 'sc.name', $order);
- }
- }
- if ($showCountUsers) {
- $tblSessionRelUser = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $sqlInjectJoins .= " LEFT JOIN $tblSessionRelUser su ON (su.session_id = s.id)";
- }
- $query = "$select FROM $tblSession s $sqlInjectJoins $where $sqlInjectWhere";
- if (api_is_multiple_url_enabled()) {
- $tblAccessUrlRelSession = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $accessUrlId = api_get_current_access_url_id();
- if ($accessUrlId != -1) {
- $where .= " AND ar.access_url_id = $accessUrlId ";
- $query = "$select
- FROM $tblSession s $sqlInjectJoins
- INNER JOIN $tblAccessUrlRelSession ar
- ON (ar.session_id = s.id) $where";
- }
- }
- if ($showCountUsers) {
- $query .= ' GROUP by s.id';
- }
- $allowOrder = api_get_configuration_value('session_list_order');
- if ($allowOrder) {
- $order = ' ORDER BY position ASC';
- }
- $query .= $order;
- $query .= $limit;
- $result = Database::query($query);
- $sessions = Database::store_result($result, 'ASSOC');
- if ($getCount) {
- return $sessions[0]['total_rows'];
- }
- return $sessions;
- }
- /**
- * Gets the admin session list callback of the session/session_list.php page.
- *
- * @param array $options order and limit keys
- * @param bool $getCount Whether to get all the results or only the count
- * @param array $columns
- * @param array $extraFieldsToLoad
- *
- * @return mixed Integer for number of rows, or array of results
- * @assert ([],true) !== false
- */
- public static function formatSessionsAdminForGrid(
- $options = [],
- $getCount = false,
- $columns = [],
- $extraFieldsToLoad = []
- ) {
- $showCountUsers = false;
- if (!$getCount && !empty($columns['column_model'])) {
- foreach ($columns['column_model'] as $column) {
- if ($column['name'] == 'users') {
- $showCountUsers = true;
- }
- }
- }
- $userId = api_get_user_id();
- $sessions = self::getSessionsForAdmin($userId, $options, $getCount, $columns);
- if ($getCount) {
- return (int) $sessions;
- }
- $formattedSessions = [];
- $categories = self::get_all_session_category();
- $orderedCategories = [];
- if (!empty($categories)) {
- foreach ($categories as $category) {
- $orderedCategories[$category['id']] = $category['name'];
- }
- }
- $activeIcon = Display::return_icon('accept.png', get_lang('active'));
- $inactiveIcon = Display::return_icon('error.png', get_lang('inactive'));
- foreach ($sessions as $session) {
- if ($showCountUsers) {
- $session['users'] = self::get_users_by_session($session['id'], 0, true);
- }
- $url = api_get_path(WEB_CODE_PATH).'session/resume_session.php?id_session='.$session['id'];
- if ($extraFieldsToLoad || api_is_drh()) {
- $url = api_get_path(WEB_PATH).'session/'.$session['id'].'/about/';
- }
- $session['name'] = Display::url($session['name'], $url);
- if (!empty($extraFieldsToLoad)) {
- foreach ($extraFieldsToLoad as $field) {
- $extraFieldValue = new ExtraFieldValue('session');
- $fieldData = $extraFieldValue->getAllValuesByItemAndField(
- $session['id'],
- $field['id']
- );
- $fieldDataArray = [];
- $fieldDataToString = '';
- if (!empty($fieldData)) {
- foreach ($fieldData as $data) {
- $fieldDataArray[] = $data['value'];
- }
- $fieldDataToString = implode(', ', $fieldDataArray);
- }
- $session[$field['variable']] = $fieldDataToString;
- }
- }
- if (isset($session['session_active']) && $session['session_active'] == 1) {
- $session['session_active'] = $activeIcon;
- } else {
- $session['session_active'] = $inactiveIcon;
- }
- $session = self::convert_dates_to_local($session, true);
- switch ($session['visibility']) {
- case SESSION_VISIBLE_READ_ONLY: //1
- $session['visibility'] = get_lang('Read only');
- break;
- case SESSION_VISIBLE: //2
- case SESSION_AVAILABLE: //4
- $session['visibility'] = get_lang('Visible');
- break;
- case SESSION_INVISIBLE: //3
- $session['visibility'] = api_ucfirst(get_lang('invisible'));
- break;
- }
- // Cleaning double selects.
- foreach ($session as $key => &$value) {
- if (isset($optionsByDouble[$key]) || isset($optionsByDouble[$key.'_second'])) {
- $options = explode('::', $value);
- }
- $original_key = $key;
- if (strpos($key, '_second') !== false) {
- $key = str_replace('_second', '', $key);
- }
- if (isset($optionsByDouble[$key]) &&
- isset($options[0]) &&
- isset($optionsByDouble[$key][$options[0]])
- ) {
- if (strpos($original_key, '_second') === false) {
- $value = $optionsByDouble[$key][$options[0]]['option_display_text'];
- } else {
- $value = $optionsByDouble[$key][$options[1]]['option_display_text'];
- }
- }
- }
- $categoryName = isset($orderedCategories[$session['session_category_id']])
- ? $orderedCategories[$session['session_category_id']]
- : '';
- $session['category_name'] = $categoryName;
- $formattedSessions[] = $session;
- }
- return $formattedSessions;
- }
- /**
- * Gets the progress of learning paths in the given session.
- *
- * @param int $sessionId
- * @param int $courseId
- * @param string $date_from
- * @param string $date_to
- * @param array options order and limit keys
- *
- * @return array table with user name, lp name, progress
- */
- public static function get_session_lp_progress(
- $sessionId = 0,
- $courseId = 0,
- $date_from,
- $date_to,
- $options
- ) {
- //escaping vars
- $sessionId = $sessionId == 'T' ? 'T' : intval($sessionId);
- $courseId = intval($courseId);
- //tables
- $session_course_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $user = Database::get_main_table(TABLE_MAIN_USER);
- $tbl_course_lp_view = Database::get_course_table(TABLE_LP_VIEW);
- $course = api_get_course_info_by_id($courseId);
- $sessionCond = 'and session_id = %s';
- if ($sessionId == 'T') {
- $sessionCond = '';
- }
- $where = " WHERE c_id = '%s' AND s.status <> 2 $sessionCond";
- $limit = null;
- if (!empty($options['limit'])) {
- $limit = " LIMIT ".$options['limit'];
- }
- if (!empty($options['where'])) {
- $where .= ' '.$options['where'];
- }
- $order = null;
- if (!empty($options['order'])) {
- $order = " ORDER BY ".$options['order'];
- }
- $sql = "SELECT u.user_id, u.lastname, u.firstname, u.username, u.email, s.c_id
- FROM $session_course_user s
- INNER JOIN $user u ON u.user_id = s.user_id
- $where
- $order
- $limit";
- $sql_query = sprintf($sql, Database::escape_string($course['real_id']), $sessionId);
- $rs = Database::query($sql_query);
- while ($user = Database::fetch_array($rs)) {
- $users[$user['user_id']] = $user;
- }
- // Get lessons
- $lessons = LearnpathList::get_course_lessons($course['code'], $sessionId);
- $table = [];
- foreach ($users as $user) {
- $data = [
- 'lastname' => $user[1],
- 'firstname' => $user[2],
- 'username' => $user[3],
- ];
- $sessionCond = 'AND v.session_id = %d';
- if ($sessionId == 'T') {
- $sessionCond = "";
- }
- //Get lessons progress by user
- $sql = "SELECT v.lp_id as id, v.progress
- FROM $tbl_course_lp_view v
- WHERE v.c_id = %d
- AND v.user_id = %d
- $sessionCond";
- $sql_query = sprintf(
- $sql,
- intval($courseId),
- intval($user['user_id']),
- $sessionId
- );
- $result = Database::query($sql_query);
- $user_lessons = [];
- while ($row = Database::fetch_array($result)) {
- $user_lessons[$row['id']] = $row;
- }
- //Match course lessons with user progress
- $progress = 0;
- $count = 0;
- foreach ($lessons as $lesson) {
- $data[$lesson['id']] = (!empty($user_lessons[$lesson['id']]['progress'])) ? $user_lessons[$lesson['id']]['progress'] : 0;
- $progress += $data[$lesson['id']];
- $data[$lesson['id']] = $data[$lesson['id']].'%';
- $count++;
- }
- if ($count == 0) {
- $data['total'] = 0;
- } else {
- $data['total'] = round($progress / $count, 2).'%';
- }
- $table[] = $data;
- }
- return $table;
- }
- /**
- * Gets the survey answers.
- *
- * @param int $sessionId
- * @param int $courseId
- * @param int $surveyId
- * @param array options order and limit keys
- *
- * @todo fix the query
- *
- * @return array table with user name, lp name, progress
- */
- public static function get_survey_overview(
- $sessionId = 0,
- $courseId = 0,
- $surveyId = 0,
- $date_from,
- $date_to,
- $options
- ) {
- //escaping vars
- $sessionId = intval($sessionId);
- $courseId = intval($courseId);
- $surveyId = intval($surveyId);
- //tables
- $session_course_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $user = Database::get_main_table(TABLE_MAIN_USER);
- $c_survey = Database::get_course_table(TABLE_SURVEY);
- $c_survey_answer = Database::get_course_table(TABLE_SURVEY_ANSWER);
- $c_survey_question = Database::get_course_table(TABLE_SURVEY_QUESTION);
- $c_survey_question_option = Database::get_course_table(TABLE_SURVEY_QUESTION_OPTION);
- $course = api_get_course_info_by_id($courseId);
- $where = " WHERE c_id = '%s' AND s.status <> 2 AND session_id = %s";
- $limit = null;
- if (!empty($options['limit'])) {
- $limit = " LIMIT ".$options['limit'];
- }
- if (!empty($options['where'])) {
- $where .= ' '.$options['where'];
- }
- $order = null;
- if (!empty($options['order'])) {
- $order = " ORDER BY ".$options['order'];
- }
- $sql = "SELECT u.user_id, u.lastname, u.firstname, u.username, u.email, s.c_id
- FROM $session_course_user s
- INNER JOIN $user u ON u.user_id = s.user_id
- $where $order $limit";
- $sql_query = sprintf($sql, intval($course['real_id']), $sessionId);
- $rs = Database::query($sql_query);
- while ($user = Database::fetch_array($rs)) {
- $users[$user['user_id']] = $user;
- }
- //Get survey questions
- $questions = SurveyManager::get_questions($surveyId, $courseId);
- //Survey is anonymous?
- $result = Database::query(sprintf("SELECT anonymous FROM $c_survey WHERE survey_id = %d", $surveyId));
- $row = Database::fetch_array($result);
- $anonymous = ($row['anonymous'] == 1) ? true : false;
- $table = [];
- foreach ($users as $user) {
- $data = [
- 'lastname' => ($anonymous ? '***' : $user[1]),
- 'firstname' => ($anonymous ? '***' : $user[2]),
- 'username' => ($anonymous ? '***' : $user[3]),
- ];
- //Get questions by user
- $sql = "SELECT sa.question_id, sa.option_id, sqo.option_text, sq.type
- FROM $c_survey_answer sa
- INNER JOIN $c_survey_question sq
- ON sq.question_id = sa.question_id
- LEFT JOIN $c_survey_question_option sqo
- ON
- sqo.c_id = sa.c_id AND
- sqo.question_id = sq.question_id AND
- sqo.question_option_id = sa.option_id AND
- sqo.survey_id = sq.survey_id
- WHERE
- sa.survey_id = %d AND
- sa.c_id = %d AND
- sa.user = %d
- "; //. $where_survey;
- $sql_query = sprintf($sql, $surveyId, $courseId, $user['user_id']);
- $result = Database::query($sql_query);
- $user_questions = [];
- while ($row = Database::fetch_array($result)) {
- $user_questions[$row['question_id']] = $row;
- }
- //Match course lessons with user progress
- foreach ($questions as $question_id => $question) {
- $option_text = 'option_text';
- if ($user_questions[$question_id]['type'] == 'open') {
- $option_text = 'option_id';
- }
- $data[$question_id] = $user_questions[$question_id][$option_text];
- }
- $table[] = $data;
- }
- return $table;
- }
- /**
- * Gets the progress of the given session.
- *
- * @param int $sessionId
- * @param int $courseId
- * @param array options order and limit keys
- *
- * @return array table with user name, lp name, progress
- */
- public static function get_session_progress(
- $sessionId,
- $courseId,
- $date_from,
- $date_to,
- $options
- ) {
- $sessionId = (int) $sessionId;
- $getAllSessions = false;
- if (empty($sessionId)) {
- $sessionId = 0;
- $getAllSessions = true;
- }
- //tables
- $session_course_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $user = Database::get_main_table(TABLE_MAIN_USER);
- $workTable = Database::get_course_table(TABLE_STUDENT_PUBLICATION);
- $workTableAssignment = Database::get_course_table(TABLE_STUDENT_PUBLICATION_ASSIGNMENT);
- $tbl_course_lp = Database::get_course_table(TABLE_LP_MAIN);
- $wiki = Database::get_course_table(TABLE_WIKI);
- $table_stats_default = Database::get_main_table(TABLE_STATISTIC_TRACK_E_DEFAULT);
- $table_stats_access = Database::get_main_table(TABLE_STATISTIC_TRACK_E_ACCESS);
- $course = api_get_course_info_by_id($courseId);
- $where = " WHERE c_id = '%s' AND s.status <> 2 ";
- $limit = null;
- if (!empty($options['limit'])) {
- $limit = " LIMIT ".$options['limit'];
- }
- if (!empty($options['where'])) {
- $where .= ' '.$options['where'];
- }
- $order = null;
- if (!empty($options['order'])) {
- $order = " ORDER BY ".$options['order'];
- }
- //TODO, fix create report without session
- $queryVariables = [$course['real_id']];
- if (!empty($sessionId)) {
- $where .= ' AND session_id = %s';
- $queryVariables[] = $sessionId;
- $sql = "SELECT
- u.user_id, u.lastname, u.firstname, u.username,
- u.email, s.c_id, s.session_id
- FROM $session_course_user s
- INNER JOIN $user u
- ON u.user_id = s.user_id
- $where $order $limit";
- } else {
- $sql = "SELECT
- u.user_id, u.lastname, u.firstname, u.username,
- u.email, s.c_id, s.session_id
- FROM $session_course_user s
- INNER JOIN $user u ON u.user_id = s.user_id
- $where $order $limit";
- }
- $sql_query = vsprintf($sql, $queryVariables);
- $rs = Database::query($sql_query);
- while ($user = Database::fetch_array($rs)) {
- $users[$user['user_id']] = $user;
- }
- /**
- * Lessons.
- */
- $sql = "SELECT * FROM $tbl_course_lp WHERE c_id = %s "; //AND session_id = %s
- $sql_query = sprintf($sql, $course['real_id']);
- $result = Database::query($sql_query);
- $arrLesson = [[]];
- while ($row = Database::fetch_array($result)) {
- if (empty($arrLesson[$row['session_id']]['lessons_total'])) {
- $arrLesson[$row['session_id']]['lessons_total'] = 1;
- } else {
- $arrLesson[$row['session_id']]['lessons_total']++;
- }
- }
- /**
- * Exercises.
- */
- $exercises = ExerciseLib::get_all_exercises(
- $course,
- $sessionId,
- false,
- '',
- $getAllSessions
- );
- $exercises_total = count($exercises);
- /**
- * Assignments.
- */
- //total
- $params = [$course['real_id']];
- if ($getAllSessions) {
- $sql = "SELECT count(w.id) as count
- FROM $workTable w
- LEFT JOIN $workTableAssignment a
- ON (a.publication_id = w.id AND a.c_id = w.c_id)
- WHERE
- w.c_id = %s AND
- parent_id = 0 AND
- active IN (1, 0)";
- } else {
- $sql = "SELECT count(w.id) as count
- FROM $workTable w
- LEFT JOIN $workTableAssignment a
- ON (a.publication_id = w.id AND a.c_id = w.c_id)
- WHERE
- w.c_id = %s AND
- parent_id = 0 AND
- active IN (1, 0)";
- if (empty($sessionId)) {
- $sql .= ' AND w.session_id = NULL ';
- } else {
- $sql .= ' AND w.session_id = %s ';
- $params[] = $sessionId;
- }
- }
- $sql_query = vsprintf($sql, $params);
- $result = Database::query($sql_query);
- $row = Database::fetch_array($result);
- $assignments_total = $row['count'];
- /**
- * Wiki.
- */
- if ($getAllSessions) {
- $sql = "SELECT count(distinct page_id) as count FROM $wiki
- WHERE c_id = %s";
- } else {
- $sql = "SELECT count(distinct page_id) as count FROM $wiki
- WHERE c_id = %s and session_id = %s";
- }
- $sql_query = sprintf($sql, $course['real_id'], $sessionId);
- $result = Database::query($sql_query);
- $row = Database::fetch_array($result);
- $wiki_total = $row['count'];
- /**
- * Surveys.
- */
- $survey_user_list = [];
- $survey_list = SurveyManager::get_surveys($course['code'], $sessionId);
- $surveys_total = count($survey_list);
- foreach ($survey_list as $survey) {
- $user_list = SurveyManager::get_people_who_filled_survey(
- $survey['survey_id'],
- false,
- $course['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;
- }
- }
- /**
- * Forums.
- */
- $forums_total = CourseManager::getCountForum(
- $course['real_id'],
- $sessionId,
- $getAllSessions
- );
- //process table info
- foreach ($users as $user) {
- //Course description
- $sql = "SELECT count(*) as count
- FROM $table_stats_access
- WHERE access_tool = 'course_description'
- AND c_id = '%s'
- AND access_session_id = %s
- AND access_user_id = %s ";
- $sql_query = sprintf($sql, $course['real_id'], $user['id_session'], $user['user_id']);
- $result = Database::query($sql_query);
- $row = Database::fetch_array($result);
- $course_description_progress = ($row['count'] > 0) ? 100 : 0;
- if (!empty($arrLesson[$user['id_session']]['lessons_total'])) {
- $lessons_total = $arrLesson[$user['id_session']]['lessons_total'];
- } else {
- $lessons_total = !empty($arrLesson[0]['lessons_total']) ? $arrLesson[0]['lessons_total'] : 0;
- }
- //Lessons
- //TODO: Lessons done and left is calculated by progress per item in lesson, maybe we should calculate it only per completed lesson?
- $lessons_progress = Tracking::get_avg_student_progress(
- $user['user_id'],
- $course['code'],
- [],
- $user['id_session']
- );
- $lessons_done = ($lessons_progress * $lessons_total) / 100;
- $lessons_left = $lessons_total - $lessons_done;
- // Exercises
- $exercises_progress = str_replace(
- '%',
- '',
- Tracking::get_exercise_student_progress(
- $exercises,
- $user['user_id'],
- $course['real_id'],
- $user['id_session']
- )
- );
- $exercises_done = round(($exercises_progress * $exercises_total) / 100);
- $exercises_left = $exercises_total - $exercises_done;
- //Assignments
- $assignments_done = Tracking::count_student_assignments($user['user_id'], $course['code'], $user['id_session']);
- $assignments_left = $assignments_total - $assignments_done;
- if (!empty($assignments_total)) {
- $assignments_progress = round((($assignments_done * 100) / $assignments_total), 2);
- } else {
- $assignments_progress = 0;
- }
- // Wiki
- // total revisions per user
- $sql = "SELECT count(*) as count
- FROM $wiki
- WHERE c_id = %s and session_id = %s and user_id = %s";
- $sql_query = sprintf($sql, $course['real_id'], $user['id_session'], $user['user_id']);
- $result = Database::query($sql_query);
- $row = Database::fetch_array($result);
- $wiki_revisions = $row['count'];
- //count visited wiki pages
- $sql = "SELECT count(distinct default_value) as count
- FROM $table_stats_default
- WHERE
- default_user_id = %s AND
- default_event_type = 'wiki_page_view' AND
- default_value_type = 'wiki_page_id' AND
- c_id = %s
- ";
- $sql_query = sprintf($sql, $user['user_id'], $course['real_id']);
- $result = Database::query($sql_query);
- $row = Database::fetch_array($result);
- $wiki_read = $row['count'];
- $wiki_unread = $wiki_total - $wiki_read;
- if (!empty($wiki_total)) {
- $wiki_progress = round((($wiki_read * 100) / $wiki_total), 2);
- } else {
- $wiki_progress = 0;
- }
- //Surveys
- $surveys_done = (isset($survey_user_list[$user['user_id']]) ? $survey_user_list[$user['user_id']] : 0);
- $surveys_left = $surveys_total - $surveys_done;
- if (!empty($surveys_total)) {
- $surveys_progress = round((($surveys_done * 100) / $surveys_total), 2);
- } else {
- $surveys_progress = 0;
- }
- //Forums
- $forums_done = CourseManager::getCountForumPerUser(
- $user['user_id'],
- $course['real_id'],
- $user['id_session']
- );
- $forums_left = $forums_total - $forums_done;
- if (!empty($forums_total)) {
- $forums_progress = round((($forums_done * 100) / $forums_total), 2);
- } else {
- $forums_progress = 0;
- }
- // Overall Total
- $overall_total = ($course_description_progress + $exercises_progress + $forums_progress + $assignments_progress + $wiki_progress + $surveys_progress) / 6;
- $link = '<a href="'.api_get_path(WEB_CODE_PATH).'mySpace/myStudents.php?student='.$user[0].'&details=true&course='.$course['code'].'&id_session='.$user['id_session'].'"> %s </a>';
- $linkForum = '<a href="'.api_get_path(WEB_CODE_PATH).'forum/index.php?cidReq='.$course['code'].'&id_session='.$user['id_session'].'"> %s </a>';
- $linkWork = '<a href="'.api_get_path(WEB_CODE_PATH).'work/work.php?cidReq='.$course['code'].'&id_session='.$user['id_session'].'"> %s </a>';
- $linkWiki = '<a href="'.api_get_path(WEB_CODE_PATH).'wiki/index.php?cidReq='.$course['code'].'&session_id='.$user['id_session'].'&action=statistics"> %s </a>';
- $linkSurvey = '<a href="'.api_get_path(WEB_CODE_PATH).'survey/survey_list.php?cidReq='.$course['code'].'&id_session='.$user['id_session'].'"> %s </a>';
- $table[] = [
- 'lastname' => $user[1],
- 'firstname' => $user[2],
- 'username' => $user[3],
- //'profile' => '',
- 'total' => round($overall_total, 2).'%',
- 'courses' => sprintf($link, $course_description_progress.'%'),
- 'lessons' => sprintf($link, $lessons_progress.'%'),
- 'exercises' => sprintf($link, $exercises_progress.'%'),
- 'forums' => sprintf($link, $forums_progress.'%'),
- 'homeworks' => sprintf($link, $assignments_progress.'%'),
- 'wikis' => sprintf($link, $wiki_progress.'%'),
- 'surveys' => sprintf($link, $surveys_progress.'%'),
- //course description
- 'course_description_progress' => $course_description_progress.'%',
- //lessons
- 'lessons_total' => sprintf($link, $lessons_total),
- 'lessons_done' => sprintf($link, $lessons_done),
- 'lessons_left' => sprintf($link, $lessons_left),
- 'lessons_progress' => sprintf($link, $lessons_progress.'%'),
- //exercises
- 'exercises_total' => sprintf($link, $exercises_total),
- 'exercises_done' => sprintf($link, $exercises_done),
- 'exercises_left' => sprintf($link, $exercises_left),
- 'exercises_progress' => sprintf($link, $exercises_progress.'%'),
- //forums
- 'forums_total' => sprintf($linkForum, $forums_total),
- 'forums_done' => sprintf($linkForum, $forums_done),
- 'forums_left' => sprintf($linkForum, $forums_left),
- 'forums_progress' => sprintf($linkForum, $forums_progress.'%'),
- //assignments
- 'assignments_total' => sprintf($linkWork, $assignments_total),
- 'assignments_done' => sprintf($linkWork, $assignments_done),
- 'assignments_left' => sprintf($linkWork, $assignments_left),
- 'assignments_progress' => sprintf($linkWork, $assignments_progress.'%'),
- //wiki
- 'wiki_total' => sprintf($linkWiki, $wiki_total),
- 'wiki_revisions' => sprintf($linkWiki, $wiki_revisions),
- 'wiki_read' => sprintf($linkWiki, $wiki_read),
- 'wiki_unread' => sprintf($linkWiki, $wiki_unread),
- 'wiki_progress' => sprintf($linkWiki, $wiki_progress.'%'),
- //survey
- 'surveys_total' => sprintf($linkSurvey, $surveys_total),
- 'surveys_done' => sprintf($linkSurvey, $surveys_done),
- 'surveys_left' => sprintf($linkSurvey, $surveys_left),
- 'surveys_progress' => sprintf($linkSurvey, $surveys_progress.'%'),
- ];
- }
- return $table;
- }
- /**
- * Get the ip, total of clicks, login date and time logged in for all user, in one session.
- *
- * @todo track_e_course_access table should have ip so we dont have to look for it in track_e_login
- *
- * @author César Perales <cesar.perales@beeznest.com>, Beeznest Team
- *
- * @version 1.9.6
- */
- public static function get_user_data_access_tracking_overview(
- $sessionId,
- $courseId,
- $studentId = 0,
- $profile = '',
- $date_from = '',
- $date_to = '',
- $options
- ) {
- //escaping variables
- $sessionId = intval($sessionId);
- $courseId = intval($courseId);
- $studentId = intval($studentId);
- $profile = intval($profile);
- $date_from = Database::escape_string($date_from);
- $date_to = Database::escape_string($date_to);
- // database table definition
- $user = Database::get_main_table(TABLE_MAIN_USER);
- $course = Database::get_main_table(TABLE_MAIN_COURSE);
- $track_e_login = Database::get_main_table(TABLE_STATISTIC_TRACK_E_LOGIN);
- $track_e_course_access = Database::get_main_table(TABLE_STATISTIC_TRACK_E_COURSE_ACCESS);
- $sessionTable = Database::get_main_table(TABLE_MAIN_SESSION);
- global $export_csv;
- if ($export_csv) {
- $is_western_name_order = api_is_western_name_order(PERSON_NAME_DATA_EXPORT);
- } else {
- $is_western_name_order = api_is_western_name_order();
- }
- $where = null;
- if (isset($sessionId) && !empty($sessionId)) {
- $where = sprintf(" WHERE a.session_id = %d", $sessionId);
- }
- if (isset($courseId) && !empty($courseId)) {
- $where .= sprintf(" AND c.id = %d", $courseId);
- }
- if (isset($studentId) && !empty($studentId)) {
- $where .= sprintf(" AND u.user_id = %d", $studentId);
- }
- if (isset($profile) && !empty($profile)) {
- $where .= sprintf(" AND u.status = %d", $profile);
- }
- if (!empty($date_to) && !empty($date_from)) {
- $where .= sprintf(
- " AND a.login_course_date >= '%s 00:00:00'
- AND a.login_course_date <= '%s 23:59:59'",
- $date_from,
- $date_to
- );
- }
- $limit = null;
- if (!empty($options['limit'])) {
- $limit = " LIMIT ".$options['limit'];
- }
- if (!empty($options['where'])) {
- $where .= ' '.$options['where'];
- }
- $order = null;
- if (!empty($options['order'])) {
- $order = " ORDER BY ".$options['order'];
- }
- //TODO add course name
- $sql = "SELECT
- a.login_course_date ,
- u.username ,
- ".($is_western_name_order ? "
- u.firstname,
- u.lastname,
- " : "
- u.lastname,
- u.firstname,
- ")."
- a.logout_course_date,
- a.counter,
- c.title,
- c.code,
- u.user_id,
- a.session_id
- FROM $track_e_course_access a
- INNER JOIN $user u ON a.user_id = u.user_id
- INNER JOIN $course c ON a.c_id = c.id
- $where $order $limit";
- $result = Database::query(sprintf($sql, $sessionId, $courseId));
- $data = [];
- while ($user = Database::fetch_assoc($result)) {
- $data[] = $user;
- }
- foreach ($data as $key => $info) {
- $sql = "SELECT
- name
- FROM $sessionTable
- WHERE
- id = {$info['session_id']}";
- $result = Database::query($sql);
- $session = Database::fetch_assoc($result);
- // building array to display
- $return[] = [
- 'user_id' => $info['user_id'],
- 'logindate' => $info['login_course_date'],
- 'username' => $info['username'],
- 'firstname' => $info['firstname'],
- 'lastname' => $info['lastname'],
- 'clicks' => $info['counter'], //+ $clicks[$info['user_id']],
- 'ip' => '',
- 'timeLoggedIn' => gmdate("H:i:s", strtotime($info['logout_course_date']) - strtotime($info['login_course_date'])),
- 'session' => $session['name'],
- ];
- }
- foreach ($return as $key => $info) {
- //Search for ip, we do less querys if we iterate the final array
- $sql = sprintf(
- "SELECT user_ip FROM $track_e_login WHERE login_user_id = %d AND login_date < '%s' ORDER BY login_date DESC LIMIT 1",
- $info['user_id'],
- $info['logindate']
- ); //TODO add select by user too
- $result = Database::query($sql);
- $ip = Database::fetch_assoc($result);
- //if no ip founded, we search the closest higher ip
- if (empty($ip['user_ip'])) {
- $sql = sprintf(
- "SELECT user_ip FROM $track_e_login WHERE login_user_id = %d AND login_date > '%s' ORDER BY login_date ASC LIMIT 1",
- $info['user_id'],
- $info['logindate']
- ); //TODO add select by user too
- $result = Database::query($sql);
- $ip = Database::fetch_assoc($result);
- }
- //add ip to final array
- $return[$key]['ip'] = $ip['user_ip'];
- }
- return $return;
- }
- /**
- * Creates a new course code based in given code.
- *
- * @param string $session_name
- * <code>
- * $wanted_code = 'curse' if there are in the DB codes like curse1 curse2 the function will return: course3
- * if the course code doest not exist in the DB the same course code will be returned
- * </code>
- *
- * @return string wanted unused code
- */
- public static function generateNextSessionName($session_name)
- {
- $session_name_ok = !self::sessionNameExists($session_name);
- if (!$session_name_ok) {
- $table = Database::get_main_table(TABLE_MAIN_SESSION);
- $session_name = Database::escape_string($session_name);
- $sql = "SELECT count(*) as count FROM $table
- WHERE name LIKE '$session_name%'";
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0) {
- $row = Database::fetch_array($result);
- $count = $row['count'] + 1;
- $session_name = $session_name.'_'.$count;
- $result = self::sessionNameExists($session_name);
- if (!$result) {
- return $session_name;
- }
- }
- return false;
- }
- return $session_name;
- }
- /**
- * Edit a session.
- *
- * @author Carlos Vargas from existing code
- *
- * @param int $id Session primary key
- * @param string $name
- * @param string $startDate
- * @param string $endDate
- * @param string $displayStartDate
- * @param string $displayEndDate
- * @param string $coachStartDate
- * @param string $coachEndDate
- * @param int $coachId
- * @param int $sessionCategoryId
- * @param int $visibility
- * @param string $description
- * @param int $showDescription
- * @param int $duration
- * @param array $extraFields
- * @param int $sessionAdminId
- * @param bool $sendSubscriptionNotification Optional.
- * Whether send a mail notification to users being subscribed
- *
- * @return mixed
- */
- public static function edit_session(
- $id,
- $name,
- $startDate,
- $endDate,
- $displayStartDate,
- $displayEndDate,
- $coachStartDate,
- $coachEndDate,
- $coachId,
- $sessionCategoryId,
- $visibility,
- $description = null,
- $showDescription = 0,
- $duration = null,
- $extraFields = [],
- $sessionAdminId = 0,
- $sendSubscriptionNotification = false
- ) {
- $coachId = (int) $coachId;
- $sessionCategoryId = (int) $sessionCategoryId;
- $visibility = (int) $visibility;
- $em = Database::getManager();
- if (empty($name)) {
- Display::addFlash(
- Display::return_message(get_lang('A name is required for the session'), 'warning')
- );
- return false;
- } elseif (empty($coachId)) {
- Display::addFlash(
- Display::return_message(get_lang('You must select a coach'), 'warning')
- );
- return false;
- } elseif (!empty($startDate) &&
- !api_is_valid_date($startDate, 'Y-m-d H:i') &&
- !api_is_valid_date($startDate, 'Y-m-d H:i:s')
- ) {
- Display::addFlash(
- Display::return_message(get_lang('Invalid start date was given.'), 'warning')
- );
- return false;
- } elseif (!empty($endDate) &&
- !api_is_valid_date($endDate, 'Y-m-d H:i') &&
- !api_is_valid_date($endDate, 'Y-m-d H:i:s')
- ) {
- Display::addFlash(
- Display::return_message(get_lang('Invalid end date was given.'), 'warning')
- );
- return false;
- } elseif (!empty($startDate) && !empty($endDate) && $startDate >= $endDate) {
- Display::addFlash(
- Display::return_message(get_lang('The first date should be before the end date'), 'warning')
- );
- return false;
- } else {
- $sessionInfo = self::get_session_by_name($name);
- $exists = false;
- if (!empty($sessionInfo)) {
- if ($sessionInfo['id'] != $id) {
- $exists = true;
- }
- }
- if ($exists) {
- Display::addFlash(
- Display::return_message(get_lang('Session name already exists'), 'warning')
- );
- return false;
- } else {
- /** @var Session $sessionEntity */
- $sessionEntity = api_get_session_entity($id);
- $sessionEntity
- ->setName($name)
- ->setDuration($duration)
- ->setDescription($description)
- ->setShowDescription($showDescription)
- ->setVisibility($visibility)
- ->setSendSubscriptionNotification($sendSubscriptionNotification)
- ->setAccessStartDate(null)
- ->setAccessStartDate(null)
- ->setDisplayStartDate(null)
- ->setDisplayEndDate(null)
- ->setCoachAccessStartDate(null)
- ->setCoachAccessEndDate(null)
- ->setGeneralCoach(api_get_user_entity($coachId))
- ;
- if (!empty($sessionAdminId)) {
- $sessionEntity->setSessionAdminId($sessionAdminId);
- }
- if (!empty($startDate)) {
- $sessionEntity->setAccessStartDate(api_get_utc_datetime($startDate, true, true));
- }
- if (!empty($endDate)) {
- $sessionEntity->setAccessEndDate(api_get_utc_datetime($endDate, true, true));
- }
- if (!empty($displayStartDate)) {
- $sessionEntity->setDisplayStartDate(api_get_utc_datetime($displayStartDate, true, true));
- }
- if (!empty($displayEndDate)) {
- $sessionEntity->setDisplayEndDate(api_get_utc_datetime($displayEndDate, true, true));
- }
- if (!empty($coachStartDate)) {
- $sessionEntity->setCoachAccessStartDate(api_get_utc_datetime($coachStartDate, true, true));
- }
- if (!empty($coachEndDate)) {
- $sessionEntity->setCoachAccessEndDate(api_get_utc_datetime($coachEndDate, true, true));
- }
- if (!empty($sessionCategoryId)) {
- $category = $em->getRepository('ChamiloCoreBundle:SessionCategory')->find($sessionCategoryId);
- $sessionEntity->setCategory($category);
- } else {
- $sessionEntity->setCategory(null);
- }
- $em->merge($sessionEntity);
- $em->flush();
- if (!empty($extraFields)) {
- $extraFields['item_id'] = $id;
- $sessionFieldValue = new ExtraFieldValue('session');
- $sessionFieldValue->saveFieldValues($extraFields);
- }
- return $id;
- }
- }
- }
- /**
- * Delete session.
- *
- * @author Carlos Vargas from existing code
- *
- * @param array $id_checked an array to delete sessions
- * @param bool $from_ws optional, true if the function is called
- * by a webservice, false otherwise
- *
- * @return bool
- * */
- public static function delete($id_checked, $from_ws = false)
- {
- $sessionId = null;
- if (is_array($id_checked)) {
- foreach ($id_checked as $sessionId) {
- self::delete($sessionId);
- }
- } else {
- $sessionId = (int) $id_checked;
- }
- if (empty($sessionId)) {
- return false;
- }
- $tbl_session_rel_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $tbl_session_rel_course_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tbl_session_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $tbl_url_session = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $tbl_item_properties = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $tbl_student_publication = Database::get_course_table(TABLE_STUDENT_PUBLICATION);
- $tbl_student_publication_assignment = Database::get_course_table(TABLE_STUDENT_PUBLICATION_ASSIGNMENT);
- $userGroupSessionTable = Database::get_main_table(TABLE_USERGROUP_REL_SESSION);
- $trackCourseAccess = Database::get_main_table(TABLE_STATISTIC_TRACK_E_COURSE_ACCESS);
- $trackAccess = Database::get_main_table(TABLE_STATISTIC_TRACK_E_ACCESS);
- $ticket = Database::get_main_table(TABLE_TICKET_TICKET);
- $em = Database::getManager();
- $userId = api_get_user_id();
- /** @var SequenceRepository $repo */
- $repo = Database::getManager()->getRepository('ChamiloCoreBundle:SequenceResource');
- $sequenceResource = $repo->findRequirementForResource(
- $sessionId,
- SequenceResource::SESSION_TYPE
- );
- if ($sequenceResource) {
- Display::addFlash(
- Display::return_message(
- get_lang('There is a sequence resource linked to this session. You must delete this link first.'),
- 'error'
- )
- );
- return false;
- }
- if (self::allowed($sessionId) && !$from_ws) {
- $qb = $em
- ->createQuery('
- SELECT s.sessionAdminId FROM ChamiloCoreBundle:Session s
- WHERE s.id = ?1
- ')
- ->setParameter(1, $sessionId);
- $res = $qb->getSingleScalarResult();
- if ($res != $userId && !api_is_platform_admin()) {
- api_not_allowed(true);
- }
- }
- // Delete documents inside a session
- $courses = self::getCoursesInSession($sessionId);
- foreach ($courses as $courseId) {
- $courseInfo = api_get_course_info_by_id($courseId);
- DocumentManager::deleteDocumentsFromSession($courseInfo, $sessionId);
- $works = Database::select(
- '*',
- $tbl_student_publication,
- [
- 'where' => ['session_id = ? AND c_id = ?' => [$sessionId, $courseId]],
- ]
- );
- $currentCourseRepositorySys = api_get_path(SYS_COURSE_PATH).$courseInfo['path'].'/';
- foreach ($works as $index => $work) {
- if ($work['filetype'] = 'folder') {
- Database::query("DELETE FROM $tbl_student_publication_assignment WHERE publication_id = $index");
- }
- my_delete($currentCourseRepositorySys.'/'.$work['url']);
- }
- }
- $sessionEntity = api_get_session_entity($sessionId);
- $sessionName = $sessionEntity->getName();
- $em->remove($sessionEntity);
- $em->flush();
- // Class
- $sql = "DELETE FROM $userGroupSessionTable
- WHERE session_id = $sessionId";
- Database::query($sql);
- Database::query("DELETE FROM $tbl_student_publication WHERE session_id = $sessionId");
- Database::query("DELETE FROM $tbl_session_rel_course WHERE session_id = $sessionId");
- Database::query("DELETE FROM $tbl_session_rel_course_rel_user WHERE session_id = $sessionId");
- Database::query("DELETE FROM $tbl_session_rel_user WHERE session_id = $sessionId");
- Database::query("DELETE FROM $tbl_item_properties WHERE session_id = $sessionId");
- Database::query("DELETE FROM $tbl_url_session WHERE session_id = $sessionId");
- Database::query("DELETE FROM $trackCourseAccess WHERE session_id = $sessionId");
- Database::query("DELETE FROM $trackAccess WHERE access_session_id = $sessionId");
- $sql = "UPDATE $ticket SET session_id = NULL WHERE session_id = $sessionId";
- Database::query($sql);
- $extraFieldValue = new ExtraFieldValue('session');
- $extraFieldValue->deleteValuesByItem($sessionId);
- $repo->deleteResource(
- $sessionId,
- SequenceResource::SESSION_TYPE
- );
- // Add event to system log
- Event::addEvent(
- LOG_SESSION_DELETE,
- LOG_SESSION_ID,
- $sessionName.' - id:'.$sessionId,
- api_get_utc_datetime(),
- $userId
- );
- return true;
- }
- /**
- * @param int $id promotion id
- *
- * @return bool
- */
- public static function clear_session_ref_promotion($id)
- {
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $id = intval($id);
- $sql = "UPDATE $tbl_session
- SET promotion_id = 0
- WHERE promotion_id = $id";
- if (Database::query($sql)) {
- return true;
- } else {
- return false;
- }
- }
- /**
- * Subscribes students to the given session and optionally (default)
- * unsubscribes previous users.
- *
- * @author Carlos Vargas from existing code
- * @author Julio Montoya. Cleaning code.
- *
- * @param int $sessionId
- * @param array $userList
- * @param int $session_visibility
- * @param bool $empty_users
- * @param bool $registerUsersToAllCourses
- *
- * @return bool
- */
- public static function subscribeUsersToSession(
- $sessionId,
- $userList,
- $session_visibility = SESSION_VISIBLE_READ_ONLY,
- $empty_users = true,
- $registerUsersToAllCourses = true
- ) {
- $sessionId = (int) $sessionId;
- if (empty($sessionId)) {
- return false;
- }
- foreach ($userList as $intUser) {
- if ($intUser != strval(intval($intUser))) {
- return false;
- }
- }
- $tbl_session_rel_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $tbl_session_rel_course_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tbl_session_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $session = api_get_session_entity($sessionId);
- // from function parameter
- if (empty($session_visibility)) {
- $session_visibility = $session->getVisibility();
- //default status loaded if empty
- // by default readonly 1
- if (empty($session_visibility)) {
- $session_visibility = SESSION_VISIBLE_READ_ONLY;
- }
- } else {
- if (!in_array($session_visibility, [SESSION_VISIBLE_READ_ONLY, SESSION_VISIBLE, SESSION_INVISIBLE])) {
- $session_visibility = SESSION_VISIBLE_READ_ONLY;
- }
- }
- $sql = "SELECT user_id FROM $tbl_session_rel_course_rel_user
- WHERE session_id = $sessionId AND status = 0";
- $result = Database::query($sql);
- $existingUsers = [];
- while ($row = Database::fetch_array($result)) {
- $existingUsers[] = $row['user_id'];
- }
- $sql = "SELECT c_id FROM $tbl_session_rel_course
- WHERE session_id = $sessionId";
- $result = Database::query($sql);
- $course_list = [];
- while ($row = Database::fetch_array($result)) {
- $course_list[] = $row['c_id'];
- }
- if ($session->getSendSubscriptionNotification() &&
- is_array($userList)
- ) {
- // Sending emails only
- foreach ($userList as $user_id) {
- if (in_array($user_id, $existingUsers)) {
- continue;
- }
- $tplSubject = new Template(
- null,
- false,
- false,
- false,
- false,
- false
- );
- $layoutSubject = $tplSubject->get_template(
- 'mail/subject_subscription_to_session_confirmation.tpl'
- );
- $subject = $tplSubject->fetch($layoutSubject);
- $user_info = api_get_user_info($user_id);
- $tplContent = new Template(
- null,
- false,
- false,
- false,
- false,
- false
- );
- // Variables for default template
- $tplContent->assign('complete_name', stripslashes($user_info['complete_name']));
- $tplContent->assign('session_name', $session->getName());
- $tplContent->assign(
- 'session_coach',
- UserManager::formatUserFullName($session->getGeneralCoach())
- );
- $layoutContent = $tplContent->get_template(
- 'mail/content_subscription_to_session_confirmation.tpl'
- );
- $content = $tplContent->fetch($layoutContent);
- api_mail_html(
- $user_info['complete_name'],
- $user_info['mail'],
- $subject,
- $content,
- api_get_person_name(
- api_get_setting('administratorName'),
- api_get_setting('administratorSurname')
- ),
- api_get_setting('emailAdministrator')
- );
- }
- }
- if ($registerUsersToAllCourses) {
- foreach ($course_list as $courseId) {
- // for each course in the session
- $nbr_users = 0;
- $courseId = (int) $courseId;
- $sql = "SELECT DISTINCT user_id
- FROM $tbl_session_rel_course_rel_user
- WHERE
- session_id = $sessionId AND
- c_id = $courseId AND
- status = 0
- ";
- $result = Database::query($sql);
- $existingUsers = [];
- while ($row = Database::fetch_array($result)) {
- $existingUsers[] = $row['user_id'];
- }
- // Delete existing users
- if ($empty_users) {
- foreach ($existingUsers as $existing_user) {
- if (!in_array($existing_user, $userList)) {
- self::unSubscribeUserFromCourseSession($existing_user, $courseId, $sessionId);
- }
- }
- }
- // Replace with this new function
- // insert new users into session_rel_course_rel_user and ignore if they already exist
- foreach ($userList as $enreg_user) {
- if (!in_array($enreg_user, $existingUsers)) {
- $status = self::get_user_status_in_course_session(
- $enreg_user,
- $courseId,
- $sessionId
- );
- // Avoid duplicate entries.
- if ($status === false || ($status !== false && $status != 0)) {
- $enreg_user = (int) $enreg_user;
- $sql = "INSERT IGNORE INTO $tbl_session_rel_course_rel_user (session_id, c_id, user_id, visibility, status)
- VALUES($sessionId, $courseId, $enreg_user, $session_visibility, 0)";
- $result = Database::query($sql);
- if (Database::affected_rows($result)) {
- $nbr_users++;
- }
- Event::addEvent(
- LOG_SESSION_ADD_USER_COURSE,
- LOG_USER_ID,
- $enreg_user,
- api_get_utc_datetime(),
- api_get_user_id(),
- $courseId,
- $sessionId
- );
- }
- }
- }
- // Count users in this session-course relation
- $sql = "SELECT COUNT(user_id) as nbUsers
- FROM $tbl_session_rel_course_rel_user
- WHERE session_id = $sessionId AND c_id = $courseId AND status<>2";
- $rs = Database::query($sql);
- list($nbr_users) = Database::fetch_array($rs);
- // update the session-course relation to add the users total
- $sql = "UPDATE $tbl_session_rel_course SET nbr_users = $nbr_users
- WHERE session_id = $sessionId AND c_id = $courseId";
- Database::query($sql);
- }
- }
- // Delete users from the session
- if ($empty_users === true) {
- $sql = "DELETE FROM $tbl_session_rel_user
- WHERE
- session_id = $sessionId AND
- relation_type <> ".SESSION_RELATION_TYPE_RRHH;
- // Don't reset session_rel_user.registered_at of users that will be registered later anyways.
- if (!empty($userList)) {
- $avoidDeleteThisUsers = " AND user_id NOT IN ('".implode("','", $userList)."')";
- $sql .= $avoidDeleteThisUsers;
- }
- Event::addEvent(
- LOG_SESSION_DELETE_USER,
- LOG_USER_ID,
- 'all',
- api_get_utc_datetime(),
- api_get_user_id(),
- null,
- $sessionId
- );
- Database::query($sql);
- }
- // Insert missing users into session
- foreach ($userList as $enreg_user) {
- $isUserSubscribed = self::isUserSubscribedAsStudent($sessionId, $enreg_user);
- if ($isUserSubscribed === false) {
- $enreg_user = (int) $enreg_user;
- $sql = "INSERT IGNORE INTO $tbl_session_rel_user (relation_type, session_id, user_id, registered_at)
- VALUES (0, $sessionId, $enreg_user, '".api_get_utc_datetime()."')";
- Database::query($sql);
- Event::addEvent(
- LOG_SESSION_ADD_USER,
- LOG_USER_ID,
- $enreg_user,
- api_get_utc_datetime(),
- api_get_user_id(),
- null,
- $sessionId
- );
- }
- }
- // update number of users in the session
- $sql = "UPDATE $tbl_session
- SET nbr_users = (SELECT count(user_id) FROM $tbl_session_rel_user WHERE session_id = $sessionId)
- WHERE id = $sessionId";
- Database::query($sql);
- }
- /**
- * Returns user list of the current users subscribed in the course-session.
- *
- * @param int $sessionId
- * @param array $courseInfo
- * @param int $status
- *
- * @return array
- */
- public static function getUsersByCourseSession(
- $sessionId,
- $courseInfo,
- $status = null
- ) {
- $sessionId = (int) $sessionId;
- $courseId = $courseInfo['real_id'];
- if (empty($sessionId) || empty($courseId)) {
- return [];
- }
- $statusCondition = null;
- if (isset($status) && !is_null($status)) {
- $status = (int) $status;
- $statusCondition = " AND status = $status";
- }
- $table = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $sql = "SELECT DISTINCT user_id
- FROM $table
- WHERE
- session_id = $sessionId AND
- c_id = $courseId
- $statusCondition
- ";
- $result = Database::query($sql);
- $existingUsers = [];
- while ($row = Database::fetch_array($result)) {
- $existingUsers[] = $row['user_id'];
- }
- return $existingUsers;
- }
- /**
- * Returns user list of the current users subscribed in the course-session.
- *
- * @param array $sessionList
- * @param array $courseList
- * @param int $status
- * @param int $start
- * @param int $limit
- *
- * @return array
- */
- public static function getUsersByCourseAndSessionList(
- $sessionList,
- $courseList,
- $status = null,
- $start = null,
- $limit = null
- ) {
- if (empty($sessionList) || empty($courseList)) {
- return [];
- }
- $sessionListToString = implode("','", $sessionList);
- $courseListToString = implode("','", $courseList);
- $statusCondition = null;
- if (isset($status) && !is_null($status)) {
- $status = (int) $status;
- $statusCondition = " AND status = $status";
- }
- $table = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $sql = "SELECT DISTINCT user_id
- FROM $table
- WHERE
- session_id IN ('$sessionListToString') AND
- c_id IN ('$courseListToString')
- $statusCondition
- ";
- if (!is_null($start) && !is_null($limit)) {
- $start = (int) $start;
- $limit = (int) $limit;
- $sql .= "LIMIT $start, $limit";
- }
- $result = Database::query($sql);
- $existingUsers = [];
- while ($row = Database::fetch_array($result)) {
- $existingUsers[] = $row['user_id'];
- }
- return $existingUsers;
- }
- /**
- * Remove a list of users from a course-session.
- *
- * @param array $userList
- * @param int $sessionId
- * @param array $courseInfo
- * @param int $status
- * @param bool $updateTotal
- *
- * @return bool
- */
- public static function removeUsersFromCourseSession(
- $userList,
- $sessionId,
- $courseInfo,
- $status = null,
- $updateTotal = true
- ) {
- $table = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tableSessionCourse = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $sessionId = (int) $sessionId;
- if (empty($sessionId) || empty($userList) || empty($courseInfo)) {
- return false;
- }
- is_array($courseInfo) ? $courseId = $courseInfo['real_id'] : $courseId = $courseInfo;
- $statusCondition = null;
- if (isset($status) && !is_null($status)) {
- $status = (int) $status;
- $statusCondition = " AND status = $status";
- }
- foreach ($userList as $userId) {
- $userId = (int) $userId;
- $sql = "DELETE FROM $table
- WHERE
- session_id = $sessionId AND
- c_id = $courseId AND
- user_id = $userId
- $statusCondition
- ";
- Database::query($sql);
- Event::addEvent(
- LOG_SESSION_DELETE_USER_COURSE,
- LOG_USER_ID,
- $userId,
- api_get_utc_datetime(),
- api_get_user_id(),
- $courseId,
- $sessionId
- );
- }
- if ($updateTotal) {
- // Count users in this session-course relation
- $sql = "SELECT COUNT(user_id) as nbUsers
- FROM $table
- WHERE
- session_id = $sessionId AND
- c_id = $courseId AND
- status <> 2";
- $result = Database::query($sql);
- list($userCount) = Database::fetch_array($result);
- // update the session-course relation to add the users total
- $sql = "UPDATE $tableSessionCourse
- SET nbr_users = $userCount
- WHERE
- session_id = $sessionId AND
- c_id = $courseId";
- Database::query($sql);
- }
- }
- /**
- * Subscribe a user to an specific course inside a session.
- *
- * @param array $user_list
- * @param int $session_id
- * @param string $course_code
- * @param int $session_visibility
- * @param bool $removeUsersNotInList
- *
- * @return bool
- */
- public static function subscribe_users_to_session_course(
- $user_list,
- $session_id,
- $course_code,
- $session_visibility = SESSION_VISIBLE_READ_ONLY,
- $removeUsersNotInList = false
- ) {
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $tbl_session_rel_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $tbl_session_rel_course_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tbl_session_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- if (empty($session_id) || empty($course_code)) {
- return false;
- }
- $session_id = (int) $session_id;
- $session_visibility = (int) $session_visibility;
- $course_code = Database::escape_string($course_code);
- $courseInfo = api_get_course_info($course_code);
- $courseId = $courseInfo['real_id'];
- $subscribe = (int) api_get_course_setting('subscribe_users_to_forum_notifications', $courseInfo);
- $forums = [];
- if ($subscribe === 1) {
- require_once api_get_path(SYS_CODE_PATH).'forum/forumfunction.inc.php';
- $forums = get_forums(0, $course_code, true, $session_id);
- }
- if ($removeUsersNotInList) {
- $currentUsers = self::getUsersByCourseSession($session_id, $courseInfo, 0);
- if (!empty($user_list)) {
- $userToDelete = array_diff($currentUsers, $user_list);
- } else {
- $userToDelete = $currentUsers;
- }
- if (!empty($userToDelete)) {
- self::removeUsersFromCourseSession(
- $userToDelete,
- $session_id,
- $courseInfo,
- 0,
- true
- );
- }
- }
- $nbr_users = 0;
- foreach ($user_list as $enreg_user) {
- $enreg_user = (int) $enreg_user;
- // Checking if user exists in session - course - user table.
- $sql = "SELECT count(user_id) as count
- FROM $tbl_session_rel_course_rel_user
- WHERE
- session_id = $session_id AND
- c_id = $courseId and
- user_id = $enreg_user ";
- $result = Database::query($sql);
- $count = 0;
- if (Database::num_rows($result) > 0) {
- $row = Database::fetch_array($result, 'ASSOC');
- $count = $row['count'];
- }
- if ($count == 0) {
- $sql = "INSERT IGNORE INTO $tbl_session_rel_course_rel_user (session_id, c_id, user_id, visibility)
- VALUES ($session_id, $courseId, $enreg_user, $session_visibility)";
- $result = Database::query($sql);
- if (Database::affected_rows($result)) {
- $nbr_users++;
- }
- }
- if (!empty($forums)) {
- $userInfo = api_get_user_info($enreg_user);
- foreach ($forums as $forum) {
- $forumId = $forum['iid'];
- set_notification('forum', $forumId, false, $userInfo, $courseInfo);
- }
- }
- // Checking if user exists in session - user table.
- $sql = "SELECT count(user_id) as count
- FROM $tbl_session_rel_user
- WHERE session_id = $session_id AND user_id = $enreg_user ";
- $result = Database::query($sql);
- $count = 0;
- if (Database::num_rows($result) > 0) {
- $row = Database::fetch_array($result, 'ASSOC');
- $count = $row['count'];
- }
- if (empty($count)) {
- // If user is not registered to a session then add it.
- $sql = "INSERT IGNORE INTO $tbl_session_rel_user (session_id, user_id, registered_at)
- VALUES ($session_id, $enreg_user, '".api_get_utc_datetime()."')";
- Database::query($sql);
- $sql = "UPDATE $tbl_session SET nbr_users = nbr_users + 1
- WHERE id = $session_id ";
- Database::query($sql);
- }
- }
- // count users in this session-course relation
- $sql = "SELECT COUNT(user_id) as nbUsers
- FROM $tbl_session_rel_course_rel_user
- WHERE session_id = $session_id AND c_id = $courseId AND status <> 2";
- $rs = Database::query($sql);
- list($nbr_users) = Database::fetch_array($rs);
- // update the session-course relation to add the users total
- $sql = "UPDATE $tbl_session_rel_course
- SET nbr_users = $nbr_users
- WHERE session_id = $session_id AND c_id = $courseId";
- Database::query($sql);
- }
- /**
- * Unsubscribe user from session.
- *
- * @param int Session id
- * @param int User id
- *
- * @return bool True in case of success, false in case of error
- */
- public static function unsubscribe_user_from_session($session_id, $user_id)
- {
- $session_id = (int) $session_id;
- $user_id = (int) $user_id;
- $tbl_session_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $sql = "DELETE FROM $tbl_session_rel_user
- WHERE
- session_id = $session_id AND
- user_id = $user_id AND
- relation_type <> ".SESSION_RELATION_TYPE_RRHH;
- $result = Database::query($sql);
- $return = Database::affected_rows($result);
- // Update number of users
- $sql = "UPDATE $tbl_session
- SET nbr_users = nbr_users - $return
- WHERE id = $session_id ";
- Database::query($sql);
- Event::addEvent(
- LOG_SESSION_DELETE_USER,
- LOG_USER_ID,
- $user_id,
- api_get_utc_datetime(),
- api_get_user_id(),
- null,
- $session_id
- );
- // Get the list of courses related to this session
- $course_list = self::get_course_list_by_session_id($session_id);
- if (!empty($course_list)) {
- foreach ($course_list as $course) {
- self::unSubscribeUserFromCourseSession($user_id, $course['id'], $session_id);
- }
- }
- return true;
- }
- /**
- * @param int $user_id
- * @param int $courseId
- * @param int $session_id
- */
- public static function unSubscribeUserFromCourseSession($user_id, $courseId, $session_id)
- {
- $user_id = (int) $user_id;
- $courseId = (int) $courseId;
- $session_id = (int) $session_id;
- $tbl_session_rel_course_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tbl_session_rel_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- // Delete user from course
- $sql = "DELETE FROM $tbl_session_rel_course_rel_user
- WHERE session_id = $session_id AND c_id = $courseId AND user_id = $user_id";
- $result = Database::query($sql);
- if (Database::affected_rows($result)) {
- // Update number of users in this relation
- $sql = "UPDATE $tbl_session_rel_course SET
- nbr_users = nbr_users - 1
- WHERE session_id = $session_id AND c_id = $courseId";
- Database::query($sql);
- }
- Event::addEvent(
- LOG_SESSION_DELETE_USER_COURSE,
- LOG_USER_ID,
- $user_id,
- api_get_utc_datetime(),
- api_get_user_id(),
- $courseId,
- $session_id
- );
- }
- /**
- * Subscribes courses to the given session and optionally (default)
- * unsubscribe previous users.
- *
- * @author Carlos Vargas from existing code
- *
- * @param int $sessionId
- * @param array $courseList List of courses int ids
- * @param bool $removeExistingCoursesWithUsers Whether to unsubscribe
- * existing courses and users (true, default) or not (false)
- * @param bool $copyEvaluation from base course to session course
- * @param bool $copyCourseTeachersAsCoach
- *
- * @throws Exception
- *
- * @return bool False on failure, true otherwise
- * */
- public static function add_courses_to_session(
- $sessionId,
- $courseList,
- $removeExistingCoursesWithUsers = true,
- $copyEvaluation = false,
- $copyCourseTeachersAsCoach = false
- ) {
- $sessionId = (int) $sessionId;
- if (empty($sessionId) || empty($courseList)) {
- return false;
- }
- $em = Database::getManager();
- /** @var Session $session */
- $session = $em->find('ChamiloCoreBundle:Session', $sessionId);
- if (!$session) {
- return false;
- }
- $sessionVisibility = $session->getVisibility();
- $tbl_session_rel_course_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $tbl_session_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $tbl_session_rel_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- // Get list of courses subscribed to this session
- $sql = "SELECT c_id
- FROM $tbl_session_rel_course
- WHERE session_id = $sessionId";
- $rs = Database::query($sql);
- $existingCourses = Database::store_result($rs);
- $nbr_courses = count($existingCourses);
- // Get list of users subscribed to this session
- $sql = "SELECT user_id
- FROM $tbl_session_rel_user
- WHERE
- session_id = $sessionId AND
- relation_type<>".SESSION_RELATION_TYPE_RRHH;
- $result = Database::query($sql);
- $user_list = Database::store_result($result);
- // Remove existing courses from the session.
- if ($removeExistingCoursesWithUsers === true && !empty($existingCourses)) {
- foreach ($existingCourses as $existingCourse) {
- if (!in_array($existingCourse['c_id'], $courseList)) {
- $sql = "DELETE FROM $tbl_session_rel_course
- WHERE
- c_id = ".$existingCourse['c_id']." AND
- session_id = $sessionId";
- Database::query($sql);
- $sql = "DELETE FROM $tbl_session_rel_course_rel_user
- WHERE
- c_id = ".$existingCourse['c_id']." AND
- session_id = $sessionId";
- Database::query($sql);
- Event::addEvent(
- LOG_SESSION_DELETE_COURSE,
- LOG_COURSE_ID,
- $existingCourse['c_id'],
- api_get_utc_datetime(),
- api_get_user_id(),
- $existingCourse['c_id'],
- $sessionId
- );
- CourseManager::remove_course_ranking(
- $existingCourse['c_id'],
- $sessionId
- );
- $nbr_courses--;
- }
- }
- }
- // Pass through the courses list we want to add to the session
- foreach ($courseList as $courseId) {
- $courseInfo = api_get_course_info_by_id($courseId);
- // If course doesn't exists continue!
- if (empty($courseInfo)) {
- continue;
- }
- $exists = false;
- // check if the course we want to add is already subscribed
- foreach ($existingCourses as $existingCourse) {
- if ($courseId == $existingCourse['c_id']) {
- $exists = true;
- }
- }
- if (!$exists) {
- // Copy gradebook categories and links (from base course)
- // to the new course session
- if ($copyEvaluation) {
- $cats = Category::load(null, null, $courseInfo['code']);
- if (!empty($cats)) {
- $sessionCategory = Category:: load(
- null,
- null,
- $courseInfo['code'],
- null,
- null,
- $sessionId,
- false
- );
- // @todo remove commented code
- if (empty($sessionCategory)) {
- // There is no category for this course+session, so create one
- $cat = new Category();
- $sessionName = $session->getName();
- $cat->set_name($courseInfo['code'].' - '.get_lang('Session').' '.$sessionName);
- $cat->set_session_id($sessionId);
- $cat->set_course_code($courseInfo['code']);
- $cat->set_description(null);
- //$cat->set_user_id($stud_id);
- $cat->set_parent_id(0);
- $cat->set_weight(100);
- $cat->set_visible(0);
- $cat->set_certificate_min_score(75);
- $cat->add();
- $sessionGradeBookCategoryId = $cat->get_id();
- } else {
- if (!empty($sessionCategory[0])) {
- $sessionGradeBookCategoryId = $sessionCategory[0]->get_id();
- }
- }
- $categoryIdList = [];
- /** @var Category $cat */
- foreach ($cats as $cat) {
- $categoryIdList[$cat->get_id()] = $cat->get_id();
- }
- $newCategoryIdList = [];
- foreach ($cats as $cat) {
- $links = $cat->get_links(
- null,
- false,
- $courseInfo['code'],
- 0
- );
- //$cat->set_session_id($sessionId);
- //$oldCategoryId = $cat->get_id();
- //$newId = $cat->add();
- //$newCategoryIdList[$oldCategoryId] = $newId;
- //$parentId = $cat->get_parent_id();
- /*if (!empty($parentId)) {
- $newParentId = $newCategoryIdList[$parentId];
- $cat->set_parent_id($newParentId);
- $cat->save();
- }*/
- if (!empty($links)) {
- /** @var AbstractLink $link */
- foreach ($links as $link) {
- //$newCategoryId = $newCategoryIdList[$link->get_category_id()];
- $link->set_category_id($sessionGradeBookCategoryId);
- $link->add();
- }
- }
- $evaluationList = $cat->get_evaluations(
- null,
- false,
- $courseInfo['code'],
- 0
- );
- if (!empty($evaluationList)) {
- /** @var Evaluation $evaluation */
- foreach ($evaluationList as $evaluation) {
- //$evaluationId = $newCategoryIdList[$evaluation->get_category_id()];
- $evaluation->set_category_id($sessionGradeBookCategoryId);
- $evaluation->add();
- }
- }
- }
- // Create
- DocumentManager::generateDefaultCertificate(
- $courseInfo,
- true,
- $sessionId
- );
- }
- }
- // If the course isn't subscribed yet
- $sql = "INSERT INTO $tbl_session_rel_course (session_id, c_id, nbr_users, position)
- VALUES ($sessionId, $courseId, 0, 0)";
- Database::query($sql);
- Event::addEvent(
- LOG_SESSION_ADD_COURSE,
- LOG_COURSE_ID,
- $courseId,
- api_get_utc_datetime(),
- api_get_user_id(),
- $courseId,
- $sessionId
- );
- // We add the current course in the existing courses array,
- // to avoid adding another time the current course
- $existingCourses[] = ['c_id' => $courseId];
- $nbr_courses++;
- // Subscribe all the users from the session to this course inside the session
- $nbr_users = 0;
- foreach ($user_list as $enreg_user) {
- $enreg_user_id = (int) $enreg_user['user_id'];
- $sql = "INSERT IGNORE INTO $tbl_session_rel_course_rel_user (session_id, c_id, user_id, visibility)
- VALUES ($sessionId, $courseId, $enreg_user_id, $sessionVisibility)";
- $result = Database::query($sql);
- Event::addEvent(
- LOG_SESSION_ADD_USER_COURSE,
- LOG_USER_ID,
- $enreg_user_id,
- api_get_utc_datetime(),
- api_get_user_id(),
- $courseId,
- $sessionId
- );
- if (Database::affected_rows($result)) {
- $nbr_users++;
- }
- }
- $sql = "UPDATE $tbl_session_rel_course
- SET nbr_users = $nbr_users
- WHERE session_id = $sessionId AND c_id = $courseId";
- Database::query($sql);
- }
- if ($copyCourseTeachersAsCoach) {
- $teachers = CourseManager::get_teacher_list_from_course_code($courseInfo['code']);
- if (!empty($teachers)) {
- foreach ($teachers as $teacher) {
- self::updateCoaches(
- $sessionId,
- $courseId,
- [$teacher['user_id']],
- false
- );
- }
- }
- }
- }
- $sql = "UPDATE $tbl_session SET nbr_courses = $nbr_courses WHERE id = $sessionId";
- Database::query($sql);
- return true;
- }
- /**
- * Unsubscribe course from a session.
- *
- * @param int $session_id
- * @param int $course_id
- *
- * @return bool True in case of success, false otherwise
- */
- public static function unsubscribe_course_from_session($session_id, $course_id)
- {
- $session_id = (int) $session_id;
- $course_id = (int) $course_id;
- $tbl_session_rel_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $tbl_session_rel_course_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- // Get course code
- $course_code = CourseManager::get_course_code_from_course_id($course_id);
- if (empty($course_code)) {
- return false;
- }
- // Unsubscribe course
- $sql = "DELETE FROM $tbl_session_rel_course
- WHERE c_id = $course_id AND session_id = $session_id";
- $result = Database::query($sql);
- $nb_affected = Database::affected_rows($result);
- $sql = "DELETE FROM $tbl_session_rel_course_rel_user
- WHERE c_id = $course_id AND session_id = $session_id";
- Database::query($sql);
- Event::addEvent(
- LOG_SESSION_DELETE_COURSE,
- LOG_COURSE_ID,
- $course_id,
- api_get_utc_datetime(),
- api_get_user_id(),
- $course_id,
- $session_id
- );
- if ($nb_affected > 0) {
- // Update number of courses in the session
- $sql = "UPDATE $tbl_session SET nbr_courses= nbr_courses - $nb_affected
- WHERE id = $session_id";
- Database::query($sql);
- return true;
- }
- return false;
- }
- /**
- * Creates a new extra field for a given session.
- *
- * @param string $variable Field's internal variable name
- * @param int $fieldType Field's type
- * @param string $displayText Field's language var name
- * @param string $default Field's default value
- *
- * @return int new extra field id
- */
- public static function create_session_extra_field(
- $variable,
- $fieldType,
- $displayText,
- $default = ''
- ) {
- $extraField = new ExtraFieldModel('session');
- $params = [
- 'variable' => $variable,
- 'field_type' => $fieldType,
- 'display_text' => $displayText,
- 'default_value' => $default,
- ];
- return $extraField->save($params);
- }
- /**
- * Update an extra field value for a given session.
- *
- * @param int $sessionId Session ID
- * @param string $variable Field variable name
- * @param string $value Optional. Default field value
- *
- * @return bool|int An integer when register a new extra field. And boolean when update the extrafield
- */
- public static function update_session_extra_field_value($sessionId, $variable, $value = '')
- {
- $extraFieldValue = new ExtraFieldValue('session');
- $params = [
- 'item_id' => $sessionId,
- 'variable' => $variable,
- 'value' => $value,
- ];
- return $extraFieldValue->save($params);
- }
- /**
- * Checks the relationship between a session and a course.
- *
- * @param int $session_id
- * @param int $courseId
- *
- * @return bool returns TRUE if the session and the course are related, FALSE otherwise
- * */
- public static function relation_session_course_exist($session_id, $courseId)
- {
- $tbl_session_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $return_value = false;
- $sql = "SELECT c_id FROM $tbl_session_course
- WHERE
- session_id = ".intval($session_id)." AND
- c_id = ".intval($courseId);
- $result = Database::query($sql);
- $num = Database::num_rows($result);
- if ($num > 0) {
- $return_value = true;
- }
- return $return_value;
- }
- /**
- * Get the session information by name.
- *
- * @param string $name
- *
- * @return mixed false if the session does not exist, array if the session exist
- */
- public static function get_session_by_name($name)
- {
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $name = Database::escape_string(trim($name));
- if (empty($name)) {
- return false;
- }
- $sql = 'SELECT *
- FROM '.$tbl_session.'
- WHERE name = "'.$name.'"';
- $result = Database::query($sql);
- $num = Database::num_rows($result);
- if ($num > 0) {
- return Database::fetch_array($result);
- } else {
- return false;
- }
- }
- /**
- * @param int $sessionId
- * @param int $name
- *
- * @return bool
- */
- public static function sessionNameExistBesidesMySession($sessionId, $name)
- {
- $table = Database::get_main_table(TABLE_MAIN_SESSION);
- $name = Database::escape_string(trim($name));
- $sessionId = (int) $sessionId;
- if (empty($name)) {
- return false;
- }
- $sql = "SELECT *
- FROM $table
- WHERE name = '$name' AND id <> $sessionId ";
- $result = Database::query($sql);
- $num = Database::num_rows($result);
- if ($num > 0) {
- return true;
- }
- return false;
- }
- /**
- * Create a session category.
- *
- * @author Jhon Hinojosa <jhon.hinojosa@dokeos.com>, from existing code
- *
- * @param string name
- * @param int year_start
- * @param int month_start
- * @param int day_start
- * @param int year_end
- * @param int month_end
- * @param int day_end
- *
- * @return int session ID
- * */
- public static function create_category_session(
- $sname,
- $syear_start,
- $smonth_start,
- $sday_start,
- $syear_end,
- $smonth_end,
- $sday_end
- ) {
- $tbl_session_category = Database::get_main_table(TABLE_MAIN_SESSION_CATEGORY);
- $name = trim($sname);
- $year_start = intval($syear_start);
- $month_start = intval($smonth_start);
- $day_start = intval($sday_start);
- $year_end = intval($syear_end);
- $month_end = intval($smonth_end);
- $day_end = intval($sday_end);
- $date_start = "$year_start-".(($month_start < 10) ? "0$month_start" : $month_start)."-".(($day_start < 10) ? "0$day_start" : $day_start);
- $date_end = "$year_end-".(($month_end < 10) ? "0$month_end" : $month_end)."-".(($day_end < 10) ? "0$day_end" : $day_end);
- if (empty($name)) {
- $msg = get_lang('Please give a name to the sessions category');
- return $msg;
- } elseif (!$month_start || !$day_start || !$year_start || !checkdate($month_start, $day_start, $year_start)) {
- $msg = get_lang('Invalid start date was given.');
- return $msg;
- } elseif (!$month_end && !$day_end && !$year_end) {
- $date_end = '';
- } elseif (!$month_end || !$day_end || !$year_end || !checkdate($month_end, $day_end, $year_end)) {
- $msg = get_lang('Invalid end date was given.');
- return $msg;
- } elseif ($date_start >= $date_end) {
- $msg = get_lang('The first date should be before the end date');
- return $msg;
- }
- $access_url_id = api_get_current_access_url_id();
- $params = [
- 'name' => $name,
- 'date_start' => $date_start,
- 'access_url_id' => $access_url_id,
- ];
- if (!empty($date_end)) {
- $params['date_end'] = $date_end;
- }
- $id = Database::insert($tbl_session_category, $params);
- // Add event to system log
- $user_id = api_get_user_id();
- Event::addEvent(
- LOG_SESSION_CATEGORY_CREATE,
- LOG_SESSION_CATEGORY_ID,
- $id,
- api_get_utc_datetime(),
- $user_id
- );
- return $id;
- }
- /**
- * Edit a sessions category.
- *
- * @author Jhon Hinojosa <jhon.hinojosa@dokeos.com>,from existing code
- *
- * @param int id
- * @param string name
- * @param int year_start
- * @param int month_start
- * @param int day_start
- * @param int year_end
- * @param int month_end
- * @param int day_end
- *
- * @return bool
- * The parameter id is a primary key
- * */
- public static function edit_category_session(
- $id,
- $sname,
- $syear_start,
- $smonth_start,
- $sday_start,
- $syear_end,
- $smonth_end,
- $sday_end
- ) {
- $tbl_session_category = Database::get_main_table(TABLE_MAIN_SESSION_CATEGORY);
- $name = trim($sname);
- $year_start = intval($syear_start);
- $month_start = intval($smonth_start);
- $day_start = intval($sday_start);
- $year_end = intval($syear_end);
- $month_end = intval($smonth_end);
- $day_end = intval($sday_end);
- $id = intval($id);
- $date_start = "$year_start-".(($month_start < 10) ? "0$month_start" : $month_start)."-".(($day_start < 10) ? "0$day_start" : $day_start);
- $date_end = "$year_end-".(($month_end < 10) ? "0$month_end" : $month_end)."-".(($day_end < 10) ? "0$day_end" : $day_end);
- if (empty($name)) {
- $msg = get_lang('Please give a name to the sessions category');
- return $msg;
- } elseif (!$month_start || !$day_start || !$year_start || !checkdate($month_start, $day_start, $year_start)) {
- $msg = get_lang('Invalid start date was given.');
- return $msg;
- } elseif (!$month_end && !$day_end && !$year_end) {
- $date_end = null;
- } elseif (!$month_end || !$day_end || !$year_end || !checkdate($month_end, $day_end, $year_end)) {
- $msg = get_lang('Invalid end date was given.');
- return $msg;
- } elseif ($date_start >= $date_end) {
- $msg = get_lang('The first date should be before the end date');
- return $msg;
- }
- if ($date_end != null) {
- $sql = "UPDATE $tbl_session_category
- SET
- name = '".Database::escape_string($name)."',
- date_start = '$date_start' ,
- date_end = '$date_end'
- WHERE id= $id";
- } else {
- $sql = "UPDATE $tbl_session_category SET
- name = '".Database::escape_string($name)."',
- date_start = '$date_start',
- date_end = NULL
- WHERE id= $id";
- }
- $result = Database::query($sql);
- return $result ? true : false;
- }
- /**
- * Delete sessions categories.
- *
- * @param array|int $categoryId
- * @param bool $deleteSessions Optional. Include delete session.
- * @param bool $fromWs Optional. True if the function is called by a webservice, false otherwise.
- *
- * @return bool Nothing, or false on error
- * The parameters is a array to delete sessions
- *
- * @author Jhon Hinojosa <jhon.hinojosa@dokeos.com>, from existing code
- */
- public static function delete_session_category($categoryId, $deleteSessions = false, $fromWs = false)
- {
- $tblSessionCategory = Database::get_main_table(TABLE_MAIN_SESSION_CATEGORY);
- $tblSession = Database::get_main_table(TABLE_MAIN_SESSION);
- if (is_array($categoryId)) {
- $categoryId = array_map('intval', $categoryId);
- } else {
- $categoryId = [(int) $categoryId];
- }
- $categoryId = implode(', ', $categoryId);
- if ($deleteSessions) {
- $sql = "SELECT id FROM $tblSession WHERE session_category_id IN ($categoryId)";
- $result = Database::query($sql);
- while ($rows = Database::fetch_array($result)) {
- $sessionId = $rows['id'];
- self::delete($sessionId, $fromWs);
- }
- } else {
- $sql = "UPDATE $tblSession SET session_category_id = NULL WHERE session_category_id IN ($categoryId)";
- Database::query($sql);
- }
- $sql = "DELETE FROM $tblSessionCategory WHERE id IN ($categoryId)";
- Database::query($sql);
- // Add event to system log
- Event::addEvent(
- LOG_SESSION_CATEGORY_DELETE,
- LOG_SESSION_CATEGORY_ID,
- $categoryId,
- api_get_utc_datetime(),
- api_get_user_id()
- );
- return true;
- }
- /**
- * Get a list of sessions of which the given conditions match with an = 'cond'.
- *
- * @param array $conditions a list of condition example :
- * array('status' => STUDENT) or
- * array('s.name' => array('operator' => 'LIKE', value = '%$needle%'))
- * @param array $order_by a list of fields on which sort
- * @param int $urlId
- * @param array $onlyThisSessionList
- *
- * @return array an array with all sessions of the platform
- *
- * @todo optional course code parameter, optional sorting parameters...
- */
- public static function get_sessions_list(
- $conditions = [],
- $order_by = [],
- $from = null,
- $to = null,
- $urlId = 0,
- $onlyThisSessionList = []
- ) {
- $session_table = Database::get_main_table(TABLE_MAIN_SESSION);
- $session_category_table = Database::get_main_table(TABLE_MAIN_SESSION_CATEGORY);
- $user_table = Database::get_main_table(TABLE_MAIN_USER);
- $table_access_url_rel_session = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $session_course_table = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $course_table = Database::get_main_table(TABLE_MAIN_COURSE);
- $urlId = empty($urlId) ? api_get_current_access_url_id() : (int) $urlId;
- $return_array = [];
- $sql_query = " SELECT
- DISTINCT(s.id),
- s.name,
- s.nbr_courses,
- s.access_start_date,
- s.access_end_date,
- u.firstname,
- u.lastname,
- sc.name as category_name,
- s.promotion_id
- FROM $session_table s
- INNER JOIN $user_table u ON s.id_coach = u.user_id
- INNER JOIN $table_access_url_rel_session ar ON ar.session_id = s.id
- LEFT JOIN $session_category_table sc ON s.session_category_id = sc.id
- LEFT JOIN $session_course_table sco ON (sco.session_id = s.id)
- INNER JOIN $course_table c ON sco.c_id = c.id
- WHERE ar.access_url_id = $urlId ";
- $availableFields = [
- 's.id',
- 's.name',
- 'c.id',
- ];
- $availableOperator = [
- 'like',
- '>=',
- '<=',
- '=',
- ];
- if (count($conditions) > 0) {
- foreach ($conditions as $field => $options) {
- $operator = strtolower($options['operator']);
- $value = Database::escape_string($options['value']);
- $sql_query .= ' AND ';
- if (in_array($field, $availableFields) && in_array($operator, $availableOperator)) {
- $sql_query .= $field." $operator '".$value."'";
- }
- }
- }
- if (!empty($onlyThisSessionList)) {
- $onlyThisSessionList = array_map('intval', $onlyThisSessionList);
- $onlyThisSessionList = implode("','", $onlyThisSessionList);
- $sql_query .= " AND s.id IN ('$onlyThisSessionList') ";
- }
- $orderAvailableList = ['name'];
- if (count($order_by) > 0) {
- $order = null;
- $direction = null;
- if (isset($order_by[0]) && in_array($order_by[0], $orderAvailableList)) {
- $order = $order_by[0];
- }
- if (isset($order_by[1]) && in_array(strtolower($order_by[1]), ['desc', 'asc'])) {
- $direction = $order_by[1];
- }
- if (!empty($order)) {
- $sql_query .= " ORDER BY $order $direction ";
- }
- }
- if (!is_null($from) && !is_null($to)) {
- $to = (int) $to;
- $from = (int) $from;
- $sql_query .= "LIMIT $from, $to";
- }
- $sql_result = Database::query($sql_query);
- if (Database::num_rows($sql_result) > 0) {
- while ($result = Database::fetch_array($sql_result)) {
- $return_array[$result['id']] = $result;
- }
- }
- return $return_array;
- }
- /**
- * Get the session category information by id.
- *
- * @param string session category ID
- *
- * @return mixed false if the session category does not exist, array if the session category exists
- */
- public static function get_session_category($id)
- {
- $table = Database::get_main_table(TABLE_MAIN_SESSION_CATEGORY);
- $id = (int) $id;
- $sql = "SELECT id, name, date_start, date_end
- FROM $table
- WHERE id= $id";
- $result = Database::query($sql);
- $num = Database::num_rows($result);
- if ($num > 0) {
- return Database::fetch_array($result);
- } else {
- return false;
- }
- }
- /**
- * Get Hot Sessions (limit 8).
- *
- * @return array with sessions
- */
- public static function getHotSessions()
- {
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $tbl_session_category = Database::get_main_table(TABLE_MAIN_SESSION_CATEGORY);
- $tbl_users = Database::get_main_table(TABLE_MAIN_USER);
- $tbl_extra_fields = Database::get_main_table(TABLE_EXTRA_FIELD_VALUES);
- $tbl_session_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $tbl_lp = Database::get_course_table(TABLE_LP_MAIN);
- $extraField = new ExtraFieldModel('session');
- $field = $extraField->get_handler_field_info_by_field_variable('image');
- $sql = "SELECT
- s.id,
- s.name,
- s.id_coach,
- u.firstname,
- u.lastname,
- s.session_category_id,
- c.name as category_name,
- s.description,
- (SELECT COUNT(*) FROM $tbl_session_user WHERE session_id = s.id) as users,
- (SELECT COUNT(*) FROM $tbl_lp WHERE session_id = s.id) as lessons ";
- if ($field !== false) {
- $fieldId = $field['id'];
- $sql .= ",(SELECT value FROM $tbl_extra_fields WHERE field_id = $fieldId AND item_id = s.id) as image ";
- }
- $sql .= " FROM $tbl_session s
- LEFT JOIN $tbl_session_category c
- ON s.session_category_id = c.id
- INNER JOIN $tbl_users u
- ON s.id_coach = u.id
- ORDER BY 9 DESC
- LIMIT 8";
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0) {
- $plugin = BuyCoursesPlugin::create();
- $checker = $plugin->isEnabled();
- $sessions = [];
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- if (!isset($row['image'])) {
- $row['image'] = '';
- }
- $row['on_sale'] = '';
- if ($checker) {
- $row['on_sale'] = $plugin->getItemByProduct(
- $row['id'],
- BuyCoursesPlugin::PRODUCT_TYPE_SESSION
- );
- }
- $sessions[] = $row;
- }
- return $sessions;
- }
- return false;
- }
- /**
- * Get all session categories (filter by access_url_id).
- *
- * @return mixed false if the session category does not exist, array if the session category exists
- */
- public static function get_all_session_category()
- {
- $table = Database::get_main_table(TABLE_MAIN_SESSION_CATEGORY);
- $id = api_get_current_access_url_id();
- $sql = 'SELECT * FROM '.$table.'
- WHERE access_url_id = '.$id.'
- ORDER BY name ASC';
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0) {
- $data = Database::store_result($result, 'ASSOC');
- return $data;
- }
- return false;
- }
- /**
- * Assign a coach to course in session with status = 2.
- *
- * @param int $userId
- * @param int $sessionId
- * @param int $courseId
- * @param bool $noCoach optional, if is true the user don't be a coach now,
- * otherwise it'll assign a coach
- *
- * @return bool true if there are affected rows, otherwise false
- */
- public static function set_coach_to_course_session(
- $userId,
- $sessionId = 0,
- $courseId = 0,
- $noCoach = false
- ) {
- // Definition of variables
- $userId = (int) $userId;
- $sessionId = !empty($sessionId) ? (int) $sessionId : api_get_session_id();
- $courseId = !empty($courseId) ? (int) $courseId : api_get_course_id();
- if (empty($sessionId) || empty($courseId) || empty($userId)) {
- return false;
- }
- // Table definition
- $tblSessionRelCourseRelUser = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tblSessionRelUser = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $tblUser = Database::get_main_table(TABLE_MAIN_USER);
- // check if user is a teacher
- $sql = "SELECT * FROM $tblUser
- WHERE status = 1 AND user_id = $userId";
- $rsCheckUser = Database::query($sql);
- if (Database::num_rows($rsCheckUser) <= 0) {
- return false;
- }
- if ($noCoach) {
- // check if user_id exists in session_rel_user (if the user is
- // subscribed to the session in any manner)
- $sql = "SELECT user_id FROM $tblSessionRelUser
- WHERE
- session_id = $sessionId AND
- user_id = $userId";
- $res = Database::query($sql);
- if (Database::num_rows($res) > 0) {
- // The user is already subscribed to the session. Change the
- // record so the user is NOT a coach for this course anymore
- // and then exit
- $sql = "UPDATE $tblSessionRelCourseRelUser
- SET status = 0
- WHERE
- session_id = $sessionId AND
- c_id = $courseId AND
- user_id = $userId ";
- $result = Database::query($sql);
- return Database::affected_rows($result) > 0;
- }
- // The user is not subscribed to the session, so make sure
- // he isn't subscribed to a course in this session either
- // and then exit
- $sql = "DELETE FROM $tblSessionRelCourseRelUser
- WHERE
- session_id = $sessionId AND
- c_id = $courseId AND
- user_id = $userId ";
- $result = Database::query($sql);
- return Database::affected_rows($result) > 0;
- }
- // Assign user as a coach to course
- // First check if the user is registered to the course
- $sql = "SELECT user_id FROM $tblSessionRelCourseRelUser
- WHERE
- session_id = $sessionId AND
- c_id = $courseId AND
- user_id = $userId";
- $rs_check = Database::query($sql);
- // Then update or insert.
- if (Database::num_rows($rs_check) > 0) {
- $sql = "UPDATE $tblSessionRelCourseRelUser SET status = 2
- WHERE
- session_id = $sessionId AND
- c_id = $courseId AND
- user_id = $userId ";
- $result = Database::query($sql);
- return Database::affected_rows($result) > 0;
- }
- $sql = "INSERT INTO $tblSessionRelCourseRelUser(session_id, c_id, user_id, status, visibility)
- VALUES($sessionId, $courseId, $userId, 2, 1)";
- $result = Database::query($sql);
- return Database::affected_rows($result) > 0;
- }
- /**
- * @param int $sessionId
- *
- * @return bool
- */
- public static function removeAllDrhFromSession($sessionId)
- {
- $tbl_session_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $sessionId = (int) $sessionId;
- if (empty($sessionId)) {
- return false;
- }
- $sql = "DELETE FROM $tbl_session_rel_user
- WHERE
- session_id = $sessionId AND
- relation_type =".SESSION_RELATION_TYPE_RRHH;
- Database::query($sql);
- return true;
- }
- /**
- * Subscribes sessions to human resource manager (Dashboard feature).
- *
- * @param array $userInfo Human Resource Manager info
- * @param array $sessions_list Sessions id
- * @param bool $sendEmail
- * @param bool $removeSessionsFromUser
- *
- * @return int
- * */
- public static function subscribeSessionsToDrh(
- $userInfo,
- $sessions_list,
- $sendEmail = false,
- $removeSessionsFromUser = true
- ) {
- // Database Table Definitions
- $tbl_session_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $tbl_session_rel_access_url = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- if (empty($userInfo)) {
- return 0;
- }
- $userId = $userInfo['user_id'];
- // Only subscribe DRH users.
- $rolesAllowed = [
- DRH,
- SESSIONADMIN,
- PLATFORM_ADMIN,
- COURSE_TUTOR,
- ];
- $isAdmin = api_is_platform_admin_by_id($userInfo['user_id']);
- if (!$isAdmin && !in_array($userInfo['status'], $rolesAllowed)) {
- return 0;
- }
- $affected_rows = 0;
- // Deleting assigned sessions to hrm_id.
- if ($removeSessionsFromUser) {
- if (api_is_multiple_url_enabled()) {
- $sql = "SELECT s.session_id
- FROM $tbl_session_rel_user s
- INNER JOIN $tbl_session_rel_access_url a
- ON (a.session_id = s.session_id)
- WHERE
- s.user_id = $userId AND
- relation_type = ".SESSION_RELATION_TYPE_RRHH." AND
- access_url_id = ".api_get_current_access_url_id();
- } else {
- $sql = "SELECT s.session_id
- FROM $tbl_session_rel_user s
- WHERE user_id = $userId AND relation_type=".SESSION_RELATION_TYPE_RRHH;
- }
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0) {
- while ($row = Database::fetch_array($result)) {
- $sql = "DELETE FROM $tbl_session_rel_user
- WHERE
- session_id = {$row['session_id']} AND
- user_id = $userId AND
- relation_type =".SESSION_RELATION_TYPE_RRHH;
- Database::query($sql);
- }
- }
- }
- // Inserting new sessions list.
- if (!empty($sessions_list) && is_array($sessions_list)) {
- foreach ($sessions_list as $session_id) {
- $session_id = intval($session_id);
- $sql = "SELECT session_id
- FROM $tbl_session_rel_user
- WHERE
- session_id = $session_id AND
- user_id = $userId AND
- relation_type = '".SESSION_RELATION_TYPE_RRHH."'";
- $result = Database::query($sql);
- if (Database::num_rows($result) == 0) {
- $sql = "INSERT IGNORE INTO $tbl_session_rel_user (session_id, user_id, relation_type, registered_at)
- VALUES (
- $session_id,
- $userId,
- '".SESSION_RELATION_TYPE_RRHH."',
- '".api_get_utc_datetime()."'
- )";
- Database::query($sql);
- $affected_rows++;
- }
- }
- }
- return $affected_rows;
- }
- /**
- * @param int $sessionId
- *
- * @return array
- */
- public static function getDrhUsersInSession($sessionId)
- {
- return self::get_users_by_session($sessionId, SESSION_RELATION_TYPE_RRHH);
- }
- /**
- * @param int $userId
- * @param int $sessionId
- *
- * @return array
- */
- public static function getSessionFollowedByDrh($userId, $sessionId)
- {
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $tbl_session_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $tbl_session_rel_access_url = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $userId = (int) $userId;
- $sessionId = (int) $sessionId;
- $select = " SELECT * ";
- if (api_is_multiple_url_enabled()) {
- $sql = " $select FROM $tbl_session s
- INNER JOIN $tbl_session_rel_user sru ON (sru.session_id = s.id)
- LEFT JOIN $tbl_session_rel_access_url a ON (s.id = a.session_id)
- WHERE
- sru.user_id = '$userId' AND
- sru.session_id = '$sessionId' AND
- sru.relation_type = '".SESSION_RELATION_TYPE_RRHH."' AND
- access_url_id = ".api_get_current_access_url_id()."
- ";
- } else {
- $sql = "$select FROM $tbl_session s
- INNER JOIN $tbl_session_rel_user sru
- ON
- sru.session_id = s.id AND
- sru.user_id = '$userId' AND
- sru.session_id = '$sessionId' AND
- sru.relation_type = '".SESSION_RELATION_TYPE_RRHH."'
- ";
- }
- $result = Database::query($sql);
- if (Database::num_rows($result)) {
- $row = Database::fetch_array($result, 'ASSOC');
- $row['course_list'] = self::get_course_list_by_session_id($sessionId);
- return $row;
- }
- return [];
- }
- /**
- * Get sessions followed by human resources manager.
- *
- * @param int $userId
- * @param int $start
- * @param int $limit
- * @param bool $getCount
- * @param bool $getOnlySessionId
- * @param bool $getSql
- * @param string $orderCondition
- * @param string $keyword
- * @param string $description
- * @param array $options
- *
- * @return array sessions
- */
- public static function get_sessions_followed_by_drh(
- $userId,
- $start = null,
- $limit = null,
- $getCount = false,
- $getOnlySessionId = false,
- $getSql = false,
- $orderCondition = null,
- $keyword = '',
- $description = '',
- $options = []
- ) {
- return self::getSessionsFollowedByUser(
- $userId,
- DRH,
- $start,
- $limit,
- $getCount,
- $getOnlySessionId,
- $getSql,
- $orderCondition,
- $keyword,
- $description,
- $options
- );
- }
- /**
- * Get sessions followed by human resources manager.
- *
- * @param int $userId
- * @param int $status DRH Optional
- * @param int $start
- * @param int $limit
- * @param bool $getCount
- * @param bool $getOnlySessionId
- * @param bool $getSql
- * @param string $orderCondition
- * @param string $keyword
- * @param string $description
- * @param array $options
- *
- * @return array sessions
- */
- public static function getSessionsFollowedByUser(
- $userId,
- $status = null,
- $start = null,
- $limit = null,
- $getCount = false,
- $getOnlySessionId = false,
- $getSql = false,
- $orderCondition = null,
- $keyword = '',
- $description = '',
- $options = []
- ) {
- // Database Table Definitions
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $tbl_session_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $tbl_session_rel_course_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tbl_session_rel_access_url = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $extraFieldModel = new ExtraFieldModel('session');
- $conditions = $extraFieldModel->parseConditions($options);
- $sqlInjectJoins = $conditions['inject_joins'];
- $extraFieldsConditions = $conditions['where'];
- $sqlInjectWhere = $conditions['inject_where'];
- $injectExtraFields = $conditions['inject_extra_fields'];
- if (!empty($injectExtraFields)) {
- $injectExtraFields = ' , '.$injectExtraFields.' s.id';
- }
- $userId = (int) $userId;
- $select = ' SELECT DISTINCT * '.$injectExtraFields;
- if ($getCount) {
- $select = ' SELECT count(DISTINCT(s.id)) as count ';
- }
- if ($getOnlySessionId) {
- $select = ' SELECT DISTINCT(s.id) ';
- }
- $limitCondition = null;
- if (!is_null($start) && !is_null($limit)) {
- $limitCondition = " LIMIT ".intval($start).", ".intval($limit);
- }
- if (empty($orderCondition)) {
- $orderCondition = ' ORDER BY s.name ';
- }
- $whereConditions = null;
- $sessionCourseConditions = null;
- $sessionConditions = null;
- $sessionQuery = '';
- $courseSessionQuery = null;
- switch ($status) {
- case DRH:
- $sessionQuery = "SELECT sru.session_id
- FROM
- $tbl_session_rel_user sru
- WHERE
- sru.relation_type = '".SESSION_RELATION_TYPE_RRHH."' AND
- sru.user_id = $userId";
- break;
- case COURSEMANAGER:
- $courseSessionQuery = "
- SELECT scu.session_id as id
- FROM $tbl_session_rel_course_rel_user scu
- WHERE (scu.status = 2 AND scu.user_id = $userId)";
- $whereConditions = " OR (s.id_coach = $userId) ";
- break;
- default:
- $sessionQuery = "SELECT sru.session_id
- FROM
- $tbl_session_rel_user sru
- WHERE
- sru.user_id = $userId";
- break;
- }
- $keywordCondition = '';
- if (!empty($keyword)) {
- $keyword = Database::escape_string($keyword);
- $keywordCondition = " AND (s.name LIKE '%$keyword%' ) ";
- if (!empty($description)) {
- $description = Database::escape_string($description);
- $keywordCondition = " AND (s.name LIKE '%$keyword%' OR s.description LIKE '%$description%' ) ";
- }
- }
- $whereConditions .= $keywordCondition;
- $subQuery = $sessionQuery.$courseSessionQuery;
- $sql = " $select
- FROM $tbl_session s
- INNER JOIN $tbl_session_rel_access_url a
- ON (s.id = a.session_id)
- $sqlInjectJoins
- WHERE
- access_url_id = ".api_get_current_access_url_id()." AND
- s.id IN (
- $subQuery
- )
- $whereConditions
- $extraFieldsConditions
- $sqlInjectWhere
- $orderCondition
- $limitCondition";
- if ($getSql) {
- return $sql;
- }
- $result = Database::query($sql);
- if ($getCount) {
- $row = Database::fetch_array($result);
- return $row['count'];
- }
- $sessions = [];
- if (Database::num_rows($result) > 0) {
- $sysUploadPath = api_get_path(SYS_UPLOAD_PATH).'sessions/';
- $webUploadPath = api_get_path(WEB_UPLOAD_PATH).'sessions/';
- $imgPath = Display::return_icon(
- 'session_default_small.png',
- null,
- [],
- ICON_SIZE_SMALL,
- false,
- true
- );
- while ($row = Database::fetch_array($result)) {
- if ($getOnlySessionId) {
- $sessions[$row['id']] = $row;
- continue;
- }
- $imageFilename = ExtraFieldModel::FIELD_TYPE_FILE_IMAGE.'_'.$row['id'].'.png';
- $row['image'] = is_file($sysUploadPath.$imageFilename) ? $webUploadPath.$imageFilename : $imgPath;
- if ($row['display_start_date'] == '0000-00-00 00:00:00' || $row['display_start_date'] == '0000-00-00') {
- $row['display_start_date'] = null;
- }
- if ($row['display_end_date'] == '0000-00-00 00:00:00' || $row['display_end_date'] == '0000-00-00') {
- $row['display_end_date'] = null;
- }
- if ($row['access_start_date'] == '0000-00-00 00:00:00' || $row['access_start_date'] == '0000-00-00') {
- $row['access_start_date'] = null;
- }
- if ($row['access_end_date'] == '0000-00-00 00:00:00' || $row['access_end_date'] == '0000-00-00') {
- $row['access_end_date'] = null;
- }
- if ($row['coach_access_start_date'] == '0000-00-00 00:00:00' ||
- $row['coach_access_start_date'] == '0000-00-00'
- ) {
- $row['coach_access_start_date'] = null;
- }
- if ($row['coach_access_end_date'] == '0000-00-00 00:00:00' ||
- $row['coach_access_end_date'] == '0000-00-00'
- ) {
- $row['coach_access_end_date'] = null;
- }
- $sessions[$row['id']] = $row;
- }
- }
- return $sessions;
- }
- /**
- * Gets the list (or the count) of courses by session filtered by access_url.
- *
- * @param int $session_id The session id
- * @param string $course_name The course code
- * @param string $orderBy Field to order the data
- * @param bool $getCount Optional. Count the session courses
- *
- * @return array|int List of courses. Whether $getCount is true, return the count
- */
- public static function get_course_list_by_session_id(
- $session_id,
- $course_name = '',
- $orderBy = null,
- $getCount = false
- ) {
- $tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
- $tbl_session_rel_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $session_id = (int) $session_id;
- $sqlSelect = '*, c.id, c.id as real_id, c.code as course_code';
- if ($getCount) {
- $sqlSelect = 'COUNT(1) as count';
- }
- // select the courses
- $sql = "SELECT $sqlSelect
- FROM $tbl_course c
- INNER JOIN $tbl_session_rel_course src
- ON (c.id = src.c_id)
- WHERE src.session_id = '$session_id' ";
- if (!empty($course_name)) {
- $course_name = Database::escape_string($course_name);
- $sql .= " AND c.title LIKE '%$course_name%' ";
- }
- if (!empty($orderBy)) {
- $orderBy = Database::escape_string($orderBy);
- $orderBy = " ORDER BY $orderBy";
- } else {
- if (self::orderCourseIsEnabled()) {
- $orderBy .= ' ORDER BY position ';
- } else {
- $orderBy .= ' ORDER BY title ';
- }
- }
- $sql .= Database::escape_string($orderBy);
- $result = Database::query($sql);
- $num_rows = Database::num_rows($result);
- $courses = [];
- if ($num_rows > 0) {
- if ($getCount) {
- $count = Database::fetch_assoc($result);
- return (int) $count['count'];
- }
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- $courses[$row['real_id']] = $row;
- }
- }
- return $courses;
- }
- /**
- * Gets the list of courses by session filtered by access_url.
- *
- * @param $userId
- * @param $sessionId
- * @param null $from
- * @param null $limit
- * @param null $column
- * @param null $direction
- * @param bool $getCount
- * @param string $keyword
- *
- * @return array
- */
- public static function getAllCoursesFollowedByUser(
- $userId,
- $sessionId,
- $from = null,
- $limit = null,
- $column = null,
- $direction = null,
- $getCount = false,
- $keyword = ''
- ) {
- if (empty($sessionId)) {
- $sessionsSQL = self::get_sessions_followed_by_drh(
- $userId,
- null,
- null,
- null,
- true,
- true
- );
- } else {
- $sessionsSQL = intval($sessionId);
- }
- $tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
- $tbl_session_rel_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- if ($getCount) {
- $select = "SELECT COUNT(DISTINCT(c.code)) as count ";
- } else {
- $select = "SELECT DISTINCT c.* ";
- }
- $keywordCondition = null;
- if (!empty($keyword)) {
- $keyword = Database::escape_string($keyword);
- $keywordCondition = " AND (c.code LIKE '%$keyword%' OR c.title LIKE '%$keyword%' ) ";
- }
- // Select the courses
- $sql = "$select
- FROM $tbl_course c
- INNER JOIN $tbl_session_rel_course src
- ON c.id = src.c_id
- WHERE
- src.session_id IN ($sessionsSQL)
- $keywordCondition
- ";
- if ($getCount) {
- $result = Database::query($sql);
- $row = Database::fetch_array($result, 'ASSOC');
- return $row['count'];
- }
- if (isset($from) && isset($limit)) {
- $from = intval($from);
- $limit = intval($limit);
- $sql .= " LIMIT $from, $limit";
- }
- $result = Database::query($sql);
- $num_rows = Database::num_rows($result);
- $courses = [];
- if ($num_rows > 0) {
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- $courses[$row['id']] = $row;
- }
- }
- return $courses;
- }
- /**
- * Gets the list of courses by session filtered by access_url.
- *
- * @param int $session_id
- * @param string $course_name
- *
- * @return array list of courses
- */
- public static function get_course_list_by_session_id_like($session_id, $course_name = '')
- {
- $tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
- $tbl_session_rel_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $session_id = (int) $session_id;
- $course_name = Database::escape_string($course_name);
- // select the courses
- $sql = "SELECT c.id, c.title FROM $tbl_course c
- INNER JOIN $tbl_session_rel_course src
- ON c.id = src.c_id
- WHERE ";
- if (!empty($session_id)) {
- $sql .= "src.session_id LIKE '$session_id' AND ";
- }
- if (!empty($course_name)) {
- $sql .= "UPPER(c.title) LIKE UPPER('%$course_name%') ";
- }
- $sql .= "ORDER BY title;";
- $result = Database::query($sql);
- $num_rows = Database::num_rows($result);
- $courses = [];
- if ($num_rows > 0) {
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- $courses[$row['id']] = $row;
- }
- }
- return $courses;
- }
- /**
- * Gets the count of courses by session filtered by access_url.
- *
- * @param int session id
- * @param string $keyword
- *
- * @return array list of courses
- */
- public static function getCourseCountBySessionId($session_id, $keyword = '')
- {
- $tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
- $tbl_session_rel_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $session_id = (int) $session_id;
- // select the courses
- $sql = "SELECT COUNT(c.code) count
- FROM $tbl_course c
- INNER JOIN $tbl_session_rel_course src
- ON c.id = src.c_id
- WHERE src.session_id = '$session_id' ";
- $keywordCondition = null;
- if (!empty($keyword)) {
- $keyword = Database::escape_string($keyword);
- $keywordCondition = " AND (c.code LIKE '%$keyword%' OR c.title LIKE '%$keyword%' ) ";
- }
- $sql .= $keywordCondition;
- $result = Database::query($sql);
- $num_rows = Database::num_rows($result);
- if ($num_rows > 0) {
- $row = Database::fetch_array($result, 'ASSOC');
- return $row['count'];
- }
- return null;
- }
- /**
- * Get the session id based on the original id and field name in the extra fields.
- * Returns 0 if session was not found.
- *
- * @param string $value Original session id
- * @param string $variable Original field name
- *
- * @return int Session id
- */
- public static function getSessionIdFromOriginalId($value, $variable)
- {
- $extraFieldValue = new ExtraFieldValue('session');
- $result = $extraFieldValue->get_item_id_from_field_variable_and_field_value(
- $variable,
- $value
- );
- if (!empty($result)) {
- return $result['item_id'];
- }
- return 0;
- }
- /**
- * Get users by session.
- *
- * @param int $id session id
- * @param int $status filter by status coach = 2
- * @param bool $getCount Optional. Allow get the number of rows from the result
- * @param int $urlId
- *
- * @return array|int A list with an user list. If $getCount is true then return a the count of registers
- */
- public static function get_users_by_session(
- $id,
- $status = null,
- $getCount = false,
- $urlId = 0
- ) {
- if (empty($id)) {
- return [];
- }
- $id = (int) $id;
- $urlId = empty($urlId) ? api_get_current_access_url_id() : (int) $urlId;
- $tbl_user = Database::get_main_table(TABLE_MAIN_USER);
- $tbl_session_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $table_access_url_user = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER);
- $selectedField = '
- u.user_id, u.lastname, u.firstname, u.username, su.relation_type, au.access_url_id,
- su.moved_to, su.moved_status, su.moved_at, su.registered_at
- ';
- if ($getCount) {
- $selectedField = 'count(1) AS count';
- }
- $sql = "SELECT $selectedField
- FROM $tbl_user u
- INNER JOIN $tbl_session_rel_user su
- ON u.user_id = su.user_id AND
- su.session_id = $id
- LEFT OUTER JOIN $table_access_url_user au
- ON (au.user_id = u.user_id)
- ";
- if (is_numeric($status)) {
- $status = (int) $status;
- $sql .= " WHERE su.relation_type = $status AND (au.access_url_id = $urlId OR au.access_url_id is null)";
- } else {
- $sql .= " WHERE (au.access_url_id = $urlId OR au.access_url_id is null )";
- }
- $sql .= ' ORDER BY su.relation_type, ';
- $sql .= api_sort_by_first_name() ? ' u.firstname, u.lastname' : ' u.lastname, u.firstname';
- $result = Database::query($sql);
- if ($getCount) {
- $count = Database::fetch_assoc($result);
- return $count['count'];
- }
- $return = [];
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- $return[] = $row;
- }
- return $return;
- }
- /**
- * The general coach (field: session.id_coach).
- *
- * @param int $user_id user id
- * @param bool $asPlatformAdmin The user is platform admin, return everything
- *
- * @return array
- */
- public static function get_sessions_by_general_coach($user_id, $asPlatformAdmin = false)
- {
- $session_table = Database::get_main_table(TABLE_MAIN_SESSION);
- $user_id = (int) $user_id;
- // Session where we are general coach
- $sql = "SELECT DISTINCT *
- FROM $session_table";
- if (!$asPlatformAdmin) {
- $sql .= " WHERE id_coach = $user_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();
- $sqlCoach = '';
- if (!$asPlatformAdmin) {
- $sqlCoach = " id_coach = $user_id AND ";
- }
- if ($access_url_id != -1) {
- $sql = 'SELECT DISTINCT session.*
- FROM '.$session_table.' session INNER JOIN '.$tbl_session_rel_access_url.' session_rel_url
- ON (session.id = session_rel_url.session_id)
- WHERE '.$sqlCoach.' access_url_id = '.$access_url_id;
- }
- }
- $sql .= ' ORDER by name';
- $result = Database::query($sql);
- return Database::store_result($result, 'ASSOC');
- }
- /**
- * @param int $user_id
- *
- * @return array
- *
- * @deprecated use get_sessions_by_general_coach()
- */
- public static function get_sessions_by_coach($user_id)
- {
- $session_table = Database::get_main_table(TABLE_MAIN_SESSION);
- return Database::select(
- '*',
- $session_table,
- ['where' => ['id_coach = ?' => $user_id]]
- );
- }
- /**
- * @param int $user_id
- * @param int $courseId
- * @param int $session_id
- *
- * @return array|bool
- */
- public static function get_user_status_in_course_session($user_id, $courseId, $session_id)
- {
- $table = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tbl_user = Database::get_main_table(TABLE_MAIN_USER);
- $sql = "SELECT session_rcru.status
- FROM $table session_rcru
- INNER JOIN $tbl_user user
- ON (session_rcru.user_id = user.user_id)
- WHERE
- session_rcru.session_id = '".intval($session_id)."' AND
- session_rcru.c_id ='".intval($courseId)."' AND
- user.user_id = ".intval($user_id);
- $result = Database::query($sql);
- $status = false;
- if (Database::num_rows($result)) {
- $status = Database::fetch_row($result);
- $status = $status['0'];
- }
- return $status;
- }
- /**
- * Gets user status within a session.
- *
- * @param int $userId
- * @param int $sessionId
- *
- * @return SessionRelUser
- */
- public static function getUserStatusInSession($userId, $sessionId)
- {
- $em = Database::getManager();
- $subscriptions = $em
- ->getRepository('ChamiloCoreBundle:SessionRelUser')
- ->findBy(['session' => $sessionId, 'user' => $userId]);
- /** @var SessionRelUser $subscription */
- $subscription = current($subscriptions);
- return $subscription;
- }
- /**
- * @param int $id
- *
- * @return array
- */
- public static function get_all_sessions_by_promotion($id)
- {
- $table = Database::get_main_table(TABLE_MAIN_SESSION);
- return Database::select(
- '*',
- $table,
- ['where' => ['promotion_id = ?' => $id]]
- );
- }
- /**
- * @param int $promotion_id
- * @param array $list
- */
- public static function subscribe_sessions_to_promotion($promotion_id, $list)
- {
- $table = Database::get_main_table(TABLE_MAIN_SESSION);
- $params = [];
- $params['promotion_id'] = 0;
- Database::update(
- $table,
- $params,
- ['promotion_id = ?' => $promotion_id]
- );
- $params['promotion_id'] = $promotion_id;
- if (!empty($list)) {
- foreach ($list as $session_id) {
- $session_id = (int) $session_id;
- Database::update($table, $params, ['id = ?' => $session_id]);
- }
- }
- }
- /**
- * Updates a session status.
- *
- * @param int session id
- * @param int status
- */
- public static function set_session_status($session_id, $status)
- {
- $t = Database::get_main_table(TABLE_MAIN_SESSION);
- $params['visibility'] = $status;
- Database::update($t, $params, ['id = ?' => $session_id]);
- }
- /**
- * Copies a session with the same data to a new session.
- * The new copy is not assigned to the same promotion.
- *
- *
- * @param int $id Session ID
- * @param bool $copy_courses Whether to copy the relationship with courses
- * @param bool $copyTeachersAndDrh
- * @param bool $create_new_courses New courses will be created
- * @param bool $set_exercises_lp_invisible Set exercises and LPs in the new session to invisible by default
- *
- * @return int The new session ID on success, 0 otherwise
- *
- * @see subscribe_sessions_to_promotions() for that.
- *
- * @todo make sure the extra session fields are copied too
- */
- public static function copy(
- $id,
- $copy_courses = true,
- $copyTeachersAndDrh = true,
- $create_new_courses = false,
- $set_exercises_lp_invisible = false
- ) {
- $id = (int) $id;
- $s = self::fetch($id);
- if (empty($s)) {
- return false;
- }
- // Check all dates before copying
- // Get timestamp for now in UTC - see http://php.net/manual/es/function.time.php#117251
- $now = time() - date('Z');
- // Timestamp in one month
- $inOneMonth = $now + (30 * 24 * 3600);
- $inOneMonth = api_get_local_time($inOneMonth);
- if (api_strtotime($s['access_start_date']) < $now) {
- $s['access_start_date'] = api_get_local_time($now);
- }
- if (api_strtotime($s['display_start_date']) < $now) {
- $s['display_start_date'] = api_get_local_time($now);
- }
- if (api_strtotime($s['coach_access_start_date']) < $now) {
- $s['coach_access_start_date'] = api_get_local_time($now);
- }
- if (api_strtotime($s['access_end_date']) < $now) {
- $s['access_end_date'] = $inOneMonth;
- }
- if (api_strtotime($s['display_end_date']) < $now) {
- $s['display_end_date'] = $inOneMonth;
- }
- if (api_strtotime($s['coach_access_end_date']) < $now) {
- $s['coach_access_end_date'] = $inOneMonth;
- }
- $extraFieldValue = new ExtraFieldValue('session');
- $extraFieldsValues = $extraFieldValue->getAllValuesByItem($id);
- $extraFieldsValuesToCopy = [];
- if (!empty($extraFieldsValues)) {
- foreach ($extraFieldsValues as $extraFieldValue) {
- //$extraFieldsValuesToCopy['extra_'.$extraFieldValue['variable']] = $extraFieldValue['value'];
- $extraFieldsValuesToCopy['extra_'.$extraFieldValue['variable']]['extra_'.$extraFieldValue['variable']] = $extraFieldValue['value'];
- }
- }
- if (isset($extraFieldsValuesToCopy['extra_image']) && isset($extraFieldsValuesToCopy['extra_image']['extra_image'])) {
- $extraFieldsValuesToCopy['extra_image'] = [
- 'tmp_name' => api_get_path(SYS_UPLOAD_PATH).$extraFieldsValuesToCopy['extra_image']['extra_image'],
- 'error' => 0,
- ];
- }
- // Now try to create the session
- $sid = self::create_session(
- $s['name'].' '.get_lang('Copy'),
- $s['access_start_date'],
- $s['access_end_date'],
- $s['display_start_date'],
- $s['display_end_date'],
- $s['coach_access_start_date'],
- $s['coach_access_end_date'],
- (int) $s['id_coach'],
- $s['session_category_id'],
- (int) $s['visibility'],
- true,
- $s['duration'],
- $s['description'],
- $s['show_description'],
- $extraFieldsValuesToCopy
- );
- if (!is_numeric($sid) || empty($sid)) {
- return false;
- }
- if ($copy_courses) {
- // Register courses from the original session to the new session
- $courses = self::get_course_list_by_session_id($id);
- $short_courses = $new_short_courses = [];
- if (is_array($courses) && count($courses) > 0) {
- foreach ($courses as $course) {
- $short_courses[] = $course;
- }
- }
- // We will copy the current courses of the session to new courses
- if (!empty($short_courses)) {
- if ($create_new_courses) {
- api_set_more_memory_and_time_limits();
- $params = [];
- $params['skip_lp_dates'] = true;
- foreach ($short_courses as $course_data) {
- $course_info = CourseManager::copy_course_simple(
- $course_data['title'].' '.get_lang(
- 'Copy'
- ),
- $course_data['course_code'],
- $id,
- $sid,
- $params
- );
- if ($course_info) {
- //By default new elements are invisible
- if ($set_exercises_lp_invisible) {
- $list = new LearnpathList('', $course_info, $sid);
- $flat_list = $list->get_flat_list();
- if (!empty($flat_list)) {
- foreach ($flat_list as $lp_id => $data) {
- api_item_property_update(
- $course_info,
- TOOL_LEARNPATH,
- $lp_id,
- 'invisible',
- api_get_user_id(),
- 0,
- 0,
- 0,
- 0,
- $sid
- );
- }
- }
- $quiz_table = Database::get_course_table(TABLE_QUIZ_TEST);
- $course_id = $course_info['real_id'];
- //@todo check this query
- $sql = "UPDATE $quiz_table SET active = 0
- WHERE c_id = $course_id AND session_id = $sid";
- Database::query($sql);
- }
- $new_short_courses[] = $course_info['real_id'];
- }
- }
- } else {
- foreach ($short_courses as $course_data) {
- $new_short_courses[] = $course_data['id'];
- }
- }
- $short_courses = $new_short_courses;
- self::add_courses_to_session($sid, $short_courses, true);
- if ($create_new_courses === false && $copyTeachersAndDrh) {
- foreach ($short_courses as $courseItemId) {
- $coachList = self::getCoachesByCourseSession($id, $courseItemId);
- foreach ($coachList as $userId) {
- self::set_coach_to_course_session($userId, $sid, $courseItemId);
- }
- }
- }
- }
- }
- if ($copyTeachersAndDrh) {
- // Register users from the original session to the new session
- $users = self::get_users_by_session($id);
- if (!empty($users)) {
- $userListByStatus = [];
- foreach ($users as $userData) {
- $userData['relation_type'] = (int) $userData['relation_type'];
- $userListByStatus[$userData['relation_type']][] = $userData;
- }
- foreach ($userListByStatus as $status => $userList) {
- $userList = array_column($userList, 'user_id');
- switch ($status) {
- case 0:
- /*self::subscribeUsersToSession(
- $sid,
- $userList,
- SESSION_VISIBLE_READ_ONLY,
- false,
- true
- );*/
- break;
- case 1:
- // drh users
- foreach ($userList as $drhId) {
- $userInfo = api_get_user_info($drhId);
- self::subscribeSessionsToDrh($userInfo, [$sid], false, false);
- }
- break;
- }
- }
- }
- }
- return $sid;
- }
- /**
- * @param int $user_id
- * @param int $session_id
- *
- * @return bool
- */
- public static function user_is_general_coach($user_id, $session_id)
- {
- $session_id = (int) $session_id;
- $user_id = (int) $user_id;
- $table = Database::get_main_table(TABLE_MAIN_SESSION);
- $sql = "SELECT DISTINCT id
- FROM $table
- WHERE session.id_coach = '".$user_id."' AND id = '$session_id'";
- $result = Database::query($sql);
- if ($result && Database::num_rows($result)) {
- return true;
- }
- return false;
- }
- /**
- * Get the number of sessions.
- *
- * @param int $access_url_id ID of the URL we want to filter on (optional)
- *
- * @return int Number of sessions
- */
- public static function count_sessions($access_url_id = 0)
- {
- $session_table = Database::get_main_table(TABLE_MAIN_SESSION);
- $access_url_rel_session_table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $access_url_id = (int) $access_url_id;
- $sql = "SELECT count(s.id) FROM $session_table s";
- if (!empty($access_url_id)) {
- $sql .= ", $access_url_rel_session_table u ".
- " WHERE s.id = u.session_id AND u.access_url_id = $access_url_id";
- }
- $res = Database::query($sql);
- $row = Database::fetch_row($res);
- return $row[0];
- }
- /**
- * @param int $id
- * @param bool $checkSession
- *
- * @return bool
- */
- public static function cantEditSession($id, $checkSession = true)
- {
- if (!self::allowToManageSessions()) {
- return false;
- }
- if (api_is_platform_admin() && self::allowed($id)) {
- return true;
- }
- if ($checkSession) {
- if (self::allowed($id)) {
- return true;
- }
- return false;
- }
- return true;
- }
- /**
- * Protect a session to be edited.
- *
- * @param int $id
- * @param bool $checkSession
- *
- * @return mixed | bool true if pass the check, api_not_allowed otherwise
- */
- public static function protectSession($id, $checkSession = true)
- {
- if (!self::cantEditSession($id, $checkSession)) {
- api_not_allowed(true);
- }
- }
- /**
- * @return bool
- */
- public static function allowToManageSessions()
- {
- if (self::allowManageAllSessions()) {
- return true;
- }
- $setting = api_get_setting('allow_teachers_to_create_sessions');
- if (api_is_teacher() && $setting == 'true') {
- return true;
- }
- return false;
- }
- /**
- * @return bool
- */
- public static function allowOnlyMySessions()
- {
- if (self::allowToManageSessions() &&
- !api_is_platform_admin() &&
- api_is_teacher()
- ) {
- return true;
- }
- return false;
- }
- /**
- * @return bool
- */
- public static function allowManageAllSessions()
- {
- if (api_is_platform_admin() || api_is_session_admin()) {
- return true;
- }
- return false;
- }
- /**
- * @param $id
- *
- * @return bool
- */
- public static function protect_teacher_session_edit($id)
- {
- if (!api_is_coach($id) && !api_is_platform_admin()) {
- api_not_allowed(true);
- } else {
- return true;
- }
- }
- /**
- * @param int $courseId
- *
- * @return array
- */
- public static function get_session_by_course($courseId)
- {
- $table_session_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $table_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $url = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $courseId = (int) $courseId;
- $urlId = api_get_current_access_url_id();
- if (empty($courseId)) {
- return [];
- }
- $sql = "SELECT name, s.id
- FROM $table_session_course sc
- INNER JOIN $table_session s
- ON (sc.session_id = s.id)
- INNER JOIN $url u
- ON (u.session_id = s.id)
- WHERE
- u.access_url_id = $urlId AND
- sc.c_id = '$courseId' ";
- $result = Database::query($sql);
- return Database::store_result($result);
- }
- /**
- * @param int $userId
- * @param bool $ignoreVisibilityForAdmins
- * @param bool $ignoreTimeLimit
- *
- * @return array
- */
- public static function get_sessions_by_user(
- $userId,
- $ignoreVisibilityForAdmins = false,
- $ignoreTimeLimit = false
- ) {
- $sessionCategories = UserManager::get_sessions_by_category(
- $userId,
- false,
- $ignoreVisibilityForAdmins,
- $ignoreTimeLimit
- );
- $sessionArray = [];
- if (!empty($sessionCategories)) {
- foreach ($sessionCategories as $category) {
- if (isset($category['sessions'])) {
- foreach ($category['sessions'] as $session) {
- $sessionArray[] = $session;
- }
- }
- }
- }
- return $sessionArray;
- }
- /**
- * @param string $file
- * @param bool $updateSession true: if the session exists it will be updated.
- * false: if session exists a new session will be created adding a counter session1, session2, etc
- * @param int $defaultUserId
- * @param Logger $logger
- * @param array $extraFields convert a file row to an extra field. Example in CSV file there's a SessionID
- * then it will converted to extra_external_session_id if you set: array('SessionId' => 'extra_external_session_id')
- * @param string $extraFieldId
- * @param int $daysCoachAccessBeforeBeginning
- * @param int $daysCoachAccessAfterBeginning
- * @param int $sessionVisibility
- * @param array $fieldsToAvoidUpdate
- * @param bool $deleteUsersNotInList
- * @param bool $updateCourseCoaches
- * @param bool $sessionWithCoursesModifier
- * @param bool $addOriginalCourseTeachersAsCourseSessionCoaches
- * @param bool $removeAllTeachersFromCourse
- * @param int $showDescription
- * @param array $teacherBackupList
- * @param array $groupBackup
- *
- * @return array
- */
- public static function importCSV(
- $file,
- $updateSession,
- $defaultUserId = null,
- $logger = null,
- $extraFields = [],
- $extraFieldId = null,
- $daysCoachAccessBeforeBeginning = null,
- $daysCoachAccessAfterBeginning = null,
- $sessionVisibility = 1,
- $fieldsToAvoidUpdate = [],
- $deleteUsersNotInList = false,
- $updateCourseCoaches = false,
- $sessionWithCoursesModifier = false,
- $addOriginalCourseTeachersAsCourseSessionCoaches = true,
- $removeAllTeachersFromCourse = true,
- $showDescription = null,
- &$teacherBackupList = [],
- &$groupBackup = []
- ) {
- $content = file($file);
- $error_message = null;
- $session_counter = 0;
- $defaultUserId = empty($defaultUserId) ? api_get_user_id() : (int) $defaultUserId;
- $eol = PHP_EOL;
- if (PHP_SAPI != 'cli') {
- $eol = '<br />';
- }
- $debug = false;
- if (isset($logger)) {
- $debug = true;
- }
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $tbl_session_user = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $tbl_session_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $tbl_session_course_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $sessions = [];
- if (!api_strstr($content[0], ';')) {
- $error_message = get_lang('The specified file is not CSV format !');
- } else {
- $tag_names = [];
- foreach ($content as $key => $enreg) {
- $enreg = explode(';', trim($enreg));
- if ($key) {
- foreach ($tag_names as $tag_key => $tag_name) {
- if (isset($enreg[$tag_key])) {
- $sessions[$key - 1][$tag_name] = $enreg[$tag_key];
- }
- }
- } else {
- foreach ($enreg as $tag_name) {
- $tag_names[] = api_preg_replace('/[^a-zA-Z0-9_\-]/', '', $tag_name);
- }
- if (!in_array('SessionName', $tag_names) ||
- !in_array('DateStart', $tag_names) ||
- !in_array('DateEnd', $tag_names)
- ) {
- $error_message = get_lang('The specified file doesn\'t contain all needed data !');
- break;
- }
- }
- }
- $sessionList = [];
- $report = [];
- // Looping the sessions.
- foreach ($sessions as $enreg) {
- $user_counter = 0;
- $course_counter = 0;
- if (isset($extraFields) && !empty($extraFields)) {
- foreach ($extraFields as $original => $to) {
- $enreg[$to] = isset($enreg[$original]) ? $enreg[$original] : null;
- }
- }
- $session_name = $enreg['SessionName'];
- if ($debug) {
- $logger->addInfo('---------------------------------------');
- $logger->addInfo("Sessions - Start process of session: $session_name");
- $logger->addInfo('---------------------------------------');
- }
- // Default visibility
- $visibilityAfterExpirationPerSession = $sessionVisibility;
- if (isset($enreg['VisibilityAfterExpiration'])) {
- $visibility = $enreg['VisibilityAfterExpiration'];
- switch ($visibility) {
- case 'read_only':
- $visibilityAfterExpirationPerSession = SESSION_VISIBLE_READ_ONLY;
- break;
- case 'accessible':
- $visibilityAfterExpirationPerSession = SESSION_VISIBLE;
- break;
- case 'not_accessible':
- $visibilityAfterExpirationPerSession = SESSION_INVISIBLE;
- break;
- }
- }
- if (empty($session_name)) {
- continue;
- }
- $displayAccessStartDate = isset($enreg['DisplayStartDate']) ? $enreg['DisplayStartDate'] : $enreg['DateStart'];
- $displayAccessEndDate = isset($enreg['DisplayEndDate']) ? $enreg['DisplayEndDate'] : $enreg['DateEnd'];
- $coachAccessStartDate = isset($enreg['CoachStartDate']) ? $enreg['CoachStartDate'] : $enreg['DateStart'];
- $coachAccessEndDate = isset($enreg['CoachEndDate']) ? $enreg['CoachEndDate'] : $enreg['DateEnd'];
- // We assume the dates are already in UTC
- $dateStart = explode('/', $enreg['DateStart']);
- $dateEnd = explode('/', $enreg['DateEnd']);
- $dateStart = $dateStart[0].'-'.$dateStart[1].'-'.$dateStart[2].' 00:00:00';
- $dateEnd = $dateEnd[0].'-'.$dateEnd[1].'-'.$dateEnd[2].' 23:59:59';
- $displayAccessStartDate = explode('/', $displayAccessStartDate);
- $displayAccessStartDate = implode('-', $displayAccessStartDate).' 00:00:00';
- $displayAccessEndDate = explode('/', $displayAccessEndDate);
- $displayAccessEndDate = implode('-', $displayAccessEndDate).' 23:59:59';
- $coachAccessStartDate = explode('/', $coachAccessStartDate);
- $coachAccessStartDate = implode('-', $coachAccessStartDate).' 00:00:00';
- $coachAccessEndDate = explode('/', $coachAccessEndDate);
- $coachAccessEndDate = implode('-', $coachAccessEndDate).' 23:59:59';
- $session_category_id = isset($enreg['SessionCategory']) ? $enreg['SessionCategory'] : null;
- $sessionDescription = isset($enreg['SessionDescription']) ? $enreg['SessionDescription'] : null;
- $classes = isset($enreg['Classes']) ? explode('|', $enreg['Classes']) : [];
- $extraParams = [];
- if (!is_null($showDescription)) {
- $extraParams['show_description'] = intval($showDescription);
- }
- $coachBefore = '';
- $coachAfter = '';
- if (!empty($daysCoachAccessBeforeBeginning) && !empty($daysCoachAccessAfterBeginning)) {
- $date = new \DateTime($dateStart);
- $interval = new DateInterval('P'.$daysCoachAccessBeforeBeginning.'D');
- $date->sub($interval);
- $coachBefore = $date->format('Y-m-d h:i');
- $coachAccessStartDate = $coachBefore;
- $coachBefore = api_get_utc_datetime($coachBefore);
- $date = new \DateTime($dateEnd);
- $interval = new DateInterval('P'.$daysCoachAccessAfterBeginning.'D');
- $date->add($interval);
- $coachAfter = $date->format('Y-m-d h:i');
- $coachAccessEndDate = $coachAfter;
- $coachAfter = api_get_utc_datetime($coachAfter);
- }
- $dateStart = api_get_utc_datetime($dateStart);
- $dateEnd = api_get_utc_datetime($dateEnd);
- $displayAccessStartDate = api_get_utc_datetime($displayAccessStartDate);
- $displayAccessEndDate = api_get_utc_datetime($displayAccessEndDate);
- $coachAccessStartDate = api_get_utc_datetime($coachAccessStartDate);
- $coachAccessEndDate = api_get_utc_datetime($coachAccessEndDate);
- if (!empty($sessionDescription)) {
- $extraParams['description'] = $sessionDescription;
- }
- if (!empty($session_category_id)) {
- $extraParams['session_category_id'] = $session_category_id;
- }
- // Searching a general coach.
- if (!empty($enreg['Coach'])) {
- $coach_id = UserManager::get_user_id_from_username($enreg['Coach']);
- if ($coach_id === false) {
- // If the coach-user does not exist - I'm the coach.
- $coach_id = $defaultUserId;
- }
- } else {
- $coach_id = $defaultUserId;
- }
- $users = explode('|', $enreg['Users']);
- $courses = explode('|', $enreg['Courses']);
- $deleteOnlyCourseCoaches = false;
- if (count($courses) == 1) {
- if ($logger) {
- $logger->addInfo('Only one course delete old coach list');
- }
- $deleteOnlyCourseCoaches = true;
- }
- if (!$updateSession) {
- // Create a session.
- $unique_name = false;
- $i = 0;
- // Change session name, verify that session doesn't exist.
- $suffix = null;
- while (!$unique_name) {
- if ($i > 1) {
- $suffix = ' - '.$i;
- }
- $sql = 'SELECT 1 FROM '.$tbl_session.'
- WHERE name="'.Database::escape_string($session_name).$suffix.'"';
- $rs = Database::query($sql);
- if (Database::result($rs, 0, 0)) {
- $i++;
- } else {
- $unique_name = true;
- $session_name .= $suffix;
- }
- }
- $sessionParams = [
- 'name' => $session_name,
- 'id_coach' => $coach_id,
- 'access_start_date' => $dateStart,
- 'access_end_date' => $dateEnd,
- 'display_start_date' => $displayAccessStartDate,
- 'display_end_date' => $displayAccessEndDate,
- 'coach_access_start_date' => $coachAccessStartDate,
- 'coach_access_end_date' => $coachAccessEndDate,
- 'visibility' => $visibilityAfterExpirationPerSession,
- 'session_admin_id' => $defaultUserId,
- ];
- if (!empty($extraParams)) {
- $sessionParams = array_merge($sessionParams, $extraParams);
- }
- // Creating the session.
- $session_id = Database::insert($tbl_session, $sessionParams);
- if ($debug) {
- if ($session_id) {
- foreach ($enreg as $key => $value) {
- if (substr($key, 0, 6) == 'extra_') { //an extra field
- self::update_session_extra_field_value($session_id, substr($key, 6), $value);
- }
- }
- $logger->addInfo("Session created: #$session_id - $session_name");
- } else {
- $message = "Sessions - Session NOT created: $session_name";
- $logger->addError($message);
- $report[] = $message;
- }
- }
- $session_counter++;
- } else {
- $sessionId = null;
- if (isset($extraFields) && !empty($extraFields) && !empty($enreg['extra_'.$extraFieldId])) {
- $sessionId = self::getSessionIdFromOriginalId($enreg['extra_'.$extraFieldId], $extraFieldId);
- if (empty($sessionId)) {
- $my_session_result = false;
- } else {
- $my_session_result = true;
- }
- } else {
- $my_session_result = self::get_session_by_name($enreg['SessionName']);
- }
- if ($my_session_result === false) {
- // One more check
- $sessionExistsWithName = self::get_session_by_name($session_name);
- if ($sessionExistsWithName) {
- if ($debug) {
- $message = "Skip Session - Trying to update a session, but name already exists: $session_name";
- $logger->addError($message);
- $report[] = $message;
- }
- continue;
- }
- $sessionParams = [
- 'name' => $session_name,
- 'id_coach' => $coach_id,
- 'access_start_date' => $dateStart,
- 'access_end_date' => $dateEnd,
- 'display_start_date' => $displayAccessStartDate,
- 'display_end_date' => $displayAccessEndDate,
- 'coach_access_start_date' => $coachAccessStartDate,
- 'coach_access_end_date' => $coachAccessEndDate,
- 'visibility' => $visibilityAfterExpirationPerSession,
- 'session_admin_id' => $defaultUserId,
- ];
- if (!empty($extraParams)) {
- $sessionParams = array_merge($sessionParams, $extraParams);
- }
- Database::insert($tbl_session, $sessionParams);
- // We get the last insert id.
- $my_session_result = self::get_session_by_name($session_name);
- $session_id = $my_session_result['id'];
- if ($session_id) {
- foreach ($enreg as $key => $value) {
- if (substr($key, 0, 6) == 'extra_') { //an extra field
- self::update_session_extra_field_value($session_id, substr($key, 6), $value);
- }
- }
- if ($debug) {
- $logger->addInfo("Sessions - #$session_id created: $session_name");
- }
- // Delete session-user relation only for students
- $sql = "DELETE FROM $tbl_session_user
- WHERE session_id = '$session_id' AND relation_type <> ".SESSION_RELATION_TYPE_RRHH;
- Database::query($sql);
- $sql = "DELETE FROM $tbl_session_course WHERE session_id = '$session_id'";
- Database::query($sql);
- // Delete session-course-user relationships students and coaches.
- if ($updateCourseCoaches) {
- $sql = "DELETE FROM $tbl_session_course_user
- WHERE session_id = '$session_id' AND status in ('0', '2')";
- Database::query($sql);
- } else {
- // Delete session-course-user relation ships *only* for students.
- $sql = "DELETE FROM $tbl_session_course_user
- WHERE session_id = '$session_id' AND status <> 2";
- Database::query($sql);
- }
- if ($deleteOnlyCourseCoaches) {
- $sql = "DELETE FROM $tbl_session_course_user
- WHERE session_id = '$session_id' AND status in ('2')";
- Database::query($sql);
- }
- }
- } else {
- // Updating the session.
- $params = [
- 'id_coach' => $coach_id,
- 'access_start_date' => $dateStart,
- 'access_end_date' => $dateEnd,
- 'display_start_date' => $displayAccessStartDate,
- 'display_end_date' => $displayAccessEndDate,
- 'coach_access_start_date' => $coachAccessStartDate,
- 'coach_access_end_date' => $coachAccessEndDate,
- 'visibility' => $visibilityAfterExpirationPerSession,
- 'session_category_id' => $session_category_id,
- ];
- if (!empty($sessionDescription)) {
- $params['description'] = $sessionDescription;
- }
- if (!empty($fieldsToAvoidUpdate)) {
- foreach ($fieldsToAvoidUpdate as $field) {
- unset($params[$field]);
- }
- }
- if (isset($sessionId) && !empty($sessionId)) {
- $session_id = $sessionId;
- if (!empty($enreg['SessionName'])) {
- $sessionExistsWithName = self::get_session_by_name($session_name);
- if ($sessionExistsWithName === false) {
- $sessionName = Database::escape_string($enreg['SessionName']);
- $sql = "UPDATE $tbl_session SET name = '$sessionName' WHERE id = $session_id";
- Database::query($sql);
- $logger->addInfo(
- "Session #$session_id name IS updated with: '$session_name' External id: ".$enreg['extra_'.$extraFieldId]
- );
- } else {
- $sessionExistsBesidesMe = self::sessionNameExistBesidesMySession(
- $session_id,
- $session_name
- );
- if ($sessionExistsBesidesMe === true) {
- if ($debug) {
- $message = "Skip Session. Error when update session Session #$session_id Name: '$session_name'. Other session has the same name. External id: ".$enreg['extra_'.$extraFieldId];
- $logger->addError($message);
- $report[] = $message;
- }
- continue;
- } else {
- if ($debug) {
- $logger->addInfo(
- "Session #$session_id name is not updated because it didn't change (but update of other session values will continue) Name: '$session_name' External id: ".$enreg['extra_'.$extraFieldId]
- );
- }
- }
- }
- }
- } else {
- $my_session_result = self::get_session_by_name($session_name);
- $session_id = $my_session_result['id'];
- }
- if ($debug) {
- $logger->addInfo("Session #$session_id to be updated: '$session_name'");
- }
- if ($session_id) {
- $sessionInfo = api_get_session_info($session_id);
- $params['show_description'] = isset($sessionInfo['show_description']) ? $sessionInfo['show_description'] : intval($showDescription);
- if (!empty($daysCoachAccessBeforeBeginning) && !empty($daysCoachAccessAfterBeginning)) {
- if (empty($sessionInfo['nb_days_access_before_beginning']) ||
- (!empty($sessionInfo['nb_days_access_before_beginning']) &&
- $sessionInfo['nb_days_access_before_beginning'] < $daysCoachAccessBeforeBeginning)
- ) {
- $params['coach_access_start_date'] = $coachBefore;
- }
- if (empty($sessionInfo['nb_days_access_after_end']) ||
- (!empty($sessionInfo['nb_days_access_after_end']) &&
- $sessionInfo['nb_days_access_after_end'] < $daysCoachAccessAfterBeginning)
- ) {
- $params['coach_access_end_date'] = $coachAfter;
- }
- }
- Database::update($tbl_session, $params, ['id = ?' => $session_id]);
- foreach ($enreg as $key => $value) {
- if (substr($key, 0, 6) == 'extra_') { //an extra field
- self::update_session_extra_field_value($session_id, substr($key, 6), $value);
- }
- }
- if ($debug) {
- $logger->addInfo("Session updated #$session_id");
- }
- // Delete session-user relation only for students
- $sql = "DELETE FROM $tbl_session_user
- WHERE session_id = '$session_id' AND relation_type <> ".SESSION_RELATION_TYPE_RRHH;
- Database::query($sql);
- $sql = "DELETE FROM $tbl_session_course WHERE session_id = '$session_id'";
- Database::query($sql);
- // Delete session-course-user relationships students and coaches.
- if ($updateCourseCoaches) {
- $sql = "DELETE FROM $tbl_session_course_user
- WHERE session_id = '$session_id' AND status in ('0', '2')";
- Database::query($sql);
- } else {
- // Delete session-course-user relation ships *only* for students.
- $sql = "DELETE FROM $tbl_session_course_user
- WHERE session_id = '$session_id' AND status <> 2";
- Database::query($sql);
- }
- if ($deleteOnlyCourseCoaches) {
- $sql = "DELETE FROM $tbl_session_course_user
- WHERE session_id = '$session_id' AND status in ('2')";
- Database::query($sql);
- }
- } else {
- if ($debug) {
- $logger->addError(
- "Sessions - Session not found"
- );
- }
- }
- }
- $session_counter++;
- }
- $sessionList[] = $session_id;
- // Adding the relationship "Session - User" for students
- $userList = [];
- if (is_array($users)) {
- $extraFieldValueCareer = new ExtraFieldValue('career');
- $careerList = isset($enreg['extra_careerid']) && !empty($enreg['extra_careerid']) ? $enreg['extra_careerid'] : [];
- $careerList = str_replace(['[', ']'], '', $careerList);
- $careerList = explode(',', $careerList);
- $finalCareerIdList = [];
- foreach ($careerList as $careerId) {
- $realCareerIdList = $extraFieldValueCareer->get_item_id_from_field_variable_and_field_value(
- 'external_career_id',
- $careerId
- );
- if (isset($realCareerIdList['item_id'])) {
- $finalCareerIdList[] = $realCareerIdList['item_id'];
- }
- }
- foreach ($users as $user) {
- $user_id = UserManager::get_user_id_from_username($user);
- if ($user_id !== false) {
- if (!empty($finalCareerIdList)) {
- foreach ($finalCareerIdList as $careerId) {
- UserManager::addUserCareer($user_id, $careerId);
- }
- }
- $userList[] = $user_id;
- // Insert new users.
- $sql = "INSERT IGNORE INTO $tbl_session_user SET
- user_id = '$user_id',
- session_id = '$session_id',
- registered_at = '".api_get_utc_datetime()."'";
- Database::query($sql);
- if ($debug) {
- $logger->addInfo("Adding User #$user_id ($user) to session #$session_id");
- }
- $user_counter++;
- }
- }
- }
- if ($deleteUsersNotInList) {
- // Getting user in DB in order to compare to the new list.
- $usersListInDatabase = self::get_users_by_session($session_id, 0);
- if (!empty($usersListInDatabase)) {
- if (empty($userList)) {
- foreach ($usersListInDatabase as $userInfo) {
- self::unsubscribe_user_from_session($session_id, $userInfo['user_id']);
- }
- } else {
- foreach ($usersListInDatabase as $userInfo) {
- if (!in_array($userInfo['user_id'], $userList)) {
- self::unsubscribe_user_from_session($session_id, $userInfo['user_id']);
- }
- }
- }
- }
- }
- // See BT#6449
- $onlyAddFirstCoachOrTeacher = false;
- if ($sessionWithCoursesModifier) {
- if (count($courses) >= 2) {
- // Only first teacher in course session;
- $onlyAddFirstCoachOrTeacher = true;
- // Remove all teachers from course.
- $removeAllTeachersFromCourse = false;
- }
- }
- foreach ($courses as $course) {
- $courseArray = bracketsToArray($course);
- $course_code = $courseArray[0];
- if (CourseManager::course_exists($course_code)) {
- $courseInfo = api_get_course_info($course_code);
- $courseId = $courseInfo['real_id'];
- // Adding the course to a session.
- $sql = "INSERT IGNORE INTO $tbl_session_course
- SET c_id = '$courseId', session_id='$session_id'";
- Database::query($sql);
- self::installCourse($session_id, $courseInfo['real_id']);
- if ($debug) {
- $logger->addInfo("Adding course '$course_code' to session #$session_id");
- }
- $course_counter++;
- $course_coaches = isset($courseArray[1]) ? $courseArray[1] : null;
- $course_users = isset($courseArray[2]) ? $courseArray[2] : null;
- $course_users = explode(',', $course_users);
- $course_coaches = explode(',', $course_coaches);
- // Checking if the flag is set TeachersWillBeAddedAsCoachInAllCourseSessions (course_edit.php)
- $addTeachersToSession = true;
- if (array_key_exists('add_teachers_to_sessions_courses', $courseInfo)) {
- $addTeachersToSession = $courseInfo['add_teachers_to_sessions_courses'];
- }
- // If any user provided for a course, use the users array.
- if (empty($course_users)) {
- if (!empty($userList)) {
- self::subscribe_users_to_session_course(
- $userList,
- $session_id,
- $course_code
- );
- if ($debug) {
- $msg = "Adding student list ".implode(', #', $userList)." to course: '$course_code' and session #$session_id";
- $logger->addInfo($msg);
- }
- }
- }
- // Adding coaches to session course user.
- if (!empty($course_coaches)) {
- $savedCoaches = [];
- // only edit if add_teachers_to_sessions_courses is set.
- if ($addTeachersToSession) {
- if ($addOriginalCourseTeachersAsCourseSessionCoaches) {
- // Adding course teachers as course session teachers.
- $alreadyAddedTeachers = CourseManager::get_teacher_list_from_course_code(
- $course_code
- );
- if (!empty($alreadyAddedTeachers)) {
- $teachersToAdd = [];
- foreach ($alreadyAddedTeachers as $user) {
- $teachersToAdd[] = $user['username'];
- }
- $course_coaches = array_merge(
- $course_coaches,
- $teachersToAdd
- );
- }
- }
- foreach ($course_coaches as $course_coach) {
- $coach_id = UserManager::get_user_id_from_username($course_coach);
- if ($coach_id !== false) {
- // Just insert new coaches
- self::updateCoaches(
- $session_id,
- $courseId,
- [$coach_id],
- false
- );
- if ($debug) {
- $logger->addInfo("Adding course coach: user #$coach_id ($course_coach) to course: '$course_code' and session #$session_id");
- }
- $savedCoaches[] = $coach_id;
- } else {
- $error_message .= get_lang('This user doesn\'t exist').' : '.$course_coach.$eol;
- }
- }
- }
- // Custom courses/session coaches
- $teacherToAdd = null;
- // Only one coach is added.
- if ($onlyAddFirstCoachOrTeacher == true) {
- if ($debug) {
- $logger->addInfo("onlyAddFirstCoachOrTeacher : true");
- }
- foreach ($course_coaches as $course_coach) {
- $coach_id = UserManager::get_user_id_from_username($course_coach);
- if ($coach_id !== false) {
- $teacherToAdd = $coach_id;
- break;
- }
- }
- // Un subscribe everyone that's not in the list.
- $teacherList = CourseManager::get_teacher_list_from_course_code($course_code);
- if (!empty($teacherList)) {
- foreach ($teacherList as $teacher) {
- if ($teacherToAdd != $teacher['user_id']) {
- $sql = "SELECT * FROM ".Database::get_main_table(TABLE_MAIN_COURSE_USER)."
- WHERE
- user_id = ".$teacher['user_id']." AND
- c_id = '".$courseId."'
- ";
- $result = Database::query($sql);
- $rows = Database::num_rows($result);
- if ($rows > 0) {
- $userCourseData = Database::fetch_array($result, 'ASSOC');
- if (!empty($userCourseData)) {
- $teacherBackupList[$teacher['user_id']][$course_code] = $userCourseData;
- }
- }
- $sql = "SELECT * FROM ".Database::get_course_table(TABLE_GROUP_USER)."
- WHERE
- user_id = ".$teacher['user_id']." AND
- c_id = '".$courseInfo['real_id']."'
- ";
- $result = Database::query($sql);
- while ($groupData = Database::fetch_array($result, 'ASSOC')) {
- $groupBackup['user'][$teacher['user_id']][$course_code][$groupData['group_id']] = $groupData;
- }
- $sql = "SELECT * FROM ".Database::get_course_table(TABLE_GROUP_TUTOR)."
- WHERE
- user_id = ".$teacher['user_id']." AND
- c_id = '".$courseInfo['real_id']."'
- ";
- $result = Database::query($sql);
- while ($groupData = Database::fetch_array($result, 'ASSOC')) {
- $groupBackup['tutor'][$teacher['user_id']][$course_code][$groupData['group_id']] = $groupData;
- }
- CourseManager::unsubscribe_user(
- $teacher['user_id'],
- $course_code
- );
- if ($debug) {
- $logger->addInfo("Delete user #".$teacher['user_id']." from base course: $course_code");
- }
- }
- }
- }
- if (!empty($teacherToAdd)) {
- self::updateCoaches(
- $session_id,
- $courseId,
- [$teacherToAdd],
- true
- );
- if ($debug) {
- $logger->addInfo("Add coach #$teacherToAdd to course $courseId and session $session_id");
- }
- $userCourseCategory = '';
- if (isset($teacherBackupList[$teacherToAdd]) &&
- isset($teacherBackupList[$teacherToAdd][$course_code])
- ) {
- $courseUserData = $teacherBackupList[$teacherToAdd][$course_code];
- $userCourseCategory = $courseUserData['user_course_cat'];
- }
- CourseManager::subscribeUser(
- $teacherToAdd,
- $course_code,
- COURSEMANAGER,
- 0,
- $userCourseCategory
- );
- if ($debug) {
- $logger->addInfo("Subscribe user #$teacherToAdd as teacher in course $course_code with user userCourseCategory $userCourseCategory");
- }
- if (isset($groupBackup['user'][$teacherToAdd]) &&
- isset($groupBackup['user'][$teacherToAdd][$course_code]) &&
- !empty($groupBackup['user'][$teacherToAdd][$course_code])
- ) {
- foreach ($groupBackup['user'][$teacherToAdd][$course_code] as $data) {
- $groupInfo = GroupManager::get_group_properties($data['group_id']);
- GroupManager::subscribe_users(
- $teacherToAdd,
- $groupInfo,
- $data['c_id']
- );
- }
- }
- if (isset($groupBackup['tutor'][$teacherToAdd]) &&
- isset($groupBackup['tutor'][$teacherToAdd][$course_code]) &&
- !empty($groupBackup['tutor'][$teacherToAdd][$course_code])
- ) {
- foreach ($groupBackup['tutor'][$teacherToAdd][$course_code] as $data) {
- $groupInfo = GroupManager::get_group_properties($data['group_id']);
- GroupManager::subscribe_tutors(
- $teacherToAdd,
- $groupInfo,
- $data['c_id']
- );
- }
- }
- }
- }
- // See BT#6449#note-195
- // All coaches are added.
- if ($removeAllTeachersFromCourse) {
- if ($debug) {
- $logger->addInfo("removeAllTeachersFromCourse true");
- }
- $teacherToAdd = null;
- foreach ($course_coaches as $course_coach) {
- $coach_id = UserManager::get_user_id_from_username(
- $course_coach
- );
- if ($coach_id !== false) {
- $teacherToAdd[] = $coach_id;
- }
- }
- if (!empty($teacherToAdd)) {
- // Deleting all course teachers and adding the only coach as teacher.
- $teacherList = CourseManager::get_teacher_list_from_course_code($course_code);
- if (!empty($teacherList)) {
- foreach ($teacherList as $teacher) {
- if (!in_array($teacher['user_id'], $teacherToAdd)) {
- $sql = "SELECT * FROM ".Database::get_main_table(TABLE_MAIN_COURSE_USER)."
- WHERE
- user_id = ".$teacher['user_id']." AND
- c_id = '".$courseId."'
- ";
- $result = Database::query($sql);
- $rows = Database::num_rows($result);
- if ($rows > 0) {
- $userCourseData = Database::fetch_array($result, 'ASSOC');
- if (!empty($userCourseData)) {
- $teacherBackupList[$teacher['user_id']][$course_code] = $userCourseData;
- }
- }
- $sql = "SELECT * FROM ".Database::get_course_table(TABLE_GROUP_USER)."
- WHERE
- user_id = ".$teacher['user_id']." AND
- c_id = '".$courseInfo['real_id']."'
- ";
- $result = Database::query($sql);
- while ($groupData = Database::fetch_array($result, 'ASSOC')) {
- $groupBackup['user'][$teacher['user_id']][$course_code][$groupData['group_id']] = $groupData;
- }
- $sql = "SELECT * FROM ".Database::get_course_table(TABLE_GROUP_TUTOR)."
- WHERE
- user_id = ".$teacher['user_id']." AND
- c_id = '".$courseInfo['real_id']."'
- ";
- $result = Database::query($sql);
- while ($groupData = Database::fetch_array($result, 'ASSOC')) {
- $groupBackup['tutor'][$teacher['user_id']][$course_code][$groupData['group_id']] = $groupData;
- }
- CourseManager::unsubscribe_user(
- $teacher['user_id'],
- $course_code
- );
- if ($debug) {
- $logger->addInfo("Delete user #".$teacher['user_id']." from base course: $course_code");
- }
- }
- }
- }
- foreach ($teacherToAdd as $teacherId) {
- $userCourseCategory = '';
- if (isset($teacherBackupList[$teacherId]) &&
- isset($teacherBackupList[$teacherId][$course_code])
- ) {
- $courseUserData = $teacherBackupList[$teacherId][$course_code];
- $userCourseCategory = $courseUserData['user_course_cat'];
- }
- CourseManager::subscribeUser(
- $teacherId,
- $course_code,
- COURSEMANAGER,
- 0,
- $userCourseCategory
- );
- if ($debug) {
- $logger->addInfo("Add user as teacher #".$teacherId." in base course: $course_code with userCourseCategory: $userCourseCategory");
- }
- if (isset($groupBackup['user'][$teacherId]) &&
- isset($groupBackup['user'][$teacherId][$course_code]) &&
- !empty($groupBackup['user'][$teacherId][$course_code])
- ) {
- foreach ($groupBackup['user'][$teacherId][$course_code] as $data) {
- $groupInfo = GroupManager::get_group_properties($data['group_id']);
- GroupManager::subscribe_users(
- $teacherId,
- $groupInfo,
- $data['c_id']
- );
- }
- }
- if (isset($groupBackup['tutor'][$teacherId]) &&
- isset($groupBackup['tutor'][$teacherId][$course_code]) &&
- !empty($groupBackup['tutor'][$teacherId][$course_code])
- ) {
- foreach ($groupBackup['tutor'][$teacherId][$course_code] as $data) {
- $groupInfo = GroupManager::get_group_properties($data['group_id']);
- GroupManager::subscribe_tutors(
- $teacherId,
- $groupInfo,
- $data['c_id']
- );
- }
- }
- }
- }
- }
- // Continue default behaviour.
- if ($onlyAddFirstCoachOrTeacher == false) {
- // Checking one more time see BT#6449#note-149
- $coaches = self::getCoachesByCourseSession($session_id, $courseId);
- // Update coaches if only there's 1 course see BT#6449#note-189
- if (empty($coaches) || count($courses) == 1) {
- foreach ($course_coaches as $course_coach) {
- $course_coach = trim($course_coach);
- $coach_id = UserManager::get_user_id_from_username($course_coach);
- if ($coach_id !== false) {
- // Just insert new coaches
- self::updateCoaches(
- $session_id,
- $courseId,
- [$coach_id],
- false
- );
- if ($debug) {
- $logger->addInfo("Sessions - Adding course coach: user #$coach_id ($course_coach) to course: '$course_code' and session #$session_id");
- }
- $savedCoaches[] = $coach_id;
- } else {
- $error_message .= get_lang('This user doesn\'t exist').' : '.$course_coach.$eol;
- }
- }
- }
- }
- }
- // Adding Students, updating relationship "Session - Course - User".
- $course_users = array_filter($course_users);
- if (!empty($course_users)) {
- foreach ($course_users as $user) {
- $user_id = UserManager::get_user_id_from_username($user);
- if ($user_id !== false) {
- self::subscribe_users_to_session_course(
- [$user_id],
- $session_id,
- $course_code
- );
- if ($debug) {
- $logger->addInfo("Adding student: user #$user_id ($user) to course: '$course_code' and session #$session_id");
- }
- } else {
- $error_message .= get_lang('This user doesn\'t exist').': '.$user.$eol;
- }
- }
- }
- $inserted_in_course[$course_code] = $courseInfo['title'];
- }
- }
- $access_url_id = api_get_current_access_url_id();
- UrlManager::add_session_to_url($session_id, $access_url_id);
- $sql = "UPDATE $tbl_session SET nbr_users = '$user_counter', nbr_courses = '$course_counter'
- WHERE id = '$session_id'";
- Database::query($sql);
- self::addClassesByName($session_id, $classes, false);
- if ($debug) {
- $logger->addInfo("End process session #$session_id -------------------- ");
- }
- }
- if (!empty($report)) {
- if ($debug) {
- $logger->addInfo("--Summary--");
- foreach ($report as $line) {
- $logger->addInfo($line);
- }
- }
- }
- }
- return [
- 'error_message' => $error_message,
- 'session_counter' => $session_counter,
- 'session_list' => $sessionList,
- ];
- }
- /**
- * @param int $sessionId
- * @param int $courseId
- *
- * @return array
- */
- public static function getCoachesByCourseSession($sessionId, $courseId)
- {
- $table = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $sessionId = (int) $sessionId;
- $courseId = (int) $courseId;
- $sql = "SELECT user_id FROM $table
- WHERE
- session_id = '$sessionId' AND
- c_id = '$courseId' AND
- status = 2";
- $result = Database::query($sql);
- $coaches = [];
- if (Database::num_rows($result) > 0) {
- while ($row = Database::fetch_array($result)) {
- $coaches[] = $row['user_id'];
- }
- }
- return $coaches;
- }
- /**
- * @param int $sessionId
- * @param int $courseId
- * @param string $separator
- *
- * @return string
- */
- public static function getCoachesByCourseSessionToString(
- $sessionId,
- $courseId,
- $separator = ''
- ) {
- $coaches = self::getCoachesByCourseSession($sessionId, $courseId);
- $list = [];
- if (!empty($coaches)) {
- foreach ($coaches as $coachId) {
- $userInfo = api_get_user_info($coachId);
- if ($userInfo) {
- $list[] = $userInfo['complete_name'];
- }
- }
- }
- $separator = empty($separator) ? CourseManager::USER_SEPARATOR : $separator;
- return array_to_string($list, $separator);
- }
- /**
- * Get all coaches added in the session - course relationship.
- *
- * @param int $sessionId
- *
- * @return array
- */
- public static function getCoachesBySession($sessionId)
- {
- $table = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $sessionId = intval($sessionId);
- $sql = "SELECT DISTINCT user_id
- FROM $table
- WHERE session_id = '$sessionId' AND status = 2";
- $result = Database::query($sql);
- $coaches = [];
- if (Database::num_rows($result) > 0) {
- while ($row = Database::fetch_array($result)) {
- $coaches[] = $row['user_id'];
- }
- }
- return $coaches;
- }
- /**
- * @param int $userId
- *
- * @return array
- */
- public static function getAllCoursesFromAllSessionFromDrh($userId)
- {
- $sessions = self::get_sessions_followed_by_drh($userId);
- $coursesFromSession = [];
- if (!empty($sessions)) {
- foreach ($sessions as $session) {
- $courseList = self::get_course_list_by_session_id($session['id']);
- foreach ($courseList as $course) {
- $coursesFromSession[] = $course['code'];
- }
- }
- }
- return $coursesFromSession;
- }
- /**
- * getAllCoursesFromAllSessions.
- *
- * @return array
- */
- public static function getAllCoursesFromAllSessions()
- {
- $sessions = self::get_sessions_list();
- $coursesFromSession = [];
- if (!empty($sessions)) {
- foreach ($sessions as $session) {
- $courseList = self::get_course_list_by_session_id($session['id']);
- foreach ($courseList as $course) {
- $coursesFromSession[$course['code'].':'.$session['id']] = $course['visual_code'].' - '.$course['title'].' ('.$session['name'].')';
- }
- }
- }
- return $coursesFromSession;
- }
- /**
- * Return user id list or count of users depending of the $getCount parameter.
- *
- * @param string $status
- * @param int $userId
- * @param bool $getCount
- * @param int $from
- * @param int $numberItems
- * @param int $column
- * @param string $direction
- * @param string $keyword
- * @param string $active
- * @param string $lastConnectionDate
- * @param array $sessionIdList
- * @param array $studentIdList
- * @param int $filterByStatus
- *
- * @return array|int
- */
- public static function getAllUsersFromCoursesFromAllSessionFromStatus(
- $status,
- $userId,
- $getCount = false,
- $from = null,
- $numberItems = null,
- $column = 1,
- $direction = 'asc',
- $keyword = null,
- $active = null,
- $lastConnectionDate = null,
- $sessionIdList = [],
- $studentIdList = [],
- $filterByStatus = null
- ) {
- $filterByStatus = (int) $filterByStatus;
- $userId = (int) $userId;
- $tbl_user = Database::get_main_table(TABLE_MAIN_USER);
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
- $tbl_course_user = Database::get_main_table(TABLE_MAIN_COURSE_USER);
- $tbl_user_rel_access_url = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER);
- $tbl_course_rel_access_url = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $tbl_session_rel_course_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $tbl_session_rel_access_url = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $direction = in_array(strtolower($direction), ['asc', 'desc']) ? $direction : 'asc';
- $column = Database::escape_string($column);
- $limitCondition = '';
- if (isset($from) && isset($numberItems)) {
- $from = (int) $from;
- $numberItems = (int) $numberItems;
- $limitCondition = "LIMIT $from, $numberItems";
- }
- $urlId = api_get_current_access_url_id();
- $sessionConditions = '';
- $courseConditions = '';
- $userConditions = '';
- if (isset($active)) {
- $active = (int) $active;
- $userConditions .= " AND active = $active";
- }
- $courseList = CourseManager::get_courses_followed_by_drh($userId, DRH);
- if (!empty($courseList)) {
- $courseIdList = array_column($courseList, 'id');
- $courseConditions = ' AND c.id IN ("'.implode('","', $courseIdList).'")';
- }
- $userConditionsFromDrh = '';
- // Classic DRH
- if (empty($studentIdList)) {
- $studentListSql = UserManager::get_users_followed_by_drh(
- $userId,
- $filterByStatus,
- true,
- false
- );
- if (!empty($studentListSql)) {
- $studentIdList = array_keys($studentListSql);
- $studentListSql = "'".implode("','", $studentIdList)."'";
- }
- } else {
- $studentIdList = array_map('intval', $studentIdList);
- $studentListSql = "'".implode("','", $studentIdList)."'";
- }
- if (!empty($studentListSql)) {
- $userConditionsFromDrh = " AND u.user_id IN ($studentListSql) ";
- }
- switch ($status) {
- case 'drh':
- break;
- case 'drh_all':
- // Show all by DRH
- if (empty($sessionIdList)) {
- $sessionsListSql = self::get_sessions_followed_by_drh(
- $userId,
- null,
- null,
- false,
- true,
- true
- );
- } else {
- $sessionIdList = array_map('intval', $sessionIdList);
- $sessionsListSql = "'".implode("','", $sessionIdList)."'";
- }
- if (!empty($sessionsListSql)) {
- $sessionConditions = " AND s.id IN ($sessionsListSql) ";
- }
- break;
- case 'session_admin':
- $sessionConditions = " AND s.id_coach = $userId ";
- $userConditionsFromDrh = '';
- break;
- case 'admin':
- break;
- case 'teacher':
- $sessionConditions = " AND s.id_coach = $userId ";
- $userConditionsFromDrh = '';
- break;
- }
- $select = 'SELECT DISTINCT u.* ';
- $masterSelect = 'SELECT DISTINCT user_id FROM ';
- if ($getCount) {
- $select = 'SELECT DISTINCT u.user_id ';
- $masterSelect = 'SELECT COUNT(DISTINCT(user_id)) as count FROM ';
- }
- if (!empty($filterByStatus)) {
- $userConditions .= " AND u.status = $filterByStatus";
- }
- if (!empty($lastConnectionDate)) {
- $lastConnectionDate = Database::escape_string($lastConnectionDate);
- $userConditions .= " AND u.last_login <= '$lastConnectionDate' ";
- }
- if (!empty($keyword)) {
- $keyword = Database::escape_string($keyword);
- $userConditions .= " AND (
- u.username LIKE '%$keyword%' OR
- u.firstname LIKE '%$keyword%' OR
- u.lastname LIKE '%$keyword%' OR
- u.official_code LIKE '%$keyword%' OR
- u.email LIKE '%$keyword%'
- )";
- }
- $where = " WHERE
- access_url_id = $urlId
- $userConditions
- ";
- $userUnion = '';
- if (!empty($userConditionsFromDrh)) {
- $userUnion = "
- UNION (
- $select
- FROM $tbl_user u
- INNER JOIN $tbl_user_rel_access_url url ON (url.user_id = u.id)
- $where
- $userConditionsFromDrh
- )";
- }
- $sql = "$masterSelect (
- ($select
- FROM $tbl_session s
- INNER JOIN $tbl_session_rel_course_rel_user su ON (s.id = su.session_id)
- INNER JOIN $tbl_user u ON (u.user_id = su.user_id)
- INNER JOIN $tbl_session_rel_access_url url ON (url.session_id = s.id)
- $where
- $sessionConditions
- $userConditionsFromDrh
- ) UNION (
- $select
- FROM $tbl_course c
- INNER JOIN $tbl_course_user cu ON (cu.c_id = c.id)
- INNER JOIN $tbl_user u ON (u.user_id = cu.user_id)
- INNER JOIN $tbl_course_rel_access_url url ON (url.c_id = c.id)
- $where
- $courseConditions
- $userConditionsFromDrh
- ) $userUnion
- ) as t1
- ";
- if ($getCount) {
- $result = Database::query($sql);
- $count = 0;
- if (Database::num_rows($result)) {
- $rows = Database::fetch_array($result);
- $count = $rows['count'];
- }
- return $count;
- }
- if (!empty($column) && !empty($direction)) {
- $column = str_replace('u.', '', $column);
- $sql .= " ORDER BY $column $direction ";
- }
- $sql .= $limitCondition;
- $result = Database::query($sql);
- $result = Database::store_result($result);
- return $result;
- }
- /**
- * @param int $sessionId
- * @param int $courseId
- * @param array $coachList
- * @param bool $deleteCoachesNotInList
- */
- public static function updateCoaches(
- $sessionId,
- $courseId,
- $coachList,
- $deleteCoachesNotInList = false
- ) {
- $currentCoaches = self::getCoachesByCourseSession($sessionId, $courseId);
- if (!empty($coachList)) {
- foreach ($coachList as $userId) {
- self::set_coach_to_course_session($userId, $sessionId, $courseId);
- }
- }
- if ($deleteCoachesNotInList) {
- if (!empty($coachList)) {
- $coachesToDelete = array_diff($currentCoaches, $coachList);
- } else {
- $coachesToDelete = $currentCoaches;
- }
- if (!empty($coachesToDelete)) {
- foreach ($coachesToDelete as $userId) {
- self::set_coach_to_course_session(
- $userId,
- $sessionId,
- $courseId,
- true
- );
- }
- }
- }
- }
- /**
- * @param array $sessions
- * @param array $sessionsDestination
- *
- * @return array
- */
- public static function copyStudentsFromSession($sessions, $sessionsDestination)
- {
- $messages = [];
- if (!empty($sessions)) {
- foreach ($sessions as $sessionId) {
- $sessionInfo = self::fetch($sessionId);
- $userList = self::get_users_by_session($sessionId, 0);
- if (!empty($userList)) {
- $newUserList = [];
- $userToString = null;
- foreach ($userList as $userInfo) {
- $newUserList[] = $userInfo['user_id'];
- $userToString .= $userInfo['firstname'].' '.$userInfo['lastname'].'<br />';
- }
- if (!empty($sessionsDestination)) {
- foreach ($sessionsDestination as $sessionDestinationId) {
- $sessionDestinationInfo = self::fetch($sessionDestinationId);
- $messages[] = Display::return_message(
- sprintf(
- get_lang(
- 'AddingStudentsFromSessionXToSessionY'
- ),
- $sessionInfo['name'],
- $sessionDestinationInfo['name']
- ),
- 'info',
- false
- );
- if ($sessionId == $sessionDestinationId) {
- $messages[] = Display::return_message(
- sprintf(
- get_lang('Session %s skipped'),
- $sessionDestinationId
- ),
- 'warning',
- false
- );
- continue;
- }
- $messages[] = Display::return_message(get_lang('Learners list').'<br />'.$userToString, 'info', false);
- self::subscribeUsersToSession(
- $sessionDestinationId,
- $newUserList,
- SESSION_VISIBLE_READ_ONLY,
- false
- );
- }
- } else {
- $messages[] = Display::return_message(get_lang('No destination session provided'), 'warning');
- }
- } else {
- $messages[] = Display::return_message(
- get_lang('No student found for the session').' #'.$sessionInfo['name'],
- 'warning'
- );
- }
- }
- } else {
- $messages[] = Display::return_message(get_lang('No data available'), 'warning');
- }
- return $messages;
- }
- /**
- * Assign coaches of a session(s) as teachers to a given course (or courses).
- *
- * @param array A list of session IDs
- * @param array A list of course IDs
- *
- * @return string
- */
- public static function copyCoachesFromSessionToCourse($sessions, $courses)
- {
- $coachesPerSession = [];
- foreach ($sessions as $sessionId) {
- $coaches = self::getCoachesBySession($sessionId);
- $coachesPerSession[$sessionId] = $coaches;
- }
- $result = [];
- if (!empty($courses)) {
- foreach ($courses as $courseId) {
- $courseInfo = api_get_course_info_by_id($courseId);
- foreach ($coachesPerSession as $sessionId => $coachList) {
- CourseManager::updateTeachers(
- $courseInfo,
- $coachList,
- false,
- false,
- false
- );
- $result[$courseInfo['code']][$sessionId] = $coachList;
- }
- }
- }
- $sessionUrl = api_get_path(WEB_CODE_PATH).'session/resume_session.php?id_session=';
- $htmlResult = null;
- if (!empty($result)) {
- foreach ($result as $courseCode => $data) {
- $url = api_get_course_url($courseCode);
- $htmlResult .= sprintf(
- get_lang('Coaches subscribed as teachers in course %s'),
- Display::url($courseCode, $url, ['target' => '_blank'])
- );
- foreach ($data as $sessionId => $coachList) {
- $sessionInfo = self::fetch($sessionId);
- $htmlResult .= '<br />';
- $htmlResult .= Display::url(
- get_lang('Session').': '.$sessionInfo['name'].' <br />',
- $sessionUrl.$sessionId,
- ['target' => '_blank']
- );
- $teacherList = [];
- foreach ($coachList as $coachId) {
- $userInfo = api_get_user_info($coachId);
- $teacherList[] = $userInfo['complete_name'];
- }
- if (!empty($teacherList)) {
- $htmlResult .= implode(', ', $teacherList);
- } else {
- $htmlResult .= get_lang('Nothing to add');
- }
- }
- $htmlResult .= '<br />';
- }
- $htmlResult = Display::return_message($htmlResult, 'normal', false);
- }
- return $htmlResult;
- }
- /**
- * @param string $keyword
- * @param string $active
- * @param string $lastConnectionDate
- * @param array $sessionIdList
- * @param array $studentIdList
- * @param int $filterUserStatus STUDENT|COURSEMANAGER constants
- *
- * @return array|int
- */
- public static function getCountUserTracking(
- $keyword = null,
- $active = null,
- $lastConnectionDate = null,
- $sessionIdList = [],
- $studentIdList = [],
- $filterUserStatus = null
- ) {
- $userId = api_get_user_id();
- $drhLoaded = false;
- if (api_is_drh()) {
- if (api_drh_can_access_all_session_content()) {
- $count = self::getAllUsersFromCoursesFromAllSessionFromStatus(
- 'drh_all',
- $userId,
- true,
- null,
- null,
- null,
- null,
- $keyword,
- $active,
- $lastConnectionDate,
- $sessionIdList,
- $studentIdList,
- $filterUserStatus
- );
- $drhLoaded = true;
- }
- }
- if ($drhLoaded == false) {
- $count = UserManager::getUsersFollowedByUser(
- $userId,
- $filterUserStatus,
- false,
- false,
- true,
- null,
- null,
- null,
- null,
- $active,
- $lastConnectionDate,
- api_is_student_boss() ? STUDENT_BOSS : COURSEMANAGER,
- $keyword
- );
- }
- return $count;
- }
- /**
- * Get teachers followed by a user.
- *
- * @param int $userId
- * @param int $active
- * @param string $lastConnectionDate
- * @param bool $getCount
- * @param array $sessionIdList
- *
- * @return array|int
- */
- public static function getTeacherTracking(
- $userId,
- $active = 1,
- $lastConnectionDate = null,
- $getCount = false,
- $sessionIdList = []
- ) {
- $teacherListId = [];
- if (api_is_drh() || api_is_platform_admin()) {
- // Followed teachers by drh
- if (api_drh_can_access_all_session_content()) {
- if (empty($sessionIdList)) {
- $sessions = self::get_sessions_followed_by_drh($userId);
- $sessionIdList = [];
- foreach ($sessions as $session) {
- $sessionIdList[] = $session['id'];
- }
- }
- $sessionIdList = array_map('intval', $sessionIdList);
- $sessionToString = implode("', '", $sessionIdList);
- $course = Database::get_main_table(TABLE_MAIN_COURSE);
- $sessionCourse = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $courseUser = Database::get_main_table(TABLE_MAIN_COURSE_USER);
- // Select the teachers.
- $sql = "SELECT DISTINCT(cu.user_id)
- FROM $course c
- INNER JOIN $sessionCourse src
- ON c.id = src.c_id
- INNER JOIN $courseUser cu
- ON (cu.c_id = c.id)
- WHERE src.session_id IN ('$sessionToString') AND cu.status = 1";
- $result = Database::query($sql);
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- $teacherListId[$row['user_id']] = $row['user_id'];
- }
- } else {
- $teacherResult = UserManager::get_users_followed_by_drh($userId, COURSEMANAGER);
- foreach ($teacherResult as $userInfo) {
- $teacherListId[] = $userInfo['user_id'];
- }
- }
- }
- if (!empty($teacherListId)) {
- $tableUser = Database::get_main_table(TABLE_MAIN_USER);
- $select = "SELECT DISTINCT u.* ";
- if ($getCount) {
- $select = "SELECT count(DISTINCT(u.user_id)) as count";
- }
- $sql = "$select FROM $tableUser u";
- if (!empty($lastConnectionDate)) {
- $tableLogin = Database::get_main_table(TABLE_STATISTIC_TRACK_E_LOGIN);
- //$sql .= " INNER JOIN $tableLogin l ON (l.login_user_id = u.user_id) ";
- }
- $active = intval($active);
- $teacherListId = implode("','", $teacherListId);
- $where = " WHERE u.active = $active AND u.user_id IN ('$teacherListId') ";
- if (!empty($lastConnectionDate)) {
- $lastConnectionDate = Database::escape_string($lastConnectionDate);
- //$where .= " AND l.login_date <= '$lastConnectionDate' ";
- }
- $sql .= $where;
- $result = Database::query($sql);
- if (Database::num_rows($result)) {
- if ($getCount) {
- $row = Database::fetch_array($result);
- return $row['count'];
- } else {
- return Database::store_result($result, 'ASSOC');
- }
- }
- }
- return 0;
- }
- /**
- * Get the list of course tools that have to be dealt with in case of
- * registering any course to a session.
- *
- * @return array The list of tools to be dealt with (literal names)
- */
- public static function getCourseToolToBeManaged()
- {
- return [
- 'courseDescription',
- 'courseIntroduction',
- ];
- }
- /**
- * Calls the methods bound to each tool when a course is registered into a session.
- *
- * @param int $sessionId
- * @param int $courseId
- *
- * @return bool
- */
- public static function installCourse($sessionId, $courseId)
- {
- return true;
- $toolList = self::getCourseToolToBeManaged();
- foreach ($toolList as $tool) {
- $method = 'add'.$tool;
- if (method_exists(get_class(), $method)) {
- self::$method($sessionId, $courseId);
- }
- }
- }
- /**
- * Calls the methods bound to each tool when a course is unregistered from
- * a session.
- *
- * @param int $sessionId
- * @param int $courseId
- */
- public static function unInstallCourse($sessionId, $courseId)
- {
- return true;
- $toolList = self::getCourseToolToBeManaged();
- foreach ($toolList as $tool) {
- $method = 'remove'.$tool;
- if (method_exists(get_class(), $method)) {
- self::$method($sessionId, $courseId);
- }
- }
- }
- /**
- * @param array $userSessionList format see self::importSessionDrhCSV()
- * @param bool $sendEmail
- * @param bool $removeOldRelationShips
- */
- public static function subscribeDrhToSessionList(
- $userSessionList,
- $sendEmail,
- $removeOldRelationShips
- ) {
- if (!empty($userSessionList)) {
- foreach ($userSessionList as $userId => $data) {
- $sessionList = [];
- foreach ($data['session_list'] as $sessionInfo) {
- $sessionList[] = $sessionInfo['session_id'];
- }
- $userInfo = $data['user_info'];
- self::subscribeSessionsToDrh(
- $userInfo,
- $sessionList,
- $sendEmail,
- $removeOldRelationShips
- );
- }
- }
- }
- /**
- * @param array $userSessionList format see self::importSessionDrhCSV()
- *
- * @return string
- */
- public static function checkSubscribeDrhToSessionList($userSessionList)
- {
- $message = null;
- if (!empty($userSessionList)) {
- if (!empty($userSessionList)) {
- foreach ($userSessionList as $userId => $data) {
- $userInfo = $data['user_info'];
- $sessionListSubscribed = self::get_sessions_followed_by_drh($userId);
- if (!empty($sessionListSubscribed)) {
- $sessionListSubscribed = array_keys($sessionListSubscribed);
- }
- $sessionList = [];
- if (!empty($data['session_list'])) {
- foreach ($data['session_list'] as $sessionInfo) {
- if (in_array($sessionInfo['session_id'], $sessionListSubscribed)) {
- $sessionList[] = $sessionInfo['session_info']['name'];
- }
- }
- }
- $message .= '<strong>'.get_lang('User').'</strong>: ';
- $message .= $userInfo['complete_name_with_username'].' <br />';
- if (!in_array($userInfo['status'], [DRH]) && !api_is_platform_admin_by_id($userInfo['user_id'])) {
- $message .= get_lang('Users must have the HR director role').'<br />';
- continue;
- }
- if (!empty($sessionList)) {
- $message .= '<strong>'.get_lang('Course sessions').':</strong> <br />';
- $message .= implode(', ', $sessionList).'<br /><br />';
- } else {
- $message .= get_lang('No session provided').' <br /><br />';
- }
- }
- }
- }
- return $message;
- }
- /**
- * @param string $file
- * @param bool $sendEmail
- * @param bool $removeOldRelationShips
- *
- * @return string
- */
- public static function importSessionDrhCSV($file, $sendEmail, $removeOldRelationShips)
- {
- $list = Import::csv_reader($file);
- if (!empty($list)) {
- $userSessionList = [];
- foreach ($list as $data) {
- $userInfo = api_get_user_info_from_username($data['Username']);
- $sessionInfo = self::get_session_by_name($data['SessionName']);
- if (empty($sessionInfo)) {
- Display::addFlash(Display::return_message(get_lang('The session was not identified').' - '.$data['SessionName'], 'warning'));
- }
- if (empty($userInfo)) {
- Display::addFlash(Display::return_message(get_lang('This user doesn\'t exist').' - '.$data['Username'], 'warning'));
- }
- if (!empty($userInfo) && !empty($sessionInfo)) {
- $userSessionList[$userInfo['user_id']]['session_list'][] = [
- 'session_id' => $sessionInfo['id'],
- 'session_info' => $sessionInfo,
- ];
- $userSessionList[$userInfo['user_id']]['user_info'] = $userInfo;
- }
- }
- self::subscribeDrhToSessionList($userSessionList, $sendEmail, $removeOldRelationShips);
- return self::checkSubscribeDrhToSessionList($userSessionList);
- }
- }
- /**
- * Courses re-ordering in resume_session.php flag see BT#8316.
- */
- public static function orderCourseIsEnabled()
- {
- $sessionCourseOrder = api_get_setting('session_course_ordering');
- if ($sessionCourseOrder === 'true') {
- return true;
- }
- return false;
- }
- /**
- * @param string $direction (up/down)
- * @param int $sessionId
- * @param int $courseId
- *
- * @return bool
- */
- public static function move($direction, $sessionId, $courseId)
- {
- if (!self::orderCourseIsEnabled()) {
- return false;
- }
- $sessionId = intval($sessionId);
- $courseId = intval($courseId);
- $table = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $courseList = self::get_course_list_by_session_id($sessionId, null, 'position');
- $position = [];
- $count = 0;
- foreach ($courseList as $course) {
- if ($course['position'] == '') {
- $course['position'] = $count;
- }
- $position[$course['code']] = $course['position'];
- // Saving current order.
- $sql = "UPDATE $table SET position = $count
- WHERE session_id = $sessionId AND c_id = '".$course['real_id']."'";
- Database::query($sql);
- $count++;
- }
- // Loading new positions.
- $courseList = self::get_course_list_by_session_id($sessionId, null, 'position');
- $found = false;
- switch ($direction) {
- case 'up':
- $courseList = array_reverse($courseList);
- break;
- case 'down':
- break;
- }
- foreach ($courseList as $course) {
- if ($found) {
- $nextId = $course['real_id'];
- $nextOrder = $course['position'];
- break;
- }
- if ($courseId == $course['real_id']) {
- $thisCourseCode = $course['real_id'];
- $thisOrder = $course['position'];
- $found = true;
- }
- }
- $sql1 = "UPDATE $table SET position = '".intval($nextOrder)."'
- WHERE session_id = $sessionId AND c_id = $thisCourseCode";
- Database::query($sql1);
- $sql2 = "UPDATE $table SET position = '".intval($thisOrder)."'
- WHERE session_id = $sessionId AND c_id = $nextId";
- Database::query($sql2);
- return true;
- }
- /**
- * @param int $sessionId
- * @param int $courseId
- *
- * @return bool
- */
- public static function moveUp($sessionId, $courseId)
- {
- return self::move('up', $sessionId, $courseId);
- }
- /**
- * @param int $sessionId
- * @param string $courseCode
- *
- * @return bool
- */
- public static function moveDown($sessionId, $courseCode)
- {
- return self::move('down', $sessionId, $courseCode);
- }
- /**
- * Use the session duration to allow/block user access see BT#8317
- * Needs these DB changes
- * ALTER TABLE session ADD COLUMN duration int;
- * ALTER TABLE session_rel_user ADD COLUMN duration int;.
- */
- public static function durationPerUserIsEnabled()
- {
- return api_get_configuration_value('session_duration_feature');
- }
- /**
- * Returns the number of days the student has left in a session when using
- * sessions durations.
- *
- * @param array $sessionInfo
- * @param int $userId
- *
- * @return int
- */
- public static function getDayLeftInSession(array $sessionInfo, $userId)
- {
- $sessionId = $sessionInfo['id'];
- $subscription = self::getUserSession($userId, $sessionId);
- $duration = empty($subscription['duration'])
- ? $sessionInfo['duration']
- : $sessionInfo['duration'] + $subscription['duration'];
- // Get an array with the details of the first access of the student to
- // this session
- $courseAccess = CourseManager::getFirstCourseAccessPerSessionAndUser(
- $sessionId,
- $userId
- );
- $currentTime = time();
- // If no previous access, return false
- if (count($courseAccess) == 0) {
- return $duration;
- }
- $firstAccess = api_strtotime($courseAccess['login_course_date'], 'UTC');
- $endDateInSeconds = $firstAccess + $duration * 24 * 60 * 60;
- $leftDays = round(($endDateInSeconds - $currentTime) / 60 / 60 / 24);
- return $leftDays;
- }
- /**
- * @param int $duration
- * @param int $userId
- * @param int $sessionId
- *
- * @return bool
- */
- public static function editUserSessionDuration($duration, $userId, $sessionId)
- {
- $duration = (int) $duration;
- $userId = (int) $userId;
- $sessionId = (int) $sessionId;
- if (empty($userId) || empty($sessionId)) {
- return false;
- }
- $table = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $parameters = ['duration' => $duration];
- $where = ['session_id = ? AND user_id = ? ' => [$sessionId, $userId]];
- Database::update($table, $parameters, $where);
- return true;
- }
- /**
- * Gets one row from the session_rel_user table.
- *
- * @param int $userId
- * @param int $sessionId
- *
- * @return array
- */
- public static function getUserSession($userId, $sessionId)
- {
- $userId = (int) $userId;
- $sessionId = (int) $sessionId;
- if (empty($userId) || empty($sessionId)) {
- return false;
- }
- $table = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $sql = "SELECT * FROM $table
- WHERE session_id = $sessionId AND user_id = $userId";
- $result = Database::query($sql);
- $values = [];
- if (Database::num_rows($result)) {
- $values = Database::fetch_array($result, 'ASSOC');
- }
- return $values;
- }
- /**
- * Check if user is subscribed inside a session as student.
- *
- * @param int $sessionId The session id
- * @param int $userId The user id
- *
- * @return bool Whether is subscribed
- */
- public static function isUserSubscribedAsStudent($sessionId, $userId)
- {
- $sessionRelUserTable = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $sessionId = (int) $sessionId;
- $userId = (int) $userId;
- // COUNT(1) actually returns the number of rows from the table (as if
- // counting the results from the first column)
- $sql = "SELECT COUNT(1) AS qty FROM $sessionRelUserTable
- WHERE
- session_id = $sessionId AND
- user_id = $userId AND
- relation_type = 0";
- $result = Database::fetch_assoc(Database::query($sql));
- if (!empty($result) && $result['qty'] > 0) {
- return true;
- }
- return false;
- }
- /**
- * Check if user is subscribed inside a session as a HRM.
- *
- * @param int $sessionId The session id
- * @param int $userId The user id
- *
- * @return bool Whether is subscribed
- */
- public static function isUserSubscribedAsHRM($sessionId, $userId)
- {
- $sessionRelUserTable = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $sessionId = (int) $sessionId;
- $userId = (int) $userId;
- // COUNT(1) actually returns the number of rows from the table (as if
- // counting the results from the first column)
- $sql = "SELECT COUNT(1) AS qty FROM $sessionRelUserTable
- WHERE
- session_id = $sessionId AND
- user_id = $userId AND
- relation_type = ".SESSION_RELATION_TYPE_RRHH;
- $result = Database::fetch_assoc(Database::query($sql));
- if (!empty($result) && $result['qty'] > 0) {
- return true;
- }
- return false;
- }
- /**
- * Get the session coached by a user (general coach and course-session coach).
- *
- * @param int $coachId The coach id
- * @param bool $checkSessionRelUserVisibility Check the session visibility
- * @param bool $asPlatformAdmin The user is a platform admin and we want all sessions
- *
- * @return array The session list
- */
- public static function getSessionsCoachedByUser(
- $coachId,
- $checkSessionRelUserVisibility = false,
- $asPlatformAdmin = false
- ) {
- // Get all sessions where $coachId is the general coach
- $sessions = self::get_sessions_by_general_coach($coachId, $asPlatformAdmin);
- // Get all sessions where $coachId is the course - session coach
- $courseSessionList = self::getCoursesListByCourseCoach($coachId);
- $sessionsByCoach = [];
- if (!empty($courseSessionList)) {
- foreach ($courseSessionList as $userCourseSubscription) {
- $session = $userCourseSubscription->getSession();
- $sessionsByCoach[$session->getId()] = api_get_session_info(
- $session->getId()
- );
- }
- }
- if (!empty($sessionsByCoach)) {
- $sessions = array_merge($sessions, $sessionsByCoach);
- }
- // Remove repeated sessions
- if (!empty($sessions)) {
- $cleanSessions = [];
- foreach ($sessions as $session) {
- $cleanSessions[$session['id']] = $session;
- }
- $sessions = $cleanSessions;
- }
- if ($checkSessionRelUserVisibility) {
- if (!empty($sessions)) {
- $newSessions = [];
- foreach ($sessions as $session) {
- $visibility = api_get_session_visibility($session['id']);
- if ($visibility == SESSION_INVISIBLE) {
- continue;
- }
- $newSessions[] = $session;
- }
- $sessions = $newSessions;
- }
- }
- return $sessions;
- }
- /**
- * Check if the course belongs to the session.
- *
- * @param int $sessionId The session id
- * @param string $courseCode The course code
- *
- * @return bool
- */
- public static function sessionHasCourse($sessionId, $courseCode)
- {
- $sessionId = (int) $sessionId;
- $courseCode = Database::escape_string($courseCode);
- $courseTable = Database::get_main_table(TABLE_MAIN_COURSE);
- $sessionRelCourseTable = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $sql = "SELECT COUNT(1) AS qty
- FROM $courseTable c
- INNER JOIN $sessionRelCourseTable src
- ON c.id = src.c_id
- WHERE src.session_id = $sessionId
- AND c.code = '$courseCode' ";
- $result = Database::query($sql);
- if ($result !== false) {
- $data = Database::fetch_assoc($result);
- if ($data['qty'] > 0) {
- return true;
- }
- }
- return false;
- }
- /**
- * Calculate the total user time in the platform.
- *
- * @param int $userId The user id
- * @param string $from Optional. From date
- * @param string $until Optional. Until date
- *
- * @return string The time (hh:mm:ss)
- */
- public static function getTotalUserTimeInPlatform($userId, $from = '', $until = '')
- {
- $userId = (int) $userId;
- $trackLoginTable = Database::get_main_table(TABLE_STATISTIC_TRACK_E_LOGIN);
- $whereConditions = [
- 'login_user_id = ? ' => $userId,
- ];
- if (!empty($from) && !empty($until)) {
- $whereConditions["AND (login_date >= '?' "] = $from;
- $whereConditions["AND logout_date <= DATE_ADD('?', INTERVAL 1 DAY)) "] = $until;
- }
- $trackResult = Database::select(
- 'SEC_TO_TIME(SUM(UNIX_TIMESTAMP(logout_date) - UNIX_TIMESTAMP(login_date))) as total_time',
- $trackLoginTable,
- [
- 'where' => $whereConditions,
- ],
- 'first'
- );
- if ($trackResult != false) {
- return $trackResult['total_time'] ? $trackResult['total_time'] : '00:00:00';
- }
- return '00:00:00';
- }
- /**
- * Get the courses list by a course coach.
- *
- * @param int $coachId The coach id
- *
- * @return array (id, user_id, session_id, c_id, visibility, status, legal_agreement)
- */
- public static function getCoursesListByCourseCoach($coachId)
- {
- $entityManager = Database::getManager();
- $scuRepo = $entityManager->getRepository(
- 'ChamiloCoreBundle:SessionRelCourseRelUser'
- );
- return $scuRepo->findBy([
- 'user' => $coachId,
- 'status' => SessionRelCourseRelUser::STATUS_COURSE_COACH,
- ]);
- }
- /**
- * Get the count of user courses in session.
- *
- * @param int $sessionId
- * @param int $courseId
- *
- * @return array
- */
- public static function getTotalUserCoursesInSession($sessionId, $courseId = 0)
- {
- $tableUser = Database::get_main_table(TABLE_MAIN_USER);
- $table = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $sessionId = (int) $sessionId;
- if (empty($sessionId)) {
- return [];
- }
- $courseCondition = '';
- if (!empty($courseId)) {
- $courseId = (int) $courseId;
- $courseCondition = " c_id = $courseId AND ";
- }
- $sql = "SELECT
- COUNT(u.id) as count,
- u.id,
- scu.status status_in_session,
- u.status user_status
- FROM $table scu
- INNER JOIN $tableUser u
- ON scu.user_id = u.id
- WHERE
- $courseCondition
- scu.session_id = ".$sessionId."
- GROUP BY u.id";
- $result = Database::query($sql);
- $list = [];
- while ($data = Database::fetch_assoc($result)) {
- $list[] = $data;
- }
- return $list;
- }
- /**
- * Returns list of a few data from session (name, short description, start
- * date, end date) and the given extra fields if defined based on a
- * session category Id.
- *
- * @param int $categoryId The internal ID of the session category
- * @param string $target Value to search for in the session field values
- * @param array $extraFields A list of fields to be scanned and returned
- *
- * @return mixed
- */
- public static function getShortSessionListAndExtraByCategory(
- $categoryId,
- $target,
- $extraFields = null,
- $publicationDate = null
- ) {
- $categoryId = (int) $categoryId;
- $sessionList = [];
- // Check if categoryId is valid
- if ($categoryId > 0) {
- $target = Database::escape_string($target);
- $sTable = Database::get_main_table(TABLE_MAIN_SESSION);
- $sfTable = Database::get_main_table(TABLE_EXTRA_FIELD);
- $sfvTable = Database::get_main_table(TABLE_EXTRA_FIELD_VALUES);
- // Join session field and session field values tables
- $joinTable = $sfTable.' sf INNER JOIN '.$sfvTable.' sfv ON sf.id = sfv.field_id';
- $fieldsArray = [];
- foreach ($extraFields as $field) {
- $fieldsArray[] = Database::escape_string($field);
- }
- $extraFieldType = ExtraField::SESSION_FIELD_TYPE;
- if (isset($publicationDate)) {
- $publicationDateString = $publicationDate->format('Y-m-d H:i:s');
- $wherePublication = " AND id NOT IN (
- SELECT sfv.item_id FROM $joinTable
- WHERE
- sf.extra_field_type = $extraFieldType AND
- ((sf.variable = 'publication_start_date' AND sfv.value > '$publicationDateString' and sfv.value != '') OR
- (sf.variable = 'publication_end_date' AND sfv.value < '$publicationDateString' and sfv.value != ''))
- )";
- }
- // Get the session list from session category and target
- $sessionList = Database::select(
- 'id, name, access_start_date, access_end_date',
- $sTable,
- [
- 'where' => [
- "session_category_id = ? AND id IN (
- SELECT sfv.item_id FROM $joinTable
- WHERE
- sf.extra_field_type = $extraFieldType AND
- sfv.item_id = session.id AND
- sf.variable = 'target' AND
- sfv.value = ?
- ) $wherePublication" => [$categoryId, $target],
- ],
- ]
- );
- $whereFieldVariables = [];
- $whereFieldIds = [];
- if (
- is_array($fieldsArray) &&
- count($fieldsArray) > 0
- ) {
- $whereParams = '?';
- for ($i = 1; $i < count($fieldsArray); $i++) {
- $whereParams .= ', ?';
- }
- $whereFieldVariables = ' variable IN ( '.$whereParams.' )';
- $whereFieldIds = 'field_id IN ( '.$whereParams.' )';
- }
- // Get session fields
- $extraField = new ExtraFieldModel('session');
- $questionMarks = substr(str_repeat('?, ', count($fieldsArray)), 0, -2);
- $fieldsList = $extraField->get_all([
- ' variable IN ( '.$questionMarks.' )' => $fieldsArray,
- ]);
- // Index session fields
- foreach ($fieldsList as $field) {
- $fields[$field['id']] = $field['variable'];
- }
- // Get session field values
- $extra = new ExtraFieldValue('session');
- $questionMarksFields = substr(str_repeat('?, ', count($fields)), 0, -2);
- $sessionFieldValueList = $extra->get_all(['where' => ['field_id IN ( '.$questionMarksFields.' )' => array_keys($fields)]]);
- // Add session fields values to session list
- foreach ($sessionList as $id => &$session) {
- foreach ($sessionFieldValueList as $sessionFieldValue) {
- // Match session field values to session
- if ($sessionFieldValue['item_id'] == $id) {
- // Check if session field value is set in session field list
- if (isset($fields[$sessionFieldValue['field_id']])) {
- // Avoid overwriting the session's ID field
- if ($fields[$sessionFieldValue['field_id']] != 'id') {
- $var = $fields[$sessionFieldValue['field_id']];
- $val = $sessionFieldValue['value'];
- // Assign session field value to session
- $session[$var] = $val;
- }
- }
- }
- }
- }
- }
- return $sessionList;
- }
- /**
- * Return the Session Category id searched by name.
- *
- * @param string $categoryName Name attribute of session category used for search query
- * @param bool $force boolean used to get even if something is wrong (e.g not unique name)
- *
- * @return int|array If success, return category id (int), else it will return an array
- * with the next structure:
- * array('error' => true, 'errorMessage' => ERROR_MESSAGE)
- */
- public static function getSessionCategoryIdByName($categoryName, $force = false)
- {
- // Start error result
- $errorResult = ['error' => true, 'errorMessage' => get_lang('There was an error.')];
- $categoryName = Database::escape_string($categoryName);
- // Check if is not empty category name
- if (!empty($categoryName)) {
- $sessionCategoryTable = Database::get_main_table(TABLE_MAIN_SESSION_CATEGORY);
- // Get all session category with same name
- $result = Database::select(
- 'id',
- $sessionCategoryTable,
- [
- 'where' => [
- 'name = ?' => $categoryName,
- ],
- ]
- );
- // Check the result
- if ($result < 1) {
- // If not found any result, update error message
- $errorResult['errorMessage'] = 'Not found any session category name '.$categoryName;
- } elseif (count($result) > 1 && !$force) {
- // If found more than one result and force is disabled, update error message
- $errorResult['errorMessage'] = 'Found many session categories';
- } elseif (count($result) == 1 || $force) {
- // If found just one session category or force option is enabled
- return key($result);
- }
- } else {
- // category name is empty, update error message
- $errorResult['errorMessage'] = 'Not valid category name';
- }
- return $errorResult;
- }
- /**
- * Return all data from sessions (plus extra field, course and coach data) by category id.
- *
- * @param int $sessionCategoryId session category id used to search sessions
- *
- * @return array If success, return session list and more session related data, else it will return an array
- * with the next structure:
- * array('error' => true, 'errorMessage' => ERROR_MESSAGE)
- */
- public static function getSessionListAndExtraByCategoryId($sessionCategoryId)
- {
- // Start error result
- $errorResult = [
- 'error' => true,
- 'errorMessage' => get_lang('There was an error.'),
- ];
- $sessionCategoryId = intval($sessionCategoryId);
- // Check if session category id is valid
- if ($sessionCategoryId > 0) {
- // Get table names
- $sessionTable = Database::get_main_table(TABLE_MAIN_SESSION);
- $sessionFieldTable = Database::get_main_table(TABLE_EXTRA_FIELD);
- $sessionFieldValueTable = Database::get_main_table(TABLE_EXTRA_FIELD_VALUES);
- $sessionCourseUserTable = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $userTable = Database::get_main_table(TABLE_MAIN_USER);
- $courseTable = Database::get_main_table(TABLE_MAIN_COURSE);
- // Get all data from all sessions whit the session category specified
- $sessionList = Database::select(
- '*',
- $sessionTable,
- [
- 'where' => [
- 'session_category_id = ?' => $sessionCategoryId,
- ],
- ]
- );
- $extraFieldType = ExtraField::SESSION_FIELD_TYPE;
- // Check if session list query had result
- if (!empty($sessionList)) {
- // implode all session id
- $sessionIdsString = '('.implode(', ', array_keys($sessionList)).')';
- // Get all field variables
- $sessionFieldList = Database::select(
- 'id, variable',
- $sessionFieldTable,
- ['extra_field_type = ? ' => [$extraFieldType]]
- );
- // Get all field values
- $sql = "SELECT item_id, field_id, value FROM
- $sessionFieldValueTable v INNER JOIN $sessionFieldTable f
- ON (f.id = v.field_id)
- WHERE
- item_id IN $sessionIdsString AND
- extra_field_type = $extraFieldType
- ";
- $result = Database::query($sql);
- $sessionFieldValueList = Database::store_result($result, 'ASSOC');
- // Check if session field values had result
- if (!empty($sessionFieldValueList)) {
- $sessionFieldValueListBySession = [];
- foreach ($sessionFieldValueList as $key => $sessionFieldValue) {
- // Create an array to index ids to session id
- $sessionFieldValueListBySession[$sessionFieldValue['item_id']][] = $key;
- }
- }
- // Query used to find course-coaches from sessions
- $sql = "SELECT
- scu.session_id,
- c.id AS course_id,
- c.code AS course_code,
- c.title AS course_title,
- u.username AS coach_username,
- u.firstname AS coach_firstname,
- u.lastname AS coach_lastname
- FROM $courseTable c
- INNER JOIN $sessionCourseUserTable scu ON c.id = scu.c_id
- INNER JOIN $userTable u ON scu.user_id = u.user_id
- WHERE scu.status = 2 AND scu.session_id IN $sessionIdsString
- ORDER BY scu.session_id ASC ";
- $res = Database::query($sql);
- $sessionCourseList = Database::store_result($res, 'ASSOC');
- // Check if course list had result
- if (!empty($sessionCourseList)) {
- foreach ($sessionCourseList as $key => $sessionCourse) {
- // Create an array to index ids to session_id
- $sessionCourseListBySession[$sessionCourse['session_id']][] = $key;
- }
- }
- // Join lists
- if (is_array($sessionList)) {
- foreach ($sessionList as $id => &$row) {
- if (
- !empty($sessionFieldValueListBySession) &&
- is_array($sessionFieldValueListBySession[$id])
- ) {
- // If have an index array for session extra fields, use it to join arrays
- foreach ($sessionFieldValueListBySession[$id] as $key) {
- $row['extra'][$key] = [
- 'field_name' => $sessionFieldList[$sessionFieldValueList[$key]['field_id']]['variable'],
- 'value' => $sessionFieldValueList[$key]['value'],
- ];
- }
- }
- if (
- !empty($sessionCourseListBySession) &&
- is_array($sessionCourseListBySession[$id])
- ) {
- // If have an index array for session course coach, use it to join arrays
- foreach ($sessionCourseListBySession[$id] as $key) {
- $row['course'][$key] = [
- 'course_id' => $sessionCourseList[$key]['course_id'],
- 'course_code' => $sessionCourseList[$key]['course_code'],
- 'course_title' => $sessionCourseList[$key]['course_title'],
- 'coach_username' => $sessionCourseList[$key]['coach_username'],
- 'coach_firstname' => $sessionCourseList[$key]['coach_firstname'],
- 'coach_lastname' => $sessionCourseList[$key]['coach_lastname'],
- ];
- }
- }
- }
- }
- return $sessionList;
- } else {
- // Not found result, update error message
- $errorResult['errorMessage'] = 'Not found any session for session category id '.$sessionCategoryId;
- }
- }
- return $errorResult;
- }
- /**
- * Return session description from session id.
- *
- * @param int $sessionId
- *
- * @return string
- */
- public static function getDescriptionFromSessionId($sessionId)
- {
- // Init variables
- $sessionId = (int) $sessionId;
- $description = '';
- // Check if session id is valid
- if ($sessionId > 0) {
- // Select query from session id
- $rows = Database::select(
- 'description',
- Database::get_main_table(TABLE_MAIN_SESSION),
- [
- 'where' => [
- 'id = ?' => $sessionId,
- ],
- ]
- );
- // Check if select query result is not empty
- if (!empty($rows)) {
- // Get session description
- $description = $rows[0]['description'];
- }
- }
- return $description;
- }
- /**
- * Get a session list filtered by name, description or any of the given extra fields.
- *
- * @param string $term The term to search
- * @param array $extraFieldsToInclude Extra fields to include in the session data
- *
- * @return array The list
- */
- public static function searchSession($term, $extraFieldsToInclude = [])
- {
- $sTable = Database::get_main_table(TABLE_MAIN_SESSION);
- $extraFieldTable = Database::get_main_table(TABLE_EXTRA_FIELD);
- $sfvTable = Database::get_main_table(TABLE_EXTRA_FIELD_VALUES);
- $term = Database::escape_string($term);
- $extraFieldType = ExtraField::SESSION_FIELD_TYPE;
- if (is_array($extraFieldsToInclude) && count($extraFieldsToInclude) > 0) {
- $resultData = Database::select('*', $sTable, [
- 'where' => [
- "name LIKE %?% " => $term,
- " OR description LIKE %?% " => $term,
- " OR id IN (
- SELECT item_id
- FROM $sfvTable v INNER JOIN $extraFieldTable e
- ON (v.field_id = e.id)
- WHERE value LIKE %?% AND extra_field_type = $extraFieldType
- ) " => $term,
- ],
- ]);
- } else {
- $resultData = Database::select('*', $sTable, [
- 'where' => [
- "name LIKE %?% " => $term,
- "OR description LIKE %?% " => $term,
- ],
- ]);
- return $resultData;
- }
- foreach ($resultData as $id => &$session) {
- $session['extra'] = self::getFilteredExtraFields($id, $extraFieldsToInclude);
- }
- return $resultData;
- }
- /**
- * @param int $sessionId
- * @param array $extraFieldsToInclude
- *
- * @return array
- */
- public static function getFilteredExtraFields($sessionId, $extraFieldsToInclude = [])
- {
- $extraData = [];
- $variables = [];
- $variablePlaceHolders = [];
- foreach ($extraFieldsToInclude as $sessionExtraField) {
- $variablePlaceHolders[] = "?";
- $variables[] = Database::escape_string($sessionExtraField);
- }
- $sessionExtraField = new ExtraFieldModel('session');
- $fieldList = $sessionExtraField->get_all([
- "variable IN ( ".implode(", ", $variablePlaceHolders)." ) " => $variables,
- ]);
- $fields = [];
- // Index session fields
- foreach ($fieldList as $field) {
- $fields[$field['id']] = $field['variable'];
- }
- // Get session field values
- $extra = new ExtraFieldValue('session');
- $sessionFieldValueList = $extra->get_all(
- [
- "field_id IN ( ".implode(", ", $variablePlaceHolders)." )" => array_keys($fields),
- ]
- );
- foreach ($sessionFieldValueList as $sessionFieldValue) {
- // Match session field values to session
- if ($sessionFieldValue['item_id'] != $sessionId) {
- continue;
- }
- // Check if session field value is set in session field list
- if (!isset($fields[$sessionFieldValue['field_id']])) {
- continue;
- }
- $extrafieldVariable = $fields[$sessionFieldValue['field_id']];
- $extrafieldValue = $sessionFieldValue['value'];
- $extraData[] = [
- 'variable' => $extrafieldVariable,
- 'value' => $extrafieldValue,
- ];
- }
- return $extraData;
- }
- /**
- * @param int $sessionId
- *
- * @return bool
- */
- public static function isValidId($sessionId)
- {
- $sessionId = intval($sessionId);
- if ($sessionId > 0) {
- $rows = Database::select(
- 'id',
- Database::get_main_table(TABLE_MAIN_SESSION),
- ['where' => ['id = ?' => $sessionId]]
- );
- if (!empty($rows)) {
- return true;
- }
- }
- return false;
- }
- /**
- * Get list of sessions based on users of a group for a group admin.
- *
- * @param int $userId The user id
- *
- * @return array
- */
- public static function getSessionsFollowedForGroupAdmin($userId)
- {
- $sessionList = [];
- $sessionTable = Database::get_main_table(TABLE_MAIN_SESSION);
- $sessionUserTable = Database::get_main_table(TABLE_MAIN_SESSION_USER);
- $userGroup = new UserGroup();
- $userIdList = $userGroup->getGroupUsersByUser($userId);
- if (empty($userIdList)) {
- return [];
- }
- $sql = "SELECT DISTINCT s.*
- FROM $sessionTable s
- INNER JOIN $sessionUserTable sru
- ON s.id = sru.id_session
- WHERE
- (sru.id_user IN (".implode(', ', $userIdList).")
- AND sru.relation_type = 0
- )";
- if (api_is_multiple_url_enabled()) {
- $sessionAccessUrlTable = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $accessUrlId = api_get_current_access_url_id();
- if ($accessUrlId != -1) {
- $sql = "SELECT DISTINCT s.*
- FROM $sessionTable s
- INNER JOIN $sessionUserTable sru ON s.id = sru.id_session
- INNER JOIN $sessionAccessUrlTable srau ON s.id = srau.session_id
- WHERE
- srau.access_url_id = $accessUrlId
- AND (
- sru.id_user IN (".implode(', ', $userIdList).")
- AND sru.relation_type = 0
- )";
- }
- }
- $result = Database::query($sql);
- while ($row = Database::fetch_assoc($result)) {
- $sessionList[] = $row;
- }
- return $sessionList;
- }
- /**
- * @param array $sessionInfo
- *
- * @return string
- */
- public static function getSessionVisibility($sessionInfo)
- {
- switch ($sessionInfo['visibility']) {
- case 1:
- return get_lang('Read only');
- case 2:
- return get_lang('Visible');
- case 3:
- return api_ucfirst(get_lang('invisible'));
- }
- }
- /**
- * Returns a human readable string.
- *
- * @param array $sessionInfo An array with all the session dates
- * @param bool $showTime
- *
- * @return array
- */
- public static function parseSessionDates($sessionInfo, $showTime = false)
- {
- $displayDates = self::convertSessionDateToString(
- $sessionInfo['display_start_date'],
- $sessionInfo['display_end_date'],
- $showTime,
- true
- );
- $accessDates = self::convertSessionDateToString(
- $sessionInfo['access_start_date'],
- $sessionInfo['access_end_date'],
- $showTime,
- true
- );
- $coachDates = self::convertSessionDateToString(
- $sessionInfo['coach_access_start_date'],
- $sessionInfo['coach_access_end_date'],
- $showTime,
- true
- );
- $result = [
- 'access' => $accessDates,
- 'display' => $displayDates,
- 'coach' => $coachDates,
- ];
- return $result;
- }
- /**
- * @param FormValidator $form
- * @param array $sessionInfo Optional
- *
- * @return array
- */
- public static function setForm(FormValidator $form, array $sessionInfo = [])
- {
- $sessionId = 0;
- $coachInfo = [];
- if (!empty($sessionInfo)) {
- $sessionId = (int) $sessionInfo['id'];
- $coachInfo = api_get_user_info($sessionInfo['id_coach']);
- }
- $categoriesList = self::get_all_session_category();
- $userInfo = api_get_user_info();
- $categoriesOptions = [
- '0' => get_lang('none'),
- ];
- if ($categoriesList != false) {
- foreach ($categoriesList as $categoryItem) {
- $categoriesOptions[$categoryItem['id']] = $categoryItem['name'];
- }
- }
- // Database Table Definitions
- $tbl_user = Database::get_main_table(TABLE_MAIN_USER);
- $form->addText(
- 'name',
- get_lang('Session name'),
- true,
- ['maxlength' => 150, 'aria-label' => get_lang('Session name')]
- );
- $form->addRule('name', get_lang('Session name already exists'), 'callback', 'check_session_name');
- if (!api_is_platform_admin() && api_is_teacher()) {
- $form->addElement(
- 'select',
- 'coach_username',
- get_lang('Coach name'),
- [api_get_user_id() => $userInfo['complete_name']],
- [
- 'id' => 'coach_username',
- 'style' => 'width:370px;',
- ]
- );
- } else {
- $sql = "SELECT COUNT(1) FROM $tbl_user WHERE status = 1";
- $rs = Database::query($sql);
- $countUsers = (int) Database::result($rs, 0, 0);
- if ($countUsers < 50) {
- $orderClause = 'ORDER BY ';
- $orderClause .= api_sort_by_first_name() ? 'firstname, lastname, username' : 'lastname, firstname, username';
- $sql = "SELECT user_id, lastname, firstname, username
- FROM $tbl_user
- WHERE status = '1' ".
- $orderClause;
- if (api_is_multiple_url_enabled()) {
- $userRelAccessUrlTable = Database::get_main_table(
- TABLE_MAIN_ACCESS_URL_REL_USER
- );
- $accessUrlId = api_get_current_access_url_id();
- if ($accessUrlId != -1) {
- $sql = "SELECT user.user_id, username, lastname, firstname
- FROM $tbl_user user
- INNER JOIN $userRelAccessUrlTable url_user
- ON (url_user.user_id = user.user_id)
- WHERE
- access_url_id = $accessUrlId AND
- status = 1 "
- .$orderClause;
- }
- }
- $result = Database::query($sql);
- $coachesList = Database::store_result($result);
- $coachesOptions = [];
- foreach ($coachesList as $coachItem) {
- $coachesOptions[$coachItem['user_id']] =
- api_get_person_name($coachItem['firstname'], $coachItem['lastname']).' ('.$coachItem['username'].')';
- }
- $form->addElement(
- 'select',
- 'coach_username',
- get_lang('Coach name'),
- $coachesOptions,
- [
- 'id' => 'coach_username',
- 'style' => 'width:370px;',
- ]
- );
- } else {
- $form->addElement(
- 'select_ajax',
- 'coach_username',
- get_lang('Coach name'),
- $coachInfo ? [$coachInfo['id'] => $coachInfo['complete_name_with_username']] : [],
- [
- 'url' => api_get_path(WEB_AJAX_PATH).'session.ajax.php?a=search_general_coach',
- 'width' => '100%',
- 'id' => 'coach_username',
- ]
- );
- }
- }
- $form->addRule('coach_username', get_lang('Required field'), 'required');
- $form->addHtml('<div id="ajax_list_coachs"></div>');
- $form->addButtonAdvancedSettings('advanced_params');
- $form->addElement('html', '<div id="advanced_params_options" style="display:none">');
- if (empty($sessionId)) {
- $sessions = self::formatSessionsAdminForGrid();
- $sessionList = [];
- $sessionList[] = '';
- foreach ($sessions as $session) {
- $sessionList[$session['id']] = strip_tags($session['name']);
- }
- $form->addSelect(
- 'session_template',
- get_lang('Session template'),
- $sessionList,
- ['id' => 'system_template']
- );
- }
- $form->addSelect(
- 'session_category',
- get_lang('Sessions categories'),
- $categoriesOptions,
- [
- 'id' => 'session_category',
- ]
- );
- $form->addHtmlEditor(
- 'description',
- get_lang('Description'),
- false,
- false,
- [
- 'ToolbarSet' => 'Minimal',
- ]
- );
- $form->addElement('checkbox', 'show_description', null, get_lang('Show description'));
- $visibilityGroup = [];
- $visibilityGroup[] = $form->createElement(
- 'select',
- 'session_visibility',
- null,
- [
- SESSION_VISIBLE_READ_ONLY => get_lang('SessionRead only'),
- SESSION_VISIBLE => get_lang('Accessible'),
- SESSION_INVISIBLE => api_ucfirst(get_lang('Not accessible')),
- ]
- );
- $form->addGroup(
- $visibilityGroup,
- 'visibility_group',
- get_lang('Visibility after end date'),
- null,
- false
- );
- $options = [
- 0 => get_lang('By duration'),
- 1 => get_lang('By dates'),
- ];
- $form->addSelect('access', get_lang('Access'), $options, [
- 'onchange' => 'accessSwitcher()',
- 'id' => 'access',
- ]);
- $form->addHtml('<div id="duration_div" style="display:none">');
- $form->addElement(
- 'number',
- 'duration',
- [
- get_lang('Session duration'),
- get_lang('The session duration allows you to set a number of days of access starting from the first access date of the user to the session. This way, you can set a session to last for 15 days instead of starting at a fixed date for all students.'),
- ],
- [
- 'maxlength' => 50,
- ]
- );
- $form->addHtml('</div>');
- $form->addHtml('<div id="date_fields" style="display:none">');
- // Dates
- $form->addDateTimePicker(
- 'access_start_date',
- [get_lang('Access start date'), get_lang('Access start dateComment')],
- ['id' => 'access_start_date']
- );
- $form->addDateTimePicker(
- 'access_end_date',
- [get_lang('Access end date'), get_lang('Access end dateComment')],
- ['id' => 'access_end_date']
- );
- $form->addRule(
- ['access_start_date', 'access_end_date'],
- get_lang('Start date must be before the end date'),
- 'compare_datetime_text',
- '< allow_empty'
- );
- $form->addDateTimePicker(
- 'display_start_date',
- [
- get_lang('Start date to display'),
- get_lang('Start date to displayComment'),
- ],
- ['id' => 'display_start_date']
- );
- $form->addDateTimePicker(
- 'display_end_date',
- [
- get_lang('End date to display'),
- get_lang('End date to displayComment'),
- ],
- ['id' => 'display_end_date']
- );
- $form->addRule(
- ['display_start_date', 'display_end_date'],
- get_lang('Start date must be before the end date'),
- 'compare_datetime_text',
- '< allow_empty'
- );
- $form->addDateTimePicker(
- 'coach_access_start_date',
- [
- get_lang('Access start date for coaches'),
- get_lang('Access start date for coachesComment'),
- ],
- ['id' => 'coach_access_start_date']
- );
- $form->addDateTimePicker(
- 'coach_access_end_date',
- [
- get_lang('Access end date for coaches'),
- get_lang('Access end date for coachesComment'),
- ],
- ['id' => 'coach_access_end_date']
- );
- $form->addRule(
- ['coach_access_start_date', 'coach_access_end_date'],
- get_lang('Start date must be before the end date'),
- 'compare_datetime_text',
- '< allow_empty'
- );
- $form->addElement('html', '</div>');
- $form->addCheckBox(
- 'send_subscription_notification',
- [
- get_lang('Send mail notification to students to inform of subscription'),
- get_lang('Send an email when a user being subscribed to session'),
- ]
- );
- // Extra fields
- $extra_field = new ExtraFieldModel('session');
- $extra = $extra_field->addElements($form, $sessionId);
- $form->addElement('html', '</div>');
- $js = $extra['jquery_ready_content'];
- return ['js' => $js];
- }
- /**
- * Gets the number of rows in the session table filtered through the given
- * array of parameters.
- *
- * @param array Array of options/filters/keys
- *
- * @return int The number of rows, or false on wrong param
- * @assert ('a') === false
- */
- public static function get_count_admin_complete($options = [])
- {
- if (!is_array($options)) {
- return false;
- }
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $tbl_session_category = Database::get_main_table(TABLE_MAIN_SESSION_CATEGORY);
- $tbl_user = Database::get_main_table(TABLE_MAIN_USER);
- $sessionCourseUserTable = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $courseTable = Database::get_main_table(TABLE_MAIN_COURSE);
- $tbl_session_field_values = Database::get_main_table(TABLE_EXTRA_FIELD_VALUES);
- $tbl_session_field_options = Database::get_main_table(TABLE_EXTRA_FIELD_OPTIONS);
- $where = 'WHERE 1 = 1 ';
- $user_id = api_get_user_id();
- if (api_is_session_admin() &&
- api_get_setting('allow_session_admins_to_see_all_sessions') == 'false'
- ) {
- $where .= " WHERE s.session_admin_id = $user_id ";
- }
- $extraFieldTables = '';
- if (!empty($options['where'])) {
- $options['where'] = str_replace('course_title', 'c.title', $options['where']);
- $options['where'] = str_replace("( session_active = '0' )", '1=1', $options['where']);
- $options['where'] = str_replace(
- ["AND session_active = '1' )", " AND ( session_active = '1' )"],
- [') GROUP BY s.name HAVING session_active = 1 ', " GROUP BY s.name HAVING session_active = 1 "],
- $options['where']
- );
- $options['where'] = str_replace(
- ["AND session_active = '0' )", " AND ( session_active = '0' )"],
- [') GROUP BY s.name HAVING session_active = 0 ', " GROUP BY s.name HAVING session_active = '0' "],
- $options['where']
- );
- if (!empty($options['extra'])) {
- $options['where'] = str_replace(' 1 = 1 AND', '', $options['where']);
- $options['where'] = str_replace('AND', 'OR', $options['where']);
- foreach ($options['extra'] as $extra) {
- $options['where'] = str_replace(
- $extra['field'],
- 'fv.field_id = '.$extra['id'].' AND fvo.option_value',
- $options['where']
- );
- $extraFieldTables = "$tbl_session_field_values fv, $tbl_session_field_options fvo, ";
- }
- }
- $where .= ' AND '.$options['where'];
- }
- $today = api_get_utc_datetime();
- $query_rows = "SELECT count(*) as total_rows, c.title as course_title, s.name,
- IF (
- (s.access_start_date <= '$today' AND '$today' < s.access_end_date) OR
- (s.access_start_date = '0000-00-00 00:00:00' AND s.access_end_date = '0000-00-00 00:00:00' ) OR
- (s.access_start_date IS NULL AND s.access_end_date IS NULL) OR
- (s.access_start_date <= '$today' AND ('0000-00-00 00:00:00' = s.access_end_date OR s.access_end_date IS NULL )) OR
- ('$today' < s.access_end_date AND ('0000-00-00 00:00:00' = s.access_start_date OR s.access_start_date IS NULL) )
- , 1, 0) as session_active
- FROM $extraFieldTables $tbl_session s
- LEFT JOIN $tbl_session_category sc
- ON s.session_category_id = sc.id
- INNER JOIN $tbl_user u
- ON s.id_coach = u.user_id
- INNER JOIN $sessionCourseUserTable scu
- ON s.id = scu.session_id
- INNER JOIN $courseTable c
- ON c.id = scu.c_id
- $where ";
- if (api_is_multiple_url_enabled()) {
- $table_access_url_rel_session = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $access_url_id = api_get_current_access_url_id();
- if ($access_url_id != -1) {
- $where .= " AND ar.access_url_id = $access_url_id ";
- $query_rows = "SELECT count(*) as total_rows
- FROM $tbl_session s
- LEFT JOIN $tbl_session_category sc
- ON s.session_category_id = sc.id
- INNER JOIN $tbl_user u
- ON s.id_coach = u.user_id
- INNER JOIN $table_access_url_rel_session ar
- ON ar.session_id = s.id $where ";
- }
- }
- $result = Database::query($query_rows);
- $num = 0;
- if (Database::num_rows($result)) {
- $rows = Database::fetch_array($result);
- $num = $rows['total_rows'];
- }
- return $num;
- }
- /**
- * @param string $listType
- * @param array $extraFields
- *
- * @return array
- */
- public static function getGridColumns(
- $listType = 'simple',
- $extraFields = []
- ) {
- $showCount = api_get_configuration_value('session_list_show_count_users');
- // Column config
- $operators = ['cn', 'nc'];
- $date_operators = ['gt', 'ge', 'lt', 'le'];
- switch ($listType) {
- case 'my_space':
- $columns = [
- get_lang('Title'),
- get_lang('Date'),
- get_lang('Number of courses per session'),
- get_lang('Number of learners by session'),
- get_lang('Details'),
- ];
- $columnModel = [
- ['name' => 'name', 'index' => 'name', 'width' => '255', 'align' => 'left'],
- ['name' => 'date', 'index' => 'access_start_date', 'width' => '150', 'align' => 'left'],
- [
- 'name' => 'course_per_session',
- 'index' => 'course_per_session',
- 'width' => '150',
- 'sortable' => 'false',
- 'search' => 'false',
- ],
- [
- 'name' => 'student_per_session',
- 'index' => 'student_per_session',
- 'width' => '100',
- 'sortable' => 'false',
- 'search' => 'false',
- ],
- ['name' => 'actions', 'index' => 'actions', 'width' => '100', 'sortable' => 'false', 'search' => 'false'],
- ];
- break;
- case 'simple':
- $columns = [
- '#',
- get_lang('Name'),
- get_lang('Category'),
- get_lang('Start date to display'),
- get_lang('End date to display'),
- get_lang('Visibility'),
- ];
- $columnModel = [
- [
- 'name' => 'id',
- 'index' => 's.id',
- 'width' => '160',
- 'hidden' => 'true',
- ],
- [
- 'name' => 'name',
- 'index' => 's.name',
- 'width' => '160',
- 'align' => 'left',
- 'search' => 'true',
- 'searchoptions' => ['sopt' => $operators],
- ],
- [
- 'name' => 'category_name',
- 'index' => 'category_name',
- 'width' => '40',
- 'align' => 'left',
- 'search' => 'true',
- 'searchoptions' => ['sopt' => $operators],
- ],
- [
- 'name' => 'display_start_date',
- 'index' => 'display_start_date',
- 'width' => '50',
- 'align' => 'left',
- 'search' => 'true',
- 'searchoptions' => [
- 'dataInit' => 'date_pick_today',
- 'sopt' => $date_operators,
- ],
- ],
- [
- 'name' => 'display_end_date',
- 'index' => 'display_end_date',
- 'width' => '50',
- 'align' => 'left',
- 'search' => 'true',
- 'searchoptions' => [
- 'dataInit' => 'date_pick_one_month',
- 'sopt' => $date_operators,
- ],
- ],
- [
- 'name' => 'visibility',
- 'index' => 'visibility',
- 'width' => '40',
- 'align' => 'left',
- 'search' => 'false',
- ],
- ];
- if ($showCount) {
- $columns[] = get_lang('Users');
- $columnModel[] = [
- 'name' => 'users',
- 'index' => 'users',
- 'width' => '20',
- 'align' => 'left',
- 'search' => 'false',
- ];
- }
- break;
- case 'complete':
- $columns = [
- get_lang('Name'),
- get_lang('Start date to display'),
- get_lang('End date to display'),
- get_lang('Coach'),
- get_lang('Status'),
- get_lang('Visibility'),
- get_lang('Course title'),
- ];
- $columnModel = [
- ['name' => 'name', 'index' => 's.name', 'width' => '200', 'align' => 'left', 'search' => 'true', 'searchoptions' => ['sopt' => $operators]],
- ['name' => 'display_start_date', 'index' => 'display_start_date', 'width' => '70', 'align' => 'left', 'search' => 'true', 'searchoptions' => ['dataInit' => 'date_pick_today', 'sopt' => $date_operators]],
- ['name' => 'display_end_date', 'index' => 'display_end_date', 'width' => '70', 'align' => 'left', 'search' => 'true', 'searchoptions' => ['dataInit' => 'date_pick_one_month', 'sopt' => $date_operators]],
- ['name' => 'coach_name', 'index' => 'coach_name', 'width' => '70', 'align' => 'left', 'search' => 'false', 'searchoptions' => ['sopt' => $operators]],
- ['name' => 'session_active', 'index' => 'session_active', 'width' => '25', 'align' => 'left', 'search' => 'true', 'stype' => 'select',
- // for the bottom bar
- 'searchoptions' => [
- 'defaultValue' => '1',
- 'value' => '1:'.get_lang('active').';0:'.get_lang('inactive'), ],
- // for the top bar
- 'editoptions' => ['value' => '" ":'.get_lang('All').';1:'.get_lang('active').';0:'.get_lang('inactive')],
- ],
- ['name' => 'visibility', 'index' => 'visibility', 'width' => '40', 'align' => 'left', 'search' => 'false'],
- ['name' => 'course_title', 'index' => 'course_title', 'width' => '50', 'hidden' => 'true', 'search' => 'true', 'searchoptions' => ['searchhidden' => 'true', 'sopt' => $operators]],
- ];
- break;
- }
- if (!empty($extraFields)) {
- foreach ($extraFields as $field) {
- $columns[] = $field['display_text'];
- $columnModel[] = [
- 'name' => $field['variable'],
- 'index' => $field['variable'],
- 'width' => '80',
- 'align' => 'center',
- 'search' => 'false',
- ];
- }
- }
- // Inject extra session fields
- $sessionField = new ExtraFieldModel('session');
- $rules = $sessionField->getRules($columns, $columnModel);
- if (!in_array('actions', array_column($columnModel, 'name'))) {
- $columnModel[] = [
- 'name' => 'actions',
- 'index' => 'actions',
- 'width' => '80',
- 'align' => 'left',
- 'formatter' => 'action_formatter',
- 'sortable' => 'false',
- 'search' => 'false',
- ];
- $columns[] = get_lang('Detail');
- }
- $columnName = [];
- foreach ($columnModel as $col) {
- $columnName[] = $col['name'];
- }
- $return = [
- 'columns' => $columns,
- 'column_model' => $columnModel,
- 'rules' => $rules,
- 'simple_column_name' => $columnName,
- ];
- return $return;
- }
- /**
- * Converts all dates sent through the param array (given form) to correct dates with timezones.
- *
- * @param array The dates The same array, with times converted
- * @param bool $applyFormat Whether apply the DATE_TIME_FORMAT_SHORT format for sessions
- *
- * @return array The same array, with times converted
- */
- public static function convert_dates_to_local($params, $applyFormat = false)
- {
- if (!is_array($params)) {
- return false;
- }
- $params['display_start_date'] = api_get_local_time($params['display_start_date'], null, null, true);
- $params['display_end_date'] = api_get_local_time($params['display_end_date'], null, null, true);
- $params['access_start_date'] = api_get_local_time($params['access_start_date'], null, null, true);
- $params['access_end_date'] = api_get_local_time($params['access_end_date'], null, null, true);
- $params['coach_access_start_date'] = isset($params['coach_access_start_date']) ? api_get_local_time($params['coach_access_start_date'], null, null, true) : null;
- $params['coach_access_end_date'] = isset($params['coach_access_end_date']) ? api_get_local_time($params['coach_access_end_date'], null, null, true) : null;
- if ($applyFormat) {
- if (isset($params['display_start_date'])) {
- $params['display_start_date'] = api_format_date($params['display_start_date'], DATE_TIME_FORMAT_SHORT);
- }
- if (isset($params['display_end_date'])) {
- $params['display_end_date'] = api_format_date($params['display_end_date'], DATE_TIME_FORMAT_SHORT);
- }
- if (isset($params['access_start_date'])) {
- $params[''] = api_format_date($params['access_start_date'], DATE_TIME_FORMAT_SHORT);
- }
- if (isset($params['access_end_date'])) {
- $params['access_end_date'] = api_format_date($params['access_end_date'], DATE_TIME_FORMAT_SHORT);
- }
- if (isset($params['coach_access_start_date'])) {
- $params['coach_access_start_date'] = api_format_date($params['coach_access_start_date'], DATE_TIME_FORMAT_SHORT);
- }
- if (isset($params['coach_access_end_date'])) {
- $params['coach_access_end_date'] = api_format_date($params['coach_access_end_date'], DATE_TIME_FORMAT_SHORT);
- }
- }
- return $params;
- }
- /**
- * Gets the admin session list callback of the session/session_list.php
- * page with all user/details in the right fomat.
- *
- * @param array $options
- *
- * @return array Array of rows results
- * @asset ('a') === false
- */
- public static function get_sessions_admin_complete($options = [])
- {
- if (!is_array($options)) {
- return false;
- }
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- $tbl_session_category = Database::get_main_table(TABLE_MAIN_SESSION_CATEGORY);
- $tbl_user = Database::get_main_table(TABLE_MAIN_USER);
- $tbl_session_rel_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
- $extraFieldTable = Database::get_main_table(TABLE_EXTRA_FIELD);
- $tbl_session_field_values = Database::get_main_table(TABLE_EXTRA_FIELD_VALUES);
- $tbl_session_field_options = Database::get_main_table(TABLE_EXTRA_FIELD_OPTIONS);
- $where = 'WHERE 1 = 1 ';
- $user_id = api_get_user_id();
- if (!api_is_platform_admin()) {
- if (api_is_session_admin() &&
- api_get_setting('allow_session_admins_to_manage_all_sessions') == 'false'
- ) {
- $where .= " AND s.session_admin_id = $user_id ";
- }
- }
- $coach_name = " CONCAT(u.lastname , ' ', u.firstname) as coach_name ";
- if (api_is_western_name_order()) {
- $coach_name = " CONCAT(u.firstname, ' ', u.lastname) as coach_name ";
- }
- $today = api_get_utc_datetime();
- $inject_extra_fields = null;
- $extra_fields_info = [];
- //for now only sessions
- $extra_field = new ExtraFieldModel('session');
- $double_fields = [];
- $extra_field_option = new ExtraFieldOption('session');
- if (isset($options['extra'])) {
- $extra_fields = $options['extra'];
- if (!empty($extra_fields)) {
- foreach ($extra_fields as $extra) {
- $inject_extra_fields .= " IF (fv.field_id = {$extra['id']}, fvo.option_display_text, NULL ) as {$extra['field']} , ";
- if (isset($extra_fields_info[$extra['id']])) {
- $info = $extra_fields_info[$extra['id']];
- } else {
- $info = $extra_field->get($extra['id']);
- $extra_fields_info[$extra['id']] = $info;
- }
- if ($info['field_type'] == ExtraFieldModel::FIELD_TYPE_DOUBLE_SELECT) {
- $double_fields[$info['id']] = $info;
- }
- }
- }
- }
- $options_by_double = [];
- foreach ($double_fields as $double) {
- $my_options = $extra_field_option->get_field_options_by_field(
- $double['id'],
- true
- );
- $options_by_double['extra_'.$double['field_variable']] = $my_options;
- }
- //sc.name as category_name,
- $select = "
- SELECT * FROM (
- SELECT DISTINCT
- IF (
- (s.access_start_date <= '$today' AND '$today' < s.access_end_date) OR
- (s.access_start_date = '0000-00-00 00:00:00' AND s.access_end_date = '0000-00-00 00:00:00' ) OR
- (s.access_start_date IS NULL AND s.access_end_date IS NULL) OR
- (s.access_start_date <= '$today' AND ('0000-00-00 00:00:00' = s.access_end_date OR s.access_end_date IS NULL )) OR
- ('$today' < s.access_end_date AND ('0000-00-00 00:00:00' = s.access_start_date OR s.access_start_date IS NULL) )
- , 1, 0) as session_active,
- s.name,
- s.nbr_courses,
- s.nbr_users,
- s.display_start_date,
- s.display_end_date,
- $coach_name,
- access_start_date,
- access_end_date,
- s.visibility,
- u.user_id,
- $inject_extra_fields
- c.title as course_title,
- s.id ";
- if (!empty($options['where'])) {
- if (!empty($options['extra'])) {
- $options['where'] = str_replace(' 1 = 1 AND', '', $options['where']);
- $options['where'] = str_replace('AND', 'OR', $options['where']);
- foreach ($options['extra'] as $extra) {
- $options['where'] = str_replace($extra['field'], 'fv.field_id = '.$extra['id'].' AND fvo.option_value', $options['where']);
- }
- }
- $options['where'] = str_replace('course_title', 'c.title', $options['where']);
- $options['where'] = str_replace("( session_active = '0' )", '1=1', $options['where']);
- $options['where'] = str_replace(
- ["AND session_active = '1' )", " AND ( session_active = '1' )"],
- [') GROUP BY s.name HAVING session_active = 1 ', " GROUP BY s.name HAVING session_active = 1 "],
- $options['where']
- );
- $options['where'] = str_replace(
- ["AND session_active = '0' )", " AND ( session_active = '0' )"],
- [') GROUP BY s.name HAVING session_active = 0 ', " GROUP BY s.name HAVING session_active = '0' "],
- $options['where']
- );
- $where .= ' AND '.$options['where'];
- }
- $limit = '';
- if (!empty($options['limit'])) {
- $limit = " LIMIT ".$options['limit'];
- }
- $query = "$select FROM $tbl_session s
- LEFT JOIN $tbl_session_field_values fv
- ON (fv.item_id = s.id)
- LEFT JOIN $extraFieldTable f
- ON f.id = fv.field_id
- LEFT JOIN $tbl_session_field_options fvo
- ON (fv.field_id = fvo.field_id)
- LEFT JOIN $tbl_session_rel_course src
- ON (src.session_id = s.id)
- LEFT JOIN $tbl_course c
- ON (src.c_id = c.id)
- LEFT JOIN $tbl_session_category sc
- ON (s.session_category_id = sc.id)
- INNER JOIN $tbl_user u
- ON (s.id_coach = u.user_id)
- $where
- $limit
- ";
- if (api_is_multiple_url_enabled()) {
- $table_access_url_rel_session = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $access_url_id = api_get_current_access_url_id();
- if ($access_url_id != -1) {
- $query = "$select
- FROM $tbl_session s
- LEFT JOIN $tbl_session_field_values fv
- ON (fv.item_id = s.id)
- LEFT JOIN $tbl_session_field_options fvo
- ON (fv.field_id = fvo.field_id)
- LEFT JOIN $tbl_session_rel_course src
- ON (src.session_id = s.id)
- LEFT JOIN $tbl_course c
- ON (src.c_id = c.id)
- LEFT JOIN $tbl_session_category sc
- ON (s.session_category_id = sc.id)
- INNER JOIN $tbl_user u
- ON (s.id_coach = u.user_id)
- INNER JOIN $table_access_url_rel_session ar
- ON (ar.session_id = s.id AND ar.access_url_id = $access_url_id)
- $where
- $limit
- ";
- }
- }
- $query .= ") AS session_table";
- if (!empty($options['order'])) {
- $query .= " ORDER BY ".$options['order'];
- }
- $result = Database::query($query);
- $acceptIcon = Display::return_icon(
- 'accept.png',
- get_lang('active'),
- [],
- ICON_SIZE_SMALL
- );
- $errorIcon = Display::return_icon(
- 'error.png',
- get_lang('inactive'),
- [],
- ICON_SIZE_SMALL
- );
- $formatted_sessions = [];
- if (Database::num_rows($result)) {
- $sessions = Database::store_result($result, 'ASSOC');
- foreach ($sessions as $session) {
- $session_id = $session['id'];
- $session['name'] = Display::url($session['name'], "resume_session.php?id_session=".$session['id']);
- $session['coach_name'] = Display::url($session['coach_name'], "user_information.php?user_id=".$session['user_id']);
- if ($session['session_active'] == 1) {
- $session['session_active'] = $acceptIcon;
- } else {
- $session['session_active'] = $errorIcon;
- }
- $session = self::convert_dates_to_local($session);
- switch ($session['visibility']) {
- case SESSION_VISIBLE_READ_ONLY: //1
- $session['visibility'] = get_lang('Read only');
- break;
- case SESSION_VISIBLE: //2
- case SESSION_AVAILABLE: //4
- $session['visibility'] = get_lang('Visible');
- break;
- case SESSION_INVISIBLE: //3
- $session['visibility'] = api_ucfirst(get_lang('invisible'));
- break;
- }
- // Cleaning double selects
- foreach ($session as $key => &$value) {
- if (isset($options_by_double[$key]) || isset($options_by_double[$key.'_second'])) {
- $options = explode('::', $value);
- }
- $original_key = $key;
- if (strpos($key, '_second') === false) {
- } else {
- $key = str_replace('_second', '', $key);
- }
- if (isset($options_by_double[$key])) {
- if (isset($options[0])) {
- if (isset($options_by_double[$key][$options[0]])) {
- if (strpos($original_key, '_second') === false) {
- $value = $options_by_double[$key][$options[0]]['option_display_text'];
- } else {
- $value = $options_by_double[$key][$options[1]]['option_display_text'];
- }
- }
- }
- }
- }
- // Magic filter
- if (isset($formatted_sessions[$session_id])) {
- $formatted_sessions[$session_id] = self::compareArraysToMerge(
- $formatted_sessions[$session_id],
- $session
- );
- } else {
- $formatted_sessions[$session_id] = $session;
- }
- }
- }
- return $formatted_sessions;
- }
- /**
- * Compare two arrays.
- *
- * @param array $array1
- * @param array $array2
- *
- * @return array
- */
- public static function compareArraysToMerge($array1, $array2)
- {
- if (empty($array2)) {
- return $array1;
- }
- foreach ($array1 as $key => $item) {
- if (!isset($array1[$key])) {
- //My string is empty try the other one
- if (isset($array2[$key]) && !empty($array2[$key])) {
- $array1[$key] = $array2[$key];
- }
- }
- }
- return $array1;
- }
- /**
- * Get link to the admin page for this session.
- *
- * @param int $id Session ID
- *
- * @return mixed URL to the admin page to manage the session, or false on error
- */
- public static function getAdminPath($id)
- {
- $id = (int) $id;
- $session = self::fetch($id);
- if (empty($session)) {
- return false;
- }
- return api_get_path(WEB_CODE_PATH).'session/resume_session.php?id_session='.$id;
- }
- /**
- * Get link to the user page for this session.
- * If a course is provided, build the link to the course.
- *
- * @param int $id Session ID
- * @param int $courseId Course ID (optional) in case the link has to send straight to the course
- *
- * @return mixed URL to the page to use the session, or false on error
- */
- public static function getPath($id, $courseId = 0)
- {
- $id = (int) $id;
- $session = self::fetch($id);
- if (empty($session)) {
- return false;
- }
- if (empty($courseId)) {
- return api_get_path(WEB_CODE_PATH).'session/index.php?session_id='.$id;
- } else {
- $courseInfo = api_get_course_info_by_id($courseId);
- if ($courseInfo) {
- return $courseInfo['course_public_url'].'?id_session='.$id;
- }
- }
- return false;
- }
- /**
- * Return an associative array 'id_course' => [id_session1, id_session2...]
- * where course id_course is in sessions id_session1, id_session2
- * for course where user is coach
- * i.e. coach for the course or
- * main coach for a session the course is in
- * for a session category (or woth no session category if empty).
- *
- * @param int $userId
- *
- * @return array
- */
- public static function getSessionCourseForUser($userId)
- {
- // list of COURSES where user is COURSE session coach
- $listCourseCourseCoachSession = self::getCoursesForCourseSessionCoach($userId);
- // list of courses where user is MAIN session coach
- $listCourseMainCoachSession = self::getCoursesForMainSessionCoach($userId);
- // merge these 2 array
- $listResCourseSession = $listCourseCourseCoachSession;
- foreach ($listCourseMainCoachSession as $courseId2 => $listSessionId2) {
- if (isset($listResCourseSession[$courseId2])) {
- // if sessionId array exists for this course
- // same courseId, merge the list of session
- foreach ($listCourseMainCoachSession[$courseId2] as $i => $sessionId2) {
- if (!in_array($sessionId2, $listResCourseSession[$courseId2])) {
- $listResCourseSession[$courseId2][] = $sessionId2;
- }
- }
- } else {
- $listResCourseSession[$courseId2] = $listSessionId2;
- }
- }
- return $listResCourseSession;
- }
- /**
- * Return an associative array 'id_course' => [id_session1, id_session2...]
- * where course id_course is in sessions id_session1, id_session2.
- *
- * @param int $userId
- *
- * @return array
- */
- public static function getCoursesForCourseSessionCoach($userId)
- {
- $userId = (int) $userId;
- $listResCourseSession = [];
- $tblCourse = Database::get_main_table(TABLE_MAIN_COURSE);
- $tblSessionRelCourseRelUser = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $sql = "SELECT session_id, c_id, c.id
- FROM $tblSessionRelCourseRelUser srcru
- LEFT JOIN $tblCourse c
- ON c.id = srcru.c_id
- WHERE
- srcru.user_id = $userId AND
- srcru.status = 2";
- $res = Database::query($sql);
- while ($data = Database::fetch_assoc($res)) {
- if (api_get_session_visibility($data['session_id'])) {
- if (!isset($listResCourseSession[$data['id']])) {
- $listResCourseSession[$data['id']] = [];
- }
- $listResCourseSession[$data['id']][] = $data['session_id'];
- }
- }
- return $listResCourseSession;
- }
- /**
- * Return an associative array 'id_course' => [id_session1, id_session2...]
- * where course id_course is in sessions id_session1, id_session2.
- *
- * @param $userId
- *
- * @return array
- */
- public static function getCoursesForMainSessionCoach($userId)
- {
- $userId = (int) $userId;
- $listResCourseSession = [];
- $tblSession = Database::get_main_table(TABLE_MAIN_SESSION);
- // list of SESSION where user is session coach
- $sql = "SELECT id FROM $tblSession
- WHERE id_coach = ".$userId;
- $res = Database::query($sql);
- while ($data = Database::fetch_assoc($res)) {
- $sessionId = $data['id'];
- $listCoursesInSession = self::getCoursesInSession($sessionId);
- foreach ($listCoursesInSession as $i => $courseId) {
- if (api_get_session_visibility($sessionId)) {
- if (!isset($listResCourseSession[$courseId])) {
- $listResCourseSession[$courseId] = [];
- }
- $listResCourseSession[$courseId][] = $sessionId;
- }
- }
- }
- return $listResCourseSession;
- }
- /**
- * Return an array of course_id used in session $sessionId.
- *
- * @param $sessionId
- *
- * @return array
- */
- public static function getCoursesInSession($sessionId)
- {
- if (empty($sessionId)) {
- return [];
- }
- $tblSessionRelCourse = Database::get_main_table(TABLE_MAIN_SESSION_COURSE);
- $tblCourse = Database::get_main_table(TABLE_MAIN_COURSE);
- // list of course in this session
- $sql = "SELECT session_id, c.id
- FROM $tblSessionRelCourse src
- LEFT JOIN $tblCourse c
- ON c.id = src.c_id
- WHERE session_id = ".intval($sessionId);
- $res = Database::query($sql);
- $listResultsCourseId = [];
- while ($data = Database::fetch_assoc($res)) {
- $listResultsCourseId[] = $data['id'];
- }
- return $listResultsCourseId;
- }
- /**
- * Return an array of courses in session for user
- * and for each courses the list of session that use this course for user.
- *
- * [0] => array
- * userCatId
- * userCatTitle
- * courseInUserCatList
- * [0] => array
- * courseId
- * title
- * courseCode
- * sessionCatList
- * [0] => array
- * catSessionId
- * catSessionName
- * sessionList
- * [0] => array
- * sessionId
- * sessionName
- *
- * @param int $userId
- *
- * @return array
- */
- public static function getNamedSessionCourseForCoach($userId)
- {
- $listResults = [];
- $listCourseSession = self::getSessionCourseForUser($userId);
- foreach ($listCourseSession as $courseId => $listSessionId) {
- // Course info
- $courseInfo = api_get_course_info_by_id($courseId);
- $listOneCourse = [];
- $listOneCourse['courseId'] = $courseId;
- $listOneCourse['title'] = $courseInfo['title'];
- //$listOneCourse['courseCode'] = $courseInfo['code'];
- $listOneCourse['course'] = $courseInfo;
- $listOneCourse['sessionCatList'] = [];
- $listCat = [];
- foreach ($listSessionId as $i => $sessionId) {
- // here we got all session for this course
- // lets check there session categories
- $sessionInfo = self::fetch($sessionId);
- $catId = $sessionInfo['session_category_id'];
- if (!isset($listCat[$catId])) {
- $listCatInfo = self::get_session_category($catId);
- $listCat[$catId] = [];
- $listCat[$catId]['catSessionId'] = $catId;
- $listCat[$catId]['catSessionName'] = $listCatInfo['name'];
- $listCat[$catId]['sessionList'] = [];
- }
- $listSessionInfo = self::fetch($sessionId);
- $listSessionIdName = [
- 'sessionId' => $sessionId,
- 'sessionName' => $listSessionInfo['name'],
- ];
- $listCat[$catId]['sessionList'][] = $listSessionIdName;
- }
- // sort $listCat by catSessionName
- usort($listCat, 'self::compareBySessionName');
- // in each catSession sort sessionList by sessionName
- foreach ($listCat as $i => $listCatSessionInfo) {
- $listSessionList = $listCatSessionInfo['sessionList'];
- usort($listSessionList, 'self::compareCatSessionInfo');
- $listCat[$i]['sessionList'] = $listSessionList;
- }
- $listOneCourse['sessionCatList'] = $listCat;
- // user course category
- $courseCategory = CourseManager::getUserCourseCategoryForCourse(
- $userId,
- $courseId
- );
- $userCatTitle = '';
- $userCatId = 0;
- if ($courseCategory) {
- $userCatId = $courseCategory['user_course_cat'];
- $userCatTitle = $courseCategory['title'];
- }
- $listResults[$userCatId]['courseInUserCategoryId'] = $userCatId;
- $listResults[$userCatId]['courseInUserCategoryTitle'] = $userCatTitle;
- $listResults[$userCatId]['courseInUserCatList'][] = $listOneCourse;
- }
- // sort by user course cat
- uasort($listResults, 'self::compareByUserCourseCat');
- // sort by course title
- foreach ($listResults as $userCourseCatId => $tabCoursesInCat) {
- $courseInUserCatList = $tabCoursesInCat['courseInUserCatList'];
- uasort($courseInUserCatList, 'self::compareByCourse');
- $listResults[$userCourseCatId]['courseInUserCatList'] = $courseInUserCatList;
- }
- return $listResults;
- }
- /**
- * @param int $userId
- * @param int $courseId
- *
- * @return array
- */
- public static function searchCourseInSessionsFromUser($userId, $courseId)
- {
- $table = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
- $userId = (int) $userId;
- $courseId = (int) $courseId;
- if (empty($userId) || empty($courseId)) {
- return [];
- }
- $sql = "SELECT * FROM $table
- WHERE c_id = $courseId AND user_id = $userId";
- $result = Database::query($sql);
- return Database::store_result($result, 'ASSOC');
- }
- /**
- * Subscribe and redirect to session after inscription.
- */
- public static function redirectToSession()
- {
- $sessionId = (int) ChamiloSession::read('session_redirect');
- $onlyOneCourseSessionToRedirect = ChamiloSession::read('only_one_course_session_redirect');
- if ($sessionId) {
- $sessionInfo = api_get_session_info($sessionId);
- if (!empty($sessionInfo)) {
- $userId = api_get_user_id();
- $response = self::isUserSubscribedAsStudent($sessionId, $userId);
- if ($response) {
- $urlToRedirect = api_get_path(WEB_CODE_PATH).'session/index.php?session_id='.$sessionId;
- if (!empty($onlyOneCourseSessionToRedirect)) {
- $urlToRedirect = api_get_path(WEB_PATH).
- 'courses/'.$onlyOneCourseSessionToRedirect.'/index.php?id_session='.$sessionId;
- }
- header('Location: '.$urlToRedirect);
- exit;
- }
- }
- }
- }
- /**
- * @param Course $course
- * @param Session $session
- *
- * @return int
- */
- public static function getCountUsersInCourseSession(
- Course $course,
- Session $session
- ) {
- return Database::getManager()
- ->createQuery("
- SELECT COUNT(scu)
- FROM ChamiloCoreBundle:SessionRelCourseRelUser scu
- INNER JOIN ChamiloCoreBundle:SessionRelUser su
- WITH scu.user = su.user
- AND scu.session = su.session
- WHERE
- scu.course = :course AND
- su.relationType <> :relationType AND
- scu.session = :session
- ")
- ->setParameters([
- 'course' => $course->getId(),
- 'relationType' => SESSION_RELATION_TYPE_RRHH,
- 'session' => $session->getId(),
- ])
- ->getSingleScalarResult();
- }
- /**
- * Get course IDs where user in not subscribed in session.
- *
- * @param User $user
- * @param Session $session
- *
- * @return array
- */
- public static function getAvoidedCoursesInSession(User $user, Session $session)
- {
- $courseIds = [];
- /** @var SessionRelCourse $sessionCourse */
- foreach ($session->getCourses() as $sessionCourse) {
- /** @var Course $course */
- $course = $sessionCourse->getCourse();
- if ($session->getUserInCourse($user, $course)->count()) {
- continue;
- }
- $courseIds[] = $course->getId();
- }
- return $courseIds;
- }
- /**
- * @param int $userId
- * @param int $sessionId
- * @param ExtraFieldValue $extraFieldValue
- * @param string $collapsableLink
- *
- * @return array
- */
- public static function getCollapsableData($userId, $sessionId, $extraFieldValue, $collapsableLink)
- {
- $collapsed = 0;
- // Get default collapsed value in extra field
- $value = $extraFieldValue->get_values_by_handler_and_field_variable($sessionId, 'collapsed');
- if (!empty($value) && isset($value['value'])) {
- $collapsed = $value['value'];
- }
- $userRelSession = self::getUserSession($userId, $sessionId);
- if ($userRelSession) {
- if (isset($userRelSession['collapsed']) && $userRelSession['collapsed'] != '') {
- $collapsed = $userRelSession['collapsed'];
- }
- } else {
- return ['collapsed' => $collapsed, 'collapsable_link' => ' '];
- }
- $link = $collapsableLink.'&session_id='.$sessionId.'&value=1';
- $image = '<i class="fa fa-folder-open"></i>';
- if ($collapsed == 1) {
- $link = $collapsableLink.'&session_id='.$sessionId.'&value=0';
- $image = '<i class="fa fa-folder"></i>';
- }
- $link = Display::url(
- $image,
- $link
- );
- return ['collapsed' => $collapsed, 'collapsable_link' => $link];
- }
- /**
- * Converts "start date" and "end date" to "From start date to end date" string.
- *
- * @param string $startDate
- * @param string $endDate
- * @param bool $showTime
- * @param bool $dateHuman
- *
- * @return string
- */
- public static function convertSessionDateToString($startDate, $endDate, $showTime, $dateHuman)
- {
- // api_get_local_time returns empty if date is invalid like 0000-00-00 00:00:00
- $startDateToLocal = api_get_local_time(
- $startDate,
- null,
- null,
- true,
- $showTime,
- $dateHuman
- );
- $endDateToLocal = api_get_local_time(
- $endDate,
- null,
- null,
- true,
- $showTime,
- $dateHuman
- );
- $format = $showTime ? DATE_TIME_FORMAT_LONG_24H : DATE_FORMAT_LONG_NO_DAY;
- $result = '';
- if (!empty($startDateToLocal) && !empty($endDateToLocal)) {
- $result = sprintf(
- get_lang('From %s to %s'),
- api_format_date($startDateToLocal, $format),
- api_format_date($endDateToLocal, $format)
- );
- } else {
- if (!empty($startDateToLocal)) {
- $result = get_lang('From').' '.api_format_date($startDateToLocal, $format);
- }
- if (!empty($endDateToLocal)) {
- $result = get_lang('Until').' '.api_format_date($endDateToLocal, $format);
- }
- }
- if (empty($result)) {
- $result = get_lang('No time limits');
- }
- return $result;
- }
- /**
- * @param int $id
- *
- * @return string
- */
- public static function getSessionChangeUserReason($id): string
- {
- $reasons = self::getSessionChangeUserReasons();
- return $reasons[$id] ?? '';
- }
- /**
- * @return array
- */
- public static function getSessionChangeUserReasons(): array
- {
- return [
- self::SESSION_CHANGE_USER_REASON_SCHEDULE => get_lang('ScheduleChanged'),
- self::SESSION_CHANGE_USER_REASON_CLASSROOM => get_lang('ClassRoomChanged'),
- self::SESSION_CHANGE_USER_REASON_LOCATION => get_lang('LocationChanged'),
- //self::SESSION_CHANGE_USER_REASON_ENROLLMENT_ANNULATION => get_lang('EnrollmentAnnulation'),
- ];
- }
- /**
- * @param int $id
- *
- * @return bool
- */
- private static function allowed($id)
- {
- $sessionInfo = self::fetch($id);
- if (empty($sessionInfo)) {
- return false;
- }
- if (api_is_platform_admin()) {
- return true;
- }
- $userId = api_get_user_id();
- if (api_is_session_admin() &&
- api_get_setting('allow_session_admins_to_manage_all_sessions') != 'true'
- ) {
- if ($sessionInfo['session_admin_id'] != $userId) {
- return false;
- }
- }
- if (api_is_teacher() &&
- api_get_setting('allow_teachers_to_create_sessions') == 'true'
- ) {
- if ($sessionInfo['id_coach'] != $userId) {
- return false;
- }
- }
- return true;
- }
- /**
- * Add classes (by their names) to a session.
- *
- * @param int $sessionId
- * @param array $classesNames
- * @param bool $deleteClassSessions Optional. Empty the session list for the usergroup (class)
- */
- private static function addClassesByName($sessionId, $classesNames, $deleteClassSessions = true)
- {
- if (!$classesNames) {
- return;
- }
- $usergroup = new UserGroup();
- foreach ($classesNames as $className) {
- if (empty($className)) {
- continue;
- }
- $usergroup->subscribe_sessions_to_usergroup(
- $usergroup->getIdByName($className),
- [$sessionId],
- $deleteClassSessions
- );
- }
- }
- /**
- * @param array $listA
- * @param array $listB
- *
- * @return int
- */
- private static function compareCatSessionInfo($listA, $listB)
- {
- if ($listA['sessionName'] == $listB['sessionName']) {
- return 0;
- } elseif ($listA['sessionName'] > $listB['sessionName']) {
- return 1;
- } else {
- return -1;
- }
- }
- /**
- * @param array $listA
- * @param array $listB
- *
- * @return int
- */
- private static function compareBySessionName($listA, $listB)
- {
- if ($listB['catSessionName'] == '') {
- return -1;
- } elseif ($listA['catSessionName'] == '') {
- return 1;
- } elseif ($listA['catSessionName'] == $listB['catSessionName']) {
- return 0;
- } elseif ($listA['catSessionName'] > $listB['catSessionName']) {
- return 1;
- } else {
- return -1;
- }
- }
- /**
- * @param array $listA
- * @param array $listB
- *
- * @return int
- */
- private static function compareByUserCourseCat($listA, $listB)
- {
- if ($listA['courseInUserCategoryTitle'] == $listB['courseInUserCategoryTitle']) {
- return 0;
- } elseif ($listA['courseInUserCategoryTitle'] > $listB['courseInUserCategoryTitle']) {
- return 1;
- } else {
- return -1;
- }
- }
- /**
- * @param array $listA
- * @param array $listB
- *
- * @return int
- */
- private static function compareByCourse($listA, $listB)
- {
- if ($listA['title'] == $listB['title']) {
- return 0;
- } elseif ($listA['title'] > $listB['title']) {
- return 1;
- } else {
- return -1;
- }
- }
- }
|