1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * Class DocumentManager
- * This is the document library for Chamilo.
- * It is / will be used to provide a service layer to all document-using tools.
- * and eliminate code duplication fro group documents, scorm documents, main documents.
- * Include/require it in your code to use its functionality.
- *
- * @package chamilo.library
- */
- class DocumentManager
- {
- /**
- * Construct
- */
- private function __construct()
- {
- }
- /**
- * @param string $course_code
- *
- * @return int the document folder quota for the current course in bytes
- * or the default quota
- */
- public static function get_course_quota($course_code = null)
- {
- if (empty($course_code)) {
- $course_info = api_get_course_info();
- } else {
- $course_info = api_get_course_info($course_code);
- }
- $course_quota = null;
- if (empty($course_info)) {
- return DEFAULT_DOCUMENT_QUOTA;
- } else {
- $course_quota = $course_info['disk_quota'];
- }
- if (is_null($course_quota) || empty($course_quota)) {
- // Course table entry for quota was null, then use default value
- $course_quota = DEFAULT_DOCUMENT_QUOTA;
- }
- return $course_quota;
- }
- /**
- * Get the content type of a file by checking the extension
- * We could use mime_content_type() with php-versions > 4.3,
- * but this doesn't work as it should on Windows installations
- *
- * @param string $filename or boolean TRUE to return complete array
- * @author ? first version
- * @author Bert Vanderkimpen
- * @return string
- *
- */
- public static function file_get_mime_type($filename)
- {
- // All MIME types in an array (from 1.6, this is the authorative source)
- // Please, keep this alphabetical if you add something to this list!
- $mime_types = array(
- 'ai' => 'application/postscript',
- 'aif' => 'audio/x-aiff',
- 'aifc' => 'audio/x-aiff',
- 'aiff' => 'audio/x-aiff',
- 'asf' => 'video/x-ms-asf',
- 'asc' => 'text/plain',
- 'au' => 'audio/basic',
- 'avi' => 'video/x-msvideo',
- 'bcpio' => 'application/x-bcpio',
- 'bin' => 'application/octet-stream',
- 'bmp' => 'image/bmp',
- 'cdf' => 'application/x-netcdf',
- 'class' => 'application/octet-stream',
- 'cpio' => 'application/x-cpio',
- 'cpt' => 'application/mac-compactpro',
- 'csh' => 'application/x-csh',
- 'css' => 'text/css',
- 'dcr' => 'application/x-director',
- 'dir' => 'application/x-director',
- 'djv' => 'image/vnd.djvu',
- 'djvu' => 'image/vnd.djvu',
- 'dll' => 'application/octet-stream',
- 'dmg' => 'application/x-diskcopy',
- 'dms' => 'application/octet-stream',
- 'doc' => 'application/msword',
- 'docm' => 'application/vnd.ms-word.document.macroEnabled.12',
- 'docx' => 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
- 'dotx' => 'application/vnd.openxmlformats-officedocument.wordprocessingml.template',
- 'dvi' => 'application/x-dvi',
- 'dwg' => 'application/vnd.dwg',
- 'dwf' => 'application/vnd.dwf',
- 'dxf' => 'application/vnd.dxf',
- 'dxr' => 'application/x-director',
- 'eps' => 'application/postscript',
- 'epub' => 'application/epub+zip',
- 'etx' => 'text/x-setext',
- 'exe' => 'application/octet-stream',
- 'ez' => 'application/andrew-inset',
- 'gif' => 'image/gif',
- 'gtar' => 'application/x-gtar',
- 'gz' => 'application/x-gzip',
- 'hdf' => 'application/x-hdf',
- 'hqx' => 'application/mac-binhex40',
- 'htm' => 'text/html',
- 'html' => 'text/html',
- 'ice' => 'x-conference-xcooltalk',
- 'ief' => 'image/ief',
- 'iges' => 'model/iges',
- 'igs' => 'model/iges',
- 'jar' => 'application/java-archiver',
- 'jpe' => 'image/jpeg',
- 'jpeg' => 'image/jpeg',
- 'jpg' => 'image/jpeg',
- 'js' => 'application/x-javascript',
- 'kar' => 'audio/midi',
- 'lam' => 'application/vnd.ms-excel.addin.macroEnabled.12',
- 'latex' => 'application/x-latex',
- 'lha' => 'application/octet-stream',
- 'log' => 'text/plain',
- 'lzh' => 'application/octet-stream',
- 'm1a' => 'audio/mpeg',
- 'm2a' => 'audio/mpeg',
- 'm3u' => 'audio/x-mpegurl',
- 'man' => 'application/x-troff-man',
- 'me' => 'application/x-troff-me',
- 'mesh' => 'model/mesh',
- 'mid' => 'audio/midi',
- 'midi' => 'audio/midi',
- 'mov' => 'video/quicktime',
- 'movie' => 'video/x-sgi-movie',
- 'mp2' => 'audio/mpeg',
- 'mp3' => 'audio/mpeg',
- 'mp4' => 'video/mpeg4-generic',
- 'mpa' => 'audio/mpeg',
- 'mpe' => 'video/mpeg',
- 'mpeg' => 'video/mpeg',
- 'mpg' => 'video/mpeg',
- 'mpga' => 'audio/mpeg',
- 'ms' => 'application/x-troff-ms',
- 'msh' => 'model/mesh',
- 'mxu' => 'video/vnd.mpegurl',
- 'nc' => 'application/x-netcdf',
- 'oda' => 'application/oda',
- 'oga' => 'audio/ogg',
- 'ogg' => 'application/ogg',
- 'ogx' => 'application/ogg',
- 'ogv' => 'video/ogg',
- 'pbm' => 'image/x-portable-bitmap',
- 'pct' => 'image/pict',
- 'pdb' => 'chemical/x-pdb',
- 'pdf' => 'application/pdf',
- 'pgm' => 'image/x-portable-graymap',
- 'pgn' => 'application/x-chess-pgn',
- 'pict' => 'image/pict',
- 'png' => 'image/png',
- 'pnm' => 'image/x-portable-anymap',
- 'potm' => 'application/vnd.ms-powerpoint.template.macroEnabled.12',
- 'potx' => 'application/vnd.openxmlformats-officedocument.presentationml.template',
- 'pps' => 'application/vnd.ms-powerpoint',
- 'ppam' => 'application/vnd.ms-powerpoint.addin.macroEnabled.12',
- 'ppsm' => 'application/vnd.ms-powerpoint.slideshow.macroEnabled.12',
- 'ppsx' => 'application/vnd.openxmlformats-officedocument.presentationml.slideshow',
- 'pptm' => 'application/vnd.ms-powerpoint.presentation.macroEnabled.12',
- 'pptx' => 'application/vnd.openxmlformats-officedocument.presentationml.presentation',
- 'ppm' => 'image/x-portable-pixmap',
- 'ppt' => 'application/vnd.ms-powerpoint',
- 'pps' => 'application/vnd.ms-powerpoint',
- 'ps' => 'application/postscript',
- 'qt' => 'video/quicktime',
- 'ra' => 'audio/x-realaudio',
- 'ram' => 'audio/x-pn-realaudio',
- 'rar' => 'image/x-rar-compressed',
- 'ras' => 'image/x-cmu-raster',
- 'rgb' => 'image/x-rgb',
- 'rm' => 'audio/x-pn-realaudio',
- 'roff' => 'application/x-troff',
- 'rpm' => 'audio/x-pn-realaudio-plugin',
- 'rtf' => 'text/rtf',
- 'rtx' => 'text/richtext',
- 'sgm' => 'text/sgml',
- 'sgml' => 'text/sgml',
- 'sh' => 'application/x-sh',
- 'shar' => 'application/x-shar',
- 'silo' => 'model/mesh',
- 'sib' => 'application/X-Sibelius-Score',
- 'sit' => 'application/x-stuffit',
- 'skd' => 'application/x-koan',
- 'skm' => 'application/x-koan',
- 'skp' => 'application/x-koan',
- 'skt' => 'application/x-koan',
- 'smi' => 'application/smil',
- 'smil' => 'application/smil',
- 'snd' => 'audio/basic',
- 'so' => 'application/octet-stream',
- 'spl' => 'application/x-futuresplash',
- 'src' => 'application/x-wais-source',
- 'sv4cpio' => 'application/x-sv4cpio',
- 'sv4crc' => 'application/x-sv4crc',
- 'svf' => 'application/vnd.svf',
- 'svg' => 'image/svg+xml',
- //'svgz' => 'image/svg+xml',
- 'swf' => 'application/x-shockwave-flash',
- 'sxc' => 'application/vnd.sun.xml.calc',
- 'sxi' => 'application/vnd.sun.xml.impress',
- 'sxw' => 'application/vnd.sun.xml.writer',
- 't' => 'application/x-troff',
- 'tar' => 'application/x-tar',
- 'tcl' => 'application/x-tcl',
- 'tex' => 'application/x-tex',
- 'texi' => 'application/x-texinfo',
- 'texinfo' => 'application/x-texinfo',
- 'tga' => 'image/x-targa',
- 'tif' => 'image/tif',
- 'tiff' => 'image/tiff',
- 'tr' => 'application/x-troff',
- 'tsv' => 'text/tab-seperated-values',
- 'txt' => 'text/plain',
- 'ustar' => 'application/x-ustar',
- 'vcd' => 'application/x-cdlink',
- 'vrml' => 'model/vrml',
- 'wav' => 'audio/x-wav',
- 'wbmp' => 'image/vnd.wap.wbmp',
- 'wbxml' => 'application/vnd.wap.wbxml',
- 'wml' => 'text/vnd.wap.wml',
- 'wmlc' => 'application/vnd.wap.wmlc',
- 'wmls' => 'text/vnd.wap.wmlscript',
- 'wmlsc' => 'application/vnd.wap.wmlscriptc',
- 'wma' => 'audio/x-ms-wma',
- 'wmv' => 'video/x-ms-wmv',
- 'wrl' => 'model/vrml',
- 'xbm' => 'image/x-xbitmap',
- 'xht' => 'application/xhtml+xml',
- 'xhtml' => 'application/xhtml+xml',
- 'xls' => 'application/vnd.ms-excel',
- 'xlsb' => 'application/vnd.ms-excel.sheet.binary.macroEnabled.12',
- 'xlsm' => 'application/vnd.ms-excel.sheet.macroEnabled.12',
- 'xlsx' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
- 'xltm' => 'application/vnd.ms-excel.template.macroEnabled.12',
- 'xltx' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.template',
- 'xml' => 'text/xml',
- 'xpm' => 'image/x-xpixmap',
- 'xsl' => 'text/xml',
- 'xwd' => 'image/x-windowdump',
- 'xyz' => 'chemical/x-xyz',
- 'zip' => 'application/zip'
- );
- if ($filename === true) {
- return $mime_types;
- }
- //get the extension of the file
- $extension = explode('.', $filename);
- //$filename will be an array if a . was found
- if (is_array($extension)) {
- $extension = strtolower($extension[sizeof($extension) - 1]);
- } else {
- //file without extension
- $extension = 'empty';
- }
- //if the extension is found, return the content type
- if (isset($mime_types[$extension])) {
- return $mime_types[$extension];
- }
- //else return octet-stream
- return 'application/octet-stream';
- }
- /**
- * @param string
- * @param string
- * @return true if the user is allowed to see the document, false otherwise
- * @author Sergio A Kessler, first version
- * @author Roan Embrechts, bugfix
- * @todo not only check if a file is visible, but also check if the user is allowed to see the file??
- */
- public static function file_visible_to_user($this_course, $doc_url)
- {
- $is_allowed_to_edit = api_is_allowed_to_edit(null, true);
- if ($is_allowed_to_edit) {
- return true;
- } else {
- $tbl_document = Database::get_course_table(TABLE_DOCUMENT);
- $tbl_item_property = $this_course.'item_property';
- $doc_url = Database::escape_string($doc_url);
- $query = "SELECT 1 FROM $tbl_document AS docs,$tbl_item_property AS props
- WHERE
- props.tool = 'document' AND
- docs.id=props.ref AND
- props.visibility <> '1' AND
- docs.path = '$doc_url'";
- $result = Database::query($query);
- return Database::num_rows($result) == 0;
- }
- }
- /**
- * This function streams a file to the client
- *
- * @param string $full_file_name
- * @param boolean $forced
- * @param string $name
- * @param string $fixLinksHttpToHttps change file content from http to https
- *
- * @return false if file doesn't exist, true if stream succeeded
- */
- public static function file_send_for_download(
- $full_file_name,
- $forced = false,
- $name = '',
- $fixLinksHttpToHttps = false
- ) {
- session_write_close(); //we do not need write access to session anymore
- if (!is_file($full_file_name)) {
- return false;
- }
- $filename = ($name == '') ? basename($full_file_name) : api_replace_dangerous_char($name);
- $len = filesize($full_file_name);
- // Fixing error when file name contains a ","
- $filename = str_replace(',', '', $filename);
- $sendFileHeaders = api_get_configuration_value('enable_x_sendfile_headers');
- if ($forced) {
- // Force the browser to save the file instead of opening it
- if (isset($sendFileHeaders) &&
- !empty($sendFileHeaders)) {
- header("X-Sendfile: $filename");
- }
- header('Content-type: application/octet-stream');
- header('Content-length: '.$len);
- if (preg_match("/MSIE 5.5/", $_SERVER['HTTP_USER_AGENT'])) {
- header('Content-Disposition: filename= '.$filename);
- } else {
- header('Content-Disposition: attachment; filename= '.$filename);
- }
- if (strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE')) {
- header('Pragma: ');
- header('Cache-Control: ');
- header('Cache-Control: public'); // IE cannot download from sessions without a cache
- }
- header('Content-Description: '.$filename);
- header('Content-Transfer-Encoding: binary');
- $res = fopen($full_file_name, 'r');
- fpassthru($res);
- return true;
- } else {
- //no forced download, just let the browser decide what to do according to the mimetype
- $content_type = self::file_get_mime_type($filename);
- $lpFixedEncoding = api_get_configuration_value('lp_fixed_encoding');
- // Commented to let courses content to be cached in order to improve performance:
- //header('Expires: Wed, 01 Jan 1990 00:00:00 GMT');
- //header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT');
- // Commented to avoid double caching declaration when playing with IE and HTTPS
- //header('Cache-Control: no-cache, must-revalidate');
- //header('Pragma: no-cache');
- switch ($content_type) {
- case 'text/html':
- if (isset($lpFixedEncoding) && $lpFixedEncoding === 'true') {
- $content_type .= '; charset=UTF-8';
- } else {
- $encoding = @api_detect_encoding_html(file_get_contents($full_file_name));
- if (!empty($encoding)) {
- $content_type .= '; charset='.$encoding;
- }
- }
- break;
- case 'text/plain':
- if (isset($lpFixedEncoding) && $lpFixedEncoding === 'true') {
- $content_type .= '; charset=UTF-8';
- } else {
- $encoding = @api_detect_encoding(strip_tags(file_get_contents($full_file_name)));
- if (!empty($encoding)) {
- $content_type .= '; charset='.$encoding;
- }
- }
- break;
- case 'application/vnd.dwg':
- case 'application/vnd.dwf':
- header('Content-type: application/octet-stream');
- break;
- }
- header('Content-type: '.$content_type);
- header('Content-Length: '.$len);
- $user_agent = strtolower($_SERVER['HTTP_USER_AGENT']);
- if (strpos($user_agent, 'msie')) {
- header('Content-Disposition: ; filename= '.$filename);
- } else {
- header('Content-Disposition: inline; filename= '.$filename);
- }
- if ($fixLinksHttpToHttps) {
- $content = file_get_contents($full_file_name);
- $content = str_replace(
- array('http%3A%2F%2F', 'http://'),
- array('https%3A%2F%2F', 'https://'),
- $content
- );
- echo $content;
- } else {
- readfile($full_file_name);
- }
- return true;
- }
- }
- /**
- * This function streams a string to the client for download.
- * You have to ensure that the calling script then stops processing (exit();)
- * otherwise it may cause subsequent use of the page to want to download
- * other pages in php rather than interpreting them.
- *
- * @param string $full_string The string contents
- * @param boolean $forced Whether "save" mode is forced (or opening directly authorized)
- * @param string $name The name of the file in the end (including extension)
- *
- * @return false if file doesn't exist, true if stream succeeded
- */
- public static function string_send_for_download($full_string, $forced = false, $name = '')
- {
- $filename = $name;
- $len = strlen($full_string);
- if ($forced) {
- //force the browser to save the file instead of opening it
- header('Content-type: application/octet-stream');
- //header('Content-Type: application/force-download');
- header('Content-length: '.$len);
- if (preg_match("/MSIE 5.5/", $_SERVER['HTTP_USER_AGENT'])) {
- header('Content-Disposition: filename= '.$filename);
- } else {
- header('Content-Disposition: attachment; filename= '.$filename);
- }
- if (strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE')) {
- header('Pragma: ');
- header('Cache-Control: ');
- header('Cache-Control: public'); // IE cannot download from sessions without a cache
- }
- header('Content-Description: '.$filename);
- header('Content-transfer-encoding: binary');
- echo $full_string;
- return true;
- //You have to ensure that the calling script then stops processing (exit();)
- //otherwise it may cause subsequent use of the page to want to download
- //other pages in php rather than interpreting them.
- } else {
- //no forced download, just let the browser decide what to do according to the mimetype
- $content_type = self::file_get_mime_type($filename);
- header('Expires: Wed, 01 Jan 1990 00:00:00 GMT');
- header('Last-Modified: '.gmdate('D, d M Y H:i:s').' GMT');
- header('Cache-Control: no-cache, must-revalidate');
- header('Pragma: no-cache');
- switch ($content_type) {
- case 'text/html':
- $encoding = @api_detect_encoding_html($full_string);
- if (!empty($encoding)) {
- $content_type .= '; charset='.$encoding;
- }
- break;
- case 'text/plain':
- $encoding = @api_detect_encoding(strip_tags($full_string));
- if (!empty($encoding)) {
- $content_type .= '; charset='.$encoding;
- }
- break;
- }
- header('Content-type: '.$content_type);
- header('Content-Length: '.$len);
- $user_agent = strtolower($_SERVER['HTTP_USER_AGENT']);
- if (strpos($user_agent, 'msie')) {
- header('Content-Disposition: ; filename= '.$filename);
- } else {
- header('Content-Disposition: inline; filename= '.$filename);
- }
- echo($full_string);
- //You have to ensure that the calling script then stops processing (exit();)
- //otherwise it may cause subsequent use of the page to want to download
- //other pages in php rather than interpreting them.
- return true;
- }
- }
- /**
- * Session folder filters
- *
- * @param string $path
- * @param int $sessionId
- *
- * @return null|string
- */
- public static function getSessionFolderFilters($path, $sessionId)
- {
- $sessionId = intval($sessionId);
- $condition = null;
- if (!empty($sessionId)) {
- // Chat folder filter
- if ($path == '/chat_files') {
- $condition .= " AND (docs.session_id = '$sessionId') ";
- }
- // share_folder filter
- $condition .= " AND docs.path != '/shared_folder' ";
- }
- return $condition;
- }
- /**
- * Fetches all document data for the given user/group
- *
- * @param array $_course
- * @param string $path
- * @param int $to_group_id iid
- * @param int $to_user_id
- * @param boolean $can_see_invisible
- * @param boolean $search
- * @param int $sessionId
- * @return array with all document data
- */
- public static function get_all_document_data(
- $_course,
- $path = '/',
- $to_group_id = 0,
- $to_user_id = null,
- $can_see_invisible = false,
- $search = false,
- $sessionId = 0
- ) {
- $TABLE_ITEMPROPERTY = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $TABLE_DOCUMENT = Database::get_course_table(TABLE_DOCUMENT);
- $userGroupFilter = '';
- if (!is_null($to_user_id)) {
- $to_user_id = intval($to_user_id);
- $userGroupFilter = "last.to_user_id = $to_user_id";
- if (empty($to_user_id)) {
- $userGroupFilter = " (last.to_user_id = 0 OR last.to_user_id IS NULL) ";
- }
- } else {
- $to_group_id = intval($to_group_id);
- $userGroupFilter = "last.to_group_id = $to_group_id";
- if (empty($to_group_id)) {
- $userGroupFilter = "( last.to_group_id = 0 OR last.to_group_id IS NULL) ";
- }
- }
- // Escape underscores in the path so they don't act as a wildcard
- $originalPath = $path;
- $path = str_replace('_', '\_', $path);
- $visibility_bit = ' <> 2';
- // The given path will not end with a slash, unless it's the root '/'
- // so no root -> add slash
- $added_slash = $path == '/' ? '' : '/';
- // Condition for the session
- $sessionId = $sessionId ?: api_get_session_id();
- $condition_session = " AND (last.session_id = '$sessionId' OR (last.session_id = '0' OR last.session_id IS NULL) )";
- $condition_session .= self::getSessionFolderFilters($originalPath, $sessionId);
- $sharedCondition = null;
- if ($originalPath == '/shared_folder') {
- $students = CourseManager::get_user_list_from_course_code($_course['code'], $sessionId);
- if (!empty($students)) {
- $conditionList = array();
- foreach ($students as $studentId => $studentInfo) {
- $conditionList[] = '/shared_folder/sf_user_'.$studentInfo['user_id'];
- }
- $sharedCondition .= ' AND docs.path IN ("'.implode('","', $conditionList).'")';
- }
- }
- $sql = "SELECT
- docs.id,
- docs.filetype,
- docs.path,
- docs.title,
- docs.comment,
- docs.size,
- docs.readonly,
- docs.session_id,
- last.session_id item_property_session_id,
- last.lastedit_date,
- last.visibility,
- last.insert_user_id
- FROM $TABLE_ITEMPROPERTY AS last
- INNER JOIN $TABLE_DOCUMENT AS docs
- ON (
- docs.id = last.ref AND
- docs.c_id = last.c_id
- )
- WHERE
- last.tool = '".TOOL_DOCUMENT."' AND
- docs.c_id = {$_course['real_id']} AND
- last.c_id = {$_course['real_id']} AND
- docs.path LIKE '".Database::escape_string($path.$added_slash.'%')."' AND
- docs.path NOT LIKE '" . Database::escape_string($path.$added_slash.'%/%')."' AND
- docs.path NOT LIKE '%_DELETED_%' AND
- $userGroupFilter AND
- last.visibility $visibility_bit
- $condition_session
- $sharedCondition
- ";
- $result = Database::query($sql);
- $doc_list = array();
- $document_data = array();
- $is_allowed_to_edit = api_is_allowed_to_edit(null, true);
- $isCoach = api_is_coach();
- if ($result !== false && Database::num_rows($result) != 0) {
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- if ($isCoach) {
- // Looking for course items that are invisible to hide it in the session
- if (in_array($row['id'], array_keys($doc_list))) {
- if ($doc_list[$row['id']]['item_property_session_id'] == 0 &&
- $doc_list[$row['id']]['session_id'] == 0
- ) {
- if ($doc_list[$row['id']]['visibility'] == 0) {
- unset($document_data[$row['id']]);
- continue;
- }
- }
- }
- $doc_list[$row['id']] = $row;
- }
- if (!$isCoach && !$is_allowed_to_edit) {
- $doc_list[] = $row;
- }
- if ($row['filetype'] == 'file' &&
- pathinfo($row['path'], PATHINFO_EXTENSION) == 'html'
- ) {
- // Templates management
- $table_template = Database::get_main_table(TABLE_MAIN_TEMPLATES);
- $sql = "SELECT id FROM $table_template
- WHERE
- course_code = '".$_course['code']."' AND
- user_id = '".api_get_user_id()."' AND
- ref_doc = '".$row['id']."'";
- $template_result = Database::query($sql);
- $row['is_template'] = (Database::num_rows($template_result) > 0) ? 1 : 0;
- }
- $row['basename'] = basename($row['path']);
- // Just filling $document_data.
- $document_data[$row['id']] = $row;
- }
- // Only for the student we filter the results see BT#1652
- if (!$isCoach && !$is_allowed_to_edit) {
- $ids_to_remove = array();
- $my_repeat_ids = $temp = array();
- // Selecting repeated ids
- foreach ($doc_list as $row) {
- if (in_array($row['id'], array_keys($temp))) {
- $my_repeat_ids[] = $row['id'];
- }
- $temp[$row['id']] = $row;
- }
- //@todo use the self::is_visible function
- // Checking visibility in a session
- foreach ($my_repeat_ids as $id) {
- foreach ($doc_list as $row) {
- if ($id == $row['id']) {
- if ($row['visibility'] == 0 && $row['item_property_session_id'] == 0) {
- $delete_repeated[$id] = true;
- }
- if ($row['visibility'] == 0 && $row['item_property_session_id'] != 0) {
- $delete_repeated[$id] = true;
- }
- }
- }
- }
- foreach ($doc_list as $key => $row) {
- if (in_array($row['visibility'], array('0', '2')) &&
- !in_array($row['id'], $my_repeat_ids)
- ) {
- $ids_to_remove[] = $row['id'];
- unset($doc_list[$key]);
- }
- }
- foreach ($document_data as $row) {
- if (in_array($row['id'], $ids_to_remove)) {
- unset($document_data[$row['id']]);
- }
- if (isset($delete_repeated[$row['id']]) && $delete_repeated[$row['id']]) {
- unset($document_data[$row['id']]);
- }
- }
- // Checking parents visibility.
- $final_document_data = array();
- foreach ($document_data as $row) {
- $is_visible = self::check_visibility_tree(
- $row['id'],
- $_course['code'],
- $sessionId,
- api_get_user_id(),
- $to_group_id
- );
- if ($is_visible) {
- $final_document_data[$row['id']] = $row;
- }
- }
- } else {
- $final_document_data = $document_data;
- }
- return $final_document_data;
- } else {
- return false;
- }
- }
- /**
- * Gets the paths of all folders in a course
- * can show all folders (except for the deleted ones) or only visible ones
- *
- * @param array $_course
- * @param int $groupIid iid
- * @param boolean $can_see_invisible
- * @param boolean $getInvisibleList
- * @param string $path current path
- *
- * @return array with paths
- */
- public static function get_all_document_folders(
- $_course,
- $groupIid = 0,
- $can_see_invisible = false,
- $getInvisibleList = false,
- $path = ''
- ) {
- $TABLE_ITEMPROPERTY = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $TABLE_DOCUMENT = Database::get_course_table(TABLE_DOCUMENT);
- $groupIid = intval($groupIid);
- $document_folders = array();
- $students = CourseManager::get_user_list_from_course_code(
- $_course['code'],
- api_get_session_id()
- );
- $conditionList = array();
- if (!empty($students)) {
- foreach ($students as $studentId => $studentInfo) {
- $conditionList[] = '/shared_folder/sf_user_'.$studentInfo['user_id'];
- }
- }
- $groupCondition = " last.to_group_id = $groupIid";
- if (empty($groupIid)) {
- $groupCondition = " (last.to_group_id = 0 OR last.to_group_id IS NULL)";
- }
- $show_users_condition = '';
- if (api_get_setting('show_users_folders') === 'false') {
- $show_users_condition = " AND docs.path NOT LIKE '%shared_folder%'";
- }
- if ($can_see_invisible) {
- // condition for the session
- $session_id = api_get_session_id();
- //$condition_session = api_get_session_condition($session_id, true, false, 'docs.session_id');
- $session_id = $session_id ?: api_get_session_id();
- $condition_session = " AND (last.session_id = '$session_id' OR (last.session_id = '0' OR last.session_id IS NULL) )";
- $condition_session .= self::getSessionFolderFilters($path, $session_id);
- if ($groupIid <> 0) {
- $sql = "SELECT DISTINCT docs.id, path
- FROM $TABLE_ITEMPROPERTY AS last
- INNER JOIN $TABLE_DOCUMENT AS docs
- ON (
- docs.id = last.ref AND
- docs.c_id = last.c_id
- )
- WHERE
- last.tool = '".TOOL_DOCUMENT."' AND
- last.c_id = {$_course['real_id']} AND
- docs.c_id = {$_course['real_id']} AND
- docs.filetype = 'folder' AND
- $groupCondition AND
- docs.path NOT LIKE '%shared_folder%' AND
- docs.path NOT LIKE '%_DELETED_%' AND
- last.visibility <> 2
- $condition_session ";
- } else {
- $sql = "SELECT DISTINCT docs.id, path
- FROM $TABLE_ITEMPROPERTY AS last
- INNER JOIN $TABLE_DOCUMENT AS docs
- ON (
- docs.id = last.ref AND
- docs.c_id = last.c_id
- )
- WHERE
- last.tool = '".TOOL_DOCUMENT."' AND
- last.c_id = {$_course['real_id']} AND
- docs.c_id = {$_course['real_id']} AND
- docs.filetype = 'folder' AND
- docs.path NOT LIKE '%_DELETED_%' AND
- $groupCondition AND
- last.visibility <> 2
- $show_users_condition
- $condition_session
- ";
- }
- $result = Database::query($sql);
- if ($result && Database::num_rows($result) != 0) {
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- if (self::is_folder_to_avoid($row['path'])) {
- continue;
- }
- if (strpos($row['path'], '/shared_folder/') !== false) {
- if (!in_array($row['path'], $conditionList)) {
- continue;
- }
- }
- $document_folders[$row['id']] = $row['path'];
- }
- if (!empty($document_folders)) {
- natsort($document_folders);
- }
- return $document_folders;
- } else {
- return false;
- }
- } else {
- // No invisible folders
- // Condition for the session
- $session_id = api_get_session_id();
- $condition_session = api_get_session_condition(
- $session_id,
- true,
- false,
- 'docs.session_id'
- );
- $visibilityCondition = 'last.visibility = 1';
- $fileType = "docs.filetype = 'folder' AND";
- if ($getInvisibleList) {
- $visibilityCondition = 'last.visibility = 0';
- $fileType = '';
- }
- //get visible folders
- $sql = "SELECT DISTINCT docs.id, path
- FROM
- $TABLE_ITEMPROPERTY AS last
- INNER JOIN $TABLE_DOCUMENT AS docs
- ON (docs.id = last.ref AND last.c_id = docs.c_id)
- WHERE
- $fileType
- last.tool = '".TOOL_DOCUMENT."' AND
- $groupCondition AND
- $visibilityCondition
- $show_users_condition
- $condition_session AND
- last.c_id = {$_course['real_id']} AND
- docs.c_id = {$_course['real_id']} ";
- $result = Database::query($sql);
- $visibleFolders = array();
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- $visibleFolders[$row['id']] = $row['path'];
- }
- if ($getInvisibleList) {
- return $visibleFolders;
- }
- //get invisible folders
- $sql = "SELECT DISTINCT docs.id, path
- FROM $TABLE_ITEMPROPERTY AS last
- INNER JOIN $TABLE_DOCUMENT AS docs
- ON (docs.id = last.ref AND last.c_id = docs.c_id)
- WHERE
- docs.filetype = 'folder' AND
- last.tool = '".TOOL_DOCUMENT."' AND
- $groupCondition AND
- last.visibility = 0 $condition_session AND
- last.c_id = {$_course['real_id']} AND
- docs.c_id = {$_course['real_id']} ";
- $result = Database::query($sql);
- $invisibleFolders = array();
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- //get visible folders in the invisible ones -> they are invisible too
- $sql = "SELECT DISTINCT docs.id, path
- FROM $TABLE_ITEMPROPERTY AS last
- INNER JOIN $TABLE_DOCUMENT AS docs
- ON (docs.id = last.ref AND docs.c_id = last.c_id)
- WHERE
- docs.path LIKE '".Database::escape_string($row['path'].'/%')."' AND
- docs.filetype = 'folder' AND
- last.tool = '" . TOOL_DOCUMENT."' AND
- $groupCondition AND
- last.visibility = 1 $condition_session AND
- last.c_id = {$_course['real_id']} AND
- docs.c_id = {$_course['real_id']} ";
- $folder_in_invisible_result = Database::query($sql);
- while ($folders_in_invisible_folder = Database::fetch_array($folder_in_invisible_result, 'ASSOC')) {
- $invisibleFolders[$folders_in_invisible_folder['id']] = $folders_in_invisible_folder['path'];
- }
- }
- // If both results are arrays -> //calculate the difference between the 2 arrays -> only visible folders are left :)
- if (is_array($visibleFolders) && is_array($invisibleFolders)) {
- $document_folders = array_diff($visibleFolders, $invisibleFolders);
- natsort($document_folders);
- return $document_folders;
- } elseif (is_array($visibleFolders)) {
- natsort($visibleFolders);
- return $visibleFolders;
- } else {
- //no visible folders found
- return false;
- }
- }
- }
- /**
- * This check if a document has the readonly property checked, then see if the user
- * is the owner of this file, if all this is true then return true.
- *
- * @param array $_course
- * @param int $user_id id of the current user
- * @param string $file path stored in the database (if not defined, $documentId must be used)
- * @param int $document_id in case you dont have the file path ,
- * insert the id of the file here and leave $file in blank ''
- * @param bool $to_delete
- * @param int $sessionId
- * @return boolean true/false
- * */
- public static function check_readonly(
- $_course,
- $user_id,
- $file = null,
- $document_id = '',
- $to_delete = false,
- $sessionId = null,
- $documentId = null
- ) {
- if (empty($sessionId)) {
- $sessionId = api_get_session_id();
- } else {
- $sessionId = intval($sessionId);
- }
- if (empty($document_id) || !is_numeric($document_id)) {
- $document_id = self::get_document_id($_course, $file, $sessionId);
- } else {
- $document_id = intval($document_id);
- }
- $TABLE_PROPERTY = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $TABLE_DOCUMENT = Database::get_course_table(TABLE_DOCUMENT);
- $course_id = $_course['real_id'];
- if ($to_delete) {
- if (self::is_folder($_course, $document_id)) {
- if (!empty($file)) {
- $path = Database::escape_string($file);
- // Check
- $sql = "SELECT td.id, readonly, tp.insert_user_id
- FROM $TABLE_DOCUMENT td
- INNER JOIN $TABLE_PROPERTY tp
- ON (td.c_id = tp.c_id AND tp.ref= td.id)
- WHERE
- td.c_id = $course_id AND
- tp.c_id = $course_id AND
- td.session_id = $sessionId AND
- (path='".$path."' OR path LIKE BINARY '".$path."/%' ) ";
- // Get all id's of documents that are deleted
- $what_to_check_result = Database::query($sql);
- if ($what_to_check_result && Database::num_rows($what_to_check_result) != 0) {
- // file with readonly set to 1 exist?
- $readonly_set = false;
- while ($row = Database::fetch_array($what_to_check_result)) {
- //query to delete from item_property table
- if ($row['readonly'] == 1) {
- if (!($row['insert_user_id'] == $user_id)) {
- $readonly_set = true;
- break;
- }
- }
- }
- if ($readonly_set) {
- return true;
- }
- }
- }
- return false;
- }
- }
- if (!empty($document_id)) {
- $sql = "SELECT a.insert_user_id, b.readonly
- FROM $TABLE_PROPERTY a
- INNER JOIN $TABLE_DOCUMENT b
- ON (a.c_id = b.c_id AND a.ref= b.id)
- WHERE
- a.c_id = $course_id AND
- b.c_id = $course_id AND
- a.ref = $document_id
- LIMIT 1";
- $result = Database::query($sql);
- $doc_details = Database::fetch_array($result, 'ASSOC');
- if ($doc_details['readonly'] == 1) {
- return !($doc_details['insert_user_id'] == $user_id || api_is_platform_admin());
- }
- }
- return false;
- }
- /**
- * This check if a document is a folder or not
- * @param array $_course
- * @param int $document_id of the item
- * @return boolean true/false
- * */
- public static function is_folder($_course, $document_id)
- {
- $TABLE_DOCUMENT = Database::get_course_table(TABLE_DOCUMENT);
- $course_id = $_course['real_id'];
- $document_id = intval($document_id);
- $sql = "SELECT filetype FROM $TABLE_DOCUMENT
- WHERE c_id = $course_id AND id= $document_id";
- $result = Database::fetch_array(Database::query($sql), 'ASSOC');
- return $result['filetype'] == 'folder';
- }
- /**
- * @param int $document_id
- * @param array $course_info
- * @param int $session_id
- * @param bool $remove_content_from_db
- */
- public static function deleteDocumentFromDb(
- $document_id,
- $course_info = array(),
- $session_id = 0,
- $remove_content_from_db = false
- ) {
- $TABLE_DOCUMENT = Database::get_course_table(TABLE_DOCUMENT);
- $TABLE_ITEMPROPERTY = Database::get_course_table(TABLE_ITEM_PROPERTY);
- // Deleting from the DB
- $user_id = api_get_user_id();
- $document_id = intval($document_id);
- if (empty($course_info)) {
- $course_info = api_get_course_info();
- }
- if (empty($session_id)) {
- $session_id = api_get_session_id();
- }
- // Soft DB delete
- api_item_property_update(
- $course_info,
- TOOL_DOCUMENT,
- $document_id,
- 'delete',
- $user_id,
- null,
- null,
- null,
- null,
- $session_id
- );
- self::delete_document_from_search_engine($course_info['code'], $document_id);
- self::unset_document_as_template($document_id, $course_info['code'], $user_id);
- //Hard DB delete
- if ($remove_content_from_db) {
- $sql = "DELETE FROM $TABLE_ITEMPROPERTY
- WHERE
- c_id = {$course_info['real_id']} AND
- ref = ".$document_id." AND
- tool='".TOOL_DOCUMENT."'";
- Database::query($sql);
- $sql = "DELETE FROM $TABLE_DOCUMENT
- WHERE c_id = {$course_info['real_id']} AND id = ".$document_id;
- Database::query($sql);
- }
- }
- /**
- * This deletes a document by changing visibility to 2, renaming it to filename_DELETED_#id
- * Files/folders that are inside a deleted folder get visibility 2
- *
- * @param array $_course
- * @param string $path Path stored in the database
- * @param string $base_work_dir Path to the documents folder (if not defined, $documentId must be used)
- * @param int $sessionId The ID of the session, if any
- * @param int $documentId The document id, if available
- * @param int $groupId iid
- * @return boolean true/false
- * @todo now only files/folders in a folder get visibility 2, we should rename them too.
- * @todo We should be able to get rid of this later when using only documentId (check further usage)
- */
- public static function delete_document(
- $_course,
- $path = null,
- $base_work_dir = null,
- $sessionId = null,
- $documentId = null,
- $groupId = 0
- ) {
- $TABLE_DOCUMENT = Database::get_course_table(TABLE_DOCUMENT);
- if (empty($groupId)) {
- $groupId = api_get_group_id();
- } else {
- $groupId = intval($groupId);
- }
- if (empty($sessionId)) {
- $sessionId = api_get_session_id();
- } else {
- $sessionId = intval($sessionId);
- }
- $course_id = $_course['real_id'];
- if (empty($course_id)) {
- return false;
- }
- if (empty($base_work_dir)) {
- return false;
- }
- if (empty($documentId)) {
- $documentId = self::get_document_id($_course, $path, $sessionId);
- $docInfo = self::get_document_data_by_id(
- $documentId,
- $_course['code'],
- false,
- $sessionId
- );
- $path = $docInfo['path'];
- } else {
- $docInfo = self::get_document_data_by_id(
- $documentId,
- $_course['code'],
- false,
- $sessionId
- );
- if (empty($docInfo)) {
- return false;
- }
- $path = $docInfo['path'];
- }
- $documentId = intval($documentId);
- if (empty($path) || empty($docInfo) || empty($documentId)) {
- return false;
- }
- $itemInfo = api_get_item_property_info(
- $_course['real_id'],
- TOOL_DOCUMENT,
- $documentId,
- $sessionId,
- $groupId
- );
- if (empty($itemInfo)) {
- return false;
- }
- // File was already deleted.
- if ($itemInfo['lastedit_type'] == 'DocumentDeleted' ||
- $itemInfo['lastedit_type'] == 'delete' ||
- $itemInfo['visibility'] == 2
- ) {
- return false;
- }
- // Filtering by group.
- if ($itemInfo['to_group_id'] != $groupId) {
- return false;
- }
- $document_exists_in_disk = file_exists($base_work_dir.$path);
- $new_path = $path.'_DELETED_'.$documentId;
- $file_deleted_from_db = false;
- $file_deleted_from_disk = false;
- $file_renamed_from_disk = false;
- if ($documentId) {
- // Deleting doc from the DB.
- self::deleteDocumentFromDb($documentId, $_course, $sessionId);
- // Checking
- // $file_exists_in_db = self::get_document_data_by_id($documentId, $_course['code']);
- $file_deleted_from_db = true;
- }
- // Looking for children.
- if ($docInfo['filetype'] == 'folder') {
- $cleanPath = Database::escape_string($path);
- // Deleted files inside this folder.
- $sql = "SELECT id FROM $TABLE_DOCUMENT
- WHERE
- c_id = $course_id AND
- session_id = $sessionId AND
- path LIKE BINARY '".$cleanPath."/%'";
- // Get all id's of documents that are deleted.
- $result = Database::query($sql);
- if ($result && Database::num_rows($result) != 0) {
- // Recursive delete.
- while ($row = Database::fetch_array($result)) {
- self::delete_document(
- $_course,
- null,
- $base_work_dir,
- $sessionId,
- $row['id'],
- $groupId
- );
- }
- }
- }
- if ($document_exists_in_disk) {
- if (api_get_setting('permanently_remove_deleted_files') === 'true') {
- // Delete documents, do it like this so metadata gets deleted too
- my_delete($base_work_dir.$path);
- // Hard delete.
- self::deleteDocumentFromDb($documentId, $_course, $sessionId, true);
- $file_deleted_from_disk = true;
- } else {
- // Set visibility to 2 and rename file/folder to xxx_DELETED_#id (soft delete)
- if (is_file($base_work_dir.$path) || is_dir($base_work_dir.$path)) {
- if (rename($base_work_dir.$path, $base_work_dir.$new_path)) {
- $new_path = Database::escape_string($new_path);
- $sql = "UPDATE $TABLE_DOCUMENT
- SET path = '".$new_path."'
- WHERE
- c_id = $course_id AND
- session_id = $sessionId AND
- id = ".$documentId;
- Database::query($sql);
- // Soft delete.
- self::deleteDocumentFromDb($documentId, $_course, $sessionId);
- // Change path of sub folders and documents in database.
- $old_item_path = $docInfo['path'];
- $new_item_path = $new_path.substr($old_item_path, strlen($path));
- $new_item_path = Database::escape_string($new_item_path);
- $sql = "UPDATE $TABLE_DOCUMENT
- SET path = '".$new_item_path."'
- WHERE
- c_id = $course_id AND
- session_id = $sessionId AND
- id = ".$documentId;
- Database::query($sql);
- $file_renamed_from_disk = true;
- } else {
- // Couldn't rename - file permissions problem?
- error_log(
- __FILE__.' '.__LINE__.': Error renaming '.$base_work_dir.$path.' to '.$base_work_dir.$new_path.'. This is probably due to file permissions',
- 0
- );
- }
- }
- }
- }
- // Checking inconsistency
- //error_log('Doc status: (1 del db :'.($file_deleted_from_db?'yes':'no').') - (2 del disk: '.($file_deleted_from_disk?'yes':'no').') - (3 ren disk: '.($file_renamed_from_disk?'yes':'no').')');
- if ($file_deleted_from_db && $file_deleted_from_disk ||
- $file_deleted_from_db && $file_renamed_from_disk
- ) {
- return true;
- } else {
- //Something went wrong
- //The file or directory isn't there anymore (on the filesystem)
- // This means it has been removed externally. To prevent a
- // blocking error from happening, we drop the related items from the
- // item_property and the document table.
- error_log(
- __FILE__.' '.__LINE__.': System inconsistency detected. The file or directory '.$base_work_dir.$path.' seems to have been removed from the filesystem independently from the web platform. To restore consistency, the elements using the same path will be removed from the database',
- 0
- );
- return false;
- }
- }
- /**
- * Removes documents from search engine database
- *
- * @param string $course_id Course code
- * @param int $document_id Document id to delete
- */
- public static function delete_document_from_search_engine($course_id, $document_id)
- {
- // remove from search engine if enabled
- if (api_get_setting('search_enabled') === 'true') {
- $tbl_se_ref = Database::get_main_table(TABLE_MAIN_SEARCH_ENGINE_REF);
- $sql = 'SELECT * FROM %s WHERE course_code=\'%s\' AND tool_id=\'%s\' AND ref_id_high_level=%s LIMIT 1';
- $sql = sprintf($sql, $tbl_se_ref, $course_id, TOOL_DOCUMENT, $document_id);
- $res = Database::query($sql);
- if (Database::num_rows($res) > 0) {
- $row2 = Database::fetch_array($res);
- require_once api_get_path(LIBRARY_PATH).'search/ChamiloIndexer.class.php';
- $di = new ChamiloIndexer();
- $di->remove_document((int) $row2['search_did']);
- }
- $sql = 'DELETE FROM %s WHERE course_code=\'%s\' AND tool_id=\'%s\' AND ref_id_high_level=%s LIMIT 1';
- $sql = sprintf($sql, $tbl_se_ref, $course_id, TOOL_DOCUMENT, $document_id);
- Database::query($sql);
- // remove terms from db
- require_once api_get_path(LIBRARY_PATH).'specific_fields_manager.lib.php';
- delete_all_values_for_item($course_id, TOOL_DOCUMENT, $document_id);
- }
- }
- /**
- * Gets the id of a document with a given path
- *
- * @param array $courseInfo
- * @param string $path
- * @param int $sessionId
- * @return int id of document / false if no doc found
- */
- public static function get_document_id($courseInfo, $path, $sessionId = null)
- {
- $table = Database::get_course_table(TABLE_DOCUMENT);
- $courseId = $courseInfo['real_id'];
- if (!isset($sessionId)) {
- $sessionId = api_get_session_id();
- } else {
- $sessionId = intval($sessionId);
- }
- $path = Database::escape_string($path);
- if (!empty($courseId) && !empty($path)) {
- $sql = "SELECT id FROM $table
- WHERE
- c_id = $courseId AND
- path LIKE BINARY '$path' AND
- session_id = $sessionId
- LIMIT 1";
- $result = Database::query($sql);
- if (Database::num_rows($result)) {
- $row = Database::fetch_array($result);
- return intval($row['id']);
- }
- }
- return false;
- }
- /**
- * Gets the document data with a given id
- *
- * @param int $id Document Id (id field in c_document table)
- * @param string $course_code Course code
- * @param bool $load_parents load folder parents.
- * @param int $session_id The session ID,
- * 0 if requires context *out of* session, and null to use global context
- * @return array document content
- */
- public static function get_document_data_by_id(
- $id,
- $course_code,
- $load_parents = false,
- $session_id = null
- ) {
- $course_info = api_get_course_info($course_code);
- $course_id = $course_info['real_id'];
- if (empty($course_info)) {
- return false;
- }
- $session_id = empty($session_id) ? api_get_session_id() : intval($session_id);
- $www = api_get_path(WEB_COURSE_PATH).$course_info['path'].'/document';
- $TABLE_DOCUMENT = Database::get_course_table(TABLE_DOCUMENT);
- $id = intval($id);
- $sessionCondition = api_get_session_condition($session_id, true, true);
- $sql = "SELECT * FROM $TABLE_DOCUMENT
- WHERE c_id = $course_id $sessionCondition AND id = $id";
- $result = Database::query($sql);
- if ($result && Database::num_rows($result) == 1) {
- $row = Database::fetch_array($result, 'ASSOC');
- //@todo need to clarify the name of the URLs not nice right now
- $url_path = urlencode($row['path']);
- $path = str_replace('%2F', '/', $url_path);
- $pathinfo = pathinfo($row['path']);
- $row['url'] = api_get_path(WEB_CODE_PATH).'document/showinframes.php?cidReq='.$course_code.'&id='.$id;
- $row['document_url'] = api_get_path(WEB_CODE_PATH).'document/document.php?cidReq='.$course_code.'&id='.$id;
- $row['absolute_path'] = api_get_path(SYS_COURSE_PATH).$course_info['path'].'/document'.$row['path'];
- $row['absolute_path_from_document'] = '/document'.$row['path'];
- $row['absolute_parent_path'] = api_get_path(SYS_COURSE_PATH).$course_info['path'].'/document'.$pathinfo['dirname'].'/';
- $row['direct_url'] = $www.$path;
- $row['basename'] = basename($row['path']);
- if (dirname($row['path']) == '.') {
- $row['parent_id'] = '0';
- } else {
- $row['parent_id'] = self::get_document_id($course_info, dirname($row['path']), $session_id);
- }
- $parents = array();
- //Use to generate parents (needed for the breadcrumb)
- //@todo sorry but this for is here because there's not a parent_id in the document table so we parsed the path!!
- if ($load_parents) {
- $dir_array = explode('/', $row['path']);
- $dir_array = array_filter($dir_array);
- $array_len = count($dir_array) + 1;
- $real_dir = '';
- for ($i = 1; $i < $array_len; $i++) {
- $real_dir .= '/'.(isset($dir_array[$i]) ? $dir_array[$i] : '');
- $parent_id = self::get_document_id($course_info, $real_dir);
- if ($session_id != 0 && empty($parent_id)) {
- $parent_id = self::get_document_id($course_info, $real_dir, 0);
- }
- if (!empty($parent_id)) {
- $sub_document_data = self::get_document_data_by_id(
- $parent_id,
- $course_code,
- false,
- $session_id
- );
- if ($session_id != 0 and !$sub_document_data) {
- $sub_document_data = self::get_document_data_by_id(
- $parent_id,
- $course_code,
- false,
- 0
- );
- }
- //@todo add visibility here
- $parents[] = $sub_document_data;
- }
- }
- }
- $row['parents'] = $parents;
- return $row;
- }
- return false;
- }
- /**
- * Allow to set a specific document as a new template for CKeditor
- * for a particular user in a particular course
- *
- * @param string $title
- * @param string $description
- * @param int $document_id_for_template the document id
- * @param string $course_code
- * @param int $user_id
- * @param string $image
- * @return bool
- */
- public static function set_document_as_template(
- $title,
- $description,
- $document_id_for_template,
- $course_code,
- $user_id,
- $image
- ) {
- // Database table definition
- $table_template = Database::get_main_table(TABLE_MAIN_TEMPLATES);
- $params = [
- 'title' => $title,
- 'description' => $description,
- 'course_code' => $course_code,
- 'user_id' => $user_id,
- 'ref_doc' => $document_id_for_template,
- 'image' => $image,
- ];
- Database::insert($table_template, $params);
- return true;
- }
- /**
- * Unset a document as template
- *
- * @param int $document_id
- * @param string $course_code
- * @param int $user_id
- */
- public static function unset_document_as_template(
- $document_id,
- $course_code,
- $user_id
- ) {
- $table_template = Database::get_main_table(TABLE_MAIN_TEMPLATES);
- $course_code = Database::escape_string($course_code);
- $user_id = intval($user_id);
- $document_id = intval($document_id);
- $sql = 'SELECT id FROM '.$table_template.'
- WHERE
- course_code="' . $course_code.'" AND
- user_id="' . $user_id.'" AND
- ref_doc="' . $document_id.'"';
- $result = Database::query($sql);
- $template_id = Database::result($result, 0, 0);
- my_delete(api_get_path(SYS_CODE_PATH).'upload/template_thumbnails/'.$template_id.'.jpg');
- $sql = 'DELETE FROM '.$table_template.'
- WHERE
- course_code="' . $course_code.'" AND
- user_id="' . $user_id.'" AND
- ref_doc="' . $document_id.'"';
- Database::query($sql);
- }
- /**
- * Return true if the documentpath have visibility=1 as
- * item_property (you should use the is_visible_by_id)
- *
- * @param string $doc_path the relative complete path of the document
- * @param array $course the _course array info of the document's course
- * @param int
- * @param string
- * @return bool
- */
- public static function is_visible(
- $doc_path,
- $course,
- $session_id = 0,
- $file_type = 'file'
- ) {
- $docTable = Database::get_course_table(TABLE_DOCUMENT);
- $propTable = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $course_id = $course['real_id'];
- //note the extra / at the end of doc_path to match every path in the document table that is part of the document path
- $session_id = intval($session_id);
- $condition = "AND d.session_id IN ('$session_id', '0') ";
- // The " d.filetype='file' " let the user see a file even if the folder is hidden see #2198
- /*
- When using hotpotatoes files, a new html files are generated
- in the hotpotatoes folder to display the test.
- The genuine html file is copied to math4.htm(user_id).t.html
- Images files are not copied, and keep same name.
- To check the html file visibility, we don't have to check file math4.htm(user_id).t.html but file math4.htm
- In this case, we have to remove (user_id).t.html to check the visibility of the file
- For images, we just check the path of the image file.
- Exemple of hotpotatoes folder :
- A.jpg
- maths4-consigne.jpg
- maths4.htm
- maths4.htm1.t.html
- maths4.htm52.t.html
- maths4.htm654.t.html
- omega.jpg
- theta.jpg
- */
- if (strpos($doc_path, 'HotPotatoes_files') && preg_match("/\.t\.html$/", $doc_path)) {
- $doc_path = substr($doc_path, 0, strlen($doc_path) - 7 - strlen(api_get_user_id()));
- }
- if (!in_array($file_type, array('file', 'folder'))) {
- $file_type = 'file';
- }
- $doc_path = Database::escape_string($doc_path).'/';
- $sql = "SELECT visibility
- FROM $docTable d
- INNER JOIN $propTable ip
- ON (d.id = ip.ref AND d.c_id = ip.c_id)
- WHERE
- d.c_id = $course_id AND
- ip.c_id = $course_id AND
- ip.tool = '".TOOL_DOCUMENT."' $condition AND
- filetype = '$file_type' AND
- locate(concat(path,'/'), '$doc_path')=1
- ";
- $result = Database::query($sql);
- $is_visible = false;
- if (Database::num_rows($result) > 0) {
- $row = Database::fetch_array($result, 'ASSOC');
- if ($row['visibility'] == 1) {
- $is_visible = api_is_allowed_in_course() || api_is_platform_admin();
- }
- }
- /* improved protection of documents viewable directly through the url:
- incorporates the same protections of the course at the url of
- documents:
- access allowed for the whole world Open, access allowed for
- users registered on the platform Private access, document accessible
- only to course members (see the Users list), Completely closed;
- the document is only accessible to the course admin and
- teaching assistants.*/
- //return $_SESSION ['is_allowed_in_course'] || api_is_platform_admin();
- return $is_visible;
- }
- /**
- * Return true if user can see a file
- *
- * @param int document id
- * @param array course info
- * @param int
- * @param int
- * @param bool
- * @return bool
- */
- public static function is_visible_by_id(
- $doc_id,
- $course_info,
- $session_id,
- $user_id,
- $admins_can_see_everything = true,
- $userIsSubscribed = null
- ) {
- $user_in_course = false;
- //1. Checking the course array
- if (empty($course_info)) {
- $course_info = api_get_course_info();
- if (empty($course_info)) {
- return false;
- }
- }
- $doc_id = intval($doc_id);
- $session_id = intval($session_id);
- //2. Course and Session visibility are handle in local.inc.php/global.inc.php
- //3. Checking if user exist in course/session
- if ($session_id == 0) {
- if (is_null($userIsSubscribed)) {
- $userIsSubscribed = CourseManager::is_user_subscribed_in_course(
- $user_id,
- $course_info['code']
- );
- }
- if ($userIsSubscribed === true || api_is_platform_admin()) {
- $user_in_course = true;
- }
- // Check if course is open then we can consider that the student is registered to the course
- if (isset($course_info) &&
- in_array(
- $course_info['visibility'],
- array(COURSE_VISIBILITY_OPEN_PLATFORM, COURSE_VISIBILITY_OPEN_WORLD)
- )
- ) {
- $user_in_course = true;
- }
- } else {
- $user_status = SessionManager::get_user_status_in_course_session(
- $user_id,
- $course_info['real_id'],
- $session_id
- );
- if (in_array($user_status, array('0', '2', '6'))) {
- //is true if is an student, course session teacher or coach
- $user_in_course = true;
- }
- if (api_is_platform_admin()) {
- $user_in_course = true;
- }
- }
- // 4. Checking document visibility (i'm repeating the code in order to be more clear when reading ) - jm
- if ($user_in_course) {
- // 4.1 Checking document visibility for a Course
- if ($session_id == 0) {
- $item_info = api_get_item_property_info(
- $course_info['real_id'],
- 'document',
- $doc_id,
- 0
- );
- if (isset($item_info['visibility'])) {
- // True for admins if document exists
- if ($admins_can_see_everything && api_is_platform_admin()) {
- return true;
- }
- if ($item_info['visibility'] == 1) {
- return true;
- }
- }
- } else {
- // 4.2 Checking document visibility for a Course in a Session
- $item_info = api_get_item_property_info(
- $course_info['real_id'],
- 'document',
- $doc_id,
- 0
- );
- $item_info_in_session = api_get_item_property_info(
- $course_info['real_id'],
- 'document',
- $doc_id,
- $session_id
- );
- // True for admins if document exists
- if (isset($item_info['visibility'])) {
- if ($admins_can_see_everything && api_is_platform_admin()) {
- return true;
- }
- }
- if (isset($item_info_in_session['visibility'])) {
- if ($item_info_in_session['visibility'] == 1) {
- return true;
- }
- } else {
- if ($item_info['visibility'] == 1) {
- return true;
- }
- }
- }
- } elseif ($admins_can_see_everything && api_is_platform_admin()) {
- return true;
- }
- return false;
- }
- /**
- * Allow attach a certificate to a course
- * @param string $course_id
- * @param int $document_id
- * @param int $session_id
- * @return void
- */
- public static function attach_gradebook_certificate($course_id, $document_id, $session_id = 0)
- {
- $tbl_category = Database::get_main_table(TABLE_MAIN_GRADEBOOK_CATEGORY);
- $session_id = intval($session_id);
- if (empty($session_id)) {
- $session_id = api_get_session_id();
- }
- if (empty($session_id)) {
- $sql_session = 'AND (session_id = 0 OR isnull(session_id)) ';
- } elseif ($session_id > 0) {
- $sql_session = 'AND session_id='.intval($session_id);
- } else {
- $sql_session = '';
- }
- $sql = 'UPDATE '.$tbl_category.' SET document_id="'.intval($document_id).'"
- WHERE course_code="' . Database::escape_string($course_id).'" '.$sql_session;
- Database::query($sql);
- }
- /**
- * get the document id of default certificate
- * @param string $course_id
- * @param int $session_id
- *
- * @return int The default certificate id
- */
- public static function get_default_certificate_id($course_id, $session_id = 0)
- {
- $tbl_category = Database::get_main_table(TABLE_MAIN_GRADEBOOK_CATEGORY);
- $session_id = intval($session_id);
- if (empty($session_id)) {
- $session_id = api_get_session_id();
- }
- if (empty($session_id)) {
- $sql_session = 'AND (session_id = 0 OR isnull(session_id)) ';
- } elseif ($session_id > 0) {
- $sql_session = 'AND session_id='.intval($session_id);
- } else {
- $sql_session = '';
- }
- $sql = 'SELECT document_id FROM '.$tbl_category.'
- WHERE course_code="' . Database::escape_string($course_id).'" '.$sql_session;
- $rs = Database::query($sql);
- $num = Database::num_rows($rs);
- if ($num == 0) {
- return null;
- }
- $row = Database::fetch_array($rs);
- return $row['document_id'];
- }
- /**
- * Allow replace user info in file html
- * @param int $user_id
- * @param string $course_code
- * @param int $sessionId
- * @param bool $is_preview
- * @return string The html content of the certificate
- */
- public static function replace_user_info_into_html(
- $user_id,
- $course_code,
- $sessionId,
- $is_preview = false
- ) {
- $user_id = intval($user_id);
- $course_info = api_get_course_info($course_code);
- $tbl_document = Database::get_course_table(TABLE_DOCUMENT);
- $course_id = $course_info['real_id'];
- $document_id = self::get_default_certificate_id(
- $course_code,
- $sessionId
- );
- $my_content_html = null;
- if ($document_id) {
- $sql = "SELECT path FROM $tbl_document
- WHERE c_id = $course_id AND id = $document_id";
- $rs = Database::query($sql);
- $new_content = '';
- $all_user_info = array();
- if (Database::num_rows($rs)) {
- $row = Database::fetch_array($rs);
- $filepath = api_get_path(SYS_COURSE_PATH).$course_info['path'].'/document'.$row['path'];
- if (is_file($filepath)) {
- $my_content_html = file_get_contents($filepath);
- }
- $all_user_info = self::get_all_info_to_certificate(
- $user_id,
- $course_code,
- $is_preview
- );
- $info_to_be_replaced_in_content_html = $all_user_info[0];
- $info_to_replace_in_content_html = $all_user_info[1];
- $new_content = str_replace(
- $info_to_be_replaced_in_content_html,
- $info_to_replace_in_content_html,
- $my_content_html
- );
- }
- return [
- 'content' => $new_content,
- 'variables' => $all_user_info
- ];
- }
- return [];
- }
- /**
- * Return all content to replace and all content to be replace
- * @param int $user_id
- * @param int $course_id
- * @param bool $is_preview
- * @return array
- */
- public static function get_all_info_to_certificate($user_id, $course_id, $is_preview = false)
- {
- $info_list = array();
- $user_id = intval($user_id);
- $course_info = api_get_course_info($course_id);
- // Portal info
- $organization_name = api_get_setting('Institution');
- $portal_name = api_get_setting('siteName');
- // Extra user data information
- $extra_user_info_data = UserManager::get_extra_user_data(
- $user_id,
- false,
- false,
- false,
- true
- );
- // get extra fields
- $extraField = new ExtraField('user');
- $extraFields = $extraField->get_all(['filter = ? AND visible_to_self = ?' => [1, 1]]);
- //Student information
- $user_info = api_get_user_info($user_id);
- $first_name = $user_info['firstname'];
- $last_name = $user_info['lastname'];
- $official_code = $user_info['official_code'];
- // Teacher information
- $info_teacher_id = UserManager::get_user_id_of_course_admin_or_session_admin($course_info);
- $teacher_info = api_get_user_info($info_teacher_id);
- $teacher_first_name = $teacher_info['firstname'];
- $teacher_last_name = $teacher_info['lastname'];
- // info gradebook certificate
- $info_grade_certificate = UserManager::get_info_gradebook_certificate($course_id, $user_id);
- $date_certificate = $info_grade_certificate['created_at'];
- $date_long_certificate = '';
- $date_no_time = api_convert_and_format_date(api_get_utc_datetime(), DATE_FORMAT_LONG_NO_DAY);
- if (!empty($date_certificate)) {
- $date_long_certificate = api_convert_and_format_date($date_certificate);
- $date_no_time = api_convert_and_format_date($date_certificate, DATE_FORMAT_LONG_NO_DAY);
- }
- if ($is_preview) {
- $date_long_certificate = api_convert_and_format_date(api_get_utc_datetime());
- $date_no_time = api_convert_and_format_date(api_get_utc_datetime(), DATE_FORMAT_LONG_NO_DAY);
- }
- $url = api_get_path(WEB_PATH).'certificates/index.php?id='.$info_grade_certificate['id'];
- $externalStyleFile = api_get_path(SYS_CSS_PATH).'themes/'.api_get_visual_theme().'/certificate.css';
- $externalStyle = '';
- if (is_file($externalStyleFile)) {
- $externalStyle = file_get_contents($externalStyleFile);
- }
- // Replace content
- $info_to_replace_in_content_html = array(
- $first_name,
- $last_name,
- $organization_name,
- $portal_name,
- $teacher_first_name,
- $teacher_last_name,
- $official_code,
- $date_long_certificate,
- $date_no_time,
- $course_id,
- $course_info['name'],
- $info_grade_certificate['grade'],
- $url,
- '<a href="'.$url.'" target="_blank">'.get_lang('CertificateOnlineLink').'</a>',
- '((certificate_barcode))',
- $externalStyle
- );
- $info_to_be_replaced_in_content_html = array(
- '((user_firstname))',
- '((user_lastname))',
- '((gradebook_institution))',
- '((gradebook_sitename))',
- '((teacher_firstname))',
- '((teacher_lastname))',
- '((official_code))',
- '((date_certificate))',
- '((date_certificate_no_time))',
- '((course_code))',
- '((course_title))',
- '((gradebook_grade))',
- '((certificate_link))',
- '((certificate_link_html))',
- '((certificate_barcode))',
- '((external_style))'
- );
- if (!empty($extraFields)) {
- foreach ($extraFields as $extraField) {
- $valueExtra = isset($extra_user_info_data[$extraField['variable']]) ? $extra_user_info_data[$extraField['variable']] : '';
- $info_to_be_replaced_in_content_html[] = '(('.strtolower($extraField['variable']).'))';
- $info_to_replace_in_content_html[] = $valueExtra;
- }
- }
- $info_list[] = $info_to_be_replaced_in_content_html;
- $info_list[] = $info_to_replace_in_content_html;
- return $info_list;
- }
- /**
- * Remove default certificate
- * @param string $course_id The course code
- * @param int $default_certificate_id The document id of the default certificate
- * @return void
- */
- public static function remove_attach_certificate($course_id, $default_certificate_id)
- {
- if (empty($default_certificate_id)) {
- return false;
- }
- $default_certificate = self::get_default_certificate_id($course_id);
- if ((int) $default_certificate == (int) $default_certificate_id) {
- $tbl_category = Database::get_main_table(TABLE_MAIN_GRADEBOOK_CATEGORY);
- $session_id = api_get_session_id();
- if ($session_id == 0 || is_null($session_id)) {
- $sql_session = 'AND (session_id='.intval($session_id).' OR isnull(session_id)) ';
- } elseif ($session_id > 0) {
- $sql_session = 'AND session_id='.intval($session_id);
- } else {
- $sql_session = '';
- }
- $sql = 'UPDATE '.$tbl_category.' SET document_id = null
- WHERE
- course_code = "' . Database::escape_string($course_id).'" AND
- document_id="' . $default_certificate_id.'" '.$sql_session;
- Database::query($sql);
- }
- }
- /**
- * Create directory certificate
- * @param array $courseInfo
- * @return void
- */
- public static function create_directory_certificate_in_course($courseInfo)
- {
- if (!empty($courseInfo)) {
- $to_group_id = 0;
- $to_user_id = null;
- $course_dir = $courseInfo['path']."/document/";
- $sys_course_path = api_get_path(SYS_COURSE_PATH);
- $base_work_dir = $sys_course_path.$course_dir;
- $base_work_dir_test = $base_work_dir.'certificates';
- $dir_name = '/certificates';
- $post_dir_name = get_lang('CertificatesFiles');
- $visibility_command = 'invisible';
- $id = self::get_document_id_of_directory_certificate();
- if (empty($id)) {
- create_unexisting_directory(
- $courseInfo,
- api_get_user_id(),
- api_get_session_id(),
- $to_group_id,
- $to_user_id,
- $base_work_dir,
- $dir_name,
- $post_dir_name,
- null,
- false
- );
- $id = self::get_document_id_of_directory_certificate();
- if (empty($id)) {
- $id = add_document(
- $courseInfo,
- $dir_name,
- 'folder',
- 0,
- $post_dir_name,
- null,
- 0,
- true,
- $to_group_id
- );
- }
- if (!empty($id)) {
- api_item_property_update(
- $courseInfo,
- TOOL_DOCUMENT,
- $id,
- $visibility_command,
- api_get_user_id()
- );
- }
- }
- }
- }
- /**
- * Get the document id of the directory certificate
- * @return int The document id of the directory certificate
- */
- public static function get_document_id_of_directory_certificate()
- {
- $tbl_document = Database::get_course_table(TABLE_DOCUMENT);
- $course_id = api_get_course_int_id();
- $sql = "SELECT id FROM $tbl_document
- WHERE c_id = $course_id AND path='/certificates' ";
- $rs = Database::query($sql);
- $row = Database::fetch_array($rs);
- return $row['id'];
- }
- /**
- * Check if a directory given is for certificate
- * @param string $dir path of directory
- * @return bool true if is a certificate or false otherwise
- */
- public static function is_certificate_mode($dir)
- {
- // I'm in the certification module?
- $is_certificate_mode = false;
- $is_certificate_array = explode('/', $dir);
- array_shift($is_certificate_array);
- if (isset($is_certificate_array[0]) && $is_certificate_array[0] == 'certificates') {
- $is_certificate_mode = true;
- }
- return $is_certificate_mode;
- }
- /**
- * Gets the list of included resources as a list of absolute or relative paths from a html file or string html
- * This allows for a better SCORM export or replace urls inside content html from copy course
- * The list will generally include pictures, flash objects, java applets, or any other
- * stuff included in the source of the current item. The current item is expected
- * to be an HTML file or string html. If it is not, then the function will return and empty list.
- * @param string source html (content or path)
- * @param bool is file or string html
- * @param string type (one of the app tools) - optional (otherwise takes the current item's type)
- * @param int level of recursivity we're in
- * @return array List of file paths. An additional field containing 'local' or 'remote' helps determine
- * if the file should be copied into the zip or just linked
- */
- public static function get_resources_from_source_html($source_html, $is_file = false, $type = null, $recursivity = 1)
- {
- $max = 5;
- $attributes = array();
- $wanted_attributes = array('src', 'url', '@import', 'href', 'value', 'flashvars', 'poster');
- $explode_attributes = array('flashvars' => 'file');
- $abs_path = '';
- if ($recursivity > $max) {
- return array();
- }
- if (!isset($type)) {
- $type = TOOL_DOCUMENT;
- }
- if (!$is_file) {
- $attributes = self::parse_HTML_attributes(
- $source_html,
- $wanted_attributes,
- $explode_attributes
- );
- } else {
- if (is_file($source_html)) {
- $abs_path = $source_html;
- //for now, read the whole file in one go (that's gonna be a problem when the file is too big)
- $info = pathinfo($abs_path);
- $ext = $info['extension'];
- switch (strtolower($ext)) {
- case 'html':
- case 'htm':
- case 'shtml':
- case 'css':
- $file_content = file_get_contents($abs_path);
- //get an array of attributes from the HTML source
- $attributes = self::parse_HTML_attributes($file_content, $wanted_attributes, $explode_attributes);
- break;
- default:
- break;
- }
- } else {
- return false;
- }
- }
- $files_list = array();
- switch ($type) {
- case TOOL_DOCUMENT:
- case TOOL_QUIZ:
- case 'sco':
- foreach ($wanted_attributes as $attr) {
- if (isset($attributes[$attr])) {
- //find which kind of path these are (local or remote)
- $sources = $attributes[$attr];
- foreach ($sources as $source) {
- //skip what is obviously not a resource
- if (strpos($source, '+this.')) {
- continue; //javascript code - will still work unaltered
- }
- if (strpos($source, '.') === false) {
- continue; //no dot, should not be an external file anyway
- }
- if (strpos($source, 'mailto:')) {
- continue; //mailto link
- }
- if (strpos($source, ';') && !strpos($source, '&')) {
- continue; //avoid code - that should help
- }
- if ($attr == 'value') {
- if (strpos($source, 'mp3file')) {
- $files_list[] = array(substr($source, 0, strpos($source, '.swf') + 4), 'local', 'abs');
- $mp3file = substr($source, strpos($source, 'mp3file=') + 8);
- if (substr($mp3file, 0, 1) == '/') {
- $files_list[] = array($mp3file, 'local', 'abs');
- } else {
- $files_list[] = array($mp3file, 'local', 'rel');
- }
- } elseif (strpos($source, 'flv=') === 0) {
- $source = substr($source, 4);
- if (strpos($source, '&') > 0) {
- $source = substr($source, 0, strpos($source, '&'));
- }
- if (strpos($source, '://') > 0) {
- if (strpos($source, api_get_path(WEB_PATH)) !== false) {
- //we found the current portal url
- $files_list[] = array($source, 'local', 'url');
- } else {
- //we didn't find any trace of current portal
- $files_list[] = array($source, 'remote', 'url');
- }
- } else {
- $files_list[] = array($source, 'local', 'abs');
- }
- /* skipping anything else to avoid two entries
- (while the others can have sub-files in their url, flv's can't)*/
- continue;
- }
- }
- if (strpos($source, '://') > 0) {
- //cut at '?' in a URL with params
- if (strpos($source, '?') > 0) {
- $second_part = substr($source, strpos($source, '?'));
- if (strpos($second_part, '://') > 0) {
- //if the second part of the url contains a url too, treat the second one before cutting
- $pos1 = strpos($second_part, '=');
- $pos2 = strpos($second_part, '&');
- $second_part = substr($second_part, $pos1 + 1, $pos2 - ($pos1 + 1));
- if (strpos($second_part, api_get_path(WEB_PATH)) !== false) {
- //we found the current portal url
- $files_list[] = array($second_part, 'local', 'url');
- $in_files_list[] = self::get_resources_from_source_html($second_part, true, TOOL_DOCUMENT, $recursivity + 1);
- if (count($in_files_list) > 0) {
- $files_list = array_merge($files_list, $in_files_list);
- }
- } else {
- //we didn't find any trace of current portal
- $files_list[] = array($second_part, 'remote', 'url');
- }
- } elseif (strpos($second_part, '=') > 0) {
- if (substr($second_part, 0, 1) === '/') {
- //link starts with a /, making it absolute (relative to DocumentRoot)
- $files_list[] = array($second_part, 'local', 'abs');
- $in_files_list[] = self::get_resources_from_source_html($second_part, true, TOOL_DOCUMENT, $recursivity + 1);
- if (count($in_files_list) > 0) {
- $files_list = array_merge($files_list, $in_files_list);
- }
- } elseif (strstr($second_part, '..') === 0) {
- //link is relative but going back in the hierarchy
- $files_list[] = array($second_part, 'local', 'rel');
- //$dir = api_get_path(SYS_CODE_PATH);//dirname($abs_path);
- //$new_abs_path = realpath($dir.'/'.$second_part);
- $dir = '';
- if (!empty($abs_path)) {
- $dir = dirname($abs_path).'/';
- }
- $new_abs_path = realpath($dir.$second_part);
- $in_files_list[] = self::get_resources_from_source_html($new_abs_path, true, TOOL_DOCUMENT, $recursivity + 1);
- if (count($in_files_list) > 0) {
- $files_list = array_merge($files_list, $in_files_list);
- }
- } else {
- //no starting '/', making it relative to current document's path
- if (substr($second_part, 0, 2) == './') {
- $second_part = substr($second_part, 2);
- }
- $files_list[] = array($second_part, 'local', 'rel');
- $dir = '';
- if (!empty($abs_path)) {
- $dir = dirname($abs_path).'/';
- }
- $new_abs_path = realpath($dir.$second_part);
- $in_files_list[] = self::get_resources_from_source_html(
- $new_abs_path,
- true,
- TOOL_DOCUMENT,
- $recursivity + 1
- );
- if (count($in_files_list) > 0) {
- $files_list = array_merge($files_list, $in_files_list);
- }
- }
- }
- //leave that second part behind now
- $source = substr($source, 0, strpos($source, '?'));
- if (strpos($source, '://') > 0) {
- if (strpos($source, api_get_path(WEB_PATH)) !== false) {
- //we found the current portal url
- $files_list[] = array($source, 'local', 'url');
- $in_files_list[] = self::get_resources_from_source_html($source, true, TOOL_DOCUMENT, $recursivity + 1);
- if (count($in_files_list) > 0) {
- $files_list = array_merge($files_list, $in_files_list);
- }
- } else {
- //we didn't find any trace of current portal
- $files_list[] = array($source, 'remote', 'url');
- }
- } else {
- //no protocol found, make link local
- if (substr($source, 0, 1) === '/') {
- //link starts with a /, making it absolute (relative to DocumentRoot)
- $files_list[] = array($source, 'local', 'abs');
- $in_files_list[] = self::get_resources_from_source_html(
- $source,
- true,
- TOOL_DOCUMENT,
- $recursivity + 1
- );
- if (count($in_files_list) > 0) {
- $files_list = array_merge($files_list, $in_files_list);
- }
- } elseif (strstr($source, '..') === 0) { //link is relative but going back in the hierarchy
- $files_list[] = array($source, 'local', 'rel');
- $dir = '';
- if (!empty($abs_path)) {
- $dir = dirname($abs_path).'/';
- }
- $new_abs_path = realpath($dir.$source);
- $in_files_list[] = self::get_resources_from_source_html($new_abs_path, true, TOOL_DOCUMENT, $recursivity + 1);
- if (count($in_files_list) > 0) {
- $files_list = array_merge($files_list, $in_files_list);
- }
- } else {
- //no starting '/', making it relative to current document's path
- if (substr($source, 0, 2) == './') {
- $source = substr($source, 2);
- }
- $files_list[] = array($source, 'local', 'rel');
- $dir = '';
- if (!empty($abs_path)) {
- $dir = dirname($abs_path).'/';
- }
- $new_abs_path = realpath($dir.$source);
- $in_files_list[] = self::get_resources_from_source_html($new_abs_path, true, TOOL_DOCUMENT, $recursivity + 1);
- if (count($in_files_list) > 0) {
- $files_list = array_merge($files_list, $in_files_list);
- }
- }
- }
- }
- //found some protocol there
- if (strpos($source, api_get_path(WEB_PATH)) !== false) {
- //we found the current portal url
- $files_list[] = array($source, 'local', 'url');
- $in_files_list[] = self::get_resources_from_source_html($source, true, TOOL_DOCUMENT, $recursivity + 1);
- if (count($in_files_list) > 0) {
- $files_list = array_merge($files_list, $in_files_list);
- }
- } else {
- //we didn't find any trace of current portal
- $files_list[] = array($source, 'remote', 'url');
- }
- } else {
- //no protocol found, make link local
- if (substr($source, 0, 1) === '/') {
- //link starts with a /, making it absolute (relative to DocumentRoot)
- $files_list[] = array($source, 'local', 'abs');
- $in_files_list[] = self::get_resources_from_source_html($source, true, TOOL_DOCUMENT, $recursivity + 1);
- if (count($in_files_list) > 0) {
- $files_list = array_merge($files_list, $in_files_list);
- }
- } elseif (strpos($source, '..') === 0) {
- //link is relative but going back in the hierarchy
- $files_list[] = array($source, 'local', 'rel');
- $dir = '';
- if (!empty($abs_path)) {
- $dir = dirname($abs_path).'/';
- }
- $new_abs_path = realpath($dir.$source);
- $in_files_list[] = self::get_resources_from_source_html(
- $new_abs_path,
- true,
- TOOL_DOCUMENT,
- $recursivity + 1
- );
- if (count($in_files_list) > 0) {
- $files_list = array_merge($files_list, $in_files_list);
- }
- } else {
- //no starting '/', making it relative to current document's path
- if (substr($source, 0, 2) == './') {
- $source = substr($source, 2);
- }
- $files_list[] = array($source, 'local', 'rel');
- $dir = '';
- if (!empty($abs_path)) {
- $dir = dirname($abs_path).'/';
- }
- $new_abs_path = realpath($dir.$source);
- $in_files_list[] = self::get_resources_from_source_html(
- $new_abs_path,
- true,
- TOOL_DOCUMENT,
- $recursivity + 1
- );
- if (count($in_files_list) > 0) {
- $files_list = array_merge($files_list, $in_files_list);
- }
- }
- }
- }
- }
- }
- break;
- default: //ignore
- break;
- }
- $checked_files_list = array();
- $checked_array_list = array();
- if (count($files_list) > 0) {
- foreach ($files_list as $idx => $file) {
- if (!empty($file[0])) {
- if (!in_array($file[0], $checked_files_list)) {
- $checked_files_list[] = $files_list[$idx][0];
- $checked_array_list[] = $files_list[$idx];
- }
- }
- }
- }
- return $checked_array_list;
- }
- /**
- * Parses the HTML attributes given as string.
- *
- * @param string HTML attribute string
- * @param array List of attributes that we want to get back
- * @param array
- * @return array An associative array of attributes
- * @author Based on a function from the HTML_Common2 PEAR module *
- */
- public static function parse_HTML_attributes($attrString, $wanted = array(), $explode_variables = array())
- {
- $attributes = array();
- $regs = array();
- $reduced = false;
- if (count($wanted) > 0) {
- $reduced = true;
- }
- try {
- //Find all occurences of something that looks like a URL
- // The structure of this regexp is:
- // (find protocol) then
- // (optionally find some kind of space 1 or more times) then
- // find (either an equal sign or a bracket) followed by an optional space
- // followed by some text without quotes (between quotes itself or not)
- // then possible closing brackets if we were in the opening bracket case
- // OR something like @import()
- $res = preg_match_all(
- '/(((([A-Za-z_:])([A-Za-z0-9_:\.-]*))'.
- // '/(((([A-Za-z_:])([A-Za-z0-9_:\.-]|[^\x00-\x7F])*)' . -> seems to be taking too much
- // '/(((([A-Za-z_:])([^\x00-\x7F])*)' . -> takes only last letter of parameter name
- '([ \n\t\r]+)?('.
- // '(=([ \n\t\r]+)?("[^"]+"|\'[^\']+\'|[^ \n\t\r]+))' . -> doesn't restrict close enough to the url itself
- '(=([ \n\t\r]+)?("[^"\)]+"|\'[^\'\)]+\'|[^ \n\t\r\)]+))'.
- '|'.
- // '(\(([ \n\t\r]+)?("[^"]+"|\'[^\']+\'|[^ \n\t\r]+)\))' . -> doesn't restrict close enough to the url itself
- '(\(([ \n\t\r]+)?("[^"\)]+"|\'[^\'\)]+\'|[^ \n\t\r\)]+)\))'.
- '))'.
- '|'.
- // '(@import([ \n\t\r]+)?("[^"]+"|\'[^\']+\'|[^ \n\t\r]+)))?/', -> takes a lot (like 100's of thousands of empty possibilities)
- '(@import([ \n\t\r]+)?("[^"]+"|\'[^\']+\'|[^ \n\t\r]+)))/',
- $attrString,
- $regs
- );
- } catch (Exception $e) {
- error_log('Caught exception: '.$e->getMessage(), 0);
- }
- if ($res) {
- for ($i = 0; $i < count($regs[1]); $i++) {
- $name = trim($regs[3][$i]);
- $check = trim($regs[0][$i]);
- $value = trim($regs[10][$i]);
- if (empty($value) and !empty($regs[13][$i])) {
- $value = $regs[13][$i];
- }
- if (empty($name) && !empty($regs[16][$i])) {
- $name = '@import';
- $value = trim($regs[16][$i]);
- }
- if (!empty($name)) {
- if (!$reduced OR in_array(strtolower($name), $wanted)) {
- if ($name == $check) {
- $attributes[strtolower($name)][] = strtolower($name);
- } else {
- if (!empty($value) && ($value[0] == '\'' || $value[0] == '"')) {
- $value = substr($value, 1, -1);
- }
- if ($value == 'API.LMSGetValue(name') {
- $value = 'API.LMSGetValue(name)';
- }
- //Gets the xx.flv value from the string flashvars="width=320&height=240&autostart=false&file=xxx.flv&repeat=false"
- if (isset($explode_variables[$name])) {
- $value_modified = str_replace('&', '&', $value);
- $value_array = explode('&', $value_modified);
- foreach ($value_array as $item) {
- list($key, $item_value) = explode('=', $item);
- if ($key == $explode_variables[$name]) {
- $attributes[strtolower($name)][] = $item_value;
- }
- }
- }
- $attributes[strtolower($name)][] = $value;
- }
- }
- }
- }
- }
- return $attributes;
- }
- /**
- * Replace urls inside content html from a copy course
- * @param string $content_html
- * @param string $origin_course_code
- * @param string $destination_course_directory
- * @param string $origin_course_path_from_zip
- * @param string $origin_course_info_path
- *
- * @return string new content html with replaced urls or return false if content is not a string
- */
- public static function replace_urls_inside_content_html_from_copy_course(
- $content_html,
- $origin_course_code,
- $destination_course_directory,
- $origin_course_path_from_zip = null,
- $origin_course_info_path = null
- ) {
- if (empty($content_html)) {
- return false;
- }
- $orig_source_html = self::get_resources_from_source_html($content_html);
- $orig_course_info = api_get_course_info($origin_course_code);
- // Course does not exist in the current DB probably this came from a zip file?
- if (empty($orig_course_info)) {
- if (!empty($origin_course_path_from_zip)) {
- $orig_course_path = $origin_course_path_from_zip.'/';
- $orig_course_info_path = $origin_course_info_path;
- }
- } else {
- $orig_course_path = api_get_path(SYS_COURSE_PATH).$orig_course_info['path'].'/';
- $orig_course_info_path = $orig_course_info['path'];
- }
- $destination_course_code = CourseManager::get_course_id_from_path($destination_course_directory);
- $destination_course_info = api_get_course_info($destination_course_code);
- $dest_course_path = api_get_path(SYS_COURSE_PATH).$destination_course_directory.'/';
- $dest_course_path_rel = api_get_path(REL_COURSE_PATH).$destination_course_directory.'/';
- $user_id = api_get_user_id();
- if (!empty($orig_source_html)) {
- foreach ($orig_source_html as $source) {
- // Get information about source url
- $real_orig_url = $source[0]; // url
- $scope_url = $source[1]; // scope (local, remote)
- $type_url = $source[2]; // type (rel, abs, url)
- // Get path and query from origin url
- $orig_parse_url = parse_url($real_orig_url);
- $real_orig_path = isset($orig_parse_url['path']) ? $orig_parse_url['path'] : null;
- $real_orig_query = isset($orig_parse_url['query']) ? $orig_parse_url['query'] : null;
- // Replace origin course code by destination course code from origin url query
- $dest_url_query = '';
- if (!empty($real_orig_query)) {
- $dest_url_query = '?'.$real_orig_query;
- if (strpos($dest_url_query, $origin_course_code) !== false) {
- $dest_url_query = str_replace($origin_course_code, $destination_course_code, $dest_url_query);
- }
- }
- if ($scope_url == 'local') {
- if ($type_url == 'abs' || $type_url == 'rel') {
- $document_file = strstr($real_orig_path, 'document');
- if (strpos($real_orig_path, $document_file) !== false) {
- $origin_filepath = $orig_course_path.$document_file;
- $destination_filepath = $dest_course_path.$document_file;
- // copy origin file inside destination course
- if (file_exists($origin_filepath)) {
- $filepath_dir = dirname($destination_filepath);
- if (!is_dir($filepath_dir)) {
- $perm = api_get_permissions_for_new_directories();
- $result = @mkdir($filepath_dir, $perm, true);
- if ($result) {
- $filepath_to_add = str_replace(array($dest_course_path, 'document'), '', $filepath_dir);
- //Add to item properties to the new folder
- $doc_id = add_document(
- $destination_course_info,
- $filepath_to_add,
- 'folder',
- 0,
- basename($filepath_to_add)
- );
- api_item_property_update(
- $destination_course_info,
- TOOL_DOCUMENT,
- $doc_id,
- 'FolderCreated',
- $user_id,
- null,
- null,
- null,
- null
- );
- }
- }
- if (!file_exists($destination_filepath)) {
- $result = @copy($origin_filepath, $destination_filepath);
- if ($result) {
- $filepath_to_add = str_replace(array($dest_course_path, 'document'), '', $destination_filepath);
- $size = filesize($destination_filepath);
- // Add to item properties to the file
- $doc_id = add_document(
- $destination_course_info,
- $filepath_to_add,
- 'file',
- $size,
- basename($filepath_to_add)
- );
- api_item_property_update(
- $destination_course_info,
- TOOL_DOCUMENT,
- $doc_id,
- 'FolderCreated',
- $user_id,
- null,
- null,
- null,
- null
- );
- }
- }
- }
- // Replace origin course path by destination course path.
- if (strpos($content_html, $real_orig_url) !== false) {
- $url_course_path = str_replace($orig_course_info_path.'/'.$document_file, '', $real_orig_path);
- //$destination_url = $url_course_path . $destination_course_directory . '/' . $document_file . $dest_url_query;
- // See BT#7780
- $destination_url = $dest_course_path_rel.$document_file.$dest_url_query;
- // If the course code doesn't exist in the path? what we do? Nothing! see BT#1985
- if (strpos($real_orig_path, $origin_course_code) === false) {
- $url_course_path = $real_orig_path;
- $destination_url = $real_orig_path;
- }
- $content_html = str_replace($real_orig_url, $destination_url, $content_html);
- }
- }
- // replace origin course code by destination course code from origin url
- if (strpos($real_orig_url, '?') === 0) {
- $dest_url = str_replace($origin_course_code, $destination_course_code, $real_orig_url);
- $content_html = str_replace($real_orig_url, $dest_url, $content_html);
- }
- }
- }
- }
- }
- return $content_html;
- }
- /**
- * Replace urls inside content html when moving a file
- * @todo this code is only called in document.php but is commented
- * @param string content html
- * @param string origin
- * @param string destination
- * @return string new content html with replaced urls or return false if content is not a string
- */
- public function replace_urls_inside_content_html_when_moving_file($file_name, $original_path, $destiny_path)
- {
- if (substr($original_path, strlen($original_path) - 1, strlen($original_path)) == '/') {
- $original = $original_path.$file_name;
- } else {
- $original = $original_path.'/'.$file_name;
- }
- if (substr($destiny_path, strlen($destiny_path) - 1, strlen($destiny_path)) == '/') {
- $destination = $destiny_path.$file_name;
- } else {
- $destination = $destiny_path.'/'.$file_name;
- }
- $original_count = count(explode('/', $original));
- $destination_count = count(explode('/', $destination));
- if ($original_count == $destination_count) {
- //Nothing to change
- return true;
- }
- if ($original_count > $destination_count) {
- $mode = 'outside';
- } else {
- $mode = 'inside';
- }
- //We do not select the $original_path becayse the file was already moved
- $content_html = file_get_contents($destiny_path.'/'.$file_name);
- $destination_file = $destiny_path.'/'.$file_name;
- $pre_original = strstr($original_path, 'document');
- $pre_destin = strstr($destiny_path, 'document');
- $pre_original = substr($pre_original, 8, strlen($pre_original));
- $pre_destin = substr($pre_destin, 8, strlen($pre_destin));
- $levels = count(explode('/', $pre_destin)) - 1;
- $link_to_add = '';
- for ($i = 1; $i <= $levels; $i++) {
- $link_to_add .= '../';
- }
- if ($pre_original == '/') {
- $pre_original = '';
- }
- if ($pre_destin == '/') {
- $pre_destin = '';
- }
- if ($pre_original != '') {
- $pre_original = '..'.$pre_original.'/';
- }
- if ($pre_destin != '') {
- $pre_destin = '..'.$pre_destin.'/';
- }
- $levels = explode('/', $pre_original);
- $count_pre_destination_levels = 0;
- foreach ($levels as $item) {
- if (!empty($item) && $item != '..') {
- $count_pre_destination_levels++;
- }
- }
- $count_pre_destination_levels--;
- //$count_pre_destination_levels = count() - 3;
- if ($count_pre_destination_levels == 0) {
- $count_pre_destination_levels = 1;
- }
- //echo '$count_pre_destination_levels '. $count_pre_destination_levels;
- $pre_remove = '';
- for ($i = 1; $i <= $count_pre_destination_levels; $i++) {
- $pre_remove .= '..\/';
- }
- $orig_source_html = self::get_resources_from_source_html($content_html);
- foreach ($orig_source_html as $source) {
- // get information about source url
- $real_orig_url = $source[0]; // url
- $scope_url = $source[1]; // scope (local, remote)
- $type_url = $source[2]; // tyle (rel, abs, url)
- // Get path and query from origin url
- $orig_parse_url = parse_url($real_orig_url);
- $real_orig_path = $orig_parse_url['path'];
- $real_orig_query = $orig_parse_url['query'];
- // Replace origin course code by destination course code from origin url query
- /*
- $dest_url_query = '';
- if (!empty($real_orig_query)) {
- $dest_url_query = '?'.$real_orig_query;
- if (strpos($dest_url_query,$origin_course_code) !== false) {
- $dest_url_query = str_replace($origin_course_code, $destination_course_code, $dest_url_query);
- }
- } */
- if ($scope_url == 'local') {
- if ($type_url == 'abs' || $type_url == 'rel') {
- $document_file = strstr($real_orig_path, 'document');
- if (strpos($real_orig_path, $document_file) !== false) {
- echo 'continue1';
- continue;
- } else {
- $real_orig_url_temp = '';
- if ($mode == 'inside') {
- $real_orig_url_temp = str_replace('../', '', $real_orig_url);
- $destination_url = $link_to_add.$real_orig_url_temp;
- } else {
- $real_orig_url_temp = $real_orig_url;
- $destination_url = preg_replace("/".$pre_remove."/", '', $real_orig_url, 1);
- }
- if ($real_orig_url == $destination_url) {
- //echo 'continue2';
- continue;
- }
- $content_html = str_replace($real_orig_url, $destination_url, $content_html);
- }
- } else {
- echo 'continue3';
- continue;
- }
- }
- }
- $return = file_put_contents($destination, $content_html);
- return $return;
- }
- /**
- * Export document to PDF
- *
- * @param int $document_id
- * @param string $courseCode
- * @param string $orientation
- * @param bool $showHeaderAndFooter
- */
- public static function export_to_pdf(
- $document_id,
- $courseCode,
- $orientation = 'landscape',
- $showHeaderAndFooter = true
- ) {
- $course_data = api_get_course_info($courseCode);
- $document_data = self::get_document_data_by_id($document_id, $courseCode);
- $file_path = api_get_path(SYS_COURSE_PATH).$course_data['path'].'/document'.$document_data['path'];
- if ($orientation == 'landscape') {
- $pageFormat = 'A4-L';
- $pdfOrientation = 'L';
- } else {
- $pageFormat = 'A4';
- $pdfOrientation = 'P';
- }
- $pdf = new PDF($pageFormat, $pdfOrientation);
- if (api_get_configuration_value('use_alternative_document_pdf_footer')) {
- $view = new Template('', false, false, false, true, false, false);
- $template = $view->get_template('export/alt_pdf_footer.tpl');
- $pdf->set_custom_footer([
- 'html' => $view->fetch($template)
- ]);
- }
- $pdf->html_to_pdf(
- $file_path,
- $document_data['title'],
- $courseCode,
- false,
- $showHeaderAndFooter
- );
- }
- /**
- * Uploads a document
- *
- * @param array $files the $_FILES variable
- * @param string $path
- * @param string $title
- * @param string $comment
- * @param int $unzip unzip or not the file
- * @param string $if_exists overwrite, rename or warn (default)
- * @param bool $index_document index document (search xapian module)
- * @param bool $show_output print html messages
- * @param string $fileKey
- * @param bool $treat_spaces_as_hyphens
- *
- * @return array|bool
- */
- public static function upload_document(
- $files,
- $path,
- $title = null,
- $comment = null,
- $unzip = 0,
- $if_exists = null,
- $index_document = false,
- $show_output = false,
- $fileKey = 'file',
- $treat_spaces_as_hyphens = true
- ) {
- $course_info = api_get_course_info();
- $sessionId = api_get_session_id();
- $course_dir = $course_info['path'].'/document';
- $sys_course_path = api_get_path(SYS_COURSE_PATH);
- $base_work_dir = $sys_course_path.$course_dir;
- $group_properties = GroupManager::get_group_properties(api_get_group_id());
- $groupIid = isset($group_properties['iid']) ? $group_properties['iid'] : 0;
- if (isset($files[$fileKey])) {
- $upload_ok = process_uploaded_file($files[$fileKey], $show_output);
- if ($upload_ok) {
- $new_path = handle_uploaded_document(
- $course_info,
- $files[$fileKey],
- $base_work_dir,
- $path,
- api_get_user_id(),
- $groupIid,
- null,
- $unzip,
- $if_exists,
- $show_output,
- false,
- null,
- $sessionId,
- $treat_spaces_as_hyphens
- );
- // Showing message when sending zip files
- if ($new_path === true && $unzip == 1) {
- if ($show_output) {
- echo Display::return_message(
- get_lang('UplUploadSucceeded').'<br />',
- 'confirm',
- false
- );
- }
- return [
- 'title' => $path,
- 'url' => $path,
- ];
- }
- if ($new_path) {
- $documentId = self::get_document_id(
- $course_info,
- $new_path,
- $sessionId
- );
- if (!empty($documentId)) {
- $table_document = Database::get_course_table(TABLE_DOCUMENT);
- $params = array();
- /*if ($if_exists == 'rename') {
- // Remove prefix
- $suffix = self::getDocumentSuffix(
- $course_info,
- $sessionId,
- api_get_group_id()
- );
- $new_path = basename($new_path);
- $new_path = str_replace($suffix, '', $new_path);
- error_log('renamed');
- error_log($new_path);
- $params['title'] = get_document_title($new_path);
- } else {
- if (!empty($title)) {
- $params['title'] = get_document_title($title);
- } else {
- $params['title'] = get_document_title($files['file']['name']);
- }
- }*/
- if (!empty($title)) {
- $params['title'] = $title;
- }
- if (!empty($comment)) {
- $params['comment'] = trim($comment);
- }
- Database::update(
- $table_document,
- $params,
- array(
- 'id = ? AND c_id = ? ' => array(
- $documentId,
- $course_info['real_id']
- )
- )
- );
- }
- if ($index_document) {
- self::index_document(
- $documentId,
- $course_info['code'],
- null,
- $_POST['language'],
- $_REQUEST,
- $if_exists
- );
- }
- if (!empty($documentId) && is_numeric($documentId)) {
- $documentData = self::get_document_data_by_id(
- $documentId,
- $course_info['code'],
- false,
- $sessionId
- );
- return $documentData;
- }
- }
- }
- }
- return false;
- }
- /**
- * Obtains the text inside the file with the right parser
- */
- public static function get_text_content($doc_path, $doc_mime)
- {
- // TODO: review w$ compatibility
- // Use usual exec output lines array to store stdout instead of a temp file
- // because we need to store it at RAM anyway before index on ChamiloIndexer object
- $ret_val = null;
- switch ($doc_mime) {
- case 'text/plain':
- $handle = fopen($doc_path, 'r');
- $output = array(fread($handle, filesize($doc_path)));
- fclose($handle);
- break;
- case 'application/pdf':
- exec("pdftotext $doc_path -", $output, $ret_val);
- break;
- case 'application/postscript':
- $temp_file = tempnam(sys_get_temp_dir(), 'chamilo');
- exec("ps2pdf $doc_path $temp_file", $output, $ret_val);
- if ($ret_val !== 0) { // shell fail, probably 127 (command not found)
- return false;
- }
- exec("pdftotext $temp_file -", $output, $ret_val);
- unlink($temp_file);
- break;
- case 'application/msword':
- exec("catdoc $doc_path", $output, $ret_val);
- break;
- case 'text/html':
- exec("html2text $doc_path", $output, $ret_val);
- break;
- case 'text/rtf':
- // Note: correct handling of code pages in unrtf
- // on debian lenny unrtf v0.19.2 can not, but unrtf v0.20.5 can
- exec("unrtf --text $doc_path", $output, $ret_val);
- if ($ret_val == 127) { // command not found
- return false;
- }
- // Avoid index unrtf comments
- if (is_array($output) && count($output) > 1) {
- $parsed_output = array();
- foreach ($output as & $line) {
- if (!preg_match('/^###/', $line, $matches)) {
- if (!empty($line)) {
- $parsed_output[] = $line;
- }
- }
- }
- $output = $parsed_output;
- }
- break;
- case 'application/vnd.ms-powerpoint':
- exec("catppt $doc_path", $output, $ret_val);
- break;
- case 'application/vnd.ms-excel':
- exec("xls2csv -c\" \" $doc_path", $output, $ret_val);
- break;
- }
- $content = '';
- if (!is_null($ret_val)) {
- if ($ret_val !== 0) { // shell fail, probably 127 (command not found)
- return false;
- }
- }
- if (isset($output)) {
- foreach ($output as & $line) {
- $content .= $line."\n";
- }
- return $content;
- } else {
- return false;
- }
- }
- /**
- * Calculates the total size of all documents in a course
- *
- * @author Bert vanderkimpen
- * @param int $course_id
- * @param int $group_id (to calculate group document space)
- * @param int $session_id
- *
- * @return int total size
- */
- public static function documents_total_space($course_id = null, $group_id = null, $session_id = null)
- {
- $TABLE_ITEMPROPERTY = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $TABLE_DOCUMENT = Database::get_course_table(TABLE_DOCUMENT);
- if (isset($course_id)) {
- $course_id = intval($course_id);
- } else {
- $course_id = api_get_course_int_id();
- }
- $group_condition = null;
- if (isset($group_id)) {
- $group_id = intval($group_id);
- $group_condition = " AND props.to_group_id='".$group_id."' ";
- }
- $session_condition = null;
- if (isset($session_id)) {
- $session_id = intval($session_id);
- $session_condition = " AND props.session_id='".$session_id."' ";
- }
- $sql = "SELECT SUM(size)
- FROM $TABLE_ITEMPROPERTY AS props
- INNER JOIN $TABLE_DOCUMENT AS docs
- ON (docs.id = props.ref AND props.c_id = docs.c_id)
- WHERE
- props.c_id = $course_id AND
- docs.c_id = $course_id AND
- props.tool = '".TOOL_DOCUMENT."' AND
- props.visibility <> 2
- $group_condition
- $session_condition
- ";
- $result = Database::query($sql);
- if ($result && Database::num_rows($result) != 0) {
- $row = Database::fetch_row($result);
- return $row[0];
- } else {
- return 0;
- }
- }
- /**
- * Here we count 1 Kilobyte = 1024 Bytes, 1 Megabyte = 1048576 Bytes
- */
- public static function display_quota($course_quota, $already_consumed_space)
- {
- $course_quota_m = round($course_quota / 1048576);
- $already_consumed_space_m = round($already_consumed_space / 1048576);
- $message = get_lang('MaximumAllowedQuota').' <strong>'.$course_quota_m.' megabyte</strong>.<br />';
- $message .= get_lang('CourseCurrentlyUses').' <strong>'.$already_consumed_space_m.' megabyte</strong>.<br />';
- $percentage = round(($already_consumed_space / $course_quota * 100), 1);
- $other_percentage = $percentage < 100 ? 100 - $percentage : 0;
- // Decide where to place percentage in graph
- if ($percentage >= 50) {
- $text_in_filled = ' '.$other_percentage.'%';
- $text_in_unfilled = '';
- } else {
- $text_in_unfilled = ' '.$other_percentage.'%';
- $text_in_filled = '';
- }
- // Decide the background colour of the graph
- if ($percentage < 65) {
- $colour = '#00BB00'; // Safe - green
- } elseif ($percentage < 90) {
- $colour = '#ffd400'; // Filling up - yelloworange
- } else {
- $colour = '#DD0000'; // Full - red
- }
- // This is used for the table width: a table of only 100 pixels looks too small
- $visual_percentage = 4 * $percentage;
- $visual_other_percentage = 4 * $other_percentage;
- $message .= get_lang('PercentageQuotaInUse').': <strong>'.$percentage.'%</strong>.<br />'.
- get_lang('PercentageQuotaFree').': <strong>'.$other_percentage.'%</strong>.<br />';
- $show_percentage = ' '.$percentage.'%';
- $message .= '<div style="width: 80%; text-align: center; -moz-border-radius: 5px 5px 5px 5px; border: 1px solid #aaa; background-image: url(\''.api_get_path(WEB_CODE_PATH).'css/'.api_get_visual_theme().'/images/bg-header4.png\');" class="document-quota-bar">'.
- '<div style="width:'.$percentage.'%; background-color: #bbb; border-right:3px groove #bbb; -moz-border-radius:5px;"> </div>'.
- '<span style="margin-top: -15px; margin-left:-15px; position: absolute;font-weight:bold;">'.$show_percentage.'</span></div>';
- echo $message;
- }
- /**
- * Display the document quota in a simple way
- *
- * Here we count 1 Kilobyte = 1024 Bytes, 1 Megabyte = 1048576 Bytes
- */
- public static function display_simple_quota($course_quota, $already_consumed_space)
- {
- $course_quota_m = round($course_quota / 1048576);
- $already_consumed_space_m = round($already_consumed_space / 1048576, 2);
- $percentage = $already_consumed_space / $course_quota * 100;
- $percentage = round($percentage, 1);
- $message = get_lang('YouAreCurrentlyUsingXOfYourX');
- $message = sprintf($message, $already_consumed_space_m, $percentage.'%', $course_quota_m.' ');
- return Display::div($message, array('id' => 'document_quota'));
- }
- /**
- * Checks if there is enough place to add a file on a directory
- * on the base of a maximum directory size allowed
- *
- * @author Bert Vanderkimpen
- * @param int $file_size size of the file in byte
- * @param int $max_dir_space maximum size
- * @return boolean true if there is enough space, false otherwise
- *
- * @see enough_space() uses documents_total_space() function
- */
- public static function enough_space($file_size, $max_dir_space)
- {
- if ($max_dir_space) {
- $already_filled_space = self::documents_total_space();
- if (($file_size + $already_filled_space) > $max_dir_space) {
- return false;
- }
- }
- return true;
- }
- /**
- * @param array $params count, url, extension
- * @return string
- */
- public static function generate_jplayer_jquery($params = array())
- {
- $js_path = api_get_path(WEB_LIBRARY_PATH).'javascript/';
- $js = '
- $("#jquery_jplayer_' . $params['count'].'").jPlayer({
- ready: function() {
- $(this).jPlayer("setMedia", {
- ' . $params['extension'].' : "'.$params['url'].'"
- });
- },
- play: function() { // To avoid both jPlayers playing together.
- $(this).jPlayer("pauseOthers");
- },
- //errorAlerts: true,
- //warningAlerts: true,
- swfPath: "' . $js_path.'jquery-jplayer/jplayer/",
- //supplied: "m4a, oga, mp3, ogg, wav",
- supplied: "' . $params['extension'].'",
- wmode: "window",
- solution: "flash, html", // Do not change this setting
- cssSelectorAncestor: "#jp_container_' . $params['count'].'",
- }); ' . "\n\n";
- return $js;
- }
- /**
- *
- * Shows a play icon next to the document title in the document list
- * @param int
- * @param string
- * @return string html content
- */
- public static function generate_media_preview($i, $type = 'simple')
- {
- $i = intval($i);
- $extra_controls = $progress = '';
- if ($type == 'advanced') {
- $extra_controls = ' <li><a href="javascript:;" class="jp-stop" tabindex="1">stop</a></li>
- <li><a href="#" class="jp-mute" tabindex="1">mute</a></li>
- <li><a href="#" class="jp-unmute" tabindex="1">unmute</a></li>';
- $progress = '<div class="jp-progress">
- <div class="jp-seek-bar">
- <div class="jp-play-bar"></div>
- </div>
- </div>';
- }
- //Shows only the play button
- $html = '<div id="jquery_jplayer_'.$i.'" class="jp-jplayer"></div>
- <div id="jp_container_' . $i.'" class="jp-audio">
- <div class="jp-type-single">
- <div class="jp-gui jp-interface">
- <ul class="jp-controls">
- <li><a href="javascript:;" class="jp-play" tabindex="1">play</a></li>
- <li><a href="javascript:;" class="jp-pause" tabindex="1">pause</a></li>
- ' . $extra_controls.'
- </ul>
- ' . $progress.'
- </div>
- </div>
- </div>';
- //<div id="jplayer_inspector_'.$i.'"></div>
- return $html;
- }
- /**
- * @param array $document_data
- * @return string
- */
- public static function generate_video_preview($document_data = array())
- {
- //<button class="jp-video-play-icon" role="button" tabindex="0">play</button>
- $html = '
- <div id="jp_container_1" class="jp-video center-block" role="application" aria-label="media player">
- <div class="jp-type-single">
- <div id="jquery_jplayer_1" class="jp-jplayer"></div>
- <div class="jp-gui">
- <div class="jp-video-play">
- </div>
- <div class="jp-interface">
- <div class="jp-progress">
- <div class="jp-seek-bar">
- <div class="jp-play-bar"></div>
- </div>
- </div>
- <div class="jp-current-time" role="timer" aria-label="time"> </div>
- <div class="jp-duration" role="timer" aria-label="duration"> </div>
- <div class="jp-controls-holder">
- <div class="jp-controls">
- <button class="jp-play" role="button" tabindex="0">play</button>
- <button class="jp-stop" role="button" tabindex="0">stop</button>
- </div>
- <div class="jp-volume-controls">
- <button class="jp-mute" role="button" tabindex="0">mute</button>
- <button class="jp-volume-max" role="button" tabindex="0">max volume</button>
- <div class="jp-volume-bar">
- <div class="jp-volume-bar-value"></div>
- </div>
- </div>
- <div class="jp-toggles">
- <button class="jp-repeat" role="button" tabindex="0">repeat</button>
- <button class="jp-full-screen" role="button" tabindex="0">full screen</button>
- </div>
- </div>
- <div class="jp-details">
- <div class="jp-title" aria-label="title"> </div>
- </div>
- </div>
- </div>
- <div class="jp-no-solution">
- <span>' . get_lang('UpdateRequire').'</span>
- ' . get_lang("ToPlayTheMediaYouWillNeedToUpdateYourBrowserToARecentVersionYouCanAlsoDownloadTheFile").'
- </div>
- </div>
- </div>';
- return $html;
- }
- /**
- * @param array $course_info
- * @param bool $lp_id
- * @param string $target
- * @param int $session_id
- * @param bool $add_move_button
- * @param string $filter_by_folder
- * @param string $overwrite_url
- * @param bool $showInvisibleFiles
- * @param bool $showOnlyFolders
- * @param int $folderId
- *
- * @return string
- */
- public static function get_document_preview(
- $course_info,
- $lp_id = false,
- $target = '',
- $session_id = 0,
- $add_move_button = false,
- $filter_by_folder = null,
- $overwrite_url = null,
- $showInvisibleFiles = false,
- $showOnlyFolders = false,
- $folderId = false
- ) {
- if (empty($course_info['real_id']) || empty($course_info['code']) || !is_array($course_info)) {
- return '';
- }
- $overwrite_url = Security::remove_XSS($overwrite_url);
- $user_id = api_get_user_id();
- $userInfo = api_get_user_info();
- $user_in_course = false;
- if (api_is_platform_admin()) {
- $user_in_course = true;
- }
- if (!$user_in_course) {
- if (CourseManager::is_course_teacher($user_id, $course_info['code'])) {
- $user_in_course = true;
- }
- }
- // Condition for the session
- $session_id = intval($session_id);
- if (!$user_in_course) {
- if (empty($session_id)) {
- if (CourseManager::is_user_subscribed_in_course($user_id, $course_info['code'])) {
- $user_in_course = true;
- }
- // Check if course is open then we can consider that the student is registered to the course
- if (isset($course_info) && in_array($course_info['visibility'], array(2, 3))) {
- $user_in_course = true;
- }
- } else {
- $user_status = SessionManager::get_user_status_in_course_session(
- $user_id,
- $course_info['real_id'],
- $session_id
- );
- //is true if is an student, course session teacher or coach
- if (in_array($user_status, array('0', '2', '6'))) {
- $user_in_course = true;
- }
- }
- }
- $tbl_doc = Database::get_course_table(TABLE_DOCUMENT);
- $tbl_item_prop = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $condition_session = " AND (last.session_id = '$session_id' OR last.session_id = '0' OR last.session_id IS NULL)";
- $add_folder_filter = null;
- if (!empty($filter_by_folder)) {
- $add_folder_filter = " AND docs.path LIKE '".Database::escape_string($filter_by_folder)."%'";
- }
- // If we are in LP display hidden folder https://support.chamilo.org/issues/6679
- $lp_visibility_condition = null;
- if ($lp_id) {
- // $lp_visibility_condition = " OR filetype='folder'";
- if ($showInvisibleFiles) {
- $lp_visibility_condition .= ' OR last.visibility = 0';
- }
- }
- $showOnlyFoldersCondition = null;
- if ($showOnlyFolders) {
- //$showOnlyFoldersCondition = " AND docs.filetype = 'folder' ";
- }
- $folderCondition = " AND docs.path LIKE '/%' ";
- if (!api_is_allowed_to_edit()) {
- $protectedFolders = self::getProtectedFolderFromStudent();
- foreach ($protectedFolders as $folder) {
- $folderCondition .= " AND docs.path NOT LIKE '$folder' ";
- }
- }
- $parentData = [];
- if ($folderId !== false) {
- $parentData = self::get_document_data_by_id($folderId, $course_info['code'], false, $session_id);
- if (!empty($parentData)) {
- $cleanedPath = $parentData['path'];
- $num = substr_count($cleanedPath, '/');
- $notLikeCondition = null;
- for ($i = 1; $i <= $num; $i++) {
- $repeat = str_repeat('/%', $i + 1);
- $notLikeCondition .= " AND docs.path NOT LIKE '".Database::escape_string($cleanedPath.$repeat)."' ";
- }
- $folderCondition = " AND
- docs.id <> $folderId AND
- docs.path LIKE '".$cleanedPath."/%'
- $notLikeCondition
- ";
- } else {
- $folderCondition = " AND
- docs.filetype = 'file' ";
- }
- }
- $levelCondition = null;
- if ($folderId === false) {
- $levelCondition = " AND docs.path NOT LIKE'/%/%'";
- }
- $sql = "SELECT DISTINCT last.visibility, docs.*
- FROM $tbl_item_prop AS last INNER JOIN $tbl_doc AS docs
- ON (docs.id = last.ref AND docs.c_id = last.c_id)
- WHERE
- docs.path NOT LIKE '%_DELETED_%' AND
- last.tool = '".TOOL_DOCUMENT."' $condition_session AND
- (last.visibility = '1' $lp_visibility_condition) AND
- last.visibility <> 2 AND
- docs.c_id = {$course_info['real_id']} AND
- last.c_id = {$course_info['real_id']}
- $showOnlyFoldersCondition
- $folderCondition
- $levelCondition
- $add_folder_filter
- ORDER BY docs.filetype DESC, docs.title ASC";
- $res_doc = Database::query($sql);
- $resources = Database::store_result($res_doc, 'ASSOC');
- $return = '';
- if ($lp_id) {
- if ($folderId === false) {
- /*$return .= '<div class="lp_resource_element">';
- $return .= Display::return_icon('new_doc.gif', '', array(), ICON_SIZE_SMALL);
- $return .= Display::url(
- get_lang('CreateTheDocument'),
- api_get_self().'?'.api_get_cidreq().'&action=add_item&type='.TOOL_DOCUMENT.'&lp_id='.$_SESSION['oLP']->lp_id
- );
- $return .= '</div>';*/
- }
- } else {
- $return .= Display::div(
- Display::url(
- Display::return_icon('close.png', get_lang('Close'), array(), ICON_SIZE_SMALL),
- ' javascript:void(0);',
- array('id' => 'close_div_'.$course_info['real_id'].'_'.$session_id, 'class' => 'close_div')
- ),
- array('style' => 'position:absolute;right:10px')
- );
- }
- // If you want to debug it, I advise you to do "echo" on the eval statements.
- $newResources = array();
- if (!empty($resources) && $user_in_course) {
- foreach ($resources as $resource) {
- $is_visible = self::is_visible_by_id(
- $resource['id'],
- $course_info,
- $session_id,
- api_get_user_id()
- );
- if ($showInvisibleFiles == false) {
- if (!$is_visible) {
- continue;
- }
- }
- $newResources[] = $resource;
- }
- }
- $label = get_lang('Documents');
- $documents = [];
- if ($folderId === false) {
- $documents[$label] = array(
- 'id' => 0,
- 'files' => $newResources
- );
- } else {
- if (is_array($parentData)) {
- $documents[$parentData['title']] = array(
- 'id' => intval($folderId),
- 'files' => $newResources
- );
- }
- }
- $write_result = self::write_resources_tree(
- $userInfo,
- $course_info,
- $session_id,
- $documents,
- $lp_id,
- $target,
- $add_move_button,
- $overwrite_url,
- $folderId
- );
- $return .= $write_result;
- if ($lp_id == false) {
- $url = api_get_path(WEB_AJAX_PATH).'lp.ajax.php?a=get_documents&url='.$overwrite_url.'&lp_id='.$lp_id.'&cidReq='.$course_info['code'];
- $return .= "<script>
- $('.doc_folder').click(function() {
- var realId = this.id;
- var my_id = this.id.split('_')[2];
- var tempId = 'temp_'+my_id;
- $('#res_'+my_id).show();
- var tempDiv = $('#'+realId).find('#'+tempId);
- if (tempDiv.length == 0) {
- $.ajax({
- async: false,
- type: 'GET',
- url: '".$url."',
- data: 'folder_id='+my_id,
- success: function(data) {
- $('#'+realId).append('<div id='+tempId+'>'+data+'</div>');
- }
- });
- }
- });
- $('.close_div').click(function() {
- var course_id = this.id.split('_')[2];
- var session_id = this.id.split('_')[3];
- $('#document_result_'+course_id+'_'+session_id).hide();
- $('.lp_resource').remove();
- $('.document_preview_container').html('');
- });
- </script>";
- } else {
- //For LPs
- $url = api_get_path(WEB_AJAX_PATH).'lp.ajax.php?a=get_documents&lp_id='.$lp_id.'&'.api_get_cidreq();
- $return .= "<script>
- function testResources(id, img) {
- var numericId = id.split('_')[1];
- var parentId = 'doc_id_'+numericId;
- var tempId = 'temp_'+numericId;
- var image = $('#'+img);
- if (image.hasClass('open')) {
- image.removeClass('open');
- image.attr('src', '" . Display::returnIconPath('nolines_plus.gif')."');
- $('#'+id).show();
- $('#'+tempId).hide();
- } else {
- image.addClass('open');
- image.attr('src', '" . Display::returnIconPath('nolines_minus.gif')."');
- $('#'+id).hide();
- $('#'+tempId).show();
- var tempDiv = $('#'+parentId).find('#'+tempId);
- if (tempDiv.length == 0) {
- $.ajax({
- type: 'GET',
- async: false,
- url: '".$url."',
- data: 'folder_id='+numericId,
- success: function(data) {
- tempDiv = $('#doc_id_'+numericId).append('<div id='+tempId+'>'+data+'</div>');
- }
- });
- }
- }
- }
- </script>";
- }
- if (!$user_in_course) {
- $return = '';
- }
- return $return;
- }
- /**
- * Parse file information into a link
- *
- * @param array $userInfo Current user info
- * @param array $course_info
- * @param int $session_id
- * @param array $resource
- * @param int $lp_id
- * @param bool $add_move_button
- * @param string $target
- * @param string $overwrite_url
- * @return null|string
- */
- private static function parseFile(
- $userInfo,
- $course_info,
- $session_id,
- $resource,
- $lp_id,
- $add_move_button,
- $target,
- $overwrite_url
- ) {
- $img_sys_path = api_get_path(SYS_CODE_PATH).'img/';
- $web_code_path = api_get_path(WEB_CODE_PATH);
- $documentId = $resource['id'];
- $path = $resource['path'];
- if (empty($path)) {
- $num = 0;
- } else {
- $num = substr_count($path, '/') - 1;
- }
- // It's a file.
- $icon = choose_image($path);
- $position = strrpos($icon, '.');
- $icon = substr($icon, 0, $position).'_small.gif';
- $my_file_title = $resource['title'];
- $visibility = $resource['visibility'];
- // If title is empty we try to use the path
- if (empty($my_file_title)) {
- $my_file_title = basename($path);
- }
- // Show the "image name" not the filename of the image.
- if ($lp_id) {
- // LP URL
- $url = api_get_path(WEB_CODE_PATH).'lp/lp_controller.php?'.api_get_cidreq().'&action=add_item&type='.TOOL_DOCUMENT.'&file='.$documentId.'&lp_id='.$lp_id;
- if (!empty($overwrite_url)) {
- $url = $overwrite_url.'&cidReq='.$course_info['code'].'&id_session='.$session_id.'&document_id='.$documentId.'';
- }
- } else {
- // Direct document URL
- $url = $web_code_path.'document/document.php?cidReq='.$course_info['code'].'&id_session='.$session_id.'&id='.$documentId;
- if (!empty($overwrite_url)) {
- $url = $overwrite_url.'&cidReq='.$course_info['code'].'&id_session='.$session_id.'&document_id='.$documentId;
- }
- }
- $img = Display::returnIconPath($icon);
- if (!file_exists($img_sys_path.$icon)) {
- $img = Display::returnIconPath('default_small.gif');
- }
- $link = Display::url(
- '<img alt="" src="'.$img.'" title="" /> '.$my_file_title, $url,
- array('target' => $target, 'class' => 'moved')
- );
- $directUrl = $web_code_path.'document/document.php?cidReq='.$course_info['code'].'&id_session='.$session_id.'&id='.$documentId;
- $link .= Display::url(
- Display::return_icon('preview_view.png', get_lang('Preview')),
- $directUrl,
- ['target' => '_blank']
- );
- $visibilityClass = null;
- if ($visibility == 0) {
- $visibilityClass = ' text-muted ';
- }
- $return = null;
- if ($lp_id == false) {
- $return .= '<li class="doc_resource '.$visibilityClass.' " data_id="'.$documentId.'" data_type="document" title="'.$my_file_title.'" >';
- } else {
- $return .= '<li class="doc_resource lp_resource_element '.$visibilityClass.' " data_id="'.$documentId.'" data_type="document" title="'.$my_file_title.'" >';
- }
- $return .= '<div class="item_data" style="margin-left:'.($num * 5).'px;margin-right:5px;">';
- if ($add_move_button) {
- $return .= '<a class="moved" href="#">';
- $return .= Display::return_icon('move_everywhere.png', get_lang('Move'), array(), ICON_SIZE_TINY);
- $return .= '</a> ';
- }
- $return .= $link;
- $sessionStar = api_get_session_image($resource['session_id'], $userInfo['status']);
- $return .= $sessionStar;
- $return .= '</div></li>';
- return $return;
- }
- /**
- * @param int $folderId
- * @param array $resource
- * @param int $lp_id
- * @return null|string
- */
- private static function parseFolder($folderId, $resource, $lp_id)
- {
- $title = isset($resource['title']) ? $resource['title'] : null;
- $path = isset($resource['path']) ? $resource['path'] : null;
- if (empty($path)) {
- $num = 0;
- } else {
- $num = substr_count($path, '/');
- }
- // It's a folder.
- //hide some folders
- if (in_array($path,
- array('shared_folder', 'chat_files', 'HotPotatoes_files', 'css', 'certificates'))) {
- return null;
- } elseif (preg_match('/_groupdocs/', $path)) {
- return null;
- } elseif (preg_match('/sf_user_/', $path)) {
- return null;
- } elseif (preg_match('/shared_folder_session_/', $path)) {
- return null;
- }
- //trad some titles
- /*
- if ($key == 'images') {
- $key = get_lang('Images');
- } elseif ($key == 'gallery') {
- $key = get_lang('Gallery');
- } elseif ($key == 'flash') {
- $key = get_lang('Flash');
- } elseif ($key == 'audio') {
- $key = get_lang('Audio');
- } elseif ($key == 'video') {
- $key = get_lang('Video');
- }*/
- $onclick = '';
- // if in LP, hidden folder are displayed in grey
- $folder_class_hidden = '';
- if ($lp_id) {
- if (isset($resource['visible']) && $resource['visible'] == 0) {
- $folder_class_hidden = "doc_folder_hidden"; // in base.css
- }
- $onclick = 'onclick="javascript: testResources(\'res_'.$resource['id'].'\',\'img_'.$resource['id'].'\')"';
- }
- $return = null;
- if (empty($path)) {
- $return = '<ul class="lp_resource">';
- }
- $return .= '<li class="doc_folder '.$folder_class_hidden.'" id="doc_id_'.$resource['id'].'" style="margin-left:'.($num * 18).'px; ">';
- $image = Display::returnIconPath('nolines_plus.gif');
- if (empty($path)) {
- $image = Display::returnIconPath('nolines_minus.gif');
- }
- $return .= '<img style="cursor: pointer;" src="'.$image.'" align="absmiddle" id="img_'.$resource['id'].'" '.$onclick.'>';
- $return .= Display::return_icon('lp_folder.gif').' ';
- $return .= '<span '.$onclick.' style="cursor: pointer;" >'.$title.'</span>';
- $return .= '</li>';
- if (empty($path)) {
- if ($folderId == false) {
- $return .= '<div id="res_'.$resource['id'].'" >';
- } else {
- $return .= '<div id="res_'.$resource['id'].'" style="display: none;" >';
- }
- }
- return $return;
- }
- /**
- * Generate and return an HTML list of resources based on a given array.
- * This list is used to show the course creator a list of available resources to choose from
- * when creating a learning path.
- * @param array $userInfo current user info
- * @param array $course_info
- * @param int $session_id
- * @param array $documents
- * @param bool $lp_id
- * @param string $target
- * @param bool $add_move_button
- * @param string $overwrite_url
- * @param int $folderId
- *
- * @return string
- */
- public static function write_resources_tree(
- $userInfo,
- $course_info,
- $session_id,
- $documents,
- $lp_id = false,
- $target = '',
- $add_move_button = false,
- $overwrite_url = null,
- $folderId = false
- ) {
- $return = '';
- if (!empty($documents)) {
- foreach ($documents as $key => $resource) {
- if (isset($resource['id']) && is_int($resource['id'])) {
- $mainFolderResource = array(
- 'id' => $resource['id'],
- 'title' => $key,
- );
- if ($folderId === false) {
- $return .= self::parseFolder($folderId, $mainFolderResource, $lp_id);
- }
- if (isset($resource['files'])) {
- $return .= self::write_resources_tree(
- $userInfo,
- $course_info,
- $session_id,
- $resource['files'],
- $lp_id,
- $target,
- $add_move_button,
- $overwrite_url
- );
- }
- $return .= '</div>';
- $return .= '</ul>';
- } else {
- if ($resource['filetype'] == 'folder') {
- $return .= self::parseFolder($folderId, $resource, $lp_id);
- } else {
- $return .= self::parseFile(
- $userInfo,
- $course_info,
- $session_id,
- $resource,
- $lp_id,
- $add_move_button,
- $target,
- $overwrite_url
- );
- }
- }
- }
- }
- return $return;
- }
- /**
- * @param int $doc_id
- * @param string $course_code
- * @param int $session_id
- * @param int $user_id
- * @param int $groupId iid
- * @return bool
- */
- public static function check_visibility_tree(
- $doc_id,
- $course_code,
- $session_id,
- $user_id,
- $groupId = 0
- ) {
- $document_data = self::get_document_data_by_id($doc_id, $course_code, null, $session_id);
- if ($session_id != 0 && !$document_data) {
- $document_data = self::get_document_data_by_id($doc_id, $course_code, null, 0);
- }
- if (!empty($document_data)) {
- // If admin or course teacher, allow anyway
- if (api_is_platform_admin() || CourseManager::is_course_teacher($user_id, $course_code)) {
- return true;
- }
- $course_info = api_get_course_info($course_code);
- if ($document_data['parent_id'] == false || empty($document_data['parent_id'])) {
- if (!empty($groupId)) {
- return true;
- }
- $visible = self::is_visible_by_id($doc_id, $course_info, $session_id, $user_id);
- return $visible;
- } else {
- $visible = self::is_visible_by_id($doc_id, $course_info, $session_id, $user_id);
- if (!$visible) {
- return false;
- } else {
- return self::check_visibility_tree(
- $document_data['parent_id'],
- $course_code,
- $session_id,
- $user_id,
- $groupId
- );
- }
- }
- } else {
- return false;
- }
- }
- /**
- * Index a given document.
- * @param int Document ID inside its corresponding course
- * @param string Course code
- * @param int Session ID (not used yet)
- * @param string Language of document's content (defaults to course language)
- * @param array Array of specific fields (['code'=>'value',...])
- * @param string What to do if the file already exists (default or overwrite)
- * @param bool When set to true, this runs the indexer without actually saving anything to any database
- * @return bool Returns true on presumed success, false on failure
- */
- public static function index_document(
- $docid,
- $course_code,
- $session_id = 0,
- $lang = 'english',
- $specific_fields_values = array(),
- $if_exists = '',
- $simulation = false
- ) {
- if (api_get_setting('search_enabled') !== 'true') {
- return false;
- }
- if (empty($docid) or $docid != intval($docid)) {
- return false;
- }
- if (empty($session_id)) {
- $session_id = api_get_session_id();
- }
- $course_info = api_get_course_info($course_code);
- $course_dir = $course_info['path'].'/document';
- $sys_course_path = api_get_path(SYS_COURSE_PATH);
- $base_work_dir = $sys_course_path.$course_dir;
- $course_id = $course_info['real_id'];
- $table_document = Database::get_course_table(TABLE_DOCUMENT);
- $qry = "SELECT path, title FROM $table_document WHERE c_id = $course_id AND id = '$docid' LIMIT 1";
- $result = Database::query($qry);
- if (Database::num_rows($result) == 1) {
- $row = Database::fetch_array($result);
- $doc_path = api_get_path(SYS_COURSE_PATH).$course_dir.$row['path'];
- //TODO: mime_content_type is deprecated, fileinfo php extension is enabled by default as of PHP 5.3.0
- // now versions of PHP on Debian testing(5.2.6-5) and Ubuntu(5.2.6-2ubuntu) are lower, so wait for a while
- $doc_mime = mime_content_type($doc_path);
- $allowed_mime_types = self::file_get_mime_type(true);
- // mime_content_type does not detect correctly some formats that are going to be supported for index, so an extensions array is used for the moment
- if (empty($doc_mime)) {
- $allowed_extensions = array(
- 'doc',
- 'docx',
- 'ppt',
- 'pptx',
- 'pps',
- 'ppsx',
- 'xls',
- 'xlsx',
- 'odt',
- 'odp',
- 'ods',
- 'pdf',
- 'txt',
- 'rtf',
- 'msg',
- 'csv',
- 'html',
- 'htm',
- );
- $extensions = preg_split("/[\/\\.]/", $doc_path);
- $doc_ext = strtolower($extensions[count($extensions) - 1]);
- if (in_array($doc_ext, $allowed_extensions)) {
- switch ($doc_ext) {
- case 'ppt':
- case 'pps':
- $doc_mime = 'application/vnd.ms-powerpoint';
- break;
- case 'xls':
- $doc_mime = 'application/vnd.ms-excel';
- break;
- }
- }
- }
- //@todo move this nightmare in a search controller or something like that!!! J.M
- if (in_array($doc_mime, $allowed_mime_types)) {
- $file_title = $row['title'];
- $file_content = self::get_text_content($doc_path, $doc_mime);
- $course_code = Database::escape_string($course_code);
- require_once api_get_path(LIBRARY_PATH).'search/ChamiloIndexer.class.php';
- require_once api_get_path(LIBRARY_PATH).'search/IndexableChunk.class.php';
- $ic_slide = new IndexableChunk();
- $ic_slide->addValue('title', $file_title);
- $ic_slide->addCourseId($course_code);
- $ic_slide->addToolId(TOOL_DOCUMENT);
- $xapian_data = array(
- SE_COURSE_ID => $course_code,
- SE_TOOL_ID => TOOL_DOCUMENT,
- SE_DATA => array('doc_id' => $docid),
- SE_USER => api_get_user_id(),
- );
- $ic_slide->xapian_data = serialize($xapian_data);
- $di = new ChamiloIndexer();
- $return = $di->connectDb(null, null, $lang);
- require_once api_get_path(LIBRARY_PATH).'specific_fields_manager.lib.php';
- $specific_fields = get_specific_field_list();
- // process different depending on what to do if file exists
- /**
- * @TODO Find a way to really verify if the file had been
- * overwriten. Now all work is done at
- * handle_uploaded_document() and it's difficult to verify it
- */
- if (!empty($if_exists) && $if_exists == 'overwrite') {
- // Overwrite the file on search engine
- // Actually, it consists on a delete of terms from db,
- // insert new ones, create a new search engine document,
- // and remove the old one
- // Get search_did
- $tbl_se_ref = Database::get_main_table(TABLE_MAIN_SEARCH_ENGINE_REF);
- $sql = 'SELECT * FROM %s WHERE course_code=\'%s\' AND tool_id=\'%s\' AND ref_id_high_level=%s LIMIT 1';
- $sql = sprintf($sql, $tbl_se_ref, $course_code, TOOL_DOCUMENT, $docid);
- $res = Database::query($sql);
- if (Database::num_rows($res) > 0) {
- $se_ref = Database::fetch_array($res);
- if (!$simulation) {
- $di->remove_document($se_ref['search_did']);
- }
- $all_specific_terms = '';
- foreach ($specific_fields as $specific_field) {
- if (!$simulation) {
- delete_all_specific_field_value($course_code, $specific_field['id'], TOOL_DOCUMENT, $docid);
- }
- // Update search engine
- if (isset($specific_fields_values[$specific_field['code']])) {
- $sterms = trim($specific_fields_values[$specific_field['code']]);
- } else { //if the specific field is not defined, force an empty one
- $sterms = '';
- }
- $all_specific_terms .= ' '.$sterms;
- $sterms = explode(',', $sterms);
- foreach ($sterms as $sterm) {
- $sterm = trim($sterm);
- if (!empty($sterm)) {
- $ic_slide->addTerm($sterm, $specific_field['code']);
- // updated the last param here from $value to $sterm without being sure - see commit15464
- if (!$simulation) {
- add_specific_field_value($specific_field['id'], $course_code, TOOL_DOCUMENT, $docid, $sterm);
- }
- }
- }
- }
- // Add terms also to content to make terms findable by probabilistic search
- $file_content = $all_specific_terms.' '.$file_content;
- if (!$simulation) {
- $ic_slide->addValue('content', $file_content);
- $di->addChunk($ic_slide);
- // Index and return a new search engine document id
- $did = $di->index();
- if ($did) {
- // update the search_did on db
- $tbl_se_ref = Database::get_main_table(TABLE_MAIN_SEARCH_ENGINE_REF);
- $sql = 'UPDATE %s SET search_did=%d WHERE id=%d LIMIT 1';
- $sql = sprintf($sql, $tbl_se_ref, (int) $did, (int) $se_ref['id']);
- Database::query($sql);
- }
- }
- }
- } else {
- // Add all terms
- $all_specific_terms = '';
- foreach ($specific_fields as $specific_field) {
- if (isset($specific_fields_values[$specific_field['code']])) {
- $sterms = trim($specific_fields_values[$specific_field['code']]);
- } else { //if the specific field is not defined, force an empty one
- $sterms = '';
- }
- $all_specific_terms .= ' '.$sterms;
- if (!empty($sterms)) {
- $sterms = explode(',', $sterms);
- foreach ($sterms as $sterm) {
- if (!$simulation) {
- $ic_slide->addTerm(trim($sterm), $specific_field['code']);
- add_specific_field_value($specific_field['id'], $course_code, TOOL_DOCUMENT, $docid, $sterm);
- }
- }
- }
- }
- // Add terms also to content to make terms findable by probabilistic search
- $file_content = $all_specific_terms.' '.$file_content;
- if (!$simulation) {
- $ic_slide->addValue('content', $file_content);
- $di->addChunk($ic_slide);
- // Index and return search engine document id
- $did = $di->index();
- if ($did) {
- // Save it to db
- $tbl_se_ref = Database::get_main_table(TABLE_MAIN_SEARCH_ENGINE_REF);
- $sql = 'INSERT INTO %s (id, course_code, tool_id, ref_id_high_level, search_did)
- VALUES (NULL , \'%s\', \'%s\', %s, %s)';
- $sql = sprintf($sql, $tbl_se_ref, $course_code, TOOL_DOCUMENT, $docid, $did);
- Database::query($sql);
- } else {
- return false;
- }
- }
- }
- } else {
- return false;
- }
- }
- return true;
- }
- /**
- * @return array
- */
- public static function get_web_odf_extension_list()
- {
- return array('ods', 'odt', 'odp');
- }
- /**
- * Set of extension allowed to use Jodconverter
- * @param $mode 'from'
- * 'to'
- * 'all'
- * @param $format 'text'
- * 'spreadsheet'
- * 'presentation'
- * 'drawing'
- * 'all'
- * @return array
- */
- public static function getJodconverterExtensionList($mode, $format)
- {
- $extensionList = array();
- $extensionListFromText = array(
- 'odt',
- 'sxw',
- 'rtf',
- 'doc',
- 'docx',
- 'wpd',
- 'txt',
- );
- $extensionListToText = array(
- 'pdf',
- 'odt',
- 'sxw',
- 'rtf',
- 'doc',
- 'docx',
- 'txt',
- );
- $extensionListFromSpreadsheet = array(
- 'ods',
- 'sxc',
- 'xls',
- 'xlsx',
- 'csv',
- 'tsv',
- );
- $extensionListToSpreadsheet = array(
- 'pdf',
- 'ods',
- 'sxc',
- 'xls',
- 'xlsx',
- 'csv',
- 'tsv',
- );
- $extensionListFromPresentation = array(
- 'odp',
- 'sxi',
- 'ppt',
- 'pptx',
- );
- $extensionListToPresentation = array(
- 'pdf',
- 'swf',
- 'odp',
- 'sxi',
- 'ppt',
- 'pptx',
- );
- $extensionListFromDrawing = array('odg');
- $extensionListToDrawing = array('svg', 'swf');
- if ($mode === 'from') {
- if ($format === 'text') {
- $extensionList = array_merge($extensionList, $extensionListFromText);
- } elseif ($format === 'spreadsheet') {
- $extensionList = array_merge($extensionList, $extensionListFromSpreadsheet);
- } elseif ($format === 'presentation') {
- $extensionList = array_merge($extensionList, $extensionListFromPresentation);
- } elseif ($format === 'drawing') {
- $extensionList = array_merge($extensionList, $extensionListFromDrawing);
- } elseif ($format === 'all') {
- $extensionList = array_merge($extensionList, $extensionListFromText);
- $extensionList = array_merge($extensionList, $extensionListFromSpreadsheet);
- $extensionList = array_merge($extensionList, $extensionListFromPresentation);
- $extensionList = array_merge($extensionList, $extensionListFromDrawing);
- }
- } elseif ($mode === 'to') {
- if ($format === 'text') {
- $extensionList = array_merge($extensionList, $extensionListToText);
- } elseif ($format === 'spreadsheet') {
- $extensionList = array_merge($extensionList, $extensionListToSpreadsheet);
- } elseif ($format === 'presentation') {
- $extensionList = array_merge($extensionList, $extensionListToPresentation);
- } elseif ($format === 'drawing') {
- $extensionList = array_merge($extensionList, $extensionListToDrawing);
- } elseif ($format === 'all') {
- $extensionList = array_merge($extensionList, $extensionListToText);
- $extensionList = array_merge($extensionList, $extensionListToSpreadsheet);
- $extensionList = array_merge($extensionList, $extensionListToPresentation);
- $extensionList = array_merge($extensionList, $extensionListToDrawing);
- }
- } elseif ($mode === 'all') {
- if ($format === 'text') {
- $extensionList = array_merge($extensionList, $extensionListFromText);
- $extensionList = array_merge($extensionList, $extensionListToText);
- } elseif ($format === 'spreadsheet') {
- $extensionList = array_merge($extensionList, $extensionListFromSpreadsheet);
- $extensionList = array_merge($extensionList, $extensionListToSpreadsheet);
- } elseif ($format === 'presentation') {
- $extensionList = array_merge($extensionList, $extensionListFromPresentation);
- $extensionList = array_merge($extensionList, $extensionListToPresentation);
- } elseif ($format === 'drawing') {
- $extensionList = array_merge($extensionList, $extensionListFromDrawing);
- $extensionList = array_merge($extensionList, $extensionListToDrawing);
- } elseif ($format === 'all') {
- $extensionList = array_merge($extensionList, $extensionListFromText);
- $extensionList = array_merge($extensionList, $extensionListToText);
- $extensionList = array_merge($extensionList, $extensionListFromSpreadsheet);
- $extensionList = array_merge($extensionList, $extensionListToSpreadsheet);
- $extensionList = array_merge($extensionList, $extensionListFromPresentation);
- $extensionList = array_merge($extensionList, $extensionListToPresentation);
- $extensionList = array_merge($extensionList, $extensionListFromDrawing);
- $extensionList = array_merge($extensionList, $extensionListToDrawing);
- }
- }
- return $extensionList;
- }
- /**
- * Get Format type list by extension and mode
- * @param string $mode Mode to search format type list
- * @example 'from'
- * @example 'to'
- * @param string $extension file extension to check file type
- * @return array
- */
- public static function getFormatTypeListConvertor($mode = 'from', $extension)
- {
- $formatTypesList = array();
- $formatTypes = array('text', 'spreadsheet', 'presentation', 'drawing');
- foreach ($formatTypes as $formatType) {
- if (
- in_array(
- $extension,
- self::getJodconverterExtensionList($mode, $formatType)
- )
- ) {
- $formatTypesList[] = $formatType;
- }
- }
- return $formatTypesList;
- }
- /**
- * @param string $path
- * @param bool $is_certificate_mode
- * @return bool
- */
- public static function is_folder_to_avoid($path, $is_certificate_mode = false)
- {
- $foldersToAvoid = array(
- '/HotPotatoes_files',
- '/certificates',
- );
- $systemFolder = api_get_course_setting('show_system_folders');
- if ($systemFolder == 1) {
- $foldersToAvoid = array();
- }
- if (basename($path) == 'css') {
- return true;
- }
- if ($is_certificate_mode == false) {
- //Certificate results
- if (strstr($path, 'certificates')) {
- return true;
- }
- }
- // Admin setting for Hide/Show the folders of all users
- if (api_get_setting('show_users_folders') == 'false') {
- $foldersToAvoid[] = '/shared_folder';
- if (strstr($path, 'shared_folder_session_')) {
- return true;
- }
- }
- // Admin setting for Hide/Show Default folders to all users
- if (api_get_setting('show_default_folders') == 'false') {
- $foldersToAvoid[] = '/images';
- $foldersToAvoid[] = '/flash';
- $foldersToAvoid[] = '/audio';
- $foldersToAvoid[] = '/video';
- }
- // Admin setting for Hide/Show chat history folder
- if (api_get_setting('show_chat_folder') == 'false') {
- $foldersToAvoid[] = '/chat_files';
- }
- if (is_array($foldersToAvoid)) {
- return in_array($path, $foldersToAvoid);
- } else {
- return false;
- }
- }
- /**
- * @return array
- */
- public static function get_system_folders()
- {
- return array(
- '/certificates',
- '/HotPotatoes_files',
- '/chat_files',
- '/images',
- '/flash',
- '/audio',
- '/video',
- '/shared_folder',
- '/learning_path'
- );
- }
- /**
- * @return array
- */
- public static function getProtectedFolderFromStudent()
- {
- return array(
- '/certificates',
- '/HotPotatoes_files',
- '/chat_files',
- '/shared_folder',
- '/learning_path'
- );
- }
- /**
- * @param string $courseCode
- * @return string 'visible' or 'invisible' string
- */
- public static function getDocumentDefaultVisibility($courseCode)
- {
- $settings = api_get_setting('tool_visible_by_default_at_creation');
- $defaultVisibility = 'visible';
- if (isset($settings['documents'])) {
- $portalDefaultVisibility = 'invisible';
- if ($settings['documents'] == 'true') {
- $portalDefaultVisibility = 'visible';
- }
- $defaultVisibility = $portalDefaultVisibility;
- }
- if (api_get_setting('documents_default_visibility_defined_in_course') == 'true') {
- $courseVisibility = api_get_course_setting('documents_default_visibility', $courseCode);
- if (!empty($courseVisibility) && in_array($courseVisibility, array('visible', 'invisible'))) {
- $defaultVisibility = $courseVisibility;
- }
- }
- return $defaultVisibility;
- }
- /**
- * @param array $courseInfo
- * @param int $id doc id
- * @param string $visibility visible/invisible
- * @param int $userId
- */
- public static function updateVisibilityFromAllSessions($courseInfo, $id, $visibility, $userId)
- {
- $sessionList = SessionManager::get_session_by_course($courseInfo['real_id']);
- if (!empty($sessionList)) {
- foreach ($sessionList as $session) {
- $sessionId = $session['id'];
- api_item_property_update(
- $courseInfo,
- TOOL_DOCUMENT,
- $id,
- $visibility,
- $userId,
- null,
- null,
- null,
- null,
- $sessionId
- );
- }
- }
- }
- /**
- * @param string $file
- * @return string
- */
- public static function readNanogongFile($file)
- {
- $nanoGongJarFile = api_get_path(WEB_LIBRARY_PATH).'nanogong/nanogong.jar';
- $html = '<applet id="applet" archive="'.$nanoGongJarFile.'" code="gong.NanoGong" width="160" height="95">';
- $html .= '<param name="SoundFileURL" value="'.$file.'" />';
- $html .= '<param name="ShowSaveButton" value="false" />';
- $html .= '<param name="ShowTime" value="true" />';
- $html .= '<param name="ShowRecordButton" value="false" />';
- $html .= '</applet>';
- return $html;
- }
- /**
- * @param string $filePath
- * @param string $path
- * @param array $courseInfo
- * @param int $sessionId
- * @param string $whatIfFileExists overwrite|rename
- * @param int $userId
- * @param int $groupId
- * @param int $toUserId
- * @param string $comment
- * @return bool|path
- */
- public static function addFileToDocumentTool(
- $filePath,
- $path,
- $courseInfo,
- $sessionId,
- $userId,
- $whatIfFileExists = 'overwrite',
- $groupId = null,
- $toUserId = null,
- $comment = null
- ) {
- if (!file_exists($filePath)) {
- return false;
- }
- $fileInfo = pathinfo($filePath);
- $file = array(
- 'name' => $fileInfo['basename'],
- 'tmp_name' => $filePath,
- 'size' => filesize($filePath),
- 'from_file' => true
- );
- $course_dir = $courseInfo['path'].'/document';
- $baseWorkDir = api_get_path(SYS_COURSE_PATH).$course_dir;
- $filePath = handle_uploaded_document(
- $courseInfo,
- $file,
- $baseWorkDir,
- $path,
- $userId,
- $groupId,
- $toUserId,
- false,
- $whatIfFileExists,
- false,
- false,
- $comment,
- $sessionId
- );
- if ($filePath) {
- return self::get_document_id(
- $courseInfo,
- $filePath,
- $sessionId
- );
- }
- return false;
- }
- /**
- * Converts wav to mp3 file.
- * Requires the ffmpeg lib. In ubuntu: sudo apt-get install ffmpeg
- * @param string $wavFile
- * @param bool $removeWavFileIfSuccess
- * @return bool
- */
- public static function convertWavToMp3($wavFile, $removeWavFileIfSuccess = false)
- {
- if (file_exists($wavFile)) {
- try {
- $ffmpeg = \FFMpeg\FFMpeg::create();
- $video = $ffmpeg->open($wavFile);
- $mp3File = str_replace('wav', 'mp3', $wavFile);
- $result = $video->save(new FFMpeg\Format\Audio\Mp3(), $mp3File);
- if ($result && $removeWavFileIfSuccess) {
- unlink($wavFile);
- }
- if (file_exists($mp3File)) {
- return $mp3File;
- }
- } catch (Exception $e) {
- error_log($e->getMessage());
- error_log($e->getPrevious()->getMessage());
- }
- }
- return false;
- }
- /**
- * @param string $documentData wav document information
- * @param array $courseInfo
- * @param int $sessionId
- * @param int $userId user that adds the document
- * @param string $whatIfFileExists
- * @param bool $deleteWavFile
- *
- * @return bool
- */
- public static function addAndConvertWavToMp3(
- $documentData,
- $courseInfo,
- $sessionId,
- $userId,
- $whatIfFileExists = 'overwrite',
- $deleteWavFile = false
- ) {
- if (empty($documentData)) {
- return false;
- }
- if (isset($documentData['absolute_path']) &&
- file_exists($documentData['absolute_path'])
- ) {
- $mp3FilePath = self::convertWavToMp3($documentData['absolute_path']);
- error_log($mp3FilePath);
- if (!empty($mp3FilePath) && file_exists($mp3FilePath)) {
- $documentId = self::addFileToDocumentTool(
- $mp3FilePath,
- dirname($documentData['path']),
- $courseInfo,
- $sessionId,
- $userId,
- $whatIfFileExists,
- null,
- null,
- $documentData['comment']
- );
- if (!empty($documentId)) {
- if ($deleteWavFile) {
- $coursePath = $courseInfo['directory'].'/document';
- $documentPath = api_get_path(SYS_COURSE_PATH).$coursePath;
- self::delete_document(
- $courseInfo,
- null,
- $documentPath,
- $sessionId,
- $documentData['id']
- );
- }
- return $documentId;
- }
- }
- }
- return false;
- }
- /**
- * Sets
- * @param string $file ($document_data['path'])
- * @param string $file_url_sys
- * @return string
- */
- public static function generateAudioTempFile($file, $file_url_sys)
- {
- //make temp audio
- $temp_folder = api_get_path(SYS_ARCHIVE_PATH).'temp/audio';
- if (!file_exists($temp_folder)) {
- @mkdir($temp_folder, api_get_permissions_for_new_directories(), true);
- }
- //make htaccess with allow from all, and file index.html into temp/audio
- $htaccess = api_get_path(SYS_ARCHIVE_PATH).'temp/audio/.htaccess';
- if (!file_exists($htaccess)) {
- $htaccess_content = "order deny,allow\r\nallow from all\r\nOptions -Indexes";
- $fp = @ fopen(api_get_path(SYS_ARCHIVE_PATH).'temp/audio/.htaccess', 'w');
- if ($fp) {
- fwrite($fp, $htaccess_content);
- fclose($fp);
- }
- }
- //encript temp name file
- $name_crip = sha1(uniqid()); //encript
- $findext = explode(".", $file);
- $extension = $findext[count($findext) - 1];
- $file_crip = $name_crip.'.'.$extension;
- //copy file to temp/audio directory
- $from_sys = $file_url_sys;
- $to_sys = api_get_path(SYS_ARCHIVE_PATH).'temp/audio/'.$file_crip;
- if (file_exists($from_sys)) {
- copy($from_sys, $to_sys);
- }
- //get file from tmp directory
- $_SESSION['temp_audio_nanogong'] = $to_sys;
- return api_get_path(WEB_ARCHIVE_PATH).'temp/audio/'.$file_crip;
- }
- /**
- * Erase temp nanogong audio.
- */
- public static function removeGeneratedAudioTempFile()
- {
- if (isset($_SESSION['temp_audio_nanogong'])
- && !empty($_SESSION['temp_audio_nanogong'])
- && is_file($_SESSION['temp_audio_nanogong'])) {
- unlink($_SESSION['temp_audio_nanogong']);
- unset($_SESSION['temp_audio_nanogong']);
- }
- }
- /**
- * Check if the past is used in this course.
- * @param array $courseInfo
- * @param string $path
- *
- * @return array
- */
- public static function getDocumentByPathInCourse($courseInfo, $path)
- {
- $table = Database::get_course_table(TABLE_DOCUMENT);
- $path = Database::escape_string($path);
- $courseId = $courseInfo['real_id'];
- if (empty($courseId)) {
- return false;
- }
- $sql = "SELECT * FROM $table WHERE c_id = $courseId AND path = '$path'";
- $result = Database::query($sql);
- return Database::store_result($result, 'ASSOC');
- }
- /**
- * @param array $_course
- * @return int
- */
- public static function createDefaultAudioFolder($_course)
- {
- if (!isset($_course['path'])) {
- return false;
- }
- $audioId = null;
- $path = api_get_path(SYS_COURSE_PATH).$_course['path'].'/document/';
- if (!is_dir($path.'audio')) {
- mkdir($path.'audio', api_get_permissions_for_new_directories());
- $audioId = add_document($_course, '/audio', 'folder', 0, 'Audio');
- api_item_property_update(
- $_course,
- TOOL_DOCUMENT,
- $audioId,
- 'FolderCreated',
- api_get_user_id(),
- null,
- null,
- null,
- null,
- api_get_session_id()
- );
- }
- return $audioId;
- }
- /**
- * Generate a default certificate for a courses
- *
- * @global string $css CSS directory
- * @global string $img_dir image directory
- * @global string $default_course_dir Course directory
- * @global string $js JS directory
- * @param array $courseData The course info
- * @param bool $fromBaseCourse
- * @param int $sessionId
- */
- public static function generateDefaultCertificate($courseData, $fromBaseCourse = false, $sessionId = 0)
- {
- if (empty($courseData)) {
- return false;
- }
- global $css, $img_dir, $default_course_dir, $js;
- $codePath = api_get_path(REL_CODE_PATH);
- $dir = '/certificates';
- $comment = null;
- $title = get_lang('DefaultCertificate');
- $fileName = api_replace_dangerous_char($title);
- $filePath = api_get_path(SYS_COURSE_PATH)."{$courseData['directory']}/document$dir";
- if (!is_dir($filePath)) {
- mkdir($filePath, api_get_permissions_for_new_directories());
- }
- $fileFullPath = "$filePath/$fileName.html";
- $fileType = 'file';
- $templateContent = file_get_contents(api_get_path(SYS_CODE_PATH).'gradebook/certificate_template/template.html');
- $search = array('{CSS}', '{IMG_DIR}', '{REL_CODE_PATH}', '{COURSE_DIR}');
- $replace = array($css.$js, $img_dir, $codePath, $default_course_dir);
- $fileContent = str_replace($search, $replace, $templateContent);
- $saveFilePath = "$dir/$fileName.html";
- if ($fromBaseCourse) {
- $defaultCertificateId = self::get_default_certificate_id(
- $courseData['code'],
- 0
- );
- if (!empty($defaultCertificateId)) {
- // We have a certificate from the course base
- $documentData = self::get_document_data_by_id(
- $defaultCertificateId,
- $courseData['code'],
- false,
- 0
- );
- if ($documentData) {
- $fileContent = file_get_contents($documentData['absolute_path']);
- }
- }
- }
- if (file_exists($fileFullPath) === false) {
- $result = file_put_contents($fileFullPath, $fileContent);
- if ($result) {
- $fileSize = filesize($fileFullPath);
- $documentId = add_document(
- $courseData,
- $saveFilePath,
- $fileType,
- $fileSize,
- $title,
- $comment,
- 0, //$readonly = 0,
- true, //$save_visibility = true,
- null, //$group_id = null,
- $sessionId
- );
- api_item_property_update(
- $courseData,
- TOOL_DOCUMENT,
- $documentId,
- 'DocumentAdded',
- api_get_user_id(),
- null,
- null,
- null,
- null,
- $sessionId
- );
- $defaultCertificateId = self::get_default_certificate_id(
- $courseData['code'],
- $sessionId
- );
- if (!isset($defaultCertificateId)) {
- self::attach_gradebook_certificate(
- $courseData['code'],
- $documentId,
- $sessionId
- );
- }
- }
- }
- }
- /**
- * Update the document name
- * @param int $documentId The document id
- * @param string $newName The new name
- */
- public static function renameDocument($documentId, $newName)
- {
- $documentId = intval($documentId);
- $newName = Database::escape_string($newName);
- $docuentTable = Database::get_course_table(TABLE_DOCUMENT);
- $values = array(
- 'title' => $newName
- );
- $whereConditions = array(
- 'id = ?' => $documentId
- );
- Database::update($docuentTable, $values, $whereConditions);
- }
- /**
- * Get folder/file suffix
- *
- * @param array $courseInfo
- * @param int $sessionId
- * @param int $groupId
- *
- * @return string
- */
- public static function getDocumentSuffix($courseInfo, $sessionId, $groupId)
- {
- // If no session or group, then no suffix.
- if (empty($sessionId) && empty($groupId)) {
- return '';
- }
- return '__'.intval($sessionId).'__'.intval($groupId);
- }
- /**
- * Fix a document name adding session id and group id
- * Turns picture.jpg -> picture__1__2.jpg
- * Where 1 = session id and 2 group id
- * Of session id and group id are empty then the function returns:
- * picture.jpg -> picture.jpg
- *
- * @param string $name folder or file name
- * @param string $type 'folder' or 'file'
- * @param array $courseInfo
- * @param int $sessionId
- * @param int $groupId
- *
- * @return string
- */
- public static function fixDocumentName($name, $type, $courseInfo, $sessionId, $groupId)
- {
- $suffix = self::getDocumentSuffix($courseInfo, $sessionId, $groupId);
- switch ($type) {
- case 'folder':
- $name = $name.$suffix;
- break;
- case 'file':
- $name = self::addSuffixToFileName($name, $suffix);
- break;
- }
- return $name;
- }
- /**
- * Add a suffix to a file Example:
- * /folder/picture.jpg => to /folder/picture_this.jpg
- * where "_this" is the suffix
- * @param string $name
- * @param string $suffix
- * @return string
- */
- public static function addSuffixToFileName($name, $suffix)
- {
- $extension = pathinfo($name, PATHINFO_EXTENSION);
- $fileName = pathinfo($name, PATHINFO_FILENAME);
- $dir = pathinfo($name, PATHINFO_DIRNAME);
- if ($dir == '.') {
- $dir = null;
- }
- if (!empty($dir) && $dir != '/') {
- $dir = $dir.'/';
- }
- $name = $dir.$fileName.$suffix.'.'.$extension;
- return $name;
- }
- /**
- * Check if folder exist in the course base or in the session course
- * @param string $folder Example: /folder/folder2
- * @param array $courseInfo
- * @param int $sessionId
- * @param int $groupId group.id
- *
- * @return bool
- */
- public static function folderExists(
- $folder,
- $courseInfo,
- $sessionId,
- $groupId
- ) {
- $courseId = $courseInfo['real_id'];
- if (empty($courseId)) {
- return false;
- }
- $sessionId = intval($sessionId);
- $folderWithSuffix = self::fixDocumentName(
- $folder,
- 'folder',
- $courseInfo,
- $sessionId,
- $groupId
- );
- $folder = Database::escape_string($folder);
- $folderWithSuffix = Database::escape_string($folderWithSuffix);
- // Check if pathname already exists inside document table
- $tbl_document = Database::get_course_table(TABLE_DOCUMENT);
- $sql = "SELECT id, path FROM $tbl_document
- WHERE
- filetype = 'folder' AND
- c_id = $courseId AND
- (path = '$folder' OR path = '$folderWithSuffix') AND
- (session_id = 0 OR session_id = $sessionId)
- ";
- $rs = Database::query($sql);
- if (Database::num_rows($rs)) {
- return true;
- }
- return false;
- }
- /**
- * Check if file exist in the course base or in the session course
- * @param string $fileName Example: /folder/picture.jpg
- * @param array $courseInfo
- * @param int $sessionId
- * @param int $groupId
- *
- * @return bool
- */
- public static function documentExists(
- $fileName,
- $courseInfo,
- $sessionId,
- $groupId
- ) {
- $courseId = $courseInfo['real_id'];
- if (empty($courseId)) {
- return false;
- }
- $sessionId = intval($sessionId);
- $fileNameEscape = Database::escape_string($fileName);
- $fileNameWithSuffix = self::fixDocumentName(
- $fileName,
- 'file',
- $courseInfo,
- $sessionId,
- $groupId
- );
- $fileNameWithSuffix = Database::escape_string($fileNameWithSuffix);
- // Check if pathname already exists inside document table
- $table = Database::get_course_table(TABLE_DOCUMENT);
- $sql = "SELECT id, path FROM $table
- WHERE
- filetype = 'file' AND
- c_id = $courseId AND
- (
- path = '".$fileNameEscape."' OR
- path = '$fileNameWithSuffix'
- ) AND
- (session_id = 0 OR session_id = $sessionId)
- ";
- $rs = Database::query($sql);
- if (Database::num_rows($rs)) {
- return true;
- }
- return false;
- }
- /**
- * Undo the suffix applied to a file example:
- * turns picture__1__1.jpg to picture.jpg
- * @param string $name
- * @param int $courseId
- * @param int $sessionId
- * @param int $groupId
- *
- * @return string
- */
- public static function undoFixDocumentName(
- $name,
- $courseId,
- $sessionId,
- $groupId
- ) {
- if (empty($sessionId) && empty($groupId)) {
- return $name;
- }
- $suffix = self::getDocumentSuffix(
- array('real_id' => $courseId),
- $sessionId,
- $groupId
- );
- $name = str_replace($suffix, '', $name);
- return $name;
- }
- /**
- * @param string $path
- * @param string $name
- * @param array $courseInfo
- * @param int $sessionId
- * @param int $groupId
- *
- * @return string
- */
- public static function getUniqueFileName($path, $name, $courseInfo, $sessionId, $groupId)
- {
- $counter = 1;
- $filePath = $path.$name;
- $uniqueName = $name;
- while ($documentExists = self::documentExists(
- $filePath,
- $courseInfo,
- $sessionId,
- $groupId
- )) {
- $uniqueName = self::addSuffixToFileName($name, '_'.$counter);
- $filePath = $path.$uniqueName;
- $counter++;
- }
- return $uniqueName;
- }
- /**
- * Builds the form that enables the user to
- * select a directory to browse/upload in
- *
- * @param array An array containing the folders we want to be able to select
- * @param string The current folder (path inside of the "document" directory, including the prefix "/")
- * @param string Group directory, if empty, prevents documents to be uploaded (because group documents cannot be uploaded in root)
- * @param boolean Whether to change the renderer (this will add a template <span> to the QuickForm object displaying the form)
- * @return string html form
- */
- public static function build_directory_selector(
- $folders,
- $document_id,
- $group_dir = '',
- $change_renderer = false,
- & $form = null,
- $selectName = 'id'
- ) {
- $doc_table = Database::get_course_table(TABLE_DOCUMENT);
- $course_id = api_get_course_int_id();
- $folder_titles = array();
- if (is_array($folders)) {
- $escaped_folders = array();
- foreach ($folders as $key => & $val) {
- $escaped_folders[$key] = Database::escape_string($val);
- }
- $folder_sql = implode("','", $escaped_folders);
- $sql = "SELECT path, title
- FROM $doc_table
- WHERE
- filetype = 'folder' AND
- c_id = $course_id AND
- path IN ('".$folder_sql."')";
- $res = Database::query($sql);
- $folder_titles = array();
- while ($obj = Database::fetch_object($res)) {
- $folder_titles[$obj->path] = $obj->title;
- }
- }
- $attributes = [];
- if (empty($form)) {
- $form = new FormValidator('selector', 'GET', api_get_self().'?'.api_get_cidreq());
- $attributes = array('onchange' => 'javascript: document.selector.submit();');
- }
- $form->addElement('hidden', 'cidReq', api_get_course_id());
- $parent_select = $form->addSelect(
- $selectName,
- get_lang('CurrentDirectory'),
- '',
- $attributes
- );
- // Group documents cannot be uploaded in the root
- if (empty($group_dir)) {
- $parent_select->addOption(get_lang('Documents'), '/');
- if (is_array($folders)) {
- foreach ($folders as $folder_id => & $folder) {
- $selected = ($document_id == $folder_id) ? ' selected="selected"' : '';
- $path_parts = explode('/', $folder);
- $folder_titles[$folder] = cut($folder_titles[$folder], 80);
- $counter = count($path_parts) - 2;
- if ($counter > 0) {
- $label = str_repeat(' ', $counter).' — '.$folder_titles[$folder];
- } else {
- $label = ' — '.$folder_titles[$folder];
- }
- $parent_select->addOption($label, $folder_id);
- if ($selected != '') {
- $parent_select->setSelected($folder_id);
- }
- }
- }
- } else {
- if (!empty($folders)) {
- foreach ($folders as $folder_id => & $folder) {
- $selected = ($document_id == $folder_id) ? ' selected="selected"' : '';
- $label = $folder_titles[$folder];
- if ($folder == $group_dir) {
- $label = get_lang('Documents');
- } else {
- $path_parts = explode('/', str_replace($group_dir, '', $folder));
- $label = cut($label, 80);
- $label = str_repeat(' ', count($path_parts) - 2).' — '.$label;
- }
- $parent_select->addOption($label, $folder_id);
- if ($selected != '') {
- $parent_select->setSelected($folder_id);
- }
- }
- }
- }
- $html = $form->toHtml();
- return $html;
- }
- /**
- * Create a html hyperlink depending on if it's a folder or a file
- *
- * @param array $document_data
- * @param array $course_info
- * @param int $show_as_icon - if it is true, only a clickable icon will be shown
- * @param int $visibility (1/0)
- * @param int $counter
- * @param int $size
- * @param bool $isAllowedToEdit
- *
- * @return string url
- */
- public static function create_document_link(
- $document_data,
- $course_info,
- $show_as_icon = false,
- $counter = null,
- $visibility,
- $size = 0,
- $isAllowedToEdit = false
- ) {
- global $dbl_click_id;
- $current_session_id = api_get_session_id();
- $courseParams = api_get_cidreq();
- $www = api_get_path(WEB_COURSE_PATH).$course_info['path'].'/document';
- $webODFList = self::get_web_odf_extension_list();
- // Get the title or the basename depending on what we're using
- if ($document_data['title'] != '') {
- $title = $document_data['title'];
- } else {
- $title = basename($document_data['path']);
- }
- $filetype = $document_data['filetype'];
- $path = $document_data['path'];
- $url_path = urlencode($document_data['path']);
- // Add class="invisible" on invisible files
- $visibility_class = $visibility == false ? ' class="muted"' : '';
- $forcedownload_link = null;
- $forcedownload_icon = null;
- $prevent_multiple_click = null;
- if (!$show_as_icon) {
- // Build download link (icon)
- $forcedownload_link = ($filetype == 'folder') ? api_get_self().'?'.$courseParams.'&action=downloadfolder&id='.$document_data['id'] : api_get_self().'?'.$courseParams.'&action=download&id='.$document_data['id'];
- // Folder download or file download?
- $forcedownload_icon = ($filetype == 'folder') ? 'save_pack.png' : 'save.png';
- // Prevent multiple clicks on zipped folder download
- $prevent_multiple_click = ($filetype == 'folder') ? " onclick=\"javascript: if(typeof clic_$dbl_click_id == 'undefined' || !clic_$dbl_click_id) { clic_$dbl_click_id=true; window.setTimeout('clic_".($dbl_click_id++)."=false;',10000); } else { return false; }\"" : '';
- }
- $target = '_self';
- $is_browser_viewable_file = false;
- if ($filetype == 'file') {
- // Check the extension
- $ext = explode('.', $path);
- $ext = strtolower($ext[sizeof($ext) - 1]);
- // HTML-files an some other types are shown in a frameset by default.
- $is_browser_viewable_file = self::is_browser_viewable($ext);
- if ($is_browser_viewable_file) {
- if ($ext == 'pdf' || in_array($ext, $webODFList)) {
- $url = api_get_self().'?'.$courseParams.'&action=download&id='.$document_data['id'];
- } else {
- $url = 'showinframes.php?'.$courseParams.'&id='.$document_data['id'];
- }
- } else {
- // url-encode for problematic characters (we may not call them dangerous characters...)
- $path = str_replace('%2F', '/', $url_path).'?'.$courseParams;
- $url = $www.$path;
- }
- } else {
- $url = api_get_self().'?'.$courseParams.'&id='.$document_data['id'];
- }
- // The little download icon
- $tooltip_title = $title;
- $tooltip_title_alt = $tooltip_title;
- if ($path == '/shared_folder') {
- $tooltip_title_alt = get_lang('UserFolders');
- } elseif (strstr($path, 'shared_folder_session_')) {
- $tooltip_title_alt = get_lang('UserFolders').' ('.api_get_session_name(api_get_session_id()).')';
- } elseif (strstr($tooltip_title, 'sf_user_')) {
- $userinfo = api_get_user_info(substr($tooltip_title, 8));
- $tooltip_title_alt = get_lang('UserFolder').' '.$userinfo['complete_name'];
- } elseif ($path == '/chat_files') {
- $tooltip_title_alt = get_lang('ChatFiles');
- } elseif ($path == '/learning_path') {
- $tooltip_title_alt = get_lang('LearningPaths');
- } elseif ($path == '/video') {
- $tooltip_title_alt = get_lang('Video');
- } elseif ($path == '/audio') {
- $tooltip_title_alt = get_lang('Audio');
- } elseif ($path == '/flash') {
- $tooltip_title_alt = get_lang('Flash');
- } elseif ($path == '/images') {
- $tooltip_title_alt = get_lang('Images');
- } elseif ($path == '/images/gallery') {
- $tooltip_title_alt = get_lang('DefaultCourseImages');
- }
- $copy_to_myfiles = $open_in_new_window_link = null;
- $curdirpath = isset($_GET['curdirpath']) ? Security::remove_XSS($_GET['curdirpath']) : null;
- $send_to = null;
- $checkExtension = $path;
- if (!$show_as_icon) {
- if ($filetype == 'folder') {
- if ($isAllowedToEdit ||
- api_is_platform_admin() ||
- api_get_setting('students_download_folders') == 'true'
- ) {
- //filter: when I am into a shared folder, I can only show "my shared folder" for donwload
- if (self::is_shared_folder($curdirpath, $current_session_id)) {
- if (preg_match('/shared_folder\/sf_user_'.api_get_user_id().'$/', urldecode($forcedownload_link)) ||
- preg_match('/shared_folder_session_'.$current_session_id.'\/sf_user_'.api_get_user_id().'$/', urldecode($forcedownload_link)) ||
- $isAllowedToEdit || api_is_platform_admin()
- ) {
- $force_download_html = ($size == 0) ? '' : '<a href="'.$forcedownload_link.'" style="float:right"'.$prevent_multiple_click.'>'.
- Display::return_icon($forcedownload_icon, get_lang('Download'), array(), ICON_SIZE_SMALL).'</a>';
- }
- } elseif (!preg_match('/shared_folder/', urldecode($forcedownload_link)) ||
- $isAllowedToEdit ||
- api_is_platform_admin()
- ) {
- $force_download_html = ($size == 0) ? '' : '<a href="'.$forcedownload_link.'" style="float:right"'.$prevent_multiple_click.'>'.
- Display::return_icon($forcedownload_icon, get_lang('Download'), array(), ICON_SIZE_SMALL).'</a>';
- }
- }
- } else {
- $force_download_html = ($size == 0) ? '' : '<a href="'.$forcedownload_link.'" style="float:right"'.$prevent_multiple_click.' download="'.$document_data['basename'].'">'.
- Display::return_icon($forcedownload_icon, get_lang('Download'), array(), ICON_SIZE_SMALL).'</a>';
- }
- // Copy files to user's myfiles
- if (api_get_setting('allow_my_files') === 'true' &&
- api_get_setting('users_copy_files') === 'true'
- ) {
- $copy_myfiles_link = ($filetype == 'file') ? api_get_self().'?'.$courseParams.'&action=copytomyfiles&id='.$document_data['id'] : api_get_self().'?'.$courseParams;
- if ($filetype == 'file') {
- $copy_to_myfiles = '<a href="'.$copy_myfiles_link.'" style="float:right"'.$prevent_multiple_click.'>'.
- Display::return_icon('briefcase.png', get_lang('CopyToMyFiles'), array(), ICON_SIZE_SMALL).' </a>';
- if (api_get_setting('allow_my_files') === 'false') {
- $copy_to_myfiles = '';
- }
- }
- if ($filetype == 'file') {
- //$send_to = Portfolio::share('document', $document_data['id'], array('style' => 'float:right;'));
- }
- }
- $pdf_icon = '';
- $extension = pathinfo($path, PATHINFO_EXTENSION);
- if (!$isAllowedToEdit &&
- api_get_setting('students_export2pdf') == 'true' &&
- $filetype == 'file' &&
- in_array($extension, array('html', 'htm'))
- ) {
- $pdf_icon = ' <a style="float:right".'.$prevent_multiple_click.' href="'.api_get_self().'?'.$courseParams.'&action=export_to_pdf&id='.$document_data['id'].'&curdirpath='.$curdirpath.'">'.
- Display::return_icon('pdf.png', get_lang('Export2PDF'), array(), ICON_SIZE_SMALL).'</a> ';
- }
- if ($is_browser_viewable_file) {
- $open_in_new_window_link = '<a href="'.$www.str_replace('%2F', '/', $url_path).'?'.$courseParams.'" style="float:right"'.$prevent_multiple_click.' target="_blank">'.
- Display::return_icon('open_in_new_window.png', get_lang('OpenInANewWindow'), array(), ICON_SIZE_SMALL).' </a>';
- }
- if ($filetype == 'file') {
- // Sound preview with jplayer
- if (preg_match('/mp3$/i', urldecode($checkExtension)) ||
- (preg_match('/wav$/i', urldecode($checkExtension))) ||
- preg_match('/ogg$/i', urldecode($checkExtension))
- ) {
- return '<span style="float:left" '.$visibility_class.'>'.
- $title.
- '</span>'.$force_download_html.$send_to.$copy_to_myfiles.$open_in_new_window_link.$pdf_icon;
- } elseif (
- // Show preview
- preg_match('/swf$/i', urldecode($checkExtension)) ||
- preg_match('/png$/i', urldecode($checkExtension)) ||
- preg_match('/gif$/i', urldecode($checkExtension)) ||
- preg_match('/jpg$/i', urldecode($checkExtension)) ||
- preg_match('/jpeg$/i', urldecode($checkExtension)) ||
- preg_match('/bmp$/i', urldecode($checkExtension)) ||
- preg_match('/svg$/i', urldecode($checkExtension))
- ) {
- // Simpler version of showinframesmin.php with no headers
- $url = 'show_content.php?'.$courseParams.'&id='.$document_data['id'];
- $class = 'ajax';
- if ($visibility == false) {
- $class = "ajax text-muted";
- }
- return Display::url(
- $title,
- $url,
- [
- 'class' => $class,
- 'title' => $tooltip_title_alt,
- 'data-title' => $title,
- 'style' => 'float:left;'
- ]
- )
- . $force_download_html.$send_to.$copy_to_myfiles
- . $open_in_new_window_link.$pdf_icon;
- } else {
- // For a "PDF Download" of the file.
- $pdfPreview = null;
- if ($ext != 'pdf' && !in_array($ext, $webODFList)) {
- $url = 'showinframes.php?'.$courseParams.'&id='.$document_data['id'];
- } else {
- $pdfPreview = Display::url(
- Display::return_icon('preview.gif', get_lang('Preview')),
- api_get_path(WEB_CODE_PATH).'document/showinframes.php?'.$courseParams.'&id='.$document_data['id'],
- array('style' => 'float:right')
- );
- }
- // No plugin just the old and good showinframes.php page
- return '<a href="'.$url.'" title="'.$tooltip_title_alt.'" style="float:left" '.$visibility_class.' >'.$title.'</a>'.
- $pdfPreview.$force_download_html.$send_to.$copy_to_myfiles.$open_in_new_window_link.$pdf_icon;
- }
- } else {
- return '<a href="'.$url.'" title="'.$tooltip_title_alt.'" '.$visibility_class.' style="float:left">'.$title.'</a>'.
- $force_download_html.$send_to.$copy_to_myfiles.$open_in_new_window_link.$pdf_icon;
- }
- // end copy files to users myfiles
- } else {
- // Icon column
- if (preg_match('/shared_folder/', urldecode($checkExtension)) &&
- preg_match('/shared_folder$/', urldecode($checkExtension)) == false &&
- preg_match('/shared_folder_session_'.$current_session_id.'$/', urldecode($url)) == false
- ) {
- if ($filetype == 'file') {
- //Sound preview with jplayer
- if (preg_match('/mp3$/i', urldecode($checkExtension)) ||
- (preg_match('/wav$/i', urldecode($checkExtension))) ||
- preg_match('/ogg$/i', urldecode($checkExtension))) {
- $sound_preview = self::generate_media_preview($counter);
- return $sound_preview;
- } elseif (
- // Show preview
- preg_match('/swf$/i', urldecode($checkExtension)) ||
- preg_match('/png$/i', urldecode($checkExtension)) ||
- preg_match('/gif$/i', urldecode($checkExtension)) ||
- preg_match('/jpg$/i', urldecode($checkExtension)) ||
- preg_match('/jpeg$/i', urldecode($checkExtension)) ||
- preg_match('/bmp$/i', urldecode($checkExtension)) ||
- preg_match('/svg$/i', urldecode($checkExtension))
- ) {
- $url = 'showinframes.php?'.$courseParams.'&id='.$document_data['id'];
- return '<a href="'.$url.'" title="'.$tooltip_title_alt.'" '.$visibility_class.' style="float:left">'.
- self::build_document_icon_tag($filetype, $path, $isAllowedToEdit).
- Display::return_icon('shared.png', get_lang('ResourceShared'), array()).'</a>';
- } else {
- return '<a href="'.$url.'" title="'.$tooltip_title_alt.'" '.$visibility_class.' style="float:left">'.
- self::build_document_icon_tag($filetype, $path, $isAllowedToEdit).
- Display::return_icon('shared.png', get_lang('ResourceShared'), array()).'</a>';
- }
- } else {
- return '<a href="'.$url.'" title="'.$tooltip_title_alt.'" target="'.$target.'"'.$visibility_class.' style="float:left">'.
- self::build_document_icon_tag($filetype, $path, $isAllowedToEdit).
- Display::return_icon('shared.png', get_lang('ResourceShared'), array()).'</a>';
- }
- } else {
- if ($filetype == 'file') {
- // Sound preview with jplayer
- if (preg_match('/mp3$/i', urldecode($checkExtension)) ||
- (preg_match('/wav$/i', urldecode($checkExtension))) ||
- preg_match('/ogg$/i', urldecode($checkExtension))) {
- $sound_preview = self::generate_media_preview($counter);
- return $sound_preview;
- } elseif (
- //Show preview
- preg_match('/html$/i', urldecode($checkExtension)) ||
- preg_match('/htm$/i', urldecode($checkExtension)) ||
- preg_match('/swf$/i', urldecode($checkExtension)) ||
- preg_match('/png$/i', urldecode($checkExtension)) ||
- preg_match('/gif$/i', urldecode($checkExtension)) ||
- preg_match('/jpg$/i', urldecode($checkExtension)) ||
- preg_match('/jpeg$/i', urldecode($checkExtension)) ||
- preg_match('/bmp$/i', urldecode($checkExtension)) ||
- preg_match('/svg$/i', urldecode($checkExtension))
- ) {
- $url = 'showinframes.php?'.$courseParams.'&id='.$document_data['id']; //without preview
- return '<a href="'.$url.'" title="'.$tooltip_title_alt.'" '.$visibility_class.' style="float:left">'.
- self::build_document_icon_tag($filetype, $path, $isAllowedToEdit).'</a>';
- } else {
- return '<a href="'.$url.'" title="'.$tooltip_title_alt.'" '.$visibility_class.' style="float:left">'.
- self::build_document_icon_tag($filetype, $path, $isAllowedToEdit).'</a>';
- }
- } else {
- return '<a href="'.$url.'" title="'.$tooltip_title_alt.'" target="'.$target.'"'.$visibility_class.' style="float:left">'.
- self::build_document_icon_tag($filetype, $path, $isAllowedToEdit).'</a>';
- }
- }
- }
- }
- /**
- * Builds an img html tag for the file type
- *
- * @param string $type (file/folder)
- * @param string $path
- * @param bool $isAllowedToEdit
- * @return string img html tag
- */
- public static function build_document_icon_tag($type, $path, $isAllowedToEdit = null)
- {
- $basename = basename($path);
- $current_session_id = api_get_session_id();
- if (is_null($isAllowedToEdit)) {
- $isAllowedToEdit = api_is_allowed_to_edit(null, true);
- }
- $user_image = false;
- if ($type == 'file') {
- $icon = choose_image($basename);
- $basename = substr(strrchr($basename, '.'), 1);
- } else {
- if ($path == '/shared_folder') {
- $icon = 'folder_users.png';
- if ($isAllowedToEdit) {
- $basename = get_lang('HelpUsersFolder');
- } else {
- $basename = get_lang('UserFolders');
- }
- } elseif (strstr($basename, 'sf_user_')) {
- $userInfo = api_get_user_info(substr($basename, 8));
- $icon = $userInfo['avatar_small'];
- $basename = get_lang('UserFolder').' '.$userInfo['complete_name'];
- $user_image = true;
- } elseif (strstr($path, 'shared_folder_session_')) {
- $sessionName = api_get_session_name($current_session_id);
- if ($isAllowedToEdit) {
- $basename = '***('.$sessionName.')*** '.get_lang('HelpUsersFolder');
- } else {
- $basename = get_lang('UserFolders').' ('.$sessionName.')';
- }
- $icon = 'folder_users.png';
- } else {
- $icon = 'folder_document.gif';
- if ($path == '/audio') {
- $icon = 'folder_audio.gif';
- if ($isAllowedToEdit) {
- $basename = get_lang('HelpDefaultDirDocuments');
- } else {
- $basename = get_lang('Audio');
- }
- } elseif ($path == '/flash') {
- $icon = 'folder_flash.gif';
- if ($isAllowedToEdit) {
- $basename = get_lang('HelpDefaultDirDocuments');
- } else {
- $basename = get_lang('Flash');
- }
- } elseif ($path == '/images') {
- $icon = 'folder_images.gif';
- if ($isAllowedToEdit) {
- $basename = get_lang('HelpDefaultDirDocuments');
- } else {
- $basename = get_lang('Images');
- }
- } elseif ($path == '/video') {
- $icon = 'folder_video.gif';
- if ($isAllowedToEdit) {
- $basename = get_lang('HelpDefaultDirDocuments');
- } else {
- $basename = get_lang('Video');
- }
- } elseif ($path == '/images/gallery') {
- $icon = 'folder_gallery.gif';
- if ($isAllowedToEdit) {
- $basename = get_lang('HelpDefaultDirDocuments');
- } else {
- $basename = get_lang('Gallery');
- }
- } elseif ($path == '/chat_files') {
- $icon = 'folder_chat.png';
- if ($isAllowedToEdit) {
- $basename = get_lang('HelpFolderChat');
- } else {
- $basename = get_lang('ChatFiles');
- }
- } elseif ($path == '/learning_path') {
- $icon = 'folder_learningpath.gif';
- if ($isAllowedToEdit) {
- $basename = get_lang('HelpFolderLearningPaths');
- } else {
- $basename = get_lang('LearningPaths');
- }
- }
- }
- }
- if ($user_image) {
- return Display::img($icon, $basename, array(), false);
- }
- return Display::return_icon($icon, $basename, array(), ICON_SIZE_MEDIUM);
- }
- /**
- * Get the button to edit document
- * @param boolean $isReadOnly
- * @param array $documentData
- * @param string $extension
- * @param boolean $isCertificateMode
- * @return string
- */
- private static function getButtonEdit($isReadOnly, array $documentData, $extension, $isCertificateMode)
- {
- $iconEn = Display::return_icon('edit.png', get_lang('Modify'));
- $iconDis = Display::return_icon('edit_na.png', get_lang('Modify'));
- $courseParams = api_get_cidreq();
- $webOdfExtensionList = self::get_web_odf_extension_list();
- $path = $documentData['path'];
- $document_id = $documentData['id'];
- if ($isReadOnly) {
- if (!api_is_course_admin() && !api_is_platform_admin()) {
- return $iconDis;
- }
- if (
- $extension == 'svg' && api_browser_support('svg') &&
- api_get_setting('enabled_support_svg') == 'true'
- ) {
- return Display::url($iconEn, "edit_draw.php?$courseParams&id=$document_id");
- }
- if (
- in_array($extension, $webOdfExtensionList) &&
- api_get_configuration_value('enabled_support_odf') === true
- ) {
- return Display::url($iconEn, "edit_odf.php?$courseParams&id=$document_id");
- }
- if (
- in_array($extension, ['png', 'jpg', 'jpeg', 'bmp', 'gif']) ||
- ($extension == 'pxd' && api_get_setting('enabled_support_pixlr') == 'true')
- ) {
- return Display::url($iconEn, "edit_paint.php?$courseParams&id=$document_id");
- }
- return Display::url($iconEn, "edit_document.php?$courseParams&id=$document_id");
- }
- if (in_array($path, self::get_system_folders())) {
- return $iconDis;
- }
- if ($isCertificateMode) {
- return Display::url($iconEn, "edit_document.php?$courseParams&id=$document_id&curdirpath=/certificates");
- }
- $sessionId = api_get_session_id();
- if ($sessionId && $documentData['session_id'] != $sessionId) {
- return $iconDis;
- }
- if (
- $extension == 'svg' && api_browser_support('svg') &&
- api_get_setting('enabled_support_svg') == 'true'
- ) {
- return Display::url($iconEn, "edit_draw.php?$courseParams&id=$document_id");
- }
- if (
- in_array($extension, $webOdfExtensionList) &&
- api_get_configuration_value('enabled_support_odf') === true
- ) {
- return Display::url($iconEn, "edit_odf.php?$courseParams&id=$document_id");
- }
- if (
- in_array($extension, ['png', 'jpg', 'jpeg', 'bmp', 'gif']) ||
- ($extension == 'pxd' && api_get_setting('enabled_support_pixlr') == 'true')
- ) {
- return Display::url($iconEn, "edit_paint.php?$courseParams&id=$document_id");
- }
- return Display::url($iconEn, "edit_document.php?$courseParams&id=$document_id");
- }
- /**
- * Get the button to move document
- * @param boolean $isReadOnly
- * @param array $documentData
- * @param boolean $isCertificateMode
- * @param int $parentId
- * @return string
- */
- private static function getButtonMove($isReadOnly, array $documentData, $isCertificateMode, $parentId)
- {
- $iconEn = Display::return_icon('move.png', get_lang('Move'));
- $iconDis = Display::return_icon('move_na.png', get_lang('Move'));
- if ($isReadOnly) {
- return $iconDis;
- }
- $path = $documentData['path'];
- $document_id = $documentData['id'];
- $sessionId = api_get_session_id();
- $courseParams = api_get_cidreq();
- if ($isCertificateMode || in_array($path, self::get_system_folders())) {
- return $iconDis;
- }
- if ($sessionId) {
- if ($documentData['session_id'] != $sessionId) {
- return $iconDis;
- }
- }
- $urlMoveParams = http_build_query(['id' => $parentId, 'move' => $document_id]);
- return Display::url(
- $iconEn,
- api_get_self()."?$courseParams&$urlMoveParams"
- );
- }
- /**
- * Get the button to set visibility to document
- * @param boolean $isReadOnly
- * @param int $visibility
- * @param array $documentData
- * @param boolean $isCertificateMode
- * @parem int $parentId
- * @return null|string
- */
- private static function getButtonVisibility($isReadOnly, $visibility, array $documentData, $isCertificateMode, $parentId)
- {
- $visibility_icon = ($visibility == 0) ? 'invisible' : 'visible';
- $visibility_command = ($visibility == 0) ? 'set_visible' : 'set_invisible';
- $courseParams = api_get_cidreq();
- if ($isReadOnly) {
- if (api_is_allowed_to_edit() || api_is_platform_admin()) {
- return Display::return_icon($visibility_icon.'.png', get_lang('VisibilityCannotBeChanged'));
- }
- return null;
- }
- if ($isCertificateMode) {
- return Display::return_icon($visibility_icon.'.png', get_lang('VisibilityCannotBeChanged'));
- }
- if (api_is_allowed_to_edit() || api_is_platform_admin()) {
- $tip_visibility = $visibility_icon == 'invisible' ? get_lang('Show') : get_lang('Hide');
- return Display::url(
- Display::return_icon($visibility_icon.'.png', $tip_visibility),
- api_get_self()."?$courseParams&id=$parentId&$visibility_command={$documentData['id']}"
- );
- }
- return null;
- }
- /**
- * GEt the button to delete a document
- * @param boolean $isReadOnly
- * @param array $documentData
- * @param boolean $isCertificateMode
- * @param string $curDirPath
- * @param int $parentId
- * @return string
- */
- private static function getButtonDelete($isReadOnly, array $documentData, $isCertificateMode, $curDirPath, $parentId)
- {
- $iconEn = Display::return_icon('delete.png', get_lang('Delete'));
- $iconDis = Display::return_icon('delete_na.png', get_lang('ThisFolderCannotBeDeleted'));
- $path = $documentData['path'];
- $id = $documentData['id'];
- $courseParams = api_get_cidreq();
- if ($isReadOnly) {
- return $iconDis;
- }
- if (in_array($path, self::get_system_folders())) {
- return $iconDis;
- }
- $titleToShow = addslashes(basename($documentData['title']));
- $urlDeleteParams = http_build_query([
- 'curdirpath' => $curDirPath,
- 'action' => 'delete_item',
- 'id' => $parentId,
- 'deleteid' => $documentData['id']
- ]);
- $btn = Display::url(
- $iconEn,
- api_get_self()."?$courseParams&$urlDeleteParams",
- ['onclick' => "return confirmation('$titleToShow');"]
- );
- if (
- isset($_GET['curdirpath']) &&
- $_GET['curdirpath'] == '/certificates' &&
- self::get_default_certificate_id(api_get_course_id()) == $id
- ) {
- return $btn;
- }
- if ($isCertificateMode) {
- return $btn;
- }
- $sessionId = api_get_session_id();
- if ($sessionId) {
- if ($documentData['session_id'] != $sessionId) {
- return $iconDis;
- }
- }
- return $btn;
- }
- /**
- * Creates the row of edit icons for a file/folder
- *
- * @param string $curdirpath current path (cfr open folder)
- * @param string $type (file/folder)
- * @param string $path dbase path of file/folder
- * @param int $visibility (1/0)
- * @param int $id dbase id of the document
- * @return string html img tags with hyperlinks
- */
- public static function build_edit_icons($document_data, $id, $is_template, $is_read_only = 0, $visibility)
- {
- $sessionId = api_get_session_id();
- $courseParams = api_get_cidreq();
- $document_id = $document_data['id'];
- $type = $document_data['filetype'];
- $is_read_only = $document_data['readonly'];
- $path = $document_data['path'];
- $parent_id = self::get_document_id(
- api_get_course_info(),
- dirname($path),
- 0
- );
- if (empty($parent_id) && !empty($sessionId)) {
- $parent_id = self::get_document_id(
- api_get_course_info(),
- dirname($path),
- $sessionId
- );
- }
- $curdirpath = dirname($document_data['path']);
- $is_certificate_mode = self::is_certificate_mode($path);
- $curdirpath = urlencode($curdirpath);
- $extension = pathinfo($path, PATHINFO_EXTENSION);
- //@todo Implement remote support for converter
- $usePpt2lp = (api_get_setting('service_ppt2lp', 'active') == 'true' && api_get_setting('service_ppt2lp', 'host') == 'localhost');
- $formatTypeList = self::getFormatTypeListConvertor('from', $extension);
- $formatType = current($formatTypeList);
- // If document is read only *or* we're in a session and the document
- // is from a non-session context, hide the edition capabilities
- $modify_icons = [];
- $modify_icons[] = self::getButtonEdit($is_read_only, $document_data, $extension, $is_certificate_mode);
- $modify_icons[] = self::getButtonMove($is_read_only, $document_data, $is_certificate_mode, $parent_id);
- $modify_icons[] = self::getButtonVisibility(
- $is_read_only,
- $visibility,
- $document_data,
- $is_certificate_mode,
- $parent_id
- );
- $modify_icons[] = self::getButtonDelete(
- $is_read_only,
- $document_data,
- $is_certificate_mode,
- $curdirpath,
- $parent_id
- );
- if (!$is_read_only /* or ($session_id!=api_get_session_id()) */) {
- // Add action to covert to PDF, will create a new document whit same filename but .pdf extension
- // @TODO: add prompt to select a format target
- if (!in_array($path, self::get_system_folders())) {
- if ($usePpt2lp && $formatType) {
- $modify_icons[] = Display::url(
- Display::return_icon('convert.png', get_lang('Convert')),
- '#',
- ['class' => 'convertAction', 'data-documentId' => $document_id, 'data-formatType' => $formatType]
- );
- }
- }
- }
- if ($type == 'file' && ($extension == 'html' || $extension == 'htm')) {
- if ($is_template == 0) {
- if ((isset($_GET['curdirpath']) && $_GET['curdirpath'] != '/certificates') || !isset($_GET['curdirpath'])) {
- $modify_icons[] = Display::url(
- Display::return_icon('wizard.png', get_lang('AddAsTemplate')),
- api_get_self()."?$courseParams&curdirpath=$curdirpath&add_as_template=$id"
- );
- }
- if (isset($_GET['curdirpath']) && $_GET['curdirpath'] == '/certificates') {//allow attach certificate to course
- $visibility_icon_certificate = 'nocertificate';
- if (self::get_default_certificate_id(api_get_course_id()) == $id) {
- $visibility_icon_certificate = 'certificate';
- $certificate = get_lang('DefaultCertificate');
- $preview = get_lang('PreviewCertificate');
- $is_preview = true;
- } else {
- $is_preview = false;
- $certificate = get_lang('NoDefaultCertificate');
- }
- if (isset($_GET['selectcat'])) {
- $modify_icons[] = Display::url(
- Display::return_icon($visibility_icon_certificate.'.png', $certificate),
- api_get_self()."?$courseParams&curdirpath=$curdirpath&selectcat=".intval($_GET['selectcat'])."&set_certificate=$id"
- );
- if ($is_preview) {
- $modify_icons[] = Display::url(
- Display::return_icon('preview_view.png', $preview),
- api_get_self()."?$courseParams&curdirpath=$curdirpath&set_preview=$id"
- );
- }
- }
- }
- } else {
- $modify_icons[] = Display::url(
- Display::return_icon('wizard_na.png', get_lang('RemoveAsTemplate')),
- api_get_self()."?$courseParams&curdirpath=$curdirpath&remove_as_template=$id"
- );
- }
- $modify_icons[] = Display::url(
- Display::return_icon('pdf.png', get_lang('Export2PDF')),
- api_get_self()."?$courseParams&action=export_to_pdf&id=$id&curdirpath=$curdirpath"
- );
- }
- return implode(PHP_EOL, $modify_icons);
- }
- /**
- * @param $folders
- * @param $curdirpath
- * @param $move_file
- * @param string $group_dir
- * @param $form
- *
- * @return string
- */
- public static function build_move_to_selector($folders, $curdirpath, $move_file, $group_dir = '')
- {
- $form = new FormValidator('move_to', 'post', api_get_self().'?'.api_get_cidreq());
- // Form title
- $form->addElement('hidden', 'move_file', $move_file);
- $options = array();
- // Group documents cannot be uploaded in the root
- if ($group_dir == '') {
- if ($curdirpath != '/') {
- $options['/'] = get_lang('Documents');
- }
- if (is_array($folders)) {
- foreach ($folders as & $folder) {
- // Hide some folders
- if ($folder == '/HotPotatoes_files' ||
- $folder == '/certificates' ||
- basename($folder) == 'css'
- ) {
- continue;
- }
- // Admin setting for Hide/Show the folders of all users
- if (api_get_setting('show_users_folders') == 'false' &&
- (strstr($folder, '/shared_folder') || strstr($folder, 'shared_folder_session_'))
- ) {
- continue;
- }
- // Admin setting for Hide/Show Default folders to all users
- if (api_get_setting('show_default_folders') == 'false' &&
- (
- $folder == '/images' ||
- $folder == '/flash' ||
- $folder == '/audio' ||
- $folder == '/video' ||
- strstr($folder, '/images/gallery') ||
- $folder == '/video/flv'
- )
- ) {
- continue;
- }
- // Admin setting for Hide/Show chat history folder
- if (api_get_setting('show_chat_folder') == 'false' &&
- $folder == '/chat_files') {
- continue;
- }
- // You cannot move a file to:
- // 1. current directory
- // 2. inside the folder you want to move
- // 3. inside a subfolder of the folder you want to move
- if (($curdirpath != $folder) &&
- ($folder != $move_file) &&
- (substr($folder, 0, strlen($move_file) + 1) != $move_file.'/')
- ) {
- $path_displayed = $folder;
- // If document title is used, we have to display titles instead of real paths...
- $path_displayed = self::get_titles_of_path($folder);
- if (empty($path_displayed)) {
- $path_displayed = get_lang('Untitled');
- }
- $options[$folder] = $path_displayed;
- }
- }
- }
- } else {
- foreach ($folders as $folder) {
- if (($curdirpath != $folder) &&
- ($folder != $move_file) &&
- (substr($folder, 0, strlen($move_file) + 1) != $move_file.'/')
- ) {
- // Cannot copy dir into his own subdir
- $path_displayed = self::get_titles_of_path($folder);
- $display_folder = substr($path_displayed, strlen($group_dir));
- $display_folder = ($display_folder == '') ? get_lang('Documents') : $display_folder;
- //$form .= '<option value="'.$folder.'">'.$display_folder.'</option>';
- $options[$folder] = $display_folder;
- }
- }
- }
- $form->addElement('select', 'move_to', get_lang('MoveTo'), $options);
- $form->addButtonNext(get_lang('MoveElement'), 'move_file_submit');
- return $form->returnForm();
- }
- /**
- * Gets the path translated with title of docs and folders
- * @param string $path the real path
- * @return the path which should be displayed
- */
- public static function get_titles_of_path($path)
- {
- global $tmp_folders_titles;
- $course_id = api_get_course_int_id();
- $nb_slashes = substr_count($path, '/');
- $current_slash_pos = 0;
- $path_displayed = '';
- for ($i = 0; $i < $nb_slashes; $i++) {
- // For each folder of the path, retrieve title.
- $current_slash_pos = strpos($path, '/', $current_slash_pos + 1);
- $tmp_path = substr($path, strpos($path, '/', 0), $current_slash_pos);
- if (empty($tmp_path)) {
- // If empty, then we are in the final part of the path
- $tmp_path = $path;
- }
- if (!empty($tmp_folders_titles[$tmp_path])) {
- // If this path has soon been stored here we don't need a new query
- $path_displayed .= $tmp_folders_titles[$tmp_path];
- } else {
- $sql = 'SELECT title FROM '.Database::get_course_table(TABLE_DOCUMENT).'
- WHERE c_id = ' . $course_id.' AND path LIKE BINARY "'.$tmp_path.'"';
- $rs = Database::query($sql);
- $tmp_title = '/'.Database::result($rs, 0, 0);
- $path_displayed .= $tmp_title;
- $tmp_folders_titles[$tmp_path] = $tmp_title;
- }
- }
- return $path_displayed;
- }
- /**
- * Creates form that asks for the directory name.
- * @return string html-output text for the form
- */
- public static function create_dir_form($dirId)
- {
- global $document_id;
- $form = new FormValidator('create_dir_form', 'post', api_get_self().'?'.api_get_cidreq());
- $form->addElement('hidden', 'create_dir', 1);
- $form->addElement('hidden', 'dir_id', intval($document_id));
- $form->addElement('hidden', 'id', intval($dirId));
- $form->addElement('header', get_lang('CreateDir'));
- $form->addText('dirname', get_lang('NewDir'), array('autofocus' => 'autofocus'));
- $form->addButtonCreate(get_lang('CreateFolder'));
- return $form->returnForm();
- }
- /**
- * Checks whether the user is in shared folder
- * @return return bool Return true when user is into shared folder
- */
- public static function is_shared_folder($curdirpath, $current_session_id)
- {
- $clean_curdirpath = Security::remove_XSS($curdirpath);
- if ($clean_curdirpath == '/shared_folder') {
- return true;
- } elseif ($clean_curdirpath == '/shared_folder_session_'.$current_session_id) {
- return true;
- } else {
- return false;
- }
- }
- /**
- * Checks whether the user is into any user shared folder
- * @return return bool Return true when user is in any user shared folder
- */
- public static function is_any_user_shared_folder($path, $current_session_id)
- {
- $clean_path = Security::remove_XSS($path);
- if (strpos($clean_path, 'shared_folder/sf_user_')) {
- return true;
- } elseif (strpos($clean_path, 'shared_folder_session_'.$current_session_id.'/sf_user_')) {
- return true;
- } else {
- return false;
- }
- }
- /**
- * Checks whether the user is into his shared folder or into a subfolder
- * @return bool Return true when user is in his user shared folder or into a subfolder
- */
- public static function is_my_shared_folder($user_id, $path, $current_session_id)
- {
- $clean_path = Security::remove_XSS($path).'/';
- //for security does not remove the last slash
- $main_user_shared_folder = '/shared_folder\/sf_user_'.$user_id.'\//';
- //for security does not remove the last slash
- $main_user_shared_folder_session = '/shared_folder_session_'.$current_session_id.'\/sf_user_'.$user_id.'\//';
- if (preg_match($main_user_shared_folder, $clean_path)) {
- return true;
- } elseif (preg_match($main_user_shared_folder_session, $clean_path)) {
- return true;
- } else {
- return false;
- }
- }
- /**
- * Check if the file name or folder searched exist
- * @return bool Return true when exist
- */
- public static function search_keyword($document_name, $keyword)
- {
- if (api_strripos($document_name, $keyword) !== false) {
- return true;
- } else {
- return false;
- }
- }
- /**
- * Checks whether a document can be previewed by using the browser.
- * @param string $file_extension The filename extension of the document (it must be in lower case).
- * @return bool Returns TRUE or FALSE.
- */
- public static function is_browser_viewable($file_extension)
- {
- static $allowed_extensions = array(
- 'htm', 'html', 'xhtml',
- 'gif', 'jpg', 'jpeg', 'png', 'tif', 'tiff',
- 'pdf', 'svg', 'swf',
- 'txt', 'log',
- 'mp4', 'ogg', 'ogv', 'ogx', 'mpg', 'mpeg', 'mov', 'avi', 'webm', 'wmv',
- 'mp3', 'oga', 'wav', 'au', 'wma', 'mid', 'kar'
- );
- /*
- //TODO: make a admin swich to strict mode
- 1. global default $allowed_extensions only: 'htm', 'html', 'xhtml', 'gif', 'jpg', 'jpeg', 'png', 'bmp', 'txt', 'log'
- if (in_array($file_extension, $allowed_extensions)) { // Assignment + a logical check.
- return true;
- }
- 2. check native support
- 3. check plugins: quicktime, mediaplayer, vlc, acrobat, flash, java
- */
- if (!($result = in_array($file_extension, $allowed_extensions))) { // Assignment + a logical check.
- return false;
- }
- //check native support (Explorer, Opera, Firefox, Chrome, Safari)
- if ($file_extension == "pdf") {
- return api_browser_support('pdf');
- } elseif ($file_extension == "mp3") {
- return api_browser_support('mp3');
- } elseif ($file_extension == "mp4") {
- return api_browser_support('mp4');
- } elseif ($file_extension == "ogg" || $file_extension == "ogx" || $file_extension == "ogv" || $file_extension == "oga") {
- return api_browser_support('ogg');
- } elseif ($file_extension == "svg") {
- return api_browser_support('svg');
- } elseif ($file_extension == "mpg" || $file_extension == "mpeg") {
- return api_browser_support('mpg');
- } elseif ($file_extension == "mov") {
- return api_browser_support('mov');
- } elseif ($file_extension == "wav") {
- return api_browser_support('wav');
- } elseif ($file_extension == "mid" || $file_extension == "kar") {
- return api_browser_support('mid');
- } elseif ($file_extension == "avi") {
- return api_browser_support('avi');
- } elseif ($file_extension == "wma") {
- return api_browser_support('wma');
- } elseif ($file_extension == "wmv") {
- return api_browser_support('wmv');
- } elseif ($file_extension == "tif" || $file_extension == "tiff") {
- return api_browser_support('tif');
- } elseif ($file_extension == "mov") {
- return api_browser_support('mov');
- } elseif ($file_extension == "au") {
- return api_browser_support('au');
- } elseif ($file_extension == "webm") {
- return api_browser_support('webm');
- }
- return $result;
- }
- /**
- * @param array $courseInfo
- * @param int $sessionId
- *
- * @return array
- */
- public static function getDeletedDocuments($courseInfo, $sessionId = 0)
- {
- $table = Database::get_course_table(TABLE_DOCUMENT);
- $courseId = $courseInfo['real_id'];
- $sessionCondition = api_get_session_condition($sessionId);
- $sql = "SELECT * FROM $table
- WHERE
- path LIKE '%DELETED%' AND
- c_id = $courseId
- $sessionCondition
- ORDER BY path
- ";
- $result = Database::query($sql);
- $files = array();
- while ($document = Database::fetch_array($result, 'ASSOC')) {
- $files[] = $document;
- }
- return $files;
- }
- /**
- * @param int $id
- * @param array $courseInfo
- * @param int $sessionId
- *
- * @return array
- */
- public static function getDeletedDocument($id, $courseInfo, $sessionId = 0)
- {
- if (empty($courseInfo)) {
- return false;
- }
- $table = Database::get_course_table(TABLE_DOCUMENT);
- $courseId = $courseInfo['real_id'];
- $sessionCondition = api_get_session_condition($sessionId);
- $sql = "SELECT * FROM $table
- WHERE
- path LIKE '%DELETED%' AND
- id = $id AND
- c_id = $courseId
- $sessionCondition
- LIMIT 1
- ";
- $result = Database::query($sql);
- if (Database::num_rows($result)) {
- $result = Database::fetch_array($result, 'ASSOC');
- return $result;
- }
- return array();
- }
- /**
- * @param int $id
- * @param array $courseInfo
- * @param int $sessionId
- * @return bool
- */
- public static function purgeDocument($id, $courseInfo, $sessionId = 0)
- {
- $document = self::getDeletedDocument($id, $courseInfo, $sessionId);
- if (!empty($document)) {
- $path = $document['path'];
- $coursePath = api_get_path(SYS_COURSE_PATH).$courseInfo['path'].'/document/';
- my_delete($coursePath.$path);
- // Hard delete.
- self::deleteDocumentFromDb($id, $courseInfo, $sessionId, true);
- return true;
- }
- return false;
- }
- /**
- * @param array $courseInfo
- * @param int $sessionId
- */
- public static function purgeDocuments($courseInfo, $sessionId)
- {
- $files = self::getDeletedDocuments($courseInfo, $sessionId);
- foreach ($files as $file) {
- self::purgeDocument($file['id'], $courseInfo, $sessionId);
- }
- }
- /**
- * @param int $id
- * @param array $courseInfo
- * @param int $sessionId
- * @return bool
- */
- public static function downloadDeletedDocument($id, $courseInfo, $sessionId)
- {
- $document = self::getDeletedDocument($id, $courseInfo, $sessionId);
- if (!empty($document)) {
- $coursePath = api_get_path(SYS_COURSE_PATH).$courseInfo['path'].'/document/';
- if (Security::check_abs_path($coursePath.$document['path'], $coursePath)) {
- self::file_send_for_download($coursePath.$document['path']);
- exit;
- }
- }
- }
- /**
- * @param array $courseInfo
- * @param int $sessionId
- *
- * @return bool
- */
- public static function downloadAllDeletedDocument($courseInfo, $sessionId)
- {
- // Zip library for creation of the zip file.
- require api_get_path(LIBRARY_PATH).'pclzip/pclzip.lib.php';
- $files = self::getDeletedDocuments($courseInfo, $sessionId);
- if (empty($files)) {
- return false;
- }
- $coursePath = api_get_path(SYS_COURSE_PATH).$courseInfo['path'].'/document';
- // Creating a ZIP file.
- $tempZipFile = api_get_path(SYS_ARCHIVE_PATH).api_get_unique_id().".zip";
- $zip = new PclZip($tempZipFile);
- foreach ($files as $file) {
- $zip->add(
- $coursePath.$file['path'],
- PCLZIP_OPT_REMOVE_PATH,
- $coursePath
- );
- }
- if (Security::check_abs_path($tempZipFile, api_get_path(SYS_ARCHIVE_PATH))) {
- self::file_send_for_download($tempZipFile, true);
- @unlink($tempZipFile);
- exit;
- }
- }
- /**
- *
- * Delete documents from a session in a course.
- * @param array $courseInfo
- * @param int $sessionId
- *
- * @return bool
- */
- public static function deleteDocumentsFromSession($courseInfo, $sessionId)
- {
- if (empty($courseInfo)) {
- return false;
- }
- if (empty($sessionId)) {
- return false;
- }
- $itemPropertyTable = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $documentTable = Database::get_course_table(TABLE_DOCUMENT);
- $conditionSession = api_get_session_condition($sessionId, true, false, 'd.session_id');
- $courseId = $courseInfo['real_id'];
- // get invisible folders
- $sql = "SELECT DISTINCT d.id, path
- FROM $itemPropertyTable i
- INNER JOIN $documentTable d
- ON (i.c_id = d.c_id)
- WHERE
- d.id = i.ref AND
- i.tool = '".TOOL_DOCUMENT."'
- $conditionSession AND
- i.c_id = $courseId AND
- d.c_id = $courseId ";
- $result = Database::query($sql);
- $documents = Database::store_result($result, 'ASSOC');
- if ($documents) {
- $course_dir = $courseInfo['directory'].'/document';
- $sys_course_path = api_get_path(SYS_COURSE_PATH);
- $base_work_dir = $sys_course_path.$course_dir;
- foreach ($documents as $document) {
- $documentId = $document['id'];
- self::delete_document(
- $courseInfo,
- null,
- $base_work_dir,
- $sessionId,
- $documentId
- );
- }
- }
- $sql = "DELETE FROM $documentTable
- WHERE c_id = $courseId AND session_id = $sessionId";
- Database::query($sql);
- $sql = "DELETE FROM $itemPropertyTable
- WHERE c_id = $courseId AND session_id = $sessionId AND tool = '".TOOL_DOCUMENT."'";
- Database::query($sql);
- }
- /**
- * Update the file or directory path in the document db document table
- *
- * @author - Hugues Peeters <peeters@ipm.ucl.ac.be>
- * @param - action (string) - action type require : 'delete' or 'update'
- * @param - old_path (string) - old path info stored to change
- * @param - new_path (string) - new path info to substitute
- * @desc Update the file or directory path in the document db document table
- *
- */
- public static function updateDbInfo($action, $old_path, $new_path = '')
- {
- $dbTable = Database::get_course_table(TABLE_DOCUMENT);
- $course_id = api_get_course_int_id();
- switch ($action) {
- case 'delete':
- $old_path = Database::escape_string($old_path);
- $query = "DELETE FROM $dbTable
- WHERE
- c_id = $course_id AND
- (
- path LIKE BINARY '".$old_path."' OR
- path LIKE BINARY '".$old_path."/%'
- )";
- Database::query($query);
- break;
- case 'update':
- if ($new_path[0] == '.') {
- $new_path = substr($new_path, 1);
- }
- $new_path = str_replace('//', '/', $new_path);
- // Attempt to update - tested & working for root dir
- $new_path = Database::escape_string($new_path);
- $query = "UPDATE $dbTable SET
- path = CONCAT('".$new_path."', SUBSTRING(path, LENGTH('".$old_path."')+1) )
- WHERE c_id = $course_id AND (path LIKE BINARY '".$old_path."' OR path LIKE BINARY '".$old_path."/%')";
- Database::query($query);
- break;
- }
- }
- }
|