<div dir="ltr"><div dir="ltr"><a class="gmail_plusreply" id="plusReplyChip-0" href="mailto:prasad@vtiger.com" tabindex="-1">@Prasad</a> do we have any plans for these security concerns?<br></div><div dir="ltr"><br></div><div>It would be helpful for the community to know if any actions have been planned by Vtiger team for mentioned security issues.</div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Mon, Jul 1, 2019 at 9:47 PM nilay khatri <<a href="mailto:nilay.spartan@gmail.com">nilay.spartan@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr">Thanks, Blazej!<div><br></div><div>I hope the community developers like us would contribute to the Open Source to make it more secure.</div><div><br></div><div><div><br></div></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Mon, Jul 1, 2019 at 7:55 PM Tony Sandman <<a href="mailto:tonysandman999@gmail.com" target="_blank">tonysandman999@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div>Gonna read tomorrow. Cannot wait! hehe</div><div><br></div><div>T<br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Mon, Jul 1, 2019 at 8:57 PM Błażej Pabiszczak <<a href="mailto:b.pabiszczak@yetiforce.com" target="_blank">b.pabiszczak@yetiforce.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div style="font-size:10pt;font-family:Verdana,Geneva,sans-serif">
<p><span>@socialboostdk</span></p>
<p><span>Together with Partner we worked on the deployment of YetiForce for PZU (the biggest insurance company in Poland) for more than 12.000 users. Before the product was selected it had to undergo security audits performed by Partner</span><span> and PZU (</span><a href="https://www.pzu.pl/" rel="noopener noreferrer" target="_blank"><span>https://www.pzu.pl/</span></a><span>). Only after these audits were completed we understood what the expectations of large companies towards software were. Since then we’ve been undergoing monthly security audits performed by one of the best security companies in Poland. </span><span><br></span></p>
<p><span>Security is a process but the product needs to be changed every day so that it complies with the highest standards. If your company doesn’t improve the security every day, it won’t manage to deliver a secure product (no matter what product you implement). Each line of code requires security analysis, it can’t be done without internal and external training as well as striving for perfection. The fact that you will implement a few guidelines from @nilaykhatri won’t cause the problem to disappear. It will not disappear unless you understand what the security problem in Vtiger is.</span></p>
<p><span>Only the system producer has a real impact on security and no matter how hard you try, you won’t significantly affect the security of Vtiger because security begins with the system’s architecture. If you want to learn more about security, I recommend reading the documentation </span><a href="https://www.owasp.org/images/d/d4/OWASP_Application_Security_Verification_Standard_4.0-en.pdf" rel="noopener noreferrer" target="_blank"><span>https://www.owasp.org/images/d/d4/OWASP_Application_Security_Verification_Standard_4.0-en.pdf</span></a><span>. This document is the standard for architecture that Vtiger should strive for. </span></p>
<p><span>@nilaykhatri</span></p>
<p><span>What you wrote is 1% of what you need to do (however, I do have some comments to make). For example:</span></p>
<ul>
<li><span>".htaccess" is wrong and shouldn’t be used, unless you have no choice. In addition to the fact it slows down the server, developers constantly forget about it or overwrite it what causes many security problems.</span></li>
<li><span>The administrator doesn’t know which files should be accessed externally and which shouldn’t, the application should take care of it! For example, in our application there is a "public_html" folder (</span><a href="https://github.com/YetiForceCompany/YetiForceCRM/tree/developer/public_html" rel="noopener noreferrer" target="_blank"><span>https://github.com/YetiForceCompany/YetiForceCRM/tree/developer/public_html</span></a><span>) and it’s the only one that should be public, otherwise, the system will generate security message informing about wrong configuration. In Vtiger, all files are always accessible externally, which is a huge threat. </span></li>
<li><span>The system does not have any protection against brute force, there are no mechanisms responsible for secure passwords, it does not enforce changing the password when the password was generated by the administrator, there is no built-in 2FA or no integration with Yubikey....</span></li>
</ul>
<p><span>I won’t go into much more detail because I don’t have time for this, but take a look at what the security verification is like in our system during installation or when it’s already installed. The whole panel can be found here: </span><a href="https://gitdeveloper.yetiforce.com/index.php?parent=Settings&module=ConfReport&view=Index&block=14&fieldid=65" rel="noopener noreferrer" target="_blank"><span>https://gitdeveloper.yetiforce.com/index.php?parent=Settings&module=ConfReport&view=Index&block=14&fieldid=65</span></a><span> </span></p>
<p><span>@Prasad </span><span><br></span><span>When I look at your answers I’m not sure if you’re a programmer or just a PR person. Maybe ask a programmer for help?</span></p>
<p><span>I’m telling you that you have 50 outdated libraries in the system and the majority of them have critical security errors, and you answer that jQuery is a user side library instead of figuring out how to solve this issue and how to update the libraries in the new version… What a lack of competence… Maybe you’ll only understand the problem if I launch a DoS attack that exists in jQuery against a couple hundreds of your clients in the On-Demand version?</span></p>
<p><span>I don’t know if you ignore the security problem because you don’t have the knowledge to understand it, or that’s your company’s strategy - and I’m not sure which one is worse… A year ago we tested VTiger 7.1 with the library list (unfortunately not all of them are there) to see how huge the library problem is in VTiger. I used <a href="http://snyk.io" target="_blank">snyk.io</a> to present the problem for a few libraries</span><span><br></span><span> </span></p>
<ol>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › cakephp/cakephp@3.0.1 [Affected versions of cakephp/cakephp are vulnerable to Arbitrary File Inclusion through View template name manipulation.] </span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › cakephp/cakephp@3.0.1 [Affected versions of cakephp/cakephp are vulnerable to Denial of Service (DoS) attacks.]</span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › codeigniter/framework@3.0.1 [Affected versions of codeigniter/framework are vulnerable to HTTP Header Injection via the set_status_header() common function.]</span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › codeigniter/framework@3.0.1 [Affected versions of codeigniter/framework are vulnerable to SQL Injection in the ODBC driver.]</span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › codeigniter/framework@3.0.1 [Affected versions of this package are vulnerable to Session Fixation because session.use_strict_mode in the Session Library was mishandled.]</span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › phpmailer/phpmailer@5.2.6 [Affected versions of phpmailer/phpmailer are vulnerable to Arbitrary Code Execution.]</span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › phpmailer/phpmailer@5.2.6 [Affected versions of this package are vulnerable to Object Injection attack.]</span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › phpmailer/phpmailer@5.2.6 [Affected versions of phpmailer/phpmailer are vulnerable to Arbitrary Code Execution.</span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › adodb/adodb-php@5.20.9 [Affected versions of this package are vulnerable to SQL injection. The SelectLimit function has a potential SQL exploit through the use of the nrows and offset parameters which are not forced to integers.]</span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › cakephp/cakephp@3.0.1 [Affected versions of cakephp/cakephp are vulnerable to Cross-site Request Forgery (CSRF). The CsrfComponent fails to invalidate requests that are missing both the CSRF token, and the CSRF post data.]</span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › cakephp/cakephp@3.0.1 [Affected versions of this package are vulnerable to Deserialization of Untrusted Data. The SmtpTransport class has the potential to deserialize untrusted user input provided as part of an SMTP connection. An attacker could leverage this vulnerability to call arbitrary class methods within the application.]</span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › codeigniter/framework@3.0.1 [Affected versions of codeigniter/framework are vulnerable to Cross-site Scripting (XSS) attack.]</span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › pear/pear@1.10.4 › pear/archive_tar@1.4.3 [Affected versions of this package are vulnerable to Remote Code Execution (RCE)]</span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › phpmailer/phpmailer@5.2.6 [Affected versions of phpmailer/phpmailer are vulnerable to Multiple CRLF injection vulnerabilities.]</span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › phpmailer/phpmailer@5.2.6 [Affected versions of phpmailer/phpmailer are vulnerable to Cross-site Scripting (XSS).]</span></li>
<li><span>Vtiger_Libraries_Vulnerabilities@0.0.0 › phpmailer/phpmailer@5.2.6 [An issue was discovered in PHPMailer before 5.2.22. PHPMailer's msgHTML method applies transformations to an HTML document to make it usable as an email message body. One of the transformations is to convert relative image URLs into attachments using a script-provided base directory. If no base directory is provided, it resolves to /, meaning that relative image URLs get treated as absolute local file paths and added as attachments. To form a remote vulnerability, the msgHTML method must be called, passed an unfiltered, user-supplied HTML document, and must not set a base directory.]</span></li>
</ol>
<p><span>This is only the beginning of the problems resulting from outdated libraries in VTiger, I assume there’s much more than that… unfortunately the problem is that VTiger doesn’t use anything to centralize libraries, eg. composer, yarn, package so nobody really knows how serious this issue is. Apart from the easy to find problems like the ones I mentioned above, there are many errors in the code directly. For example:  </span></p>
<ol>
<li><span>Loading various things from the Vtiger server to the login page is a critical security error. If someone is in an untrusted LAN, anything can be injected, including JavaScript files that will capture logins and passwords on the fly. Will taking over the Vtiger server cause the attacker to have control over ALL Vtiger systems?!</span></li>
<li><span>Attachments to e-mails are saved in a publicly accessible folder (what’s the point? Since you don’t have any tools to monitor unauthorized attempts to access this folder, the administrator will never detect the problem).</span></li>
<li><span>After connecting to your store, you disable the verification of the certificate. </span></li>
<li><span>If you have export permissions in any module, you can export all users to CSV as a regular user. </span></li>
<li><span>isPermited (main function for permissions verification) provides access to the tool (e.g. export) if this action isn’t available in the profile.</span></li>
<li><span>You can change user’s data even without GUI, e.g. you can change the username or role. All you have to do is to modify the request. </span></li>
<li><span>You can create users with the same parameters as yours (with no admin permissions). </span></li>
<li><span>You can read all fields from a record (if you have access to record but some fields are disabled for a user, the system blocks them only on the GUI level so you can access all record info by modifying a request)</span></li>
<li><span>SQL Injection in all modules on the admin side. </span></li>
<li><span>You can display all records in any module and any related module (this is a serious issue and exists in hundreds of places, it results from the fact that the system doesn’t verify actual permissions in a number of places). Example: index.php?module=Contacts&relatedModule=ModComments&view=Detail&record=17&mode=showRelatedList&relationId=165&tab_label=ModComments&app=MARKETING  (you have to match the parameters/actions depending on the version)</span></li>
<li><span>Access any record: index.php?module=Accounts&view=MergeRecord&records=9 (problem results from the fact that many functions, eg. MergeRecord don’t have a permission layer and display anything you want)</span></li>
<li><span>Access any record, comment, history index.php?module=Contacts&view=ListViewQuickPreview&record=8</span></li>
<li><span>Incorrect validation of permissions</span>
<ul>
<li><span>modules\Vtiger\actions\DeleteImage.php (you can delete any document regardless of your permissions because Vtiger, for the purpose of security,  checks a parameter that doesn’t exist)</span><span>.</span></li>
<li><span>modules\Vtiger\actions\ExportData.php (here the problem is that Vtiger checks permissions to a different module than the one you’re exporting)</span></li>
<li><span>modules\Vtiger\actions\MassSave.php (permissions to edit field are not verified so you can edit any field even if you don’t have permissions to save) </span></li>
<li><span>modules\Vtiger\actions\RelatedRecordsAjax.php (no verification of permissions to calculate the number of related records, it allows you to check if a record exists and how many related records there are) </span></li>
<li><span>modules\Vtiger\actions\RelationAjax.php - no verification of permissions to all actions which allows you to add relations between records, remove relations, check the number of related records, get the label of any record</span></li>
<li><span>modules\Vtiger\actions\SaveStar.php - </span><span>No verification of permissions to mark records</span></li>
<li><span>modules\Vtiger\actions\TagCloud.php - </span><span>No verification of permissions to use tags, it is possible to add tags to any record, download all tags and delete tags</span></li>
<li><span>modules\Vtiger\views\EmailsRelatedModulePopup.php - </span><span>No verification of permissions to the Users module, it is possible to display all users.</span><span><br></span><span>index.php?module=Users&view=EmailsRelatedModulePopup&name=CalendarActivities&type=all</span></li>
<li><span>modules\Vtiger\views\ExportExtensionLog.php - </span><span>No verification of permissions to download logs from WSAPP</span></li>
<li><span>modules\Vtiger\views\ExtensionViews.php - </span><span>No verification of permissions to download logs from WSAPP</span></li>
</ul>
</li>
<li><span>No permissions when displaying widget content - all data from each widget can be displayed, e.g. it is possible to display all calendar events to which you don’t have permissions index.php?module=Home&view=ShowWidget&name=CalendarActivities&type=all </span></li>
<li><span>Possibility to execute any file: permissions to the Home and Users modules aren’t verified (?!?) and in the Home module there is include 'modules/' . $_REQUEST['module'] . '/' . $_REQUEST['file'] . '.php' so everything from the address can be executed, e.g.</span><span><br></span><span>URL:</span><span><br></span><a href="http://test/coreBOS/7.0/index.php?action=HomeAjax&module=Home&file=../VtigerBackup/VtigerBackupRequest" rel="noopener noreferrer" target="_blank"><span>http://test/coreBOS/7.0/index.php?action=HomeAjax&module=Home&file=../VtigerBackup/VtigerBackupRequest</span><span><br></span></a><span>Triggers the file from VtigerBackup module:</span><span><br></span><span>modules/Home/../VtigerBackup/VtigerBackupRequest.php </span></li>
<li><span>Examples of SQL Injection:</span>
<ol>
<li><span>modules\Campaigns\models\Relation.php updateStatus</span></li>
<li><span>modules\Settings\Leads\models\Mapping.php save()</span></li>
<li><span>modules\Settings\Picklist\models\Module.php updateSequence()</span></li>
<li><span>modules\Vtiger\models\Block.php updateSequenceNumber()</span></li>
<li><span>modules\Vtiger\models\Relation.php updateRelationSequenceAndPresence</span></li>
</ol>
</li>
<li><span>DoS: try to trigger modules/Mobile/api.test.php a few times and the server will crash</span></li>
</ol>
<p><span>We know more than 100 errors like those above (I could write a book about them). Unfortunately, other errors require something more than simply changing parameters, e.g. in order to display logins of all CRM users, it is necessary to write a script and trigger it as a non-logged user and after a few minutes we have all users in the CRM without the need to log into it. </span></p>
<p><span>This is just the tip of the iceberg, there are hundreds of XSS/SQLInjection errors in the system and in order to fix them you have to centralize the validation mechanisms first of all (right now it’s a mess); without first fixing the entire mechanism there is no point in patching individual reported errors (you fix it in one place, but it still exists in 20 other places). </span></p>
<div>--<br>
<div class="gmail-m_501290242819567724gmail-m_-2433775992201494779gmail-m_6543678087254838116pre gmail-m_501290242819567724gmail-m_-2433775992201494779gmail-m_6543678087254838116global">
<div style="padding:0px 5px">
<div style="font-family:Tahoma,Geneva,sans-serif;font-size:12.5px;color:rgb(1,55,77);font-weight:200">Z poważaniem / Kind regards</div>
<div style="padding-top:7px;font-family:Tahoma,Geneva,sans-serif;font-size:21.67px;color:rgb(1,55,77);font-weight:bold">Błażej Pabiszczak</div>
<div style="padding-top:4px;font-family:Tahoma,Geneva,sans-serif;font-size:14.17px;color:rgb(147,207,216);font-weight:bold">CEO & Co-Founder at YetiForce</div>
<div style="padding-top:8px;font-family:Tahoma,Geneva,sans-serif;font-size:10px;color:rgb(1,55,77);font-weight:400"><span style="margin-right:6px"><a style="color:rgb(1,55,77);text-decoration:none">+48 884 999 123</a></span> | <span style="margin-left:6px"> <a style="color:rgb(1,55,77);text-decoration:none">b.pabiszczak@yetiforce.com</a></span></div>
<div style="padding-top:6px;padding-bottom:11px"><a style="font-family:Tahoma,Geneva,sans-serif;font-size:10px;color:rgb(1,55,77);font-weight:bold;text-decoration:none">www.yetiforce.com</a></div>
<div style="width:70px;height:4px;background:none 0% 0% repeat scroll rgb(235,235,235)"> </div>
</div>
</div>
</div>
<p>W dniu 2019-06-28 13:22, socialboostdk napisał(a):</p>
<blockquote type="cite" style="padding:0px 0.4em;border-left:2px solid rgb(16,16,255);margin:0px">
<div dir="ltr">Hi Nilay,<br>
<div><br>Thank you very much for this excellent list! </div>
<div> </div>
<div>Should we (the open source community) try to collect a master-list to maintain somewhere, so we have a ready list of tasks for security improvements + "best practices" within security checks?</div>
<div> </div>
<div>:)</div>
<div><br>Cheers!</div>
</div>
<br>
<div class="gmail_quote">
<div class="gmail_attr" dir="ltr">On Fri, 28 Jun 2019 at 13:05, nilay khatri <<a href="mailto:nilay.spartan@gmail.com" target="_blank">nilay.spartan@gmail.com</a>> wrote:</div>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<div dir="ltr">Hi Chris,
<div> </div>
<div>no it is not secure enough if you use it as it is.</div>
<div> </div>
<div>As I had sent an email warning everyone about hacks going on related to <a href="http://vtigersupport.com" rel="noopener noreferrer" target="_blank">vtigersupport.com</a> here are few things:</div>
<div> </div>
<div>1. if you are using SMS integration, which I guess would be the case for the insurance industry, the passwords are stored in plain text. We need to have a salt-based encryption</div>
<div> </div>
<div>2. Database credentials are stored in plain text, so if the file system is compromised the attacker would gain access to the database as well easily. Use some encryption system to encrypt the whole config file or store the database credentials in a separate file outside the document root and include that file in config.inc.php</div>
<div> </div>
<div>3. Make sure you apply the change to normalize the web service error for invalud username or password</div>
<div> </div>
<div>4. Disable import from zip files if not required</div>
<div> </div>
<div>5. Define the .htaccess rules properly such that it allows access to only the files which should have direct access such as index.php, capture.php, .png jpeg etc. files in storage, etc.. Everything rest should be forbidden</div>
<div> </div>
<div>6. There is no rule to set a secure password, even if you tel the users to always use a secure password, you can not be sure that users will do that. Quite possible the can set a password just 1 character long :)</div>
<div> </div>
<div>7. Review the custom extension thoroughly, such as VGS Document Manager(it is all good unless you set the file permissions properly)</div>
<div> </div>
<div>8. Make sure no 2 CRM systems on the same server have same application key. This normally happens if you use a Dump of already installed CRM to setup a new CRM</div>
<div> </div>
<div> </div>
<div>These are a must "security checks" you should consider.</div>
<div> </div>
<div>To make it more secure you can consider few more things:</div>
<div> </div>
<div>1. Keep the CRM behind Cloudflare. There are some issues which occur if you use Cloudflare, such captcha validation while sending an Email.</div>
<div> </div>
<div>2. Have 2FA, we are working on this and will soon have an Open Source patch for this</div>
<div> </div>
<div>Hope this helps.</div>
<div> </div>
<div>I guess Blazej will have more comments :)</div>
<div>.</div>
<div> </div>
<div> </div>
<div> </div>
<div> </div>
<div> </div>
<div> </div>
<div> </div>
</div>
<br>
<div class="gmail_quote">
<div class="gmail_attr" dir="ltr">On Fri, Jun 28, 2019 at 1:22 PM socialboostdk <<a href="mailto:socialboostdk@gmail.com" target="_blank">socialboostdk@gmail.com</a>> wrote:</div>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<div dir="ltr">Hi there,<br>
<div> </div>
<div>I have a client who needs very high security (think "insurance" category). They're asking if Vtiger 7 open source can actually be made secure enough? Ie. assuming we apply all patches, collect all known bugs/holes etc., and try to fix those.</div>
<div> </div>
<div>I would like to give them a honest answer.</div>
<div> </div>
<div>What do you think?</div>
<div> </div>
<div>Thanks,<br>Chris</div>
</div>
_______________________________________________<br> <a href="http://www.vtiger.com/" rel="noopener noreferrer" target="_blank">http://www.vtiger.com/</a></blockquote>
</div>
_______________________________________________<br> <a href="http://www.vtiger.com/" rel="noopener noreferrer" target="_blank">http://www.vtiger.com/</a></blockquote>
</div>
<br>
<div class="gmail-m_501290242819567724gmail-m_-2433775992201494779gmail-m_6543678087254838116pre" style="margin:0px;padding:0px;font-family:monospace">_______________________________________________<br> <a href="http://www.vtiger.com/" rel="noopener noreferrer" target="_blank">http://www.vtiger.com/</a></div>
</blockquote>
</div>
_______________________________________________<br>
<a href="http://www.vtiger.com/" rel="noreferrer" target="_blank">http://www.vtiger.com/</a></blockquote></div>
_______________________________________________<br>
<a href="http://www.vtiger.com/" rel="noreferrer" target="_blank">http://www.vtiger.com/</a></blockquote></div>
</blockquote></div></div>