Continued:
authorRoland Häder <roland@mxchange.org>
Fri, 17 Feb 2023 03:40:27 +0000 (04:40 +0100)
committerRoland Häder <roland@mxchange.org>
Fri, 17 Feb 2023 03:40:27 +0000 (04:40 +0100)
- scrypt (PECL) has only documentation files here
- removed akismet (see "All Your Data Belongs To Akismet")

docs/scrypt/CREDITS [new file with mode: 0644]
docs/scrypt/LICENSE [new file with mode: 0644]
docs/scrypt/README.md [new file with mode: 0644]
framework/main/third_party/akismet/akismet.class.php [deleted file]
framework/main/third_party/scrypt/CREDITS [deleted file]
framework/main/third_party/scrypt/LICENSE [deleted file]
framework/main/third_party/scrypt/README.md [deleted file]

diff --git a/docs/scrypt/CREDITS b/docs/scrypt/CREDITS
new file mode 100644 (file)
index 0000000..79c72e5
--- /dev/null
@@ -0,0 +1,2 @@
+scrypt
+Dominic Black
\ No newline at end of file
diff --git a/docs/scrypt/LICENSE b/docs/scrypt/LICENSE
new file mode 100644 (file)
index 0000000..381d3af
--- /dev/null
@@ -0,0 +1,15 @@
+Original Scrypt Implementation;
+  Copyright (c) 2009 Colin Percival
+
+PHP Module;
+  Copyright (c) 2012, Dominic Black
+
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
+
+1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
+
+2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff --git a/docs/scrypt/README.md b/docs/scrypt/README.md
new file mode 100644 (file)
index 0000000..fef282b
--- /dev/null
@@ -0,0 +1,90 @@
+PHP scrypt module
+=================
+
+[![Build Status](https://travis-ci.org/DomBlack/php-scrypt.svg?branch=master)](https://travis-ci.org/DomBlack/php-scrypt)
+
+This is a PHP library providing a wrapper to [Colin Percival's scrypt implementation](http://www.tarsnap.com/scrypt.html). Scrypt is a key derivation function designed to be far more secure against hardware brute-force attacks than alternative functions such as PBKDF2 or bcrypt.
+
+Details of the scrypt key derivation function are given in a paper by Colin Percival, Stronger Key Derivation via Sequential Memory-Hard Functions: [PDF](http://www.tarsnap.com/scrypt/scrypt-slides.pdf).
+
+An example class using this module can be found in; scrypt.php
+
+Join in!
+--------
+
+We are happy to receive bug reports, fixes, documentation enhancements, and other improvements.
+
+Please report bugs via the [github issue tracker](http://github.com/DomBlack/php-scrypt/issues).
+
+Master [git repository](https://github.com/DomBlack/php-scrypt):
+
+    git clone git://github.com/DomBlack/php-scrypt.git
+
+Authors
+-------
+
+This library is written and maintained by Dominic Black, <thephenix@gmail.com>.
+
+----
+
+PECL Install
+============
+
+This extension is now avaible through PECL.
+
+```
+pecl install scrypt
+```
+
+Build From Source
+=================
+
+Unix/OSX
+--------
+
+1. `phpize`
+2. If on OSX; `export CFLAGS='-arch i386 -arch x86_64'`
+3. `./configure --enable-scrypt`
+4. `make`
+5. `make install`
+6. Add the extension to your php.ini
+
+````
+    ; Enable scrypt extension module
+    extension=scrypt.so
+````
+
+Windows
+-------
+
+Using Visual Studio 2008 (or Visual C++ Express 2008) open up the attached project
+inside the VS2008 folder. This project assumes you have the PHP thread safe source at;
+`C:\phpsrcts\`, a PHP install at `C:\php\` and this source code extracted to
+`C:\php-scrypt\`.
+
+1. Build the project.
+2. Copy the resultant `scrypt.dll` to your ext directory in PHP.
+3. Add the extension to your php.ini
+
+````
+    ; Enable scrypt extension module
+    extension=scrypt.dll
+````
+
+Legal Stuff
+===========
+This works is licensed under the BSD 2-Clause license.
+
+Original Scrypt Implementation;
+ Copyright (c) 2009 Colin Percival
+
+PHP Module;
+ Copyright (c) 2012, Dominic Black
+
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
+
+Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
+Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff --git a/framework/main/third_party/akismet/akismet.class.php b/framework/main/third_party/akismet/akismet.class.php
deleted file mode 100644 (file)
index 021447e..0000000
+++ /dev/null
@@ -1,388 +0,0 @@
-<?php
-/**
- * 01.07.2008 22:32:28est
- * 
- * Akismet PHP4 class
- * 
- * <b>Usage</b>
- * <code>
- *    $comment = array(
- *           'author'    => 'viagra-test-123',
- *           'email'     => 'test@example.com',
- *           'website'   => 'http://www.example.com/',
- *           'body'      => 'This is a test comment',
- *           'permalink' => 'http://yourdomain.com/yourblogpost.url',
- *        );
- *
- *    $akismet = new Akismet('http://www.yourdomain.com/', 'YOUR_WORDPRESS_API_KEY', $comment);
- *
- *    if($akismet->errorsExist()) {
- *        echo"Couldn't connected to Akismet server!";
- *    } else {
- *        if($akismet->isSpam()) {
- *            echo"Spam detected";
- *        } else {
- *            echo"yay, no spam!";
- *        }
- *    }
- * </code>
- * 
- * @author Bret Kuhns {@link www.miphp.net}
- * @link http://www.miphp.net/blog/view/new_akismet_class/
- * @version 0.3.4
- * @license http://www.opensource.org/licenses/mit-license.php MIT License
- */
-
-
-
-// Error constants
-define("AKISMET_SERVER_NOT_FOUND",     0);
-define("AKISMET_RESPONSE_FAILED",      1);
-define("AKISMET_INVALID_KEY",          2);
-
-
-
-// Base class to assist in error handling between Akismet classes
-class AkismetObject {
-       var $errors = array();
-       
-       
-       /**
-        * Add a new error to the errors array in the object
-        *
-        * @param       String  $name   A name (array key) for the error
-        * @param       String  $string The error message
-        * @return void
-        */ 
-       // Set an error in the object
-       function setError($name, $message) {
-               $this->errors[$name] = $message;
-       }
-       
-
-       /**
-        * Return a specific error message from the errors array
-        *
-        * @param       String  $name   The name of the error you want
-        * @return mixed        Returns a String if the error exists, a false boolean if it does not exist
-        */
-       function getError($name) {
-               if($this->isError($name)) {
-                       return $this->errors[$name];
-               } else {
-                       return false;
-               }
-       }
-       
-       
-       /**
-        * Return all errors in the object
-        *
-        * @return String[]
-        */ 
-       function getErrors() {
-               return (array)$this->errors;
-       }
-       
-       
-       /**
-        * Check if a certain error exists
-        *
-        * @param       String  $name   The name of the error you want
-        * @return boolean
-        */ 
-       function isError($name) {
-               return isset($this->errors[$name]);
-       }
-       
-       
-       /**
-        * Check if any errors exist
-        *
-        * @return boolean
-        */
-       function errorsExist() {
-               return (count($this->errors) > 0);
-       }
-       
-       
-}
-
-
-
-
-
-// Used by the Akismet class to communicate with the Akismet service
-class AkismetHttpClient extends AkismetObject {
-       var $akismetVersion = '1.1';
-       var $con;
-       var $host;
-       var $port;
-       var $apiKey;
-       var $blogUrl;
-       var $errors = array();
-       
-       
-       // Constructor
-       function AkismetHttpClient($host, $blogUrl, $apiKey, $port = 80) {
-               $this->host = $host;
-               $this->port = $port;
-               $this->blogUrl = $blogUrl;
-               $this->apiKey = $apiKey;
-       }
-       
-       
-       // Use the connection active in $con to get a response from the server and return that response
-       function getResponse($request, $path, $type = "post", $responseLength = 1160) {
-               $this->_connect();
-               
-               if($this->con && !$this->isError(AKISMET_SERVER_NOT_FOUND)) {
-                       $request  = 
-                                       strToUpper($type)." /{$this->akismetVersion}/$path HTTP/1.1\r\n" .
-                                       "Host: ".((!empty($this->apiKey)) ? $this->apiKey."." : null)."{$this->host}\r\n" .
-                                       "Content-Type: application/x-www-form-urlencoded; charset=utf-8\r\n" .
-                                       "Content-Length: ".strlen($request)."\r\n" .
-                                       "User-Agent: Akismet PHP4 Class\r\n" .
-                                       "\r\n" .
-                                       $request
-                               ;
-                       $response = "";
-
-                       @fwrite($this->con, $request);
-
-                       while(!feof($this->con)) {
-                               $response .= @fgets($this->con, $responseLength);
-                       }
-
-                       $response = explode("\r\n\r\n", $response, 2);
-                       return $response[1];
-               } else {
-                       $this->setError(AKISMET_RESPONSE_FAILED, "The response could not be retrieved.");
-               }
-               
-               $this->_disconnect();
-       }
-       
-       
-       // Connect to the Akismet server and store that connection in the instance variable $con
-       function _connect() {
-               if(!($this->con = @fsockopen($this->host, $this->port))) {
-                       $this->setError(AKISMET_SERVER_NOT_FOUND, "Could not connect to akismet server.");
-               }
-       }
-       
-       
-       // Close the connection to the Akismet server
-       function _disconnect() {
-               @fclose($this->con);
-       }
-       
-       
-}
-
-
-
-
-
-// The controlling class. This is the ONLY class the user should instantiate in
-// order to use the Akismet service!
-class Akismet extends AkismetObject {
-       var $apiPort = 80;
-       var $akismetServer = 'rest.akismet.com';
-       var $akismetVersion = '1.1';
-       var $http;
-       
-       var $ignore = array(
-                       'HTTP_COOKIE',
-                       'HTTP_X_FORWARDED_FOR',
-                       'HTTP_X_FORWARDED_HOST',
-                       'HTTP_MAX_FORWARDS',
-                       'HTTP_X_FORWARDED_SERVER',
-                       'REDIRECT_STATUS',
-                       'SERVER_PORT',
-                       'PATH',
-                       'DOCUMENT_ROOT',
-                       'SERVER_ADMIN',
-                       'QUERY_STRING',
-                       'PHP_SELF',
-                       'argv'
-               );
-       
-       var $blogUrl = "";
-       var $apiKey  = "";
-       var $comment = array();
-       
-       
-       /**
-        * Constructor
-        * 
-        * Set instance variables, connect to Akismet, and check API key
-        * 
-        * @param       String  $blogUrl        The URL to your own blog
-        * @param       String  $apiKey         Your wordpress API key
-        * @param       String[]        $comment        A formatted comment array to be examined by the Akismet service
-        * @return      Akismet
-        */
-       function Akismet($blogUrl, $apiKey, $comment = array()) {
-               $this->blogUrl = $blogUrl;
-               $this->apiKey  = $apiKey;
-               $this->setComment($comment);
-               
-               // Connect to the Akismet server and populate errors if they exist
-               $this->http = new AkismetHttpClient($this->akismetServer, $blogUrl, $apiKey);
-               if($this->http->errorsExist()) {
-                       $this->errors = array_merge($this->errors, $this->http->getErrors());
-               }
-               
-               // Check if the API key is valid
-               if(!$this->_isValidApiKey($apiKey)) {
-                       $this->setError(AKISMET_INVALID_KEY, "Your Akismet API key is not valid.");
-               }
-       }
-       
-       
-       /**
-        * Query the Akismet and determine if the comment is spam or not
-        * 
-        * @return      boolean
-        */
-       function isSpam() {
-               $response = $this->http->getResponse($this->_getQueryString(), 'comment-check');
-               
-               return ($response == "true");
-       }
-       
-       
-       /**
-        * Submit this comment as an unchecked spam to the Akismet server
-        * 
-        * @return      void
-        */
-       function submitSpam() {
-               $this->http->getResponse($this->_getQueryString(), 'submit-spam');
-       }
-       
-       
-       /**
-        * Submit a false-positive comment as "ham" to the Akismet server
-        *
-        * @return      void
-        */
-       function submitHam() {
-               $this->http->getResponse($this->_getQueryString(), 'submit-ham');
-       }
-       
-       
-       /**
-        * Manually set the comment value of the instantiated object.
-        *
-        * @param       Array   $comment
-        * @return      void
-        */
-       function setComment($comment) {
-               $this->comment = $comment;
-               if(!empty($comment)) {
-                       $this->_formatCommentArray();
-                       $this->_fillCommentValues();
-               }
-       }
-       
-       
-       /**
-        * Returns the current value of the object's comment array.
-        *
-        * @return      Array
-        */
-       function getComment() {
-               return $this->comment;
-       }
-       
-       
-       /**
-        * Check with the Akismet server to determine if the API key is valid
-        *
-        * @access      Protected
-        * @param       String  $key    The Wordpress API key passed from the constructor argument
-        * @return      boolean
-        */
-       function _isValidApiKey($key) {
-               $keyCheck = $this->http->getResponse("key=".$this->apiKey."&blog=".$this->blogUrl, 'verify-key');
-                       
-               return ($keyCheck == "valid");
-       }
-       
-       
-       /**
-        * Format the comment array in accordance to the Akismet API
-        *
-        * @access      Protected
-        * @return      void
-        */
-       function _formatCommentArray() {
-               $format = array(
-                               'type' => 'comment_type',
-                               'author' => 'comment_author',
-                               'email' => 'comment_author_email',
-                               'website' => 'comment_author_url',
-                               'body' => 'comment_content'
-                       );
-               
-               foreach($format as $short => $long) {
-                       if(isset($this->comment[$short])) {
-                               $this->comment[$long] = $this->comment[$short];
-                               unset($this->comment[$short]);
-                       }
-               }
-       }
-       
-       
-       /**
-        * Fill any values not provided by the developer with available values.
-        *
-        * @return      void
-        */
-       function _fillCommentValues() {
-               if(!isset($this->comment['user_ip'])) {
-                       $this->comment['user_ip'] = ($_SERVER['REMOTE_ADDR'] != getenv('SERVER_ADDR')) ? $_SERVER['REMOTE_ADDR'] : getenv('HTTP_X_FORWARDED_FOR');
-               }
-               if(!isset($this->comment['user_agent'])) {
-                       $this->comment['user_agent'] = $_SERVER['HTTP_USER_AGENT'];
-               }
-               if(!isset($this->comment['referrer'])) {
-                       $this->comment['referrer'] = $_SERVER['HTTP_REFERER'];
-               }
-               if(!isset($this->comment['blog'])) {
-                       $this->comment['blog'] = $this->blogUrl;
-               }
-       }
-       
-       
-       /**
-        * Build a query string for use with HTTP requests
-        *
-        * @access      Protected
-        * @return      String
-        */
-       function _getQueryString() {
-               foreach($_SERVER as $key => $value) {
-                       if(!in_array($key, $this->ignore)) {
-                               if($key == 'REMOTE_ADDR') {
-                                       $this->comment[$key] = $this->comment['user_ip'];
-                               } else {
-                                       $this->comment[$key] = $value;
-                               }
-                       }
-               }
-
-               $query_string = '';
-
-               foreach($this->comment as $key => $data) {
-                       $query_string .= $key . '=' . urlencode(stripslashes($data)) . '&';
-               }
-
-               return $query_string;
-       }
-       
-       
-}
-?>
\ No newline at end of file
diff --git a/framework/main/third_party/scrypt/CREDITS b/framework/main/third_party/scrypt/CREDITS
deleted file mode 100644 (file)
index 79c72e5..0000000
+++ /dev/null
@@ -1,2 +0,0 @@
-scrypt
-Dominic Black
\ No newline at end of file
diff --git a/framework/main/third_party/scrypt/LICENSE b/framework/main/third_party/scrypt/LICENSE
deleted file mode 100644 (file)
index 381d3af..0000000
+++ /dev/null
@@ -1,15 +0,0 @@
-Original Scrypt Implementation;
-  Copyright (c) 2009 Colin Percival
-
-PHP Module;
-  Copyright (c) 2012, Dominic Black
-
-All rights reserved.
-
-Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
-
-1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
-
-2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
-
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff --git a/framework/main/third_party/scrypt/README.md b/framework/main/third_party/scrypt/README.md
deleted file mode 100644 (file)
index fef282b..0000000
+++ /dev/null
@@ -1,90 +0,0 @@
-PHP scrypt module
-=================
-
-[![Build Status](https://travis-ci.org/DomBlack/php-scrypt.svg?branch=master)](https://travis-ci.org/DomBlack/php-scrypt)
-
-This is a PHP library providing a wrapper to [Colin Percival's scrypt implementation](http://www.tarsnap.com/scrypt.html). Scrypt is a key derivation function designed to be far more secure against hardware brute-force attacks than alternative functions such as PBKDF2 or bcrypt.
-
-Details of the scrypt key derivation function are given in a paper by Colin Percival, Stronger Key Derivation via Sequential Memory-Hard Functions: [PDF](http://www.tarsnap.com/scrypt/scrypt-slides.pdf).
-
-An example class using this module can be found in; scrypt.php
-
-Join in!
---------
-
-We are happy to receive bug reports, fixes, documentation enhancements, and other improvements.
-
-Please report bugs via the [github issue tracker](http://github.com/DomBlack/php-scrypt/issues).
-
-Master [git repository](https://github.com/DomBlack/php-scrypt):
-
-    git clone git://github.com/DomBlack/php-scrypt.git
-
-Authors
--------
-
-This library is written and maintained by Dominic Black, <thephenix@gmail.com>.
-
-----
-
-PECL Install
-============
-
-This extension is now avaible through PECL.
-
-```
-pecl install scrypt
-```
-
-Build From Source
-=================
-
-Unix/OSX
---------
-
-1. `phpize`
-2. If on OSX; `export CFLAGS='-arch i386 -arch x86_64'`
-3. `./configure --enable-scrypt`
-4. `make`
-5. `make install`
-6. Add the extension to your php.ini
-
-````
-    ; Enable scrypt extension module
-    extension=scrypt.so
-````
-
-Windows
--------
-
-Using Visual Studio 2008 (or Visual C++ Express 2008) open up the attached project
-inside the VS2008 folder. This project assumes you have the PHP thread safe source at;
-`C:\phpsrcts\`, a PHP install at `C:\php\` and this source code extracted to
-`C:\php-scrypt\`.
-
-1. Build the project.
-2. Copy the resultant `scrypt.dll` to your ext directory in PHP.
-3. Add the extension to your php.ini
-
-````
-    ; Enable scrypt extension module
-    extension=scrypt.dll
-````
-
-Legal Stuff
-===========
-This works is licensed under the BSD 2-Clause license.
-
-Original Scrypt Implementation;
- Copyright (c) 2009 Colin Percival
-
-PHP Module;
- Copyright (c) 2012, Dominic Black
-
-All rights reserved.
-
-Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
-
-Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
-Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
-THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.