bash_perms_make_se-test.php 125 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912
  1. <?php
  2. //author Arkadiusz Binder 2013-07-30
  3. //todo do przepisania na PHP i dodania opcji generowania Symlinkow
  4. //todo @2013-08-04 do skonczenia funkcja
  5. //if(file_exists(".config.php")) require_once(".config.php");
  6. /**
  7. * by plabudda:
  8. *
  9. * 1. install:
  10. * - create *.plist file:
  11. * # php /Library/Server/Web/Data/Sites/Default/SE/se-dev-pl/bash_perms_make_se.php biuro.biall-net.pl addToLaunchctl
  12. * - load by launchctl:
  13. * # launchctl load /Library/LaunchDaemons/pl.biallnet.sync_perms.php.plist
  14. *
  15. * 2. uninstall:
  16. * - unload from launchctl:
  17. * # launchctl unload /Library/LaunchDaemons/pl.biallnet.sync_perms.php.plist
  18. *
  19. * 3. debug:
  20. * - debug by www:
  21. * /SE/se-dev-pl/bash_perms_make_se.php?DBG=1
  22. * - more verbose debug:
  23. * /SE/se-dev-pl/bash_perms_make_se.php?DBG=6
  24. */
  25. define('DS', DIRECTORY_SEPARATOR);
  26. define('APP_PATH_ROOT', dirname(__FILE__));
  27. define('APP_PATH_WWW', dirname(__FILE__));
  28. define('APP_PATH_CONFIG', APP_PATH_ROOT . DS . 'config');
  29. require_once APP_PATH_ROOT . DS . 'se-lib' . DS . 'Lib.php';
  30. Lib::loadClass('V');
  31. Lib::loadClass('Config');
  32. Lib::loadClass('DB');
  33. Lib::loadClass('User');
  34. Lib::loadClass('FoldersConfig');
  35. Lib::loadClass('FileUploader');
  36. if (isset($_SERVER["argv"][1])) {
  37. $_SERVER['SERVER_NAME'] = $_SERVER["argv"][1];
  38. }
  39. else if (empty($_SERVER["argv"]) && V::get('task', '', $_GET) == 'task') {
  40. SyncPerms::run($_SERVER["argv"][0], $_SERVER["argv"][1], 'nextTask', null);
  41. }
  42. else if (empty($_SERVER["argv"]) && V::get('task', '', $_GET) == 'newFiles') {
  43. SyncPerms::run($_SERVER["argv"][0], $_SERVER["argv"][1], 'newFiles', null);
  44. }
  45. else if (empty($_SERVER["argv"]) && V::get('task', '', $_GET) == 'testParse') {
  46. $filesWithPerms = array(
  47. 0 => "total 54512",
  48. 1 => "-rwxrwx---@ 1 kraskowskil workgroup 3268608 Sep 30 13:36 Bez nazwy-1.indd",
  49. 2 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  50. 3 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  51. 4 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  52. 5 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  53. 6 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  54. 7 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  55. 8 => "-rwxrwx---@ 1 kraskowskil workgroup 1703696 Sep 30 13:36 Bez nazwy-1.pdf",
  56. 9 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  57. 10 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  58. 11 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  59. 12 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  60. 13 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  61. 14 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  62. 15 => "drwxrwx---+ 28 kraskowskil workgroup 952 Oct 3 16:31 files",
  63. 16 => " 0: user:kraskowskil allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  64. 17 => " 1: group:workgroup allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  65. 18 => " 2: user:_www allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  66. 19 => "-rwxrwx---@ 1 kraskowskil workgroup 2527481 Oct 2 14:37 infografika.ai",
  67. 20 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  68. 21 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  69. 22 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  70. 23 => "-rwxrwx---@ 1 kraskowskil workgroup 14864384 Oct 7 16:05 katalog_biall-net.indd",
  71. 24 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  72. 25 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  73. 26 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  74. 27 => "-rwxrwx---@ 1 kraskowskil workgroup 1568645 Oct 3 14:45 katalog_biall-net.pdf",
  75. 28 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  76. 29 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  77. 30 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  78. 31 => "-rwxrwx---@ 1 kraskowskil workgroup 2596864 Sep 30 15:27 okladkii.indd",
  79. 32 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  80. 33 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  81. 34 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  82. 35 => "-rwxrwx---@ 1 kraskowskil workgroup 1369255 Sep 30 15:27 okladkii.pdf",
  83. 36 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  84. 37 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  85. 38 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  86. 39 => "",
  87. 40 => "./files:",
  88. 41 => "total 320224",
  89. 42 => "-rwxrwx---@ 1 kraskowskil workgroup 2205050 Oct 2 12:09 2 strona-05-04-04.eps",
  90. 43 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  91. 44 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  92. 45 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  93. 46 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  94. 47 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  95. 48 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  96. 49 => "-rwxrwx---@ 1 kraskowskil workgroup 2203910 Oct 2 12:06 2 strona-05-04.eps",
  97. 50 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  98. 51 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  99. 52 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  100. 53 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  101. 54 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  102. 55 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  103. 56 => "-rwxrwx---@ 1 kraskowskil workgroup 1689006 Sep 30 15:44 2 strona-05.eps",
  104. 57 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  105. 58 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  106. 59 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  107. 60 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  108. 61 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  109. 62 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  110. 63 => "-rwxrwx---@ 1 kraskowskil workgroup 20336 Oct 3 11:30 295062_520407511316102_217586070_n.jpg",
  111. 64 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  112. 65 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  113. 66 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  114. 67 => "-rwxrwx---@ 1 kraskowskil workgroup 37838 Oct 3 11:35 C0122306.jpg",
  115. 68 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  116. 69 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  117. 70 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  118. 71 => "-rwxrwx---@ 1 kraskowskil workgroup 465726 Oct 2 10:35 help_icon-20.eps",
  119. 72 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  120. 73 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  121. 74 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  122. 75 => "-rwxrwx---@ 1 kraskowskil workgroup 1031704 Sep 25 14:05 icon.ai",
  123. 76 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  124. 77 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  125. 78 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  126. 79 => "-rwxrwx---@ 1 kraskowskil workgroup 1050878 Sep 25 14:38 icon.eps",
  127. 80 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  128. 81 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  129. 82 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  130. 83 => "drwxrwx---+ 33 kraskowskil workgroup 1122 Oct 4 16:26 icons",
  131. 84 => " 0: user:kraskowskil allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  132. 85 => " 1: group:workgroup allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  133. 86 => " 2: user:_www allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  134. 87 => "drwxrwx---+ 18 kraskowskil workgroup 612 Sep 30 14:59 ideas",
  135. 88 => " 0: user:kraskowskil allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  136. 89 => " 1: group:workgroup allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  137. 90 => " 2: user:_www allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  138. 91 => "-rwxrwx---@ 1 kraskowskil workgroup 483118 Sep 30 10:35 internet_icon.eps",
  139. 92 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  140. 93 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  141. 94 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  142. 95 => "drwxrwx---+ 5 kraskowskil workgroup 170 Oct 3 15:36 mapka",
  143. 96 => " 0: user:kraskowskil allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  144. 97 => " 1: group:workgroup allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  145. 98 => " 2: user:_www allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  146. 99 => "-rwxrwx---@ 1 kraskowskil workgroup 3525022 Oct 2 12:17 mapka-03.eps",
  147. 100 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  148. 101 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  149. 102 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  150. 103 => "-rwxrwx---@ 1 kraskowskil workgroup 332462 Oct 2 09:36 network_icon.eps",
  151. 104 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  152. 105 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  153. 106 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  154. 107 => "drwxrwx---+ 38 kraskowskil workgroup 1292 Sep 30 15:22 okładki",
  155. 108 => " 0: user:kraskowskil allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  156. 109 => " 1: group:workgroup allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  157. 110 => " 2: user:_www allow list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit",
  158. 111 => "-rwxrwx---@ 1 kraskowskil workgroup 467090 Oct 2 10:50 sprawiedliwosc_icon-25.eps",
  159. 112 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  160. 113 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  161. 114 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  162. 115 => "-rwxrwx---@ 1 kraskowskil workgroup 475402 Sep 30 10:36 tel_icon.eps",
  163. 116 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  164. 117 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  165. 118 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  166. 119 => "-rwxrwx---@ 1 kraskowskil workgroup 538178 Sep 30 10:35 telefon_icon.eps",
  167. 120 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  168. 121 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  169. 122 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  170. 123 => "-rwxrwx---@ 1 kraskowskil workgroup 35522224 Sep 25 14:26 tlo.psd",
  171. 124 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  172. 125 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  173. 126 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  174. 127 => "-rwxrwx---@ 1 kraskowskil workgroup 39249644 Sep 25 14:29 tlo2.psd",
  175. 128 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  176. 129 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  177. 130 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  178. 131 => "-rwxrwx---@ 1 kraskowskil workgroup 40306893 Sep 25 14:36 tlo3.psd",
  179. 132 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  180. 133 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  181. 134 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  182. 135 => "-rwxrwx---@ 1 kraskowskil workgroup 982067 Sep 25 16:09 vector biall-katalog.ai",
  183. 136 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  184. 137 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  185. 138 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  186. 139 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  187. 140 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  188. 141 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  189. 142 => "-rwxrwx---@ 1 kraskowskil workgroup 1745198 Sep 25 14:01 vector_icon-02.eps",
  190. 143 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  191. 144 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  192. 145 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  193. 146 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  194. 147 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  195. 148 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  196. 149 => "-rwxrwx---@ 1 kraskowskil workgroup 30854359 Oct 3 16:31 vector_icon.ai",
  197. 150 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  198. 151 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  199. 152 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  200. 153 => "-rwxrwx---@ 1 kraskowskil workgroup 466622 Oct 2 11:13 wzrost_icon-26.eps",
  201. 154 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  202. 155 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  203. 156 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  204. 157 => "",
  205. 158 => "./files/icons:",
  206. 159 => "total 67864",
  207. 160 => "-rwxrwx---@ 1 kraskowskil workgroup 997806 Oct 4 16:26 ikonki-01.eps",
  208. 161 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  209. 162 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  210. 163 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  211. 164 => "-rwxrwx---@ 1 kraskowskil workgroup 996502 Oct 4 16:26 ikonki-02.eps",
  212. 165 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  213. 166 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  214. 167 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  215. 168 => "-rwxrwx---@ 1 kraskowskil workgroup 1092438 Oct 4 16:26 ikonki-03.eps",
  216. 169 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  217. 170 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  218. 171 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  219. 172 => "-rwxrwx---@ 1 kraskowskil workgroup 997674 Oct 4 16:26 ikonki-04.eps",
  220. 173 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  221. 174 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  222. 175 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  223. 176 => "-rwxrwx---@ 1 kraskowskil workgroup 995578 Oct 4 16:26 ikonki-05.eps",
  224. 177 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  225. 178 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  226. 179 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  227. 180 => "-rwxrwx---@ 1 kraskowskil workgroup 995402 Oct 4 16:26 ikonki-06.eps",
  228. 181 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  229. 182 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  230. 183 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  231. 184 => "-rwxrwx---@ 1 kraskowskil workgroup 995298 Oct 4 16:26 ikonki-07.eps",
  232. 185 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  233. 186 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  234. 187 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  235. 188 => "-rwxrwx---@ 1 kraskowskil workgroup 1000758 Oct 4 16:26 ikonki-08.eps",
  236. 189 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  237. 190 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  238. 191 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  239. 192 => "-rwxrwx---@ 1 kraskowskil workgroup 999030 Oct 4 16:26 ikonki-09.eps",
  240. 193 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  241. 194 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  242. 195 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  243. 196 => "-rwxrwx---@ 1 kraskowskil workgroup 995542 Oct 4 16:26 ikonki-10.eps",
  244. 197 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  245. 198 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  246. 199 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  247. 200 => "-rwxrwx---@ 1 kraskowskil workgroup 996810 Oct 4 16:26 ikonki-11.eps",
  248. 201 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  249. 202 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  250. 203 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  251. 204 => "-rwxrwx---@ 1 kraskowskil workgroup 997534 Oct 4 16:26 ikonki-12.eps",
  252. 205 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  253. 206 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  254. 207 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  255. 208 => "-rwxrwx---@ 1 kraskowskil workgroup 995674 Oct 4 16:26 ikonki-13.eps",
  256. 209 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  257. 210 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  258. 211 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  259. 212 => "-rwxrwx---@ 1 kraskowskil workgroup 1002458 Oct 4 16:26 ikonki-14.eps",
  260. 213 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  261. 214 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  262. 215 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  263. 216 => "-rwxrwx---@ 1 kraskowskil workgroup 997478 Oct 4 16:26 ikonki-15.eps",
  264. 217 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  265. 218 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  266. 219 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  267. 220 => "-rwxrwx---@ 1 kraskowskil workgroup 1000090 Oct 4 16:26 ikonki-16.eps",
  268. 221 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  269. 222 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  270. 223 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  271. 224 => "-rwxrwx---@ 1 kraskowskil workgroup 995934 Oct 4 16:26 ikonki-17.eps",
  272. 225 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  273. 226 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  274. 227 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  275. 228 => "-rwxrwx---@ 1 kraskowskil workgroup 998298 Oct 4 16:26 ikonki-18.eps",
  276. 229 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  277. 230 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  278. 231 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  279. 232 => "-rwxrwx---@ 1 kraskowskil workgroup 998362 Oct 4 16:26 ikonki-19.eps",
  280. 233 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  281. 234 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  282. 235 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  283. 236 => "-rwxrwx---@ 1 kraskowskil workgroup 997602 Oct 4 16:26 ikonki-20.eps",
  284. 237 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  285. 238 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  286. 239 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  287. 240 => "-rwxrwx---@ 1 kraskowskil workgroup 997114 Oct 4 16:26 ikonki-21.eps",
  288. 241 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  289. 242 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  290. 243 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  291. 244 => "-rwxrwx---@ 1 kraskowskil workgroup 996854 Oct 4 16:26 ikonki-22.eps",
  292. 245 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  293. 246 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  294. 247 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  295. 248 => "-rwxrwx---@ 1 kraskowskil workgroup 1103014 Oct 4 16:26 ikonki-23.eps",
  296. 249 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  297. 250 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  298. 251 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  299. 252 => "-rwxrwx---@ 1 kraskowskil workgroup 991438 Oct 4 16:26 ikonki-24.eps",
  300. 253 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  301. 254 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  302. 255 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  303. 256 => "-rwxrwx---@ 1 kraskowskil workgroup 991430 Oct 4 16:26 ikonki-25.eps",
  304. 257 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  305. 258 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  306. 259 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  307. 260 => "-rwxrwx---@ 1 kraskowskil workgroup 991438 Oct 4 16:26 ikonki-26.eps",
  308. 261 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  309. 262 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  310. 263 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  311. 264 => "-rwxrwx---@ 1 kraskowskil workgroup 991438 Oct 4 16:26 ikonki-27.eps",
  312. 265 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  313. 266 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  314. 267 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  315. 268 => "-rwxrwx---@ 1 kraskowskil workgroup 991438 Oct 4 16:26 ikonki-28.eps",
  316. 269 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  317. 270 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  318. 271 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  319. 272 => "-rwxrwx---@ 1 kraskowskil workgroup 1249471 Oct 4 16:25 ikonki.ai",
  320. 273 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  321. 274 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  322. 275 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  323. 276 => "-rwxrwx---@ 1 kraskowskil workgroup 5194002 Oct 4 16:26 ikonki.eps",
  324. 277 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  325. 278 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  326. 279 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  327. 280 => "",
  328. 281 => "./files/ideas:",
  329. 282 => "total 8768",
  330. 283 => "-rwxrwx---@ 1 kraskowskil workgroup 3768091 Sep 27 14:57 3paski_luk.ai",
  331. 284 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  332. 285 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  333. 286 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  334. 287 => "-rwxrwx---@ 1 kraskowskil workgroup 28477 Sep 25 09:14 400_F_49095520_EHpfz0T9xsrz4Qcos2X7b1VvSlvygWUk.jpg",
  335. 288 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  336. 289 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  337. 290 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  338. 291 => "-rwxrwx---@ 1 kraskowskil workgroup 39349 Sep 25 09:13 400_F_49756688_8HTjP8kkooigl0EnxgTqR1DvjF2cqNWp.jpg",
  339. 292 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  340. 293 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  341. 294 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  342. 295 => "-rwxrwx---@ 1 kraskowskil workgroup 29025 Sep 25 09:08 400_F_51706259_O0PU1efa5QurjxRCRNxGMHDt6f8fDCLS.jpg",
  343. 296 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  344. 297 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  345. 298 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  346. 299 => "-rwxrwx---@ 1 kraskowskil workgroup 26788 Sep 25 09:14 400_F_51706705_HDERAFHA1Os1qTla9K0HxHxzIc5quX62.jpg",
  347. 300 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  348. 301 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  349. 302 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  350. 303 => "-rwxrwx---@ 1 kraskowskil workgroup 41271 Sep 25 09:14 400_F_52552977_Pl4vTWyxrRZ4iaJuCCfZiTLeSYfN43iJ.jpg",
  351. 304 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  352. 305 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  353. 306 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  354. 307 => "-rwxrwx---@ 1 kraskowskil workgroup 43872 Sep 25 09:14 400_F_53777430_KiOaUrNdOxswacYuVn0SwOAc90JWwRG7.jpg",
  355. 308 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  356. 309 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  357. 310 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  358. 311 => "-rwxrwx---@ 1 kraskowskil workgroup 38987 Sep 25 09:13 400_F_54486482_2TZGny09uCMtw6erZaWDiR5gJQjRWIrP.jpg",
  359. 312 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  360. 313 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  361. 314 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  362. 315 => "-rwxrwx---@ 1 kraskowskil workgroup 34531 Sep 25 09:14 400_F_55830018_xkWqEtY7JcsVZ9Wtdeh6JaFQUmRzD9E0.jpg",
  363. 316 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  364. 317 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  365. 318 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  366. 319 => "-rwxrwx---@ 1 kraskowskil workgroup 21752 Sep 25 09:14 400_F_56095979_QYYraAruFiboCn2cU35DKdUuB6CVqyW7.jpg",
  367. 320 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  368. 321 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  369. 322 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  370. 323 => "-rwxrwx---@ 1 kraskowskil workgroup 14273 Sep 27 12:25 FotoliaComp_51237043_N1KrwIvq3YyjEZA1WY9QG3O7JbB3fqYs.jpg",
  371. 324 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  372. 325 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  373. 326 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  374. 327 => "-rwxrwx---@ 1 kraskowskil workgroup 8760 Sep 25 08:53 FotoliaComp_55911652_7qoklD7AAjujfZmnRrGD4ILjjr0ywEet.jpg",
  375. 328 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  376. 329 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  377. 330 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  378. 331 => "-rwxrwx---@ 1 kraskowskil workgroup 7643 Sep 25 08:52 FotoliaComp_55912081_ranuB1khyEoqTiI1zy47waHKqo5winoP.jpg",
  379. 332 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  380. 333 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  381. 334 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  382. 335 => "-rwxrwx---@ 1 kraskowskil workgroup 7937 Sep 25 08:55 FotoliaComp_56265582_E5MFDyTJnOpPzdiTjCEt9E5zwEfkLptQ.jpg",
  383. 336 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  384. 337 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  385. 338 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  386. 339 => "-rwxrwx---@ 1 kraskowskil workgroup 347866 Sep 27 13:20 dott_infographic.jpg",
  387. 340 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  388. 341 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  389. 342 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  390. 343 => "",
  391. 344 => "./files/mapka:",
  392. 345 => "total 150200",
  393. 346 => "-rwxrwx---@ 1 kraskowskil workgroup 30354351 Oct 3 13:47 mapka.ai",
  394. 347 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  395. 348 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  396. 349 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  397. 350 => "-rwxrwx---@ 1 kraskowskil workgroup 46537842 Oct 3 13:47 mapka.eps",
  398. 351 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  399. 352 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  400. 353 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  401. 354 => "",
  402. 355 => "./files/okładki:",
  403. 356 => "total 1632",
  404. 357 => "-rwxrwx---@ 1 kraskowskil workgroup 9257 Sep 30 15:18 csumx3PP.jpg.part",
  405. 358 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  406. 359 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  407. 360 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  408. 361 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  409. 362 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  410. 363 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  411. 364 => "-rwxrwx---@ 1 kraskowskil workgroup 12933 Sep 30 15:12 fotolia_29446398.jpg",
  412. 365 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  413. 366 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  414. 367 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  415. 368 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  416. 369 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  417. 370 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  418. 371 => "-rwxrwx---@ 1 kraskowskil workgroup 13501 Sep 30 15:17 fotolia_29447320.jpg",
  419. 372 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  420. 373 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  421. 374 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  422. 375 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  423. 376 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  424. 377 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  425. 378 => "-rwxrwx---@ 1 kraskowskil workgroup 12557 Sep 30 15:12 fotolia_29447379.jpg",
  426. 379 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  427. 380 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  428. 381 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  429. 382 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  430. 383 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  431. 384 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  432. 385 => "-rwxrwx---@ 1 kraskowskil workgroup 14641 Sep 30 15:13 fotolia_37429269.jpg",
  433. 386 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  434. 387 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  435. 388 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  436. 389 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  437. 390 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  438. 391 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  439. 392 => "-rwxrwx---@ 1 kraskowskil workgroup 14776 Sep 30 15:12 fotolia_37429319.jpg",
  440. 393 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  441. 394 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  442. 395 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  443. 396 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  444. 397 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  445. 398 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  446. 399 => "-rwxrwx---@ 1 kraskowskil workgroup 17084 Sep 30 15:18 fotolia_37877043.jpg",
  447. 400 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  448. 401 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  449. 402 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  450. 403 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  451. 404 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  452. 405 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  453. 406 => "-rwxrwx---@ 1 kraskowskil workgroup 15858 Sep 30 15:17 fotolia_37877044.jpg",
  454. 407 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  455. 408 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  456. 409 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  457. 410 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  458. 411 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  459. 412 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  460. 413 => "-rwxrwx---@ 1 kraskowskil workgroup 15595 Sep 30 15:18 fotolia_37877055.jpg",
  461. 414 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  462. 415 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  463. 416 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  464. 417 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  465. 418 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  466. 419 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  467. 420 => "-rwxrwx---@ 1 kraskowskil workgroup 7658 Sep 30 15:01 fotolia_40810341.jpg",
  468. 421 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  469. 422 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  470. 423 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  471. 424 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  472. 425 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  473. 426 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  474. 427 => "-rwxrwx---@ 1 kraskowskil workgroup 8255 Sep 30 15:12 fotolia_40941077.jpg",
  475. 428 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  476. 429 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  477. 430 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  478. 431 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  479. 432 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  480. 433 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  481. 434 => "-rwxrwx---@ 1 kraskowskil workgroup 9257 Sep 30 15:18 fotolia_41414049.jpg",
  482. 435 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  483. 436 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  484. 437 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  485. 438 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  486. 439 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  487. 440 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  488. 441 => "-rwxrwx---@ 1 kraskowskil workgroup 9036 Sep 30 15:17 fotolia_41414192.jpg",
  489. 442 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  490. 443 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  491. 444 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  492. 445 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  493. 446 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  494. 447 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  495. 448 => "-rwxrwx---@ 1 kraskowskil workgroup 7160 Sep 30 15:00 fotolia_42917170.jpg",
  496. 449 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  497. 450 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  498. 451 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  499. 452 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  500. 453 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  501. 454 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  502. 455 => "-rwxrwx---@ 1 kraskowskil workgroup 11022 Sep 30 15:12 fotolia_44067256.jpg",
  503. 456 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  504. 457 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  505. 458 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  506. 459 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  507. 460 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  508. 461 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  509. 462 => "-rwxrwx---@ 1 kraskowskil workgroup 8336 Sep 30 15:12 fotolia_52178094.jpg",
  510. 463 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  511. 464 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  512. 465 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  513. 466 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  514. 467 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  515. 468 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  516. 469 => "-rwxrwx---@ 1 kraskowskil workgroup 8656 Sep 30 15:12 fotolia_52420666.jpg",
  517. 470 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  518. 471 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  519. 472 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  520. 473 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  521. 474 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  522. 475 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  523. 476 => "-rwxrwx---@ 1 kraskowskil workgroup 8282 Sep 30 15:00 fotolia_55915200.jpg",
  524. 477 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  525. 478 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  526. 479 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  527. 480 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  528. 481 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  529. 482 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  530. 483 => "-rwxrwx---@ 1 kraskowskil workgroup 8599 Sep 30 15:00 fotolia_55915205.jpg",
  531. 484 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  532. 485 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  533. 486 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  534. 487 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  535. 488 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  536. 489 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  537. 490 => "-rwxrwx---@ 1 kraskowskil workgroup 8070 Sep 30 15:00 fotolia_55915214.jpg",
  538. 491 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  539. 492 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  540. 493 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  541. 494 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  542. 495 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  543. 496 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  544. 497 => "-rwxrwx---@ 1 kraskowskil workgroup 9807 Sep 30 15:01 fotolia_56010256.jpg",
  545. 498 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  546. 499 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  547. 500 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  548. 501 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  549. 502 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  550. 503 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  551. 504 => "-rwxrwx---@ 1 kraskowskil workgroup 10966 Sep 30 15:00 fotolia_56276809.jpg",
  552. 505 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  553. 506 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  554. 507 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  555. 508 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  556. 509 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  557. 510 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  558. 511 => "-rwxrwx---@ 1 kraskowskil workgroup 7704 Sep 30 15:03 fotolia_56517534.jpg",
  559. 512 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  560. 513 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  561. 514 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  562. 515 => " 3: user:kraskowskil inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  563. 516 => " 4: group:workgroup inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  564. 517 => " 5: user:_www inherited allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  565. 518 => "-rwxrwx---@ 1 kraskowskil workgroup 44802 Sep 30 14:40 stock-photo-12942297-smiling-business-man-speaking-over-a-phone.jpg",
  566. 519 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  567. 520 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  568. 521 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  569. 522 => "-rwxrwx---@ 1 kraskowskil workgroup 43787 Sep 30 14:39 stock-photo-13171306-business-man-speaking-over-cellphone-with-colleagues-at-the-back.jpg",
  570. 523 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  571. 524 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  572. 525 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  573. 526 => "-rwxrwx---@ 1 kraskowskil workgroup 39562 Sep 30 14:40 stock-photo-15199787-attentive-businessman-on-the-phone-with-colleague-in-background.jpg",
  574. 527 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  575. 528 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  576. 529 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  577. 530 => "-rwxrwx---@ 1 kraskowskil workgroup 47620 Sep 30 14:53 stock-photo-15372082-executive-viewing-presentation-on-laptop.jpg",
  578. 531 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  579. 532 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  580. 533 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  581. 534 => "-rwxrwx---@ 1 kraskowskil workgroup 35984 Sep 30 14:40 stock-photo-15416214-businessman-communicating-through-headset.jpg",
  582. 535 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  583. 536 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  584. 537 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  585. 538 => "-rwxrwx---@ 1 kraskowskil workgroup 39520 Sep 30 14:55 stock-photo-15525740-couple-shopping-online.jpg",
  586. 539 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  587. 540 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  588. 541 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  589. 542 => "-rwxrwx---@ 1 kraskowskil workgroup 37231 Sep 30 14:57 stock-photo-26891071-bringing-in-some-extra-eyes-on-the-project.jpg",
  590. 543 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  591. 544 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  592. 545 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  593. 546 => "-rwxrwx---@ 1 kraskowskil workgroup 51777 Sep 30 14:37 stock-photo-3265037-businessman-happily-working.jpg",
  594. 547 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  595. 548 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  596. 549 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  597. 550 => "-rwxrwx---@ 1 kraskowskil workgroup 45278 Sep 30 14:39 stock-photo-7007516-businessman-talking-on-telephone-in-office.jpg",
  598. 551 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  599. 552 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  600. 553 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  601. 554 => "-rwxrwx---@ 1 kraskowskil workgroup 45685 Sep 30 14:39 stock-photo-7271704-happy-young-businesswoman-talking-on-phone.jpg",
  602. 555 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  603. 556 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  604. 557 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  605. 558 => "-rwxrwx---@ 1 kraskowskil workgroup 46491 Sep 30 14:39 stock-photo-7701331-businessman-talking-on-telephone-sitting-by-computer.jpg",
  606. 559 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  607. 560 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  608. 561 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  609. 562 => "-rwxrwx---@ 1 kraskowskil workgroup 29477 Sep 30 14:52 stock-photo-7722369-working-on-the-computer.jpg",
  610. 563 => " 0: user:kraskowskil allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  611. 564 => " 1: group:workgroup allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  612. 565 => " 2: user:_www allow read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown",
  613. );
  614. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">$filesWithPerms (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($filesWithPerms);echo'</pre>';
  615. $filesWithPermsTree = array();
  616. $lastName = '';
  617. $folderParent = '';
  618. foreach ($filesWithPerms as $line) {
  619. if (substr($line, 0, 1) == '-' || substr($line, 0, 1) == 'd') {// file name
  620. $fileParts = array();
  621. $filePartsArr = explode(' ', $line);
  622. foreach ($filePartsArr as $vPart) {
  623. if (!empty($vPart)) {
  624. $fileParts[] = $vPart;
  625. }
  626. }
  627. while (count($fileParts) > 9) {
  628. $lastPart = array_pop($fileParts);
  629. $prevPart = array_pop($fileParts);
  630. array_push($fileParts, "{$prevPart} {$lastPart}");
  631. }
  632. $file = new stdClass();
  633. $file->name = $fileParts[8];
  634. $file->path = array();
  635. if ($folderParent) $file->path[] = $folderParent;
  636. $file->path[] = $fileParts[8];
  637. $file->path = implode('/', $file->path);
  638. $file->owner = $fileParts[2];
  639. $file->group = $fileParts[3];
  640. $file->perms = $fileParts[0];
  641. $file->isDir = (substr($line, 0, 1) == 'd');
  642. $file->permsExtended = array();
  643. $filesWithPermsTree[$file->name] = $file;
  644. $lastName = $file;
  645. }
  646. else if (substr($line, 0, 1) == ' ') {// extended perm line
  647. $filesWithPermsTree[$file->name]->permsExtended[] = trim($line);
  648. }
  649. else if (substr($line, 0, 2) == './' && substr($line, -1) == ':') {// folder
  650. $folderParent = substr($line, 2, -1);
  651. }
  652. else if (substr($line, 0, 5) == 'total') {
  653. continue;
  654. }
  655. else if (empty($line)) {
  656. $folderParent = '';
  657. continue;
  658. }
  659. }
  660. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">$filesWithPermsTree (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($filesWithPermsTree);echo'</pre>';
  661. die('.OEF DBG > 5');
  662. }
  663. else if (empty($_SERVER["argv"]) && V::get('DBG', '', $_GET, 'int') > 0) {
  664. SyncPerms::run($_SERVER["argv"][0], $_SERVER["argv"][1]);
  665. }
  666. else {
  667. die("\n The second argument should be server domain - e.g. biuro.kike.pl \n");
  668. }
  669. if (!empty($_SERVER["argv"][0]) && !empty($_SERVER["argv"][1])) {
  670. $arg2 = (!empty($_SERVER["argv"][2]))? $_SERVER["argv"][2] : null;
  671. $arg3 = (!empty($_SERVER["argv"][3]))? $_SERVER["argv"][3] : null;
  672. //bash_perms_make_se($_SERVER["argv"][0], $_SERVER["argv"][1], $arg2, $arg3);
  673. SyncPerms::run($_SERVER["argv"][0], $_SERVER["argv"][1], $arg2, $arg3);
  674. }
  675. require(APP_PATH_ROOT."/superedit-SEF.php");
  676. //require_once(".config.php");
  677. function group_clear($FILE_URL) {// TODO: RMME
  678. // echo "\n chmod -N ".$FILE_URL;
  679. system("chmod -N {$FILE_URL}");
  680. }
  681. function make_proj_perm($LINK_PROJ, $PR_GROUP, $PR_CLASS, $PR_L_AP_US, $PR_L_AP_US_MAN, $PR_DESC) {// TODO: RMME
  682. $CHMOD="0770";
  683. /*
  684. #SRC166-copy
  685. */
  686. echo "160: chmod -R ".$CHMOD." ".$LINK_PROJ." CLASS:".$PR_CLASS.", PR_GROUP:".$PR_GROUP." , PR_L_AP_US:".$PR_L_AP_US." PR_L_AP_US_MAN:".$PR_L_AP_US_MAN." ";
  687. system(" chmod -R ".$CHMOD." ".$LINK_PROJ." ");
  688. if( empty($PR_GROUP)) $PR_GROUP='workgroup';
  689. if(!empty($PR_L_AP_US)) {
  690. echo "\n chown -R ".$PR_L_AP_US." ".$LINK_PROJ;
  691. system("chown -R ".$PR_L_AP_US." ".$LINK_PROJ);
  692. } else if(!empty($PR_L_AP_US_MAN)) {
  693. echo "\n chown -R ".$PR_L_AP_US_MAN." ".$LINK_PROJ;
  694. system("chown -R ".$PR_L_AP_US_MAN." ".$LINK_PROJ);
  695. }
  696. if(!empty($PR_GROUP) && ($PR_GROUP!="N/S;")) {
  697. echo "\n163: chgrp -R ".$PR_GROUP." ".$LINK_PROJ." ";
  698. system("chgrp ".$PR_GROUP." ".$LINK_PROJ." ");
  699. echo "\nCzyszcze group_clear ".$LINK_PROJ." ";
  700. group_clear($LINK_PROJ);
  701. system("chmod -R +a \"user:_www allow add_file,search,add_subdirectory,delete_child,read,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit\" ".$LINK_PROJ." ");
  702. echo "\n167: chmod +a group:".$PR_GROUP." allow read... ";
  703. system("chmod -R +a \"group:".$PR_GROUP." allow add_file,search,add_subdirectory,delete_child,read,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit\" ".$LINK_PROJ." ");
  704. //#dodanie tylko widoku plikow
  705. if (!empty($PR_CLASS)) {
  706. system("chmod -R +a \"group:".$PR_CLASS." allow execute,list,readattr,readsecurity,file_inherit,directory_inherit\" ".$LINK_PROJ." ");
  707. }
  708. echo "\n177 dodanie usera z PR_L_AP_US oraz PR_L_AP_US_MAN";
  709. if (!empty($PR_L_AP_US)) {
  710. system("chmod -R +a \"user:".$PR_L_AP_US." allow add_file,search,add_subdirectory,delete_child,read,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit\" ".$LINK_PROJ." ");
  711. }
  712. if (!empty($PR_L_AP_US_MAN) && ($PR_L_AP_US_MAN!='NULL')) {
  713. system("chmod -R +a \"user:${PR_L_AP_US_MAN} allow add_file,search,add_subdirectory,delete_child,read,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit\" ".$LINK_PROJ." ");
  714. }
  715. } else {
  716. echo "\nUnknown group ".$PR_GROUP." making clear for ".$LINK_PROJ." ";
  717. echo "\nCzyszcze group_clear ".$LINK_PROJ." ";
  718. group_clear($LINK_PROJ);
  719. if (!empty($PR_CLASS)) {
  720. system("chmod -R +a \"group:".$PR_CLASS." allow execute,list,readattr,readsecurity,file_inherit,directory_inherit\" ".$LINK_PROJ." ");
  721. }
  722. echo "\n227: chmod -R +a \"user:_www allow add_file,search,add_subdirectory,delete_child,read,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit\" ".$LINK_PROJ." ";
  723. system("chmod -R +a \"user:_www allow add_file,search,add_subdirectory,delete_child,read,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit\" ".$LINK_PROJ." ");
  724. }
  725. // #SRC166EOF-copy
  726. }
  727. function bash_perms_make_se($arg0, $arg1, $arg2, $arg3) {// TODO: RMME
  728. /*
  729. #!/bin/sh
  730. #author Arkadiusz Binder 2013-07-23
  731. #plan
  732. #1.odczytaj konfig typ labudda - baza, pliki pisma/projekty
  733. #2.dla kazdego projektu rekursywnie ustaw chgrp=A_ADM_COMPANY
  734. #3.dla kazdego projektu ustaw permy crhgrp=A_ADM_COMPANY
  735. #CONFIG look for .cnf--folders.[hostname].ini.php
  736. #CONFIG look for .cnf--zasob_[DbZasobId]-[hostname].ini.php
  737. #plan 2 - jezeli jest plik w /config/.bash_perms_make_se.timestamp ,
  738. #to dzialamy tak, ze szukamy plikow, ktore sie zmienily od tego momenu
  739. #dla nich tylko zmieniamy uprawnienia
  740. #a) szukamy jakie sa wogole projekty w uzyciu ${PROJECTS_USED[@]}
  741. #b) jak zalatwimy jakis z tych projektow to robimy unsed ${PROJECT_USED[$PROJ]}
  742. #c) potem robimy dla wszystkich zmiennych for var in ${PROJECT_USED[@]} - wyzwalamy funkcje $0 -force ${var} - czyli dokladamy po sprawie, ktorej nie znalezlismy
  743. #d) trzeba tez znalezc wszystkie sprawy, ktore ulegly zmianie od ostatniego czasu i dla nich zrobic force
  744. # profile : [ ! ${PR_GROUP} ] PR_GROUP='workgroup'
  745. export PATH=$PATH:/opt/local/lib/mysql55/bin:/usr/local/mysql/bin:/Library/Server/Web/Sites/Default/SE/utils:/Library/Server/Web/Data/Sites/Default/SE/utils:/Library/Server/Web/Data/Sites/Default/SE/se-dev/utils
  746. #funkcja czysci uprawnienia dla parametru $1 w filesystemie afs - dla wszysktich grup
  747. */
  748. $PROJ_mount_point = FoldersConfig::get('IN7_MK_BAZA_DYSTRYBUCJI_COLUMN', 'mount_point');
  749. $PISMA_mount_point = FoldersConfig::get('IN7_DZIENNIK_KORESP_COLUMN', 'mount_point');
  750. if (empty($PROJ_mount_point) || empty($PISMA_mount_point)) {
  751. die('Error in config for folders!');
  752. }
  753. else {
  754. echo "\n PROJ_mount_point = {$PROJ_mount_point} and PISMA_mount_point = {$PISMA_mount_point}";
  755. }
  756. system("echo \"<?xml version=\"1.0\" encoding=\"UTF-8\"?>
  757. <!DOCTYPE plist PUBLIC \"-//Apple Computer//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">
  758. <plist version=\"1.0\">
  759. <dict>
  760. <key>Disabled</key>
  761. <false/>
  762. <key>Label</key>
  763. <string>pl.biallnet.se.bash_perm</string>
  764. <key>UserName</key>
  765. <string>root</string>
  766. <key>ProgramArguments</key>
  767. <array>
  768. <string>php</string>
  769. <string>{$arg0}</string>
  770. <string>{$arg1}</string>
  771. </array>
  772. <key>StartInterval</key>
  773. <integer>60</integer>
  774. </dict>
  775. </plist>
  776. \" > /Library/LaunchDaemons/pl.biallnet.se.bash_perm.php.plist");
  777. $LAST_TIMESTAMP = file_get_contents(APP_PATH_ROOT . DS .'config' . DS . '.bash_perms_make_se.timestamp');
  778. $LAST_TIMESTAMP = str_replace(array("\n", "\r"), '', $LAST_TIMESTAMP);
  779. echo "\n read_timestamp:".$LAST_TIMESTAMP." arg3:".$arg3;
  780. if(($arg2 != "-force" ) && (!empty($LAST_TIMESTAMP))) {
  781. echo "file exists - changing perms only to newer files : ";
  782. echo "Finding newer Project files than (".$LAST_TIMESTAMP.")";
  783. // LAST_TIMESTAMP=`cat ${1}/.bash_perms_make_se.timestamp`
  784. echo "a) szukamy jakie sa wogole projekty w uzyciu -> {PROJECTS_USED[@]}";
  785. $sql="select t1.ID from IN7_MK_BAZA_DYSTRYBUCJI as t1
  786. where t1.A_STATUS!='DELETED' ; ";
  787. $res=DB::query($sql);
  788. while($h=DB::fetch_array($res)) {
  789. $PROJECTS_USED[$h['ID']]=$h['ID'];
  790. }
  791. $PATH_CNT=explode('/',$PROJ_mount_point);
  792. $PATH_CNT=count($PATH_CNT);
  793. exec("find ".$PROJ_mount_point." -newer ".APP_PATH_ROOT . DS .'config' . DS . '.bash_perms_make_se.timestamp',$ID_PROJ_ARR);
  794. print_r($ID_PROJ_ARR);
  795. foreach($ID_PROJ_ARR as $ID_PROJ) {
  796. exec("date \"+%s\" > ".APP_PATH_ROOT . DS .'config' . DS .".bash_perms_make_se.timestamp");
  797. echo "\n ID_PROJ: ".$ID_PROJ." number ".$PATH_CNT." " ;
  798. $FOLDER_CUT=explode("/",$ID_PROJ);
  799. $FOLDER=$FOLDER_CUT[$PATH_CNT];
  800. list($ID)=explode(".",$FOLDER);
  801. if(isset($PROJECTS_USED[$ID])) { //kasujemy z listy rekord - oznaczmay, ze ustalilismy dla tego projektu permy
  802. unset($PROJECTS_USED[$ID]);
  803. } // else {
  804. // continue ;
  805. // }
  806. $sql="select t1.ID
  807. , t1.A_ADM_COMPANY
  808. , t1.A_CLASSIFIED
  809. , t1.L_APPOITMENT_USER
  810. , concat_ws('', t2.L_APPOITMENT_USER) as T2_L_APPOITMENT_USER
  811. , left(concat(t1.M_DISTRIBUTOR, '_', t1.M_DIST_DESC), 50) as DESCR
  812. from IN7_MK_BAZA_DYSTRYBUCJI as t1
  813. left join IN7_MK_BAZA_DYSTRYBUCJI as t2 on (t1.P_ID=t2.ID)
  814. where t1.ID='".$ID."'
  815. ";
  816. $res2=DB::query($sql);
  817. //echo " SQL*".$sql."* rows : ".$rows."\n";
  818. while($h2=DB::fetch_array($res2)) {
  819. $PR_GROUP=$h2['A_ADM_COMPANY'];
  820. $PR_CLASS=$h2['A_CLASSIFIED'];
  821. $PR_L_AP_US=$h2['L_APPOITMENT_USER'];
  822. $PR_L_AP_US_MAN=$h2['T2_L_APPOITMENT_USER'];
  823. $PR_DESC=str_replace($_SESSION['CONFIG']['BAD_FILE_SIGNS'],$_SESSION['CONFIG']['OK_FILE_SIGNS'],$h2['DESCR']);
  824. $LINK_PROJ=$ID_PROJ;
  825. echo "\nFFFFFolder is ".$FOLDER_CUT[$PATH_CNT]." and id is (".$ID.")\n ***DESC(".$PR_DESC.")";
  826. make_proj_perm($LINK_PROJ,$PR_GROUP,$PR_CLASS,$PR_L_AP_US,$PR_L_AP_US_MAN,$PR_DESC);
  827. // #EOF Find newer
  828. }
  829. }
  830. // echo "c) szukanie edytowanych projektow uzytych"
  831. $sql="select t1.ID from IN7_MK_BAZA_DYSTRYBUCJI as t1 where unix_timestamp(A_RECORD_UPDATE_DATE)>'".$LAST_TIMESTAMP."' ; ";
  832. $res3=DB::query($sql);
  833. echo "\n *sql*".$sql."**";
  834. while($h3=DB::fetch_array($res3)) {
  835. echo "\neditied project found ".$h3['ID']." - add to array - after ".$LAST_TIMESTAMP;
  836. ECHO "\n php ".$arg0." ".$arg1." -force ".$h3['ID']." ";
  837. bash_perms_make_se($arg0,$arg1,'-force',$h3['ID']);
  838. // done
  839. }
  840. // [ ${#PROJECTS_USED[@]} -gt 0 ] && echo "Szukam uzytych projektow , ktore moze nie maja folderow: ${#PROJECTS_USED[@]} "
  841. if(count($PROJECTS_USED)>0) {
  842. // for var in ${PROJECTS_USED[@]} ; do
  843. foreach($PROJECTS_USED as $var) {
  844. // ls -d ${mount_point}/${PROJ_mount_point}/${var}.* >/dev/null 2>/dev/null || {
  845. exec("ls -d ".$PROJ_mount_point."/".$var.".* >/dev/null 2>/dev/null",$out,$exit_find);
  846. if($exit_find==1) {
  847. $stdout="";
  848. echo "\n Brak projektu ".$var." - uruchamiam bash_perms_make_se(".$arg0." ".$arg1." -force ".$var.") ";
  849. bash_perms_make_se($arg0,$arg1,'-force',$var);
  850. }
  851. // }
  852. // done
  853. }
  854. }
  855. }
  856. else {
  857. exec("date \"+%s\" > ".APP_PATH_ROOT . DS .'config' . DS .".bash_perms_make_se.timestamp");
  858. // date "+%s" > ${1}/.bash_perms_make_se.timestamp
  859. $SQL_LIMIT="";
  860. if(isset($arg3)) {
  861. echo "\nForced limit to only one project ".$arg3;
  862. $SQL_LIMIT=" and t1.ID='".$arg3."' ";
  863. } else {
  864. echo "\nNot found ".APP_PATH_ROOT . DS .'config' . DS . '.bash_perms_make_se.timestamp file - making perms to any files in PROJECTS and LETTERS';
  865. }
  866. $sql="select t1.ID,t1.A_ADM_COMPANY,t1.A_CLASSIFIED,t1.L_APPOITMENT_USER,concat_ws('',t2.L_APPOITMENT_USER) as T2_L_APPOITMENT_USER,left(concat(t1.M_DISTRIBUTOR,'_',t1.M_DIST_DESC),50) as DESCR from IN7_MK_BAZA_DYSTRYBUCJI as t1
  867. left join IN7_MK_BAZA_DYSTRYBUCJI as t2 on t1.P_ID=t2.ID
  868. where t1.A_STATUS!='DELETED' ".$SQL_LIMIT;
  869. $res2=DB::query($sql);
  870. echo " SQL*".$sql."* rows : ".$rows."\n ";
  871. while($h2=DB::fetch_array($res2)) {
  872. $PR_ID=$h2['ID'];
  873. $PR_GROUP=$h2['A_ADM_COMPANY'];
  874. $PR_CLASS=$h2['A_CLASSIFIED'];
  875. $PR_L_AP_US=$h2['L_APPOITMENT_USER'];
  876. $PR_L_AP_US_MAN=$h2['T2_L_APPOITMENT_USER'];
  877. $PR_DESC=str_replace($_SESSION['CONFIG']['BAD_FILE_SIGNS'],$_SESSION['CONFIG']['OK_FILE_SIGNS'],$h2['DESCR']);
  878. $LINK_PROJ=$PROJ_mount_point."/".$PR_ID.".*";
  879. $FILE_EXIST=0;
  880. exec("ls -d ".$LINK_PROJ." 2>/dev/null ",$LINK_PROJ_CUST,$stderr);
  881. if($stderr==0) {
  882. $LINK_PROJ_CUST=$LINK_PROJ_CUST[0];
  883. echo "\n152:jest katalog (".$LINK_PROJ.") ".$LINK_PROJ_CUST." \n mkdir -p ".$LINK_PROJ_CUST."/PISMA_LINK \n";
  884. system("mkdir -p ".$LINK_PROJ_CUST."/PISMA_LINK");
  885. $FILE_EXIST=1;
  886. } else {
  887. echo "\n155:brak katalogu (".$stderr.")(".$stdout.") ".$PR_ID." for ".$PR_DESC." bedzie : mkdir ".$PROJ_mount_point."/".$PR_ID.".".$PR_DESC ;
  888. system("mkdir ".$PROJ_mount_point."/".$PR_ID.".".$PR_DESC);
  889. $FILE_EXIST=1;
  890. system("mkdir -p ".$LINK_PROJ_CUST."/PISMA_LINK");
  891. }
  892. if($FILE_EXIST==1) {
  893. make_proj_perm($LINK_PROJ,$PR_GROUP,$PR_CLASS,$PR_L_AP_US,$PR_L_AP_US_MAN,$PR_DESC);
  894. }
  895. $sql="select ID,K_TYP_KORESP from IN7_DZIENNIK_KORESP where ID_PROJECT=".$PR_ID." ; ";
  896. $res4=DB::query($sql);
  897. //echo " SQL*".$sql."* rows : ".$rows."\n";
  898. while($h4=DB::fetch_array($res4)) {
  899. $PR_ID=$h2['ID'];
  900. $LINK_PISMO=$PISMA_mount_point."/".$h4['K_TYP_KORESP']."/".$h4['ID'].".*";
  901. $FILE_EXIST=0;
  902. #teraz pisma
  903. //for PISMO in `echo "select concat(ID,'#;#',K_TYP_KORESP) from IN7_DZIENNIK_KORESP where ID_PROJECT=${PR_ID} ; "|mysql -s -u${DB_USER} -p${DB_PASS} -h${DB_HOST} -D${DB_NAME} |sed 's/\ /_/g' ` ; do
  904. //echo "175:PISMO is ${PISMO}"
  905. //PISMO_ID=`echo ${PISMO} |awk -F'#;#' '{ print $1 }'`
  906. //PISMO_GDZIE=`echo ${PISMO} |awk -F'#;#' '{ print $2 }'`
  907. //LINK_PISMO="${mount_point}/${PISMA_mount_point}/${PISMO_GDZIE}/${PISMO_ID}.*"
  908. exec("ls ".$LINK_PISMO." 2>/dev/null >/dev/null",$stdout,$stderr);
  909. if($stderr==0) {
  910. echo "\njest pismo ".$LINK_PISMO ;
  911. //make_proj_perm($LINK_PISMO,$PR_GROUP,$PR_CLASS,$PR_L_AP_US,$PR_L_AP_US_MAN,$PR_DESC);
  912. echo "\n177:chmod -R 0770 ".$LINK_PISMO ;
  913. system("chmod -R 0770 ".$LINK_PISMO);
  914. if(!empty($PR_GROUP) && ($PR_GROUP!="N/S;")) {
  915. echo "\n180:chgrp -R ".$PR_GROUP." ".$LINK_PISMO." ";
  916. system("chgrp -R ".$PR_GROUP." ".$LINK_PISMO);
  917. // echo "Czyszcze group_clear ${LINK_PROJ} "
  918. group_clear($LINK_PISMO);
  919. // echo "183:ONLY APPEND chmod -R +a user:_www allow (..) ${LINK_PISMO} "
  920. system("chmod -R +a \"user:_www allow add_file,search,add_subdirectory,read,readattr,append,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit\" ".$LINK_PISMO);
  921. echo "\n185:ONLY READ!! chmod -R +a group:".$PR_GROUP." allow read... ".$LINK_PISMO." ";
  922. system("chmod -R +a \"group:".$PR_GROUP." allow add_file,append,search,add_subdirectory,read,readattr,readextattr,readsecurity,file_inherit,directory_inherit\" ".$LINK_PISMO);
  923. //robie symlinki
  924. // system("ln ".$LINK_PISMO." ".$LINK_PROJ_CUST."/PISMA_LINK/");
  925. }
  926. } else {
  927. echo "\n194: brak pism dla dziennika ".$LINK_PISMO;
  928. // #FILE_EXIST=0
  929. }
  930. }
  931. }
  932. }
  933. } //eof func
  934. class SyncPerms {
  935. public static function getLastRunDate() {// TODO: RMME
  936. if (($argFromDate = V::get('_fromDate', '', $_GET)) != '') {
  937. // Format: 2013-10-07 23:46
  938. if (strlen($argFromDate) == 16
  939. && substr($argFromDate, 4, 1) == '-'
  940. && substr($argFromDate, 7, 1) == '-'
  941. && substr($argFromDate, 10, 1) == '-'
  942. && substr($argFromDate, 13, 1) == ':'
  943. && is_numeric(str_replace(array('-', ':'), '', $argFromDate))
  944. ) {
  945. $lastRunDate = mktime(substr($argFromDate, 11, 2), substr($argFromDate, 14, 2), 0, substr($argFromDate, 5, 2), substr($argFromDate, 8, 2), substr($argFromDate, 0, 4));
  946. $lastRunDate = date("Y-m-d H:i", $lastRunDate);
  947. }
  948. }
  949. if (!$lastRunDate) {
  950. $lastRunDate = mktime(date("H") - 1, date("i"), date("s"), date("n"), date("j"), date("Y"));
  951. $lastRunDate = date("Y-m-d H:i", $lastRunDate);
  952. }
  953. //$lastRunDate = '2013-09-01 01:00';
  954. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">lastRunDate (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($lastRunDate);echo'</pre>';
  955. return $lastRunDate;
  956. }
  957. public static function installTable() {
  958. $db = DB::getDB();
  959. if (!$db) {
  960. die("DB Error: No DB!");
  961. }
  962. $sql = "
  963. CREATE TABLE IF NOT EXISTS `_SYNC_FILE_PERMS` (
  964. `ID` int(11) NOT NULL AUTO_INCREMENT,
  965. `ID_PROJECT` int(11) NOT NULL,
  966. `L_APPOITMENT_USER` varchar(64) DEFAULT '',
  967. `A_ADM_COMPANY` varchar(64) NOT NULL DEFAULT '',
  968. `A_CLASSIFIED` varchar(64) NOT NULL DEFAULT '',
  969. `PARENT_L_APPOITMENT_USER` varchar(64) NOT NULL DEFAULT '',
  970. `A_LAST_SYNC` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
  971. `A_SYNCHRONIZED` tinyint(4) NOT NULL DEFAULT '0',
  972. PRIMARY KEY (`ID`),
  973. UNIQUE KEY `ID_PROJECT` (`ID_PROJECT`)
  974. ) ENGINE=MyISAM DEFAULT CHARSET=latin2 ;
  975. ";
  976. $db->query($sql);
  977. }
  978. public static function run($script_name, $domain, $arg2, $arg3) {
  979. if ($arg2 == 'addToLaunchctl') {
  980. system("echo \"<?xml version=\"1.0\" encoding=\"UTF-8\"?>
  981. <!DOCTYPE plist PUBLIC \"-//Apple Computer//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">
  982. <plist version=\"1.0\">
  983. <dict>
  984. <key>Disabled</key>
  985. <false/>
  986. <key>Label</key>
  987. <string>pl.biallnet.sync_perms.php</string>
  988. <key>UserName</key>
  989. <string>root</string>
  990. <key>ProgramArguments</key>
  991. <array>
  992. <string>php</string>
  993. <string>{$_SERVER["argv"][0]}</string>
  994. <string>{$_SERVER["argv"][1]}</string>
  995. </array>
  996. <key>StartInterval</key>
  997. <integer>60</integer>
  998. </dict>
  999. </plist>
  1000. \" > /Library/LaunchDaemons/pl.biallnet.sync_perms.php.plist");
  1001. echo "Run By Root: launchctl load /Library/LaunchDaemons/pl.biallnet.sync_perms.php.plist\n";
  1002. }
  1003. else if ($arg2 == 'newFiles') {
  1004. $time = new stdClass();
  1005. $time->start = time();
  1006. self::fixLastModifiedFiles();
  1007. self::saveTask(-1);
  1008. }
  1009. else if ($arg2 == 'nextTask') {
  1010. $time = new stdClass();
  1011. $time->start = time();
  1012. self::installTable();
  1013. self::generateTasksNewRecords();
  1014. self::generateTasksUpdated();
  1015. $limit = V::get('_limit', 1, $_GET, 'int');
  1016. for ($i = 0; $i < $limit; $i++) {
  1017. $time->cur = time();
  1018. if ($time->cur - $time->start > 60 * 5) {
  1019. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:2px solid red;text-align:left;">Force-break time('.($time->cur - $time->start).') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';echo'</pre>';}
  1020. break;
  1021. }
  1022. $task = self::getTask();
  1023. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">time('.($time->cur - $time->start).') task (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($task);echo'</pre>';}
  1024. if (!$task) {
  1025. break;
  1026. }
  1027. self::executeTask($task);
  1028. self::saveTask($task->ID_PROJECT);
  1029. }
  1030. }
  1031. else {
  1032. self::installTable();
  1033. $fixedProjIds = self::fixLastModifiedByFiles();
  1034. self::fixLastModifiedByDB($fixedProjIds);
  1035. }
  1036. }
  1037. public static function generateTasksUpdated() {
  1038. $db = DB::getDB();
  1039. if (!$db) {
  1040. die("DB Error: No DB!");
  1041. }
  1042. $sqlTest = "select p.ID, p.`L_APPOITMENT_USER`, p.`A_ADM_COMPANY`, p.`A_CLASSIFIED`, s. *
  1043. from `_SYNC_FILE_PERMS` as s, `IN7_MK_BAZA_DYSTRYBUCJI` as p, `IN7_MK_BAZA_DYSTRYBUCJI` as pp
  1044. where
  1045. s.`ID_PROJECT`=p.`ID` and pp.`ID`=p.`P_ID`
  1046. and (
  1047. s.`L_APPOITMENT_USER`!=p.`L_APPOITMENT_USER`
  1048. or s.`A_ADM_COMPANY`!=p.`A_ADM_COMPANY`
  1049. or s.`A_CLASSIFIED`!=p.`A_CLASSIFIED`
  1050. or s.`PARENT_L_APPOITMENT_USER`!=pp.`L_APPOITMENT_USER`
  1051. )
  1052. ";
  1053. $sql = "update `_SYNC_FILE_PERMS` as s, `IN7_MK_BAZA_DYSTRYBUCJI` as p, `IN7_MK_BAZA_DYSTRYBUCJI` as pp
  1054. set
  1055. s.`L_APPOITMENT_USER`=p.`L_APPOITMENT_USER`
  1056. , s.`A_ADM_COMPANY`=p.`A_ADM_COMPANY`
  1057. , s.`A_CLASSIFIED`=p.`A_CLASSIFIED`
  1058. , s.`PARENT_L_APPOITMENT_USER`=pp.`L_APPOITMENT_USER`
  1059. , s.`A_SYNCHRONIZED`=0
  1060. where
  1061. s.`ID_PROJECT`=p.`ID` and pp.`ID`=p.`P_ID`
  1062. and (
  1063. s.`L_APPOITMENT_USER`!=p.`L_APPOITMENT_USER`
  1064. or s.`A_ADM_COMPANY`!=p.`A_ADM_COMPANY`
  1065. or s.`A_CLASSIFIED`!=p.`A_CLASSIFIED`
  1066. or s.`PARENT_L_APPOITMENT_USER`!=pp.`L_APPOITMENT_USER`
  1067. )
  1068. ";
  1069. $res = $db->query($sql);
  1070. }
  1071. public static function generateTasksNewRecords() {
  1072. $db = DB::getDB();
  1073. if (!$db) {
  1074. die("DB Error: No DB!");
  1075. }
  1076. $sql = "insert ignore into `_SYNC_FILE_PERMS` (`ID_PROJECT`, `L_APPOITMENT_USER`, `A_ADM_COMPANY`, `A_CLASSIFIED`, `PARENT_L_APPOITMENT_USER`)
  1077. values (-1, '', '', '', '');
  1078. ";
  1079. $res = $db->query($sql);
  1080. $sql = "insert ignore into `_SYNC_FILE_PERMS` (`ID_PROJECT`, `L_APPOITMENT_USER`, `A_ADM_COMPANY`, `A_CLASSIFIED`, `PARENT_L_APPOITMENT_USER`)
  1081. select p.`ID`, p.`L_APPOITMENT_USER`, p.`A_ADM_COMPANY`, p.`A_CLASSIFIED`, pp.`L_APPOITMENT_USER`
  1082. from `IN7_MK_BAZA_DYSTRYBUCJI` as p
  1083. left join `IN7_MK_BAZA_DYSTRYBUCJI` as pp on (pp.`ID`=p.`P_ID`)
  1084. where p.`A_STATUS`!='DELETED'
  1085. ";
  1086. $res = $db->query($sql);
  1087. }
  1088. /**
  1089. * Znajdź najstarszy aktualizowany projekt.
  1090. */
  1091. public static function getTask() {
  1092. $task = null;
  1093. $db = DB::getDB();
  1094. if (!$db) {
  1095. die("DB Error: No DB!");
  1096. }
  1097. $sql = "select s.*
  1098. , p.`L_APPOITMENT_USER` as p__L_APPOITMENT_USER
  1099. , p.`A_ADM_COMPANY` as p__A_ADM_COMPANY
  1100. , p.`A_CLASSIFIED` as p__A_CLASSIFIED
  1101. , pp.`L_APPOITMENT_USER` as p__PARENT_L_APPOITMENT_USER
  1102. , p.`M_DIST_DESC` as p__M_DIST_DESC
  1103. from `_SYNC_FILE_PERMS` as s
  1104. left join `IN7_MK_BAZA_DYSTRYBUCJI` as p on(p.`ID`=s.`ID_PROJECT`)
  1105. left join `IN7_MK_BAZA_DYSTRYBUCJI` as pp on(pp.`ID`=p.`P_ID`)
  1106. where s.`A_SYNCHRONIZED`=0
  1107. order by s.`A_LAST_SYNC` asc, s.`ID` asc
  1108. limit 1
  1109. ";
  1110. $res = $db->query($sql);
  1111. if ($r = $db->fetch($res)) {
  1112. $task = $r;
  1113. }
  1114. return $task;
  1115. }
  1116. public static function getLastFilesTime() {
  1117. $lastFilesTime = null;
  1118. $db = DB::getDB();
  1119. if (!$db) {
  1120. die("DB Error: No DB!");
  1121. }
  1122. $sql = "select s.`A_LAST_SYNC`
  1123. from `_SYNC_FILE_PERMS` as s
  1124. where s.`ID_PROJECT`=-1
  1125. ";
  1126. $res = $db->query($sql);
  1127. if ($r = $db->fetch($res)) {
  1128. $lastFilesTime = $r->A_LAST_SYNC;
  1129. }
  1130. if (!$lastFilesTime) {
  1131. $lastFilesTime = mktime(date("H"), date("i") - 10, date("s"), date("n"), date("j"), date("Y"));
  1132. $lastFilesTime = date("Y-m-d H:i", $lastFilesTime);
  1133. }
  1134. return $lastFilesTime;
  1135. }
  1136. public static function saveTask($idProject) {
  1137. $task = null;
  1138. $db = DB::getDB();
  1139. if (!$db) {
  1140. die("DB Error: No DB!");
  1141. }
  1142. $sql = "update `_SYNC_FILE_PERMS` as s
  1143. set s.`A_SYNCHRONIZED`=1
  1144. , s.`A_LAST_SYNC`=NOW()
  1145. where s.`ID_PROJECT`={$idProject}
  1146. ";
  1147. $res = $db->query($sql);
  1148. return $task;
  1149. }
  1150. public static function executeTask($task) {
  1151. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">executeTask (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($task);echo'</pre>';}
  1152. $confTblName = 'IN7_MK_BAZA_DYSTRYBUCJI_COLUMN';
  1153. $PROJ_mount_point = FoldersConfig::get($confTblName, 'mount_point');
  1154. $project = new stdClass();
  1155. $project->ID = $task->ID_PROJECT;
  1156. $project->L_APPOITMENT_USER = $task->p__L_APPOITMENT_USER;
  1157. $project->A_ADM_COMPANY = $task->p__A_ADM_COMPANY;
  1158. $project->A_CLASSIFIED = $task->p__A_CLASSIFIED;
  1159. $project->PARENT_L_APPOITMENT_USER = $task->p__PARENT_L_APPOITMENT_USER;
  1160. $project->M_DIST_DESC = $task->p__M_DIST_DESC;
  1161. $folderConf = FoldersConfig::getAll($confTblName);
  1162. $uploader = new FileUploader($confTblName, $project);
  1163. $errMsg = '';
  1164. if (!$uploader->setConfig($folderConf, $errMsg)) {
  1165. trigger_error("Error: folders config!", E_USER_NOTICE);
  1166. die("Error: folders config!");
  1167. }
  1168. $uploader->findFolder();
  1169. $mainFolder = $uploader->getDestFolder();
  1170. if(V::get('DBG', '', $_GET, 'int') > 2){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">generated folderName('.$project->ID.') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';var_dump($uploader);echo'</pre>';}
  1171. if (!$mainFolder) {
  1172. $mainFolder = $uploader->generateFolderName();
  1173. $mainFolderPath = rtrim($PROJ_mount_point, '/') . '/' . $mainFolder;
  1174. if(V::get('DBG', '', $_GET, 'int') > 2){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">generated folderName('.$project->ID.') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r(array($mainFolder, $mainFolderPath));echo'</pre>';}
  1175. exec("mkdir {$mainFolderPath}");
  1176. mkdir($mainFolderPath, 0770, true);
  1177. @chmod($mainFolderPath, 0770);
  1178. if (!file_exists($mainFolderPath)) {
  1179. trigger_error("Error: Nie udało się utworzyć folderu! ({$mainFolder})", E_USER_NOTICE);
  1180. return false;
  1181. }
  1182. $requirePermsExt = self::getRequiredPermsExtByRecord($project);
  1183. $file = new stdClass();
  1184. $file->name = $mainFolder;
  1185. $file->path = $mainFolder;
  1186. $file->owner = '';
  1187. $file->group = '';
  1188. $file->perms = '';
  1189. $file->isDir = true;
  1190. $file->permsExt = array();
  1191. $cmdList = self::fixFilePerms($file, $requirePermsExt, "{$PROJ_mount_point}/" . addslashes($mainFolder), $project);
  1192. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">cmdList-P('.$project->ID.') fixFilePerms (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($cmdList);echo'</pre>';}
  1193. }
  1194. else {
  1195. $cmdList = self::fixProject($project, $mainFolder, $PROJ_mount_point);
  1196. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">cmdList-P('.$project->ID.') fixProject (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($cmdList);echo'</pre>';}
  1197. $cmdKorepList = self::fixProjectKoresp($project);
  1198. if (!empty($cmdKorepList)) {
  1199. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">cmdList-P('.$project->ID.') fixProjectKoresp (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($cmdKorepList);echo'</pre>';}
  1200. foreach ($cmdKorepList as $vCmd) {
  1201. $cmdList[] = $vCmd;
  1202. }
  1203. }
  1204. // TODO: $cmdDrukiList = self::fixProjectDruki($project, $mainFolder, $PROJ_mount_point);
  1205. }
  1206. if (!empty($cmdList)) {
  1207. foreach ($cmdList as $vCmd) {
  1208. if(V::get('DBG', '', $_GET, 'int') > 1){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">Exec-cmdList-P('.$project->ID.') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($vCmd);echo'</pre>';}
  1209. exec($vCmd, $out, $outValue);
  1210. if(V::get('DBG', '', $_GET, 'int') > 1){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">Done-cmdList-P('.$project->ID.') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r(array($outValue, $out));echo'</pre>';}
  1211. if ($outValue != 0) {
  1212. trigger_error("Error-cmd: {$vCmd}", E_USER_NOTICE);
  1213. }
  1214. }
  1215. }
  1216. }
  1217. public static function getRequiredPermsExtByRecord($project) {
  1218. $requirePermsExt = array();
  1219. if (!$project->L_APPOITMENT_USER && !$project->A_ADM_COMPANY) {// no owner, no write group
  1220. // TODO: group PODMIOT
  1221. $requirePermsExt["group:workgroup"] = array('write', 'read');
  1222. }
  1223. else {
  1224. if ($project->L_APPOITMENT_USER) {
  1225. $requirePermsExt["user:{$project->L_APPOITMENT_USER}"] = array('write', 'read');
  1226. }
  1227. if (!empty($project->A_ADM_COMPANY) && $project->A_ADM_COMPANY == $project->A_CLASSIFIED) {
  1228. $requirePermsExt["group:{$project->A_ADM_COMPANY}"] = array('read', 'write');
  1229. }
  1230. else if (empty($project->A_ADM_COMPANY) && empty($project->A_CLASSIFIED)) {
  1231. $requirePermsExt["group:workgroup"] = array('write', 'read');
  1232. }
  1233. else {
  1234. if ($project->A_ADM_COMPANY) {
  1235. $requirePermsExt["group:{$project->A_ADM_COMPANY}"] = array('write');
  1236. }
  1237. if ($project->A_CLASSIFIED) {
  1238. $requirePermsExt["group:{$project->A_CLASSIFIED}"] = array('read');
  1239. }
  1240. }
  1241. }
  1242. // add parent owner
  1243. if (!empty($project->PARENT_L_APPOITMENT_USER) && $project->PARENT_L_APPOITMENT_USER != $project->L_APPOITMENT_USER) {
  1244. $requirePermsExt["user:{$project->PARENT_L_APPOITMENT_USER}"] = array('write', 'read');
  1245. }
  1246. // add user:_www perms read, write
  1247. $requirePermsExt["user:_www"] = array('write', 'read');
  1248. return $requirePermsExt;
  1249. }
  1250. /**
  1251. * Used for files added/modified by samba/afp.
  1252. *
  1253. * Last execute time is stored as ID_PROJECT = -1 in _SYNC_FILE_PERMS
  1254. * @see getLastFilesTime
  1255. */
  1256. public static function fixLastModifiedFiles() {
  1257. $db = DB::getDB();
  1258. if (!$db) {
  1259. die("DB Error: No DB!");
  1260. }
  1261. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">fixLastModifiedFiles (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r("fixLastModifiedFiles");echo'</pre>';}
  1262. $PROJ_mount_point = FoldersConfig::get('IN7_MK_BAZA_DYSTRYBUCJI_COLUMN', 'mount_point');
  1263. $PISMA_mount_point = FoldersConfig::get('IN7_DZIENNIK_KORESP_COLUMN', 'mount_point');
  1264. $foundProjectFiles = array();
  1265. $lastRunDate = self::getLastFilesTime();
  1266. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">$lastRunDate (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($lastRunDate);echo'</pre>';}
  1267. //exec("cd {$PROJ_mount_point}; find . -newermt '{$lastRunDate}' ", $foundPaths);
  1268. exec("cd {$PROJ_mount_point}; find . -newermt '{$lastRunDate}' -type f -exec ls -lea '{}' \;", $filesWithPerms);
  1269. if (!empty($filesWithPerms)) {
  1270. $filesWithPermsTree = array();
  1271. $lastName = '';
  1272. foreach ($filesWithPerms as $line) {
  1273. if (substr($line, 0, 1) == '-') {// file name
  1274. $fileParts = array();
  1275. $filePartsArr = explode(' ', $line);
  1276. foreach ($filePartsArr as $vPart) {
  1277. if (!empty($vPart) || $vPart === '0') {
  1278. $fileParts[] = $vPart;
  1279. }
  1280. }
  1281. while (count($fileParts) > 9) {
  1282. $lastPart = array_pop($fileParts);
  1283. $prevPart = array_pop($fileParts);
  1284. array_push($fileParts, "{$prevPart} {$lastPart}");
  1285. }
  1286. $file = new stdClass();
  1287. if (!isset($fileParts[8])) {
  1288. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">Error parse file name (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r(array('line'=>$line, 'fileParts'=>$fileParts));echo'</pre>';
  1289. //continue;
  1290. }
  1291. $file->name = end($fileParts);
  1292. $file->path = end($fileParts);
  1293. $file->owner = $fileParts[2];
  1294. $file->group = $fileParts[3];
  1295. $file->perms = $fileParts[0];
  1296. $file->isDir = (substr($line, 0, 1) == 'd');
  1297. $file->permsExt = array();
  1298. $filesWithPermsTree[$file->name] = $file;
  1299. $lastName = $file->name;
  1300. }
  1301. else if (substr($line, 0, 1) == ' ') {// extended perm line
  1302. if ($lastName == '..') {
  1303. continue;
  1304. }
  1305. $filesWithPermsTree[$file->name]->permsExt[] = trim($line);
  1306. }
  1307. else {// parse error
  1308. $lastName = '..';
  1309. }
  1310. }
  1311. foreach ($filesWithPermsTree as $vFile) {
  1312. $vFile->path = ltrim($vFile->path, './');
  1313. $vFile->path = explode('/', $vFile->path);
  1314. $vFile->projectFolder = array_shift($vFile->path);
  1315. $vFile->path = implode('/', $vFile->path);
  1316. $projId = explode('.', $vFile->projectFolder);
  1317. $projId = reset($projId);
  1318. if (is_numeric($projId) && $projId > 0) {
  1319. $foundProjectFiles[$projId][] = $vFile;
  1320. }
  1321. }
  1322. }
  1323. if(V::get('DBG', '', $_GET, 'int') > 1){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">filesWithPerms (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): '."path: {$PROJ_mount_point}\n";print_r($filesWithPerms);echo'</pre>';}
  1324. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">foundProjectFiles (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): '."path: {$PROJ_mount_point}\n";print_r($foundProjectFiles);echo'</pre>';}
  1325. if (!empty($foundProjectFiles)) {
  1326. $sql = "select p.`ID`
  1327. , p.`L_APPOITMENT_USER`
  1328. , p.`A_ADM_COMPANY`
  1329. , p.`A_CLASSIFIED`
  1330. , pp.`L_APPOITMENT_USER` as PARENT_L_APPOITMENT_USER
  1331. from IN7_MK_BAZA_DYSTRYBUCJI as p
  1332. left join IN7_MK_BAZA_DYSTRYBUCJI as pp on (pp.ID=p.P_ID)
  1333. where p.`ID` in (" . implode(',', array_keys($foundProjectFiles)) . ")
  1334. ";
  1335. $res = $db->query($sql);
  1336. while ($r = $db->fetch($res)) {
  1337. $requirePermsExt = self::getRequiredPermsExtByRecord($r);
  1338. foreach ($foundProjectFiles[$r->ID] as $vFile) {
  1339. $cmdList = self::fixFilePerms($vFile, $requirePermsExt, "{$PROJ_mount_point}/" . addslashes($vFile->projectFolder), $r);
  1340. if (!empty($cmdList)) {
  1341. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">$cmdList P('.$r->ID.') total('.count($cmdList).') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($cmdList);echo'</pre>';}
  1342. } else {
  1343. if(V::get('DBG', '', $_GET, 'int') > 1){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">$cmdList P('.$r->ID.') total('.count($cmdList).') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($cmdList);echo'</pre>';}
  1344. }
  1345. }
  1346. }
  1347. }
  1348. }
  1349. /**
  1350. * @returns array - last modified project ids.
  1351. */
  1352. public static function fixLastModifiedByFiles() {// TODO: RMME
  1353. $db = DB::getDB();
  1354. if (!$db) {
  1355. die("DB Error: No DB!");
  1356. }
  1357. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">fixLastModifiedByFiles (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r("fixLastModifiedByFiles");echo'</pre>';}
  1358. /*
  1359. * $ man find:
  1360. -newer file
  1361. True if the current file has a more recent last modification time than file.
  1362. -newerXY file
  1363. True if the current file has a more recent last access time (X=a), inode creation time (X=B), change time (X=c),
  1364. or modification time (X=m) than the last access time (Y=a), inode creation time (Y=B), change time (Y=c), or mod-
  1365. ification time (Y=m) of file. In addition, if Y=t, then file is instead interpreted as a direct date specifica-
  1366. tion of the form understood by cvs(1). Note that -newermm is equivalent to -newer.
  1367. *
  1368. * $ man chmod:
  1369. -i Removes the 'inherited' bit from all entries in the named file(s) ACLs.
  1370. *
  1371. * chmod -a "admin allow write" file1 # remove line
  1372. * chmod -a# 1 file1 # remove line at position 1
  1373. *
  1374. * chmod +a nie zmienia modify date: find . -newermt '2013-10-07 ...'
  1375. */
  1376. // find /Library/Server/Web/Data/Sites/Default/PLIKI/PROJEKTY -newermt '2013-10-07 16:20'
  1377. $PROJ_mount_point = FoldersConfig::get('IN7_MK_BAZA_DYSTRYBUCJI_COLUMN', 'mount_point');
  1378. $PISMA_mount_point = FoldersConfig::get('IN7_DZIENNIK_KORESP_COLUMN', 'mount_point');
  1379. $foundProjectIds = array();
  1380. $lastRunDate = self::getLastRunDate();
  1381. exec("cd {$PROJ_mount_point}; find . -newermt '{$lastRunDate}' ", $foundPaths);
  1382. if (!empty($foundPaths)) {
  1383. foreach ($foundPaths as $path) {
  1384. $path = ltrim($path, './');
  1385. $folder = explode('/', $path);
  1386. $folder = reset($folder);
  1387. $projId = explode('.', $folder);
  1388. $projId = reset($projId);
  1389. if (is_numeric($projId)) {
  1390. $foundProjectIds[$projId] = $folder;
  1391. }
  1392. }
  1393. }
  1394. if(V::get('DBG', '', $_GET, 'int') > 1){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">foundPaths (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): '."path: {$PROJ_mount_point}\n";print_r($foundPaths);echo'</pre>';}
  1395. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">foundProjectIds (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): '."path: {$PROJ_mount_point}\n";print_r($foundProjectIds);echo'</pre>';}
  1396. if (!empty($foundProjectIds)) {
  1397. $sql = "select p.`ID`
  1398. , p.`L_APPOITMENT_USER`
  1399. , p.`A_ADM_COMPANY`
  1400. , p.`A_CLASSIFIED`
  1401. , pp.`L_APPOITMENT_USER` as PARENT_L_APPOITMENT_USER
  1402. from IN7_MK_BAZA_DYSTRYBUCJI as p
  1403. left join IN7_MK_BAZA_DYSTRYBUCJI as pp on (pp.ID=p.P_ID)
  1404. where p.`ID` in (" . implode(',', array_keys($foundProjectIds)) . ")
  1405. ";
  1406. $res = $db->query($sql);
  1407. while ($r = $db->fetch($res)) {
  1408. $mainFolder = $foundProjectIds[$r->ID];
  1409. $cmdList = self::fixProject($r, $mainFolder, $PROJ_mount_point);
  1410. if (!empty($cmdList)) {
  1411. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">$cmdList P('.$r->ID.') total('.count($cmdList).') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($cmdList);echo'</pre>';}
  1412. } else {
  1413. if(V::get('DBG', '', $_GET, 'int') > 1){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">$cmdList P('.$r->ID.') total('.count($cmdList).') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($cmdList);echo'</pre>';}
  1414. }
  1415. }
  1416. }
  1417. return array_keys($foundProjectIds);
  1418. }
  1419. public static function fixLastModifiedByDB($fixedProjIds) {// TODO: RMME
  1420. $db = DB::getDB();
  1421. if (!$db) {
  1422. die("DB Error: No DB!");
  1423. }
  1424. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">fixLastModifiedByDB (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r("fixLastModifiedByDB");echo'</pre>';}
  1425. $sqlWhereAdd = '';
  1426. if (!empty($fixedProjIds)) {
  1427. $sqlWhereAdd = " and p.`ID` not in (" . implode(',', $fixedProjIds) . ") ";
  1428. }
  1429. $projectList = array();
  1430. $lastRunDate = self::getLastRunDate();
  1431. $sql = "select p.`ID`
  1432. , p.`L_APPOITMENT_USER`
  1433. , p.`A_ADM_COMPANY`
  1434. , p.`A_CLASSIFIED`
  1435. , pp.`L_APPOITMENT_USER` as PARENT_L_APPOITMENT_USER
  1436. from IN7_MK_BAZA_DYSTRYBUCJI as p
  1437. left join IN7_MK_BAZA_DYSTRYBUCJI as pp on (pp.ID=p.P_ID)
  1438. where
  1439. ( p.`A_RECORD_UPDATE_DATE`>'{$lastRunDate}'
  1440. or p.`A_RECORD_CREATE_DATE`>'{$lastRunDate}'
  1441. )
  1442. {$sqlWhereAdd}
  1443. ";
  1444. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">sql (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($sql);echo'</pre>';}
  1445. $res = $db->query($sql);
  1446. while ($r = $db->fetch($res)) {
  1447. $projectList[$r->ID] = $r;
  1448. }
  1449. if(V::get('DBG', '', $_GET, 'int') > 1){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">projectList (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($projectList);echo'</pre>';}
  1450. }
  1451. public static function fixProjectKoresp($project) {
  1452. $db = DB::getDB();
  1453. if (!$db) {
  1454. die("DB Error: No DB!");
  1455. }
  1456. $PISMA_mount_point = FoldersConfig::get('IN7_DZIENNIK_KORESP_COLUMN', 'mount_point');
  1457. $PISMA_mount_point = rtrim($PISMA_mount_point, '/');
  1458. $pismaList = array();
  1459. // $PISMA_mount_point / {TYP_KORESP} / {ID} . *
  1460. $sql = "select k.`ID`
  1461. , k.`K_TYP_KORESP`
  1462. from `IN7_DZIENNIK_KORESP` as k
  1463. where k.`ID_PROJECT`={$project->ID}
  1464. ";
  1465. $res = $db->query($sql);
  1466. while ($r = $db->fetch($res)) {
  1467. $pismaList[$r->ID] = $r->K_TYP_KORESP;
  1468. }
  1469. if (empty($pismaList)) {
  1470. return false;
  1471. }
  1472. $lsCmd = array();
  1473. foreach ($pismaList as $kID => $vTyp) {
  1474. $lsCmd[] = "{$vTyp}/{$kID}.*";
  1475. }
  1476. if (empty($lsCmd)) {
  1477. return false;
  1478. }
  1479. $lsCmd = 'ls -le ' . implode($lsCmd, ' ');
  1480. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">Koreps lsCmd (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($lsCmd);echo'</pre>';}
  1481. exec("cd {$PISMA_mount_point}; {$lsCmd} ", $filesWithPerms);
  1482. if (!empty($filesWithPerms)) {
  1483. $filesWithPermsTree = array();
  1484. $lastName = '';
  1485. foreach ($filesWithPerms as $line) {
  1486. if (substr($line, 0, 1) == '-') {// file name
  1487. $fileParts = array();
  1488. $filePartsArr = explode(' ', $line);
  1489. foreach ($filePartsArr as $vPart) {
  1490. if (!empty($vPart) || $vPart === '0') {
  1491. $fileParts[] = $vPart;
  1492. }
  1493. }
  1494. while (count($fileParts) > 9) {
  1495. $lastPart = array_pop($fileParts);
  1496. $prevPart = array_pop($fileParts);
  1497. array_push($fileParts, "{$prevPart} {$lastPart}");
  1498. }
  1499. $file = new stdClass();
  1500. if (!isset($fileParts[8])) {
  1501. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">Error parse file name (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r(array('line'=>$line, 'fileParts'=>$fileParts));echo'</pre>';
  1502. //continue;
  1503. }
  1504. $file->name = end($fileParts);
  1505. $file->path = end($fileParts);
  1506. $file->owner = $fileParts[2];
  1507. $file->group = $fileParts[3];
  1508. $file->perms = $fileParts[0];
  1509. $file->isDir = (substr($line, 0, 1) == 'd');
  1510. $file->permsExt = array();
  1511. $filesWithPermsTree[$file->name] = $file;
  1512. $lastName = $file->name;
  1513. }
  1514. else if (substr($line, 0, 1) == ' ') {// extended perm line
  1515. if ($lastName == '..') {
  1516. continue;
  1517. }
  1518. $filesWithPermsTree[$file->name]->permsExt[] = trim($line);
  1519. }
  1520. else {// parse error
  1521. $lastName = '..';
  1522. }
  1523. }
  1524. }
  1525. if(V::get('DBG', '', $_GET, 'int') > 2){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">filesWithPerms (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): '."path: {$PROJ_mount_point}\n";print_r($filesWithPerms);echo'</pre>';}
  1526. if(V::get('DBG', '', $_GET, 'int') > 1){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">filesWithPermsTree (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): '."path: {$PROJ_mount_point}\n";print_r($filesWithPermsTree);echo'</pre>';}
  1527. $cmdList = array();
  1528. $requirePermsExt = self::getRequiredPermsExtByRecord($project);
  1529. foreach ($filesWithPermsTree as $kFileName => $vFile) {
  1530. $cmdFile = self::fixFilePerms($vFile, $requirePermsExt, "{$PISMA_mount_point}", $project);
  1531. if (!empty($cmdFile)) {
  1532. foreach ($cmdFile as $vCmd) {
  1533. $cmdList[] = $vCmd;
  1534. }
  1535. }
  1536. }
  1537. return $cmdList;
  1538. }
  1539. public static function fixProject($r, $mainFolder, $PROJ_mount_point) {
  1540. if ($r->ID == 1695) {// TODO: 8853 pliki w katalog - stary HANDLOWY
  1541. if(V::get('DBG', '', $_GET, 'int') > 0){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">TODO: pomin - za dużo plików ('.$r->ID.'/'.$mainFolder.') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($r);echo'</pre>';}
  1542. return false;
  1543. }
  1544. if(V::get('DBG', '', $_GET, 'int') > 1){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">r('.$r->ID.'/'.$mainFolder.') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($r);echo'</pre>';}
  1545. $requirePermsExt = self::getRequiredPermsExtByRecord($r);
  1546. //make_proj_perm($LINK_PROJ, $PR_GROUP, $PR_CLASS, $PR_L_AP_US, $PR_L_AP_US_MAN, $PR_DESC);
  1547. $filesWithPerms = array();
  1548. exec("cd \"{$PROJ_mount_point}/" . addslashes($mainFolder) . "\"; ls -Rlea . ", $filesWithPerms);
  1549. if(V::get('DBG', '', $_GET, 'int') > 2){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">$filesWithPerms (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($filesWithPerms);echo'</pre>';}
  1550. $filesWithPermsTree = array();
  1551. $lastName = '';
  1552. $folderParent = '';
  1553. foreach ($filesWithPerms as $line) {
  1554. if (substr($line, 0, 1) == '-' || substr($line, 0, 1) == 'd') {// file name
  1555. $fileParts = array();
  1556. $filePartsArr = explode(' ', $line);
  1557. foreach ($filePartsArr as $vPart) {
  1558. if (!empty($vPart) || $vPart === '0') {
  1559. $fileParts[] = $vPart;
  1560. }
  1561. }
  1562. while (count($fileParts) > 9) {
  1563. $lastPart = array_pop($fileParts);
  1564. $prevPart = array_pop($fileParts);
  1565. array_push($fileParts, "{$prevPart} {$lastPart}");
  1566. }
  1567. if (end($fileParts) == '..' || (end($fileParts) == '.' && $folderParent)) {
  1568. $lastName = '..';
  1569. continue;
  1570. }
  1571. $file = new stdClass();
  1572. if (!isset($fileParts[8])) {
  1573. echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">Error parse file name (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r(array('line'=>$line, 'fileParts'=>$fileParts));echo'</pre>';
  1574. //continue;
  1575. }
  1576. $file->name = end($fileParts);
  1577. $file->path = array();
  1578. if ($folderParent) $file->path[] = $folderParent;
  1579. $file->path[] = end($fileParts);
  1580. $file->path = implode('/', $file->path);
  1581. $file->owner = $fileParts[2];
  1582. $file->group = $fileParts[3];
  1583. $file->perms = $fileParts[0];
  1584. $file->isDir = (substr($line, 0, 1) == 'd');
  1585. $file->permsExt = array();
  1586. $filesWithPermsTree[$file->name] = $file;
  1587. $lastName = $file;
  1588. }
  1589. else if (substr($line, 0, 1) == ' ') {// extended perm line
  1590. if ($lastName == '..') {
  1591. continue;
  1592. }
  1593. $filesWithPermsTree[$file->name]->permsExt[] = trim($line);
  1594. }
  1595. else if (substr($line, 0, 2) == './' && substr($line, -1) == ':') {// folder
  1596. $folderParent = substr($line, 2, -1);
  1597. }
  1598. else if (substr($line, 0, 5) == 'total') {
  1599. continue;
  1600. }
  1601. else if (empty($line)) {
  1602. $folderParent = '';
  1603. continue;
  1604. }
  1605. }
  1606. if(V::get('DBG', '', $_GET, 'int') > 1){echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">$filesWithPermsTree (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($filesWithPermsTree);echo'</pre>';}
  1607. // check perms
  1608. /*
  1609. files:
  1610. W read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown
  1611. W read,write,execute,append,readattr,writeattr,readextattr,writeextattr,readsecurity
  1612. R read, execute, readattr, readextattr, readsecurity
  1613. dir:
  1614. W list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit
  1615. W list,add_file,search,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity, file_inherit,directory_inherit
  1616. R list, search, readattr, readextattr, readsecurity, file_inherit,directory_inherit
  1617. */
  1618. $cmdList = array();
  1619. foreach ($filesWithPermsTree as $kFileName => $vFile) {
  1620. $cmdFile = self::fixFilePerms($vFile, $requirePermsExt, "{$PROJ_mount_point}/" . addslashes($mainFolder), $r);
  1621. if (!empty($cmdFile)) {
  1622. foreach ($cmdFile as $vCmd) {
  1623. $cmdList[] = $vCmd;
  1624. }
  1625. }
  1626. }
  1627. return $cmdList;
  1628. }
  1629. public static function fixFilePerms($vFile, $requirePermsExt, $mainPath, $r) {
  1630. $vReqPermsExt = array();
  1631. foreach ($requirePermsExt as $kPermObj => $vPerms) {
  1632. $vReqPermsExt[$kPermObj] = array();
  1633. foreach ($vPerms as $vPerm) {
  1634. if ($vFile->isDir) {
  1635. if ($vPerm == 'read') {
  1636. $vReqPermsExt[$kPermObj]['list'] = 0;
  1637. $vReqPermsExt[$kPermObj]['search'] = 0;
  1638. $vReqPermsExt[$kPermObj]['readattr'] = 0;
  1639. $vReqPermsExt[$kPermObj]['readextattr'] = 0;
  1640. $vReqPermsExt[$kPermObj]['readsecurity'] = 0;
  1641. $vReqPermsExt[$kPermObj]['file_inherit'] = 0;
  1642. $vReqPermsExt[$kPermObj]['directory_inherit'] = 0;
  1643. }
  1644. else if ($vPerm == 'write') {
  1645. $vReqPermsExt[$kPermObj]['add_file'] = 0;
  1646. $vReqPermsExt[$kPermObj]['add_subdirectory'] = 0;
  1647. $vReqPermsExt[$kPermObj]['delete_child'] = 0;
  1648. $vReqPermsExt[$kPermObj]['writeattr'] = 0;
  1649. $vReqPermsExt[$kPermObj]['writeextattr'] = 0;
  1650. $vReqPermsExt[$kPermObj]['writesecurity'] = 0;
  1651. $vReqPermsExt[$kPermObj]['chown'] = 0;
  1652. }
  1653. }
  1654. else {
  1655. if ($vPerm == 'read') {
  1656. $vReqPermsExt[$kPermObj]['read'] = 0;
  1657. $vReqPermsExt[$kPermObj]['execute'] = 0;
  1658. $vReqPermsExt[$kPermObj]['readattr'] = 0;
  1659. $vReqPermsExt[$kPermObj]['readextattr'] = 0;
  1660. $vReqPermsExt[$kPermObj]['readsecurity'] = 0;
  1661. }
  1662. else if ($vPerm == 'write') {
  1663. $vReqPermsExt[$kPermObj]['write'] = 0;
  1664. $vReqPermsExt[$kPermObj]['append'] = 0;
  1665. $vReqPermsExt[$kPermObj]['writeattr'] = 0;
  1666. $vReqPermsExt[$kPermObj]['writeextattr'] = 0;
  1667. $vReqPermsExt[$kPermObj]['writesecurity'] = 0;
  1668. $vReqPermsExt[$kPermObj]['chown'] = 0;
  1669. }
  1670. }
  1671. }
  1672. }
  1673. $permsToRemove = array();
  1674. foreach ($vFile->permsExt as $vPermExtLine) {
  1675. $vPermExtArr = explode(' ', $vPermExtLine);
  1676. $vPermExt = new stdClass();
  1677. $vPermExt->nr = trim($vPermExtArr[0], ' :');
  1678. $vPermExt->permObj = $vPermExtArr[1];
  1679. $vPermExt->perms = '';
  1680. if (count($vPermExtArr) == 4) {
  1681. $vPermExt->perms = explode(',', $vPermExtArr[3]);
  1682. }
  1683. else if (count($vPermExtArr) == 5 && $vPermExtArr[2] == 'inherited') {
  1684. $vPermExt->perms = explode(',', $vPermExtArr[4]);
  1685. }
  1686. else {
  1687. echo "Error: Perm Ext Line format! ({$vPermExtLine})";
  1688. continue;
  1689. }
  1690. $permFound = false;
  1691. foreach ($vReqPermsExt as $kPermObj => $vPerms) {
  1692. if (false !== strpos($vPermExtLine, $kPermObj)) {
  1693. foreach ($vPerms as $kPerm => $vPermChecked) {
  1694. if (in_array($kPerm, $vPermExt->perms)) {
  1695. $vReqPermsExt[$kPermObj][$kPerm] = 1;
  1696. $permFound = true;
  1697. }
  1698. }
  1699. }
  1700. }
  1701. if (!$permFound) {
  1702. $permsToRemove[] = $vPermExt->nr;
  1703. }
  1704. //echo'<pre style="max-height:200px;overflow:auto;border:1px solid red;text-align:left;">$vReqPermsExt('.$vFile->name.') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r($vReqPermsExt);echo'</pre>';
  1705. }
  1706. if (!empty($permsToRemove)) {
  1707. if(V::get('DBG', '', $_GET, 'int') > 1){echo'<pre style="max-height:300px;overflow:auto;border:1px solid red;text-align:left;">TO-rm('.$r->ID.'): $permsToRemove('.$vFile->name.') isDir('.$vFile->isDir.') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r(array('permsToRemove'=>$permsToRemove, 'vFile->permsExt'=>$vFile->permsExt, 'r'=>$r));echo'</pre>';}
  1708. $permsToRemove = array_reverse($permsToRemove);
  1709. foreach ($permsToRemove as $vPermInd) {
  1710. $cmdList []= "chmod -a# {$vPermInd} \"{$mainPath}/{$vFile->path}\" ";
  1711. }
  1712. }
  1713. $permsToAdd = array();
  1714. foreach ($vReqPermsExt as $kPermObj => $vPerms) {
  1715. foreach ($vPerms as $kPerm => $vPermChecked) {
  1716. if (!$vPermChecked) {
  1717. $permsToAdd[$kPermObj][$kPerm] = 1;
  1718. }
  1719. }
  1720. }
  1721. if (!empty($permsToAdd)) {
  1722. if(V::get('DBG', '', $_GET, 'int') > 1){echo'<pre style="max-height:300px;overflow:auto;border:1px solid red;text-align:left;">TO-add('.$r->ID.'): $permsToAdd('.$vFile->name.') isDir('.$vFile->isDir.') (' . __CLASS__ . '::' . __FUNCTION__ . ':' . __LINE__ . '): ';print_r(array('permsToAdd'=>$permsToAdd, 'vFile->permsExt'=>$vFile->permsExt, 'r'=>$r));echo'</pre>';}
  1723. foreach ($permsToAdd as $kPermObj => $vPerms) {
  1724. $cmdList []= "chmod +a \"{$kPermObj} allow " . implode(',', array_keys($vPerms)) . "\" \"{$mainPath}/{$vFile->path}\" ";
  1725. }
  1726. }
  1727. return $cmdList;
  1728. }
  1729. }
  1730. //dodatkowo synchronizacja automatyczna uprawnien
  1731. //SEF('KIKE_MIGRACJA_KIKE_AUTH');
  1732. //if(strstr($_SESSION['SYSTEM_PROFILE_STRING'],'KIKE' )) KIKE_MIGRACJA_KIKE_AUTH($LAST_TIMESTAMP);
  1733. ?>