readme.txt 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446
  1. iTop - version 2.2.0 - 23-September-2015
  2. Readme file
  3. 1. ABOUT THIS RELEASE
  4. 2. INSTALLATION
  5. 2.1. Requirements
  6. 2.2. Install procedure
  7. 2.3. CRON
  8. 2.4. Upgrading from 2.0.x
  9. 2.5. Migration from 1.x versions
  10. 3. FEATURES
  11. 3.1. Changes since 2.1.0
  12. 3.2. Known limitations
  13. 3.3. Known issues
  14. 1. ABOUT THIS RELEASE
  15. ==================
  16. Thank you for downloading the 22nd packaged release of iTop.
  17. This version is a major release, with quite a few bug fixes and significative enhancements.
  18. The documentation about iTop is available as a Wiki: https://wiki.openitop.org/
  19. iTop is released under the AGPL (v3) license. (Check license.txt in this directory).
  20. The source code of iTop can be found on SourceForge: https://sourceforge.net/p/itop/code/
  21. 1.1 What's new?
  22. ---------------------------
  23. This version brings a number of expected enhancements, namely:
  24. - An new engine to compute and display impact analysis (requires Graphviz on the server, but no longer depends on Flash)
  25. - A complete rework of the exports
  26. - A "printer friendly" version of the details of an object
  27. - A few performance optimizations (APC/APCu required on the server to benefit from them)
  28. - Enhancements to customizations that can be performed in XML
  29. - A lock (not enabled by default) to prevent the concurrent modification of the same object by different agents
  30. - The Czech translation of iTop, thanks to Lukáš Dvořák
  31. ... and about 50 bug fixes
  32. 1.2 Should I upgrade to 2.2.0?
  33. --------------------------
  34. This version is a production quality version and, as such, is suitable for running in production.
  35. iTop 2.2.0 is fully backward compatible with iTop 2.1.0. The new version brings quite a number of
  36. bug fixes and enhancements and this is why we encourage you to upgrade your iTop.
  37. Anyhow, prior to making that decision, we encourage you to have a look at the migration notes:
  38. https://wiki.openitop.org/doku.php?id=2_1_0:admin:210_to_220_migration_notes
  39. Warning:
  40. If you upgrade from the 2.2.0-beta, make sure that the value 'query_cache_enabled' is not set to 'false'
  41. in the iTop configuration file. If so, please either change the value to 'true' or remove the line from
  42. the configuration file. Letting the value set to false causes a severe slow down of the application.
  43. 1.3 Special Thanks To:
  44. -----------------
  45. Bruno Bonfils for his guidance about LDAP and authentication.
  46. Randall Badilla Castro and Miguel Turrubiates for the Spanish translation.
  47. Jonathan Lucas, Stephan Rosenke and David Gümbel from ITOMIG GmbH, for the German translation.
  48. Christian Lempereur and Olivier Fouquet for their feedbacks.
  49. Everaldo Coelho and the Oxygen Team for their wonderful icons.
  50. The JQuery team and all the jQuery plugins authors for developing such a powerful library.
  51. Phil Eddies for the numerous feedbacks provided, and the first implementation of CKEdit
  52. Marco Tulio and Bruno Cassaro for the Portuguese (Brazilian) translation
  53. Vladimir Kunin, Vladimir Shilov and Shamil Khamit for the Russian translation
  54. Izzet Sirin for the Turkish translation
  55. Deng Lixin for the Chinese translation
  56. Marialaura Colantoni for the Italian translation
  57. Schlobinux for the fix of the setup temporary file verification.
  58. Gabor Kiss for the Hungarian translation
  59. Tadashi Kaneda, Shoji Seki and Hirofumi Kosaka for the Japanese translation
  60. Antoine Coetsier for the CAS support and tests
  61. Vincenzo Todisco for his contribution to the enhancement of the webservices
  62. Stephan Rickauer, Tobias Glemser and Sabri Saleh for their consulting about iTop security
  63. Claudio Cesar Sanchez Tejeda for his contribution to bug fixes on the export and data synchronization
  64. Bruno Cornec for his support and contribution to the Linux packaging of iTop
  65. Jean-François Bilger for providing a fix for an unsuspected SQL bug
  66. Remie Malik from Linprofs for the Dutch translation
  67. Erik Bøg for the Danish translation
  68. Lukáš Dvořák and Daniel Rokos for the Czech translation
  69. 2. INSTALLATION
  70. ============
  71. 2.1. Requirements
  72. ------------
  73. Server configuration:
  74. iTop is based on the AMP (Apache / MySQL / PHP) platform and requires PHP 5.3 and
  75. MySQL 5. The installation of iTop does not require any command line access to the
  76. server. The only operations required to install iTop are: copying the files to the
  77. server and browsing web pages. iTop can be installed on any web server supporting
  78. PHP 5.3: Apache, IIS, nginx...
  79. End-user configuration:
  80. Although iTop should work with most modern web browsers, the application has been
  81. tested mostly with Firefox 36+, IE9+, Safari 5 and Chrome. iTop was designed for
  82. at least a 1024x768 screen resolution. Flash version 8 or higher is still required
  83. for displaying some charts.
  84. 2.2. Install procedure
  85. -----------------
  86. 1) Make sure that you have a properly configured instance of Apache/PHP/MySQL running
  87. 2) Unpack the files contained in the zipped package, and copy the content of the "web"
  88. directory in a directory served by your web server.
  89. 3) Check the access rights on the files/folders: the setup needs to have write access
  90. either to the directory where iTop is installed or to the following subdirectories
  91. (create them if needed)
  92. - conf
  93. - data
  94. - env-production
  95. - log
  96. 4) Point your web browser to the URL corresponding to the directory where the files
  97. have been unzipped and follow the indications on the screen.
  98. If you wish to re-launch the installation process (for example in order to install
  99. more modules), just make sure that the configuration file (located at <itop>/conf/production/config-itop.php)
  100. is writable by the web server (on Windows: remove the "read-only" flag, on Linux
  101. adjust the rights of the file) and point your browser to <itop>/setup/.
  102. 2.3. cron.php
  103. --------
  104. The following features will require the activation of CRON.PHP:
  105. - asynchronous emails. By default, this option is disabled. To enable it, set 'email_asynchronous' to 1 in the configuration file.
  106. - check ticket SLA. Tickets reaching the limits will be passed into Escalation TTO/TTR states.
  107. More information into the Wiki: https://wiki.openitop.org/doku.php?id=2_0_3:admin:cron
  108. You can get a status of the cron "tasks" with the command:
  109. php cron.php --auth_user=admin_login --auth_pwd=admin_pwd --status_only=1
  110. The output will look as shown below:
  111. +---------------------------+---------+---------------------+---------------------+--------+-----------+
  112. | Task Class | Status | Last Run | Next Run | Nb Run | Avg. Dur. |
  113. +---------------------------+---------+---------------------+---------------------+--------+-----------+
  114. | CheckStopWatchThresholds | active | 2013-03-28 10:32:27 | 2013-03-28 10:32:37 | 51 | 0.317 s |
  115. | EmailBackgroundProcess | active | 2013-03-28 10:32:27 | 2013-03-28 10:32:57 | 12 | 7.089 s |
  116. | ExecAsyncTask | active | 2013-03-28 10:32:27 | 2013-03-28 10:32:29 | 51 | 0.032 s |
  117. +---------------------------+---------+---------------------+---------------------+--------+-----------+
  118. 2.4. Upgrading from 2.x.x
  119. --------------------
  120. The version 2.2.0 if fully compatible with 2.0.0, 2.0.1, 2.0.2, 2.0.3 and 2.1.0. Due to few database changes,
  121. and new modules/files that have to be installed, you must run the setup when upgrading (whatever the original
  122. version).
  123. If the location of mysql binaries is in the "path", the setup proposes to perform a full backup
  124. of iTop (database + configuration file) using mysqldump.
  125. Here is how to upgrade, step by step, a 2.x.x instance of iTop:
  126. 1) Do NOT overwrite the files from the previous version. Expand the content of the "web" directory of
  127. the new package into a new directory on the web server.
  128. 2) Check the access rights on the files/folders: the setup needs to have write access either to the
  129. whole directory where iTop is installed or to the following subdirectories (create them if needed)
  130. - conf
  131. - data
  132. - env-production
  133. - log
  134. 3) Point your web browser to the URL corresponding to the new location. You should see the setup screen.
  135. 4) When prompted (At step 2 of the installation), choose "Upgrade an existing instance"
  136. 5) Either enter the path (on the disk) to the previous instance, or supply the needed credentials.
  137. 6) Run the setup to completion. Once this is done you can connect to your upgraded iTop.
  138. 7) To replace the old instance of iTop with the newly installed one:
  139. Rename the directories to switch the locations
  140. Edit the new configuration file (now located at <itop>/conf/production/config-itop.php) and change the
  141. value of the "application_url" parameter.
  142. 2.5. Migrating from 1.x versions
  143. ---------------------------
  144. The setup is designed to upgrade existing 1.x instances of iTop automatically. In case the instance was
  145. customized (for example by altering its data model), the installation process will detect the modifications
  146. (by scanning the source files and comparing them with the manifest) and will prompt either to keep the
  147. modifications or to discard them.
  148. If the location of mysql binaries is in the "path", the installation proposes to perform a full backup
  149. of iTop (database + configuration file) using mysqldump.
  150. Here is how to upgrade, step by step, a 1.x instance of iTop.
  151. 1) Do NOT overwrite the files from the previous version. Expand the content of the "web" directory of
  152. the new package into a new directory on the web server.
  153. 2) Check the access rights on the files/folders: the setup needs to have write access either to the
  154. directory where iTop is installed or to the following subdirectories (create them if needed)
  155. - conf
  156. - data
  157. - env-production
  158. - log
  159. 3) Point your web browser to the URL corresponding to the new location. You should see the setup screen.
  160. 4) When prompted (At step 2 of the installation), choose "Upgrade an existing instance"
  161. 5) Enter the needed credentials. It is not mandatory to supply the location (on the disk of the server)
  162. where the previous instance was installed but, by doing so, you let the installation find the credentials
  163. (by looking at the previous configuration file) and also perform additional checks, for instance, to
  164. detect any customization that you may have made to iTop.
  165. 6) Run the setup to completion. Once this is done you can connect to your upgraded iTop.
  166. 7) To replace the old instance of iTop with the newly installed one:
  167. Rename the directories to switch the locations
  168. Edit the new configuration file (now located at <itop>/conf/production/config-itop.php) and change the
  169. value of the "application_url" parameter.
  170. That's it.
  171. 3. FEATURES
  172. ========
  173. 3.1. Changes since 2.1.0
  174. -------------------
  175. Modernizations
  176. --------------------
  177. New look: a little bit "flatter" and more modern, but still quite similar to
  178. previous versions of iTop for a smooth migration.
  179. The 'zip' extension is now mandatory to install iTop, since the code relies on
  180. the ZipArchive class for the Excel export and the scheduled backup.
  181. iTop now requires PHP 5.3.0 or higher (instead of PHP 5.2.0).
  182. Impact analysis
  183. -----------------
  184. The computation of the impact takes the redundancy into account (On
  185. "Power Sources" and on "Farms"), which requires also to take into account
  186. the active tickets.
  187. An new "Impact analysis" tab is now available on tickets, to show the exact
  188. impact of a given ticket (can be exported in PDF and attached to the ticket).
  189. The graphical view no longer depends on Flash (browser-side), but now depends
  190. on Graphviz (server-side) which gives a better disposition of the nodes.
  191. The view can be resized and is exportable in PDF.
  192. The display has been improved and better supports high volumes of data by
  193. automatically grouping similar objects.
  194. The impact analysis can now be customized in XML, but remains backwards
  195. compatible with legacy definitions made by the mean of PHP methods.
  196. Exports
  197. -------
  198. The bulk export has been completely redesigned:
  199. - interactive choice of the columns to export (and their order) as well as all the format specific options
  200. - support for high volumes of data for the interactive export
  201. - the same "export engine" is used for interactive or scripted exports
  202. - new PDF format
  203. - a fields specification can now be an extended attribute code (e.g. location_id->org_id->parent_id->code)
  204. - for full backward compatibility the "old" export.php page still exists, the new export is 'export-v2.php"
  205. - bulk export is now only allowed to users having the "bulk read" privilege on the specified class of objects
  206. Since the new export requires the specification of the exact list of fields to be exported, if the attribute 'fields'
  207. is left empty on a Query Phrase Book item, then the iTop user interface proposes the hyperlink to the legacy export and
  208. displays a message explaining the limitations
  209. The following enhancements/bugs were addressed:
  210. #1120 Export V2 not working when using aliases (ex: SELECT Person AS p)
  211. #1071 Bulk Read access rights
  212. #1034 List of fields for Excel export
  213. #772 Some attributes not exportedvia export.php
  214. Printer friendly version of the details
  215. ---------------------------------------
  216. #576 Printable view for object details.
  217. From the detail page of an object, a new action "Printer friendly version" has been
  218. added in the "toolkit" pull-down menu. This action displays in a new page a printer
  219. optimized representation of the details. It is also possible to adjust the output
  220. by interactively hiding/showing certain sections of the page before printing it.
  221. Locking
  222. -------------
  223. Note: The locking mechanism is disabled by default. To enable it, set the configuration
  224. parameter: 'concurrent_lock_enabled' to true in the iTop configuration file.
  225. The new locking mechanism has been introduced to prevent the concurrent interactive
  226. modification of the same object (for example a User Request ticket)by two agents
  227. (or by the same agent in two different tabs of her/his browser). In case of troubles
  228. (e.g. a locked session from an inactive user), an administrator can bypass this lock.
  229. OQL syntax
  230. --------------------
  231. 1) The OQL language now supports UNION statements:
  232. SELECT Server WHERE cpu = '...' UNION SELECT PC
  233. Unions support polymorphism: you can use UNION on as many OQL queries as needed as
  234. long as the selected classes have a common ancestor.
  235. Unions can be used anywhere in the application where an OQL query is expected.
  236. 2) JOIN ... ON objkey = id
  237. Allow JOIN on a objclass/objkey pair of attributes
  238. Enables queries on the synchronized objects (SynchroReplica::dest_id was changed into
  239. an attribute of type AttributeObjectKey), or with change tracking logs.
  240. Scalability / Performance
  241. -------------------------
  242. Optimization: improvement to the OQL cache:
  243. - take benefit of the APC cache (if present)
  244. - memory indexation may have failed in case of long queries (query id based on a md5)
  245. - added a kpi measure on the OQL parsing
  246. Optimization: when displaying an object details, do not check data synchro for each and every attribute (the cache did exist but was inoperant)
  247. Performance optimization: cache the result of the disk scan looking for icons for dashboards (speeds up the welcome page !)
  248. Optimization of DisplayBlock::FromObjectSet, load only the needed column(s)!
  249. Usability enhancements
  250. ----------------------
  251. #714 Localization of the date picker calendar. Get rid of the old jquery.datepicker.js file since iTop now relies on the built-in jQuery UI date picker widget.
  252. #257 Dashlet label hardcoded to "Search for objects of type Server"
  253. #759 Ticket lists in CI: show only active tickets (exclude tickets in states rejected/resolved/closed) and display one list per leaf class so that the status column will be visible. It it not possible anymore to edit the ticket list from the CI.
  254. #788 Whenever a timeout is detected by an ajax request, a popup dialog warns the user to log-in again.
  255. #1092 Caller not preset when creating a ticket from a contact
  256. #1082 Dashlet badge: do not display search results everytime.
  257. #1083 HTML export: show a scroll bar when needed.
  258. Better display of the "Attachments" (addition/removal) in the history, incliding a preview of images.
  259. History display enhancement: whenever a new case log entry is added, display its content in the history.
  260. The display is truncated at a configurable max length. The user can expand/collapse the truncated text, entry per entry.
  261. Usability enhancement: Autocomplete: do NOT clear the typed text when the value does not match one of the possible values,
  262. but clear the actual underlying value so that the input field gets marked as "invalid" if it is mandatory.
  263. More "compact" (but vertically aligned) search forms so that it's easier to find a field and it still works on medium screens.
  264. #1087: the sort order on "group by" dashlets inside a dashboard is now saved as a user preference.
  265. Miscellaneous fixes
  266. -------------------
  267. Log REST/JSON calls (config: 'log_rest_service' => true ; stored as EventRestService)
  268. REST/JSON services. Take the user rights into account. Something was already done for core/create and core/delete, but the symptoms were not clear. The other verbs (update, apply_stimulus, get and get_related) had no protection at all.
  269. #1123/#1133 The optimization on loaded columns in SQL queries was inoperant for some queries, resulting in a stopper issue if such queries were added to a union query (2.2.0 beta)
  270. #1062 bumped the version number of the REST/JSON API to 1.3 to be aligned with the documentation !
  271. #963 For security reasons, "Portal users" are no longer allowed to use the REST/JSON API.
  272. #1078 Properly record the history of LinkedSet(Indirect)
  273. #1079 DBWriteLinks deleting related objects
  274. Bug fix: don't accept attachments (like images) via Chrome's copy/paste since it may duplicate the text content of a normal copy/paste and moreover causes troubles because there is no file name associated with the pasted content.
  275. Small enhancement to the display of the meta model: in the list of transitions, display the code of the event as a tooltip.
  276. JSON/REST: When specifying a case log entry (or the whole), it was not possible to set the user name without knowing a valid user id
  277. Bug fix: prevent a crash of the web services when trying to log a non scalar paramater value...
  278. #1088 Support of HTMLEditor in the PortalWebPage, for example if the description of a ticket is in HTML.
  279. Bug fix: properly compute the URLs/URIs for the soap server (and its extensions)
  280. #1059 fix for the Spanish localization first_name and last_name were swaped.
  281. #1054 increase max_execution_time during the setup.
  282. #1052 Fix for the German localization.
  283. #1050 Properly support the 'list' display style for external keys - as stated in the documentation!
  284. #1047 Fix for the FindTab method.
  285. #1045 Fix in the German localization.
  286. #594 Properly display attachments inside "properties" by closing the span and the fieldset in non-edit mode.
  287. #384: Triggers should not be in the "bizmodel" category. User rights do not apply to such objects...
  288. #1106, #1122: Added a new option 'start_tls' (false by default) and improved debugging capabilities for troubleshooting when something goes wrong with LDAP. Thanks to Karl (karkoff1212) for the hint.
  289. #1148: Fixed dashboards upload: use the more modern fileupload component, since we now hook the ajax call in iTopWebPage and removed references to the old component ajax.fileupload from (almost) everywhere...
  290. #1049: CSV import (and edition) of n:n links. The Differences() function is NOT commutative: the original value (i.e. the one from the database) must the the first argument.
  291. #1144 Audit category having no rule -> PHP notices when showing the report + improved the behavior when the OQL of a rule is wrong.
  292. #1143 Records any change (add/remove/modify) for link sets that can be considered as one of the characteristics of a class (currently those having edit mode = in place)
  293. #1142 Dashboard editor: protects from unwanted "exit" without saving the modifications:
  294. - mark the dashboard as modified when a dashlet was added / moved / deleted
  295. - prevent clicking on the hyperlinks inside the preview of the dashboard
  296. #1091 CAS memberships broken (parameter "cas_memberof" NOT given as a regular expression, bugged since iTop 2.0 or earlier)
  297. #1134 Query returning a "null row": just make sure that the row gets displayed (still surprising... see ticket #1138 to follow up on the suppression of those ghost rows)
  298. #1140 UNION queries not working -in fact, loss of the optimization on column load when filtering on org hierarchies (retrofit possible but the fix will be located in MetaModel)
  299. #564 Prompt for an update in a case log on a lifecycle transition.
  300. #1111 Could not attach a UserRequest to a Problem (1-N links). Could not detach either! This fix requires attention: it is assumed that an item of a link set, if it is "modified" then its key to the current object has already been set.
  301. #1074 Portal: errors when selecting Impact/Urgency, and if the user has access to his organization only.
  302. #1130 CAS authentication security leak when cas_memberof is left empty (already committed into branch 2.1.0)
  303. Secure the server: prevent the users from browsing/getting files from the data and log directories. With Apache, it is still a must to enable htaccess with the spec "AllowOverride All". The index.php files are here to prevent from browsing whatever the HTTP server config.
  304. #1095 Object creation form and bulk modify (final step) not working when using apache-proxy
  305. #1118: fixed strange display of synchro data sources status.
  306. #1121: Regression: "filters" on Triggers had no effect. The regression was caused by the new way of computing placeholders "on the fly" (#803).
  307. #1116 (and #1117): default values for ENUMs must always be expressed as strings.
  308. Fixed a potential XSS vulnerability.
  309. Bug fix: typo causing the generation of invalid SQL queries (in some rare cases).
  310. #1099 and #1014: integration of some German translations.
  311. Extending the data model
  312. ------------------------
  313. #1081 Customizations: adjust the dimensions of the HTML Editor (CKEditor). Also fixed an issue when specifying width/height with unit (e.g. "30em") for AttributeText/AttributeLongText
  314. Customizations/XML: clearer error reporting when encountering a duplicate value for an AttributeEnum
  315. #1137: the new XML configuration for the "portal as an extension" was too limited. Now one "allow" profile is enough to allow access to a given portal.
  316. New lifecycle action SetCurrentPerson. Also improved the existing lifecycle action SetCurrentUser to prevent from calling it on an external key that is not pointing to users (!= contact), and if the target attribute is a string, then store the friendlyname there.
  317. #1069 Fix to add a new hierarchical key when there are already some records in the DB
  318. Modules implementing a lifecycle written in PHP (and having actions executed on transitions) do not work until 2.1.0. The compatibility patch had been implemented but it was not working.
  319. XML Enhancement: support injection of new modules treated as data.
  320. XML 1.2: handle the XML transformation. Added APIs to report the functionality loss when downgrading (snippets, portal, module parameters, relations and object key)
  321. XML Enhancement: PHP snippets inside the XML.
  322. XML Enhancement: the default value for a module's parameter can now be specified (and altered) via the XML and will no longer reside in the configuration file.
  323. API Enhancement: allow the API to create Case Log entries with a specified user_login.
  324. Modularization of the portal. The entry points for portals is now defined in XML, and thus can be altered by an extension.
  325. #1053 XML comments breaking the setup with message "Notice: Undefined property: DOMComment::$wholeText in ...modelfactory.class.inc.php on line 1280". Now, the XML comments are allowed.
  326. Internals
  327. ----------------------
  328. Make the 'curl' options overridable when calling utils::DoPostRequest()
  329. Allow to stop a stop watch at a specified time (case exchange)
  330. Code cleanup: deprecated the unused (and empty) class CMDBSearchFilter, replaced by DBSearch or DBObjectSearch depending on the usage.
  331. Added an alternate implementation for storing "transaction" identifiers on disk instead of inside the $_SESSION variable.
  332. Mutex instrumentation for troubleshooting...
  333. Make sure that the SQL mutexes are specific to the current iTop instance, but still preserving the capability for the setup to detect an already running cron job with or without a valid config file.
  334. Integrated the lexer/parser build tools (Lexer=0.4.0, Parser=0.1.7)
  335. Implemented GetForJSON and FromJSONToValue for AttributeLinkedSet (though this is not used for the Rest/JSON services which are doing much more) -retrofit from branch 2.1.0
  336. Make it possible to overload RestUtils (static methods called with static:: instead of self::) - iTop NOW REQUIRES PHP 5.3: we have verified, there are very installations of iTop made on PHP 5.2. It is worth to note that PHP 5.3 is already end of life (5.4 will become end of life in 8 months)
  337. Improved the symptom when an error occurs in the "apply stimulus form". The symptom used to be: Object could not be written; unknown error. Now it will give the error message (e.g. Missing query arguments) so as to help in determining what's going on.
  338. ormStopWatch::GetElapsedTime not working in case of queries containing :this-> parameters (the prototype of GetElapsedTime has changed and is NOT compatible with the previous one)
  339. Fixed a typo on the default document mimetype: application/x-octet-stream
  340. Meta information on lifecycle actions arguments: added type restrictions, and added the method ResetStopWatch
  341. Additional markup for JQuery scripts...
  342. Forms Enhancement: do not retrieve disabled fields.
  343. Forms : Support several sets of forbidden values (with a specific "reason" message) per field.
  344. - Read-only "long text" fields no longer appear as editable
  345. - Combo and FormSelector fields are now sorted by default (but sorting can be disabled if needed)
  346. Protect against JS errors when the form is in read-only mode.
  347. Properly handle property_sheets with nested selector fields...
  348. #803 template placeholders are now built on demand.
  349. #1060 Internal: improved the symptoms when calling MetaModel::GetAttributeDef with an invalid attribute code (feedback on the class name and no more FATAL errors)
  350. Internal: fixed the caching of DBObject::ToArgs()
  351. 1) Wasn't reset when the object was written the DB (thus having its ID set)
  352. 2) Wasn't taking the argument name into account (the list of placeholders was defined by the first caller)
  353. Change of the QueryReflection API to support DesignTime.
  354. ModelFactory: Re-creating a class into another location in the class hierarchy it equivalent to moving that class => the delta must be a "redefine" for the class (improved the comment from the previous commit)
  355. ModelFactory: Re-creating a class into another location in the class hierarchy it equivalent to moving that class => the delta must be a "redefine" for the class
  356. Protects the setup against renaming of non-existing classes. Useful for heavily customized models where some very basic classes have been deleted.
  357. 3.2. Known limitations (https://sourceforge.net/apps/trac/itop/report/3)
  358. -----------------
  359. #71 The same MySQL credentials are used during the setup and for running the application.
  360. Suhosin can interfere with iTop. More information can be found here: http://www.combodo.com/wiki/doku.php?id=admin:suhosin
  361. Internet Explorer 6 is not supported (neither IE7 nor IE8 in compatibility mode)
  362. Tested with IE8 and IE9, Firefox 3.6 up to Firefox 24 and Chrome. Be aware that there are certain limitations when using IE8 in "security mode" (when running IE on a Windows 2008 Server for example)
  363. 3.3. Known issues (https://sourceforge.net/apps/trac/itop/report/3)
  364. ------------
  365. #259 Not instantaneously logged off when the administrator deletes a user account
  366. #273 The administrator can delete his/her own user account
  367. #372 APC Cache not efficient (multi org usage, global search)
  368. #382 Search form / base class lost after a search
  369. #377 Case log: exclude the index from the views
  370. #388 IE9: edition fields not resizable
  371. #443 Objects remain in the database after de-installing some modules
  372. #442 Useless profiles installed (1.x legacy data model only)
  373. #438 The selection of Organizations using the hierarchy does not work on IE8 in security mode
  374. #436 Cannot type "All Organizations"
  375. #381 Deletion of dependencies could fail in a multi-org environment
  376. #241 "status" is a free-text field when configuring a Trigger
  377. #358 Multi-column queries sometimes returning an empty set
  378. #399 Copy/paste from iTop's CaseLog looses tabs
  379. #343 CKEditor (HTML Editor) not compatible with direct object creation on ExtKeys
  380. #350 Object edition form: validation does not tell which field has a problem
  381. #730 Leaving temporary files when performing a backup of the data during installation
  382. #1145 Two connections between a connectable CI and a network device must have different ports
  383. #1146 History not reflecting a modification of the connection between a connectable CI and a network device
  384. #1147 Identical links not always modified as expected