You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
roundcubemail/program/lib/Roundcube
Aleksander Machniak a844db6a27 Merge branch 'dev-layouts' 8 years ago
..
README.md Describe Framework requirements, drop some redundant code (since we require mbstring) 8 years ago
bootstrap.php Remove code related to magic_quotes_* and register_globals 8 years ago
html.php Do not show inline images of unsupported mimetype (#5463) 8 years ago
rcube.php Improve uppercase/lowercase/ucfirst attrib handling in rcube::gettext() 8 years ago
rcube_addressbook.php CS fixes (mostly phpdoc) 8 years ago
rcube_base_replacer.php
rcube_browser.php
rcube_cache.php Fix storing "empty" values in rcube_cache/rcube_cache_shared (#5519) 8 years ago
rcube_cache_shared.php Fix storing "empty" values in rcube_cache/rcube_cache_shared (#5519) 8 years ago
rcube_charset.php Simplify mbstring code path in rcube_charset::convert() 8 years ago
rcube_config.php Unify automatic marking as \Seen in preview pane, full-page and extwin views (#5071) 8 years ago
rcube_contacts.php CS fixes (mostly phpdoc) 8 years ago
rcube_content_filter.php
rcube_csv2vcard.php
rcube_db.php Implemented rcube::sleep() method for disconnecting all external connection in long-running/sleeping scripts 8 years ago
rcube_db_mssql.php
rcube_db_mysql.php
rcube_db_oracle.php Implemented rcube::sleep() method for disconnecting all external connection in long-running/sleeping scripts 8 years ago
rcube_db_pgsql.php
rcube_db_sqlite.php
rcube_db_sqlsrv.php
rcube_enriched.php
rcube_html2text.php CS fixes (mostly phpdoc) 8 years ago
rcube_image.php Fix regression in resizing JPEG images with Imagick (#5376) 8 years ago
rcube_imap.php Fix bug where deleting folders with subfolders could fail in some cases (#5466) 8 years ago
rcube_imap_cache.php Make SQL selects less expensive in memory for some cases where we fetch big data chunks 9 years ago
rcube_imap_generic.php Make sure $prefs property is an array (#5523) 8 years ago
rcube_imap_search.php
rcube_ldap.php Support contact+group searches in all relevant places (T1360) 8 years ago
rcube_ldap_generic.php
rcube_message.php Fix regression where messages with no text part (but e.g. application/zip) were not displayed as an attachment (#5357) 8 years ago
rcube_message_header.php
rcube_message_part.php
rcube_mime.php Performance improvements in format_flowed() and unfold_flowed() 9 years ago
rcube_mime_decode.php Enigma: Code refactoring with better handling of encrypted-inside-encrypted (e.g. forwarded) and signed+ncrypted messages 9 years ago
rcube_output.php Use JSON_PRETTY_PRINT in devel_mode 8 years ago
rcube_plugin.php
rcube_plugin_api.php Use ternary operator where aplicable 9 years ago
rcube_result_index.php CS fixes 9 years ago
rcube_result_multifolder.php
rcube_result_set.php
rcube_result_thread.php CS fixes 9 years ago
rcube_session.php Add convenient method to create new session records 8 years ago
rcube_session_db.php Removed useless 'created' column from 'session' table (#5389) 8 years ago
rcube_session_memcache.php Properly set the memcache debug log file name 8 years ago
rcube_session_php.php
rcube_session_redis.php
rcube_smtp.php Support host-specific imap_conn_options/smtp_conn_options/managesieve_conn_options (#5136) 8 years ago
rcube_spellcheck_atd.php Use ternary operator where aplicable 9 years ago
rcube_spellcheck_enchant.php
rcube_spellcheck_engine.php
rcube_spellcheck_googie.php Trim error message 9 years ago
rcube_spellcheck_pspell.php
rcube_spellchecker.php Disable links list when converting html2text for spellchecking 9 years ago
rcube_storage.php Use ternary operator where aplicable 9 years ago
rcube_string_replacer.php Fix converting mail addresses with @www. into mailto links (#5197) 9 years ago
rcube_text2html.php Small performance optimization 9 years ago
rcube_tnef_decoder.php Use ternary operator where aplicable 9 years ago
rcube_user.php Improve randomness of password salts and random hashes (#5266) 8 years ago
rcube_utils.php Fix bug where it wasn't possible to store more that 2MB objects in memcache/apc (#5452) 8 years ago
rcube_vcard.php Export vCard PHOTO with "ENCODING=b" (instead of "ENCODING=B") as specified in RFC2426 9 years ago
rcube_washtml.php Merge remote-tracking branch 'upstream/master' 8 years ago

README.md

Roundcube Framework

INTRODUCTION

The Roundcube Framework is the basic library used for the Roundcube Webmail application. It is an extract of classes providing the core functionality for an email system. They can be used individually or as package for the following tasks:

  • IMAP mailbox access with optional caching
  • MIME message handling
  • Email message creation and sending through SMTP
  • General caching utilities using the local database
  • Database abstraction using PDO
  • VCard parsing and writing

REQUIREMENTS

PHP Version 5.4 or greater including:

  • PCRE, DOM, JSON, Session, Sockets, OpenSSL, Mbstring (required)
  • PHP PDO with driver for either MySQL, PostgreSQL, SQL Server, Oracle or SQLite (required)
  • Libiconv, Zip, Fileinfo, Intl, Exif (recommended)
  • LDAP for LDAP addressbook support (optional)

INSTALLATION

Copy all files of this directory to your project or install it in the default include_path directory of your webserver. Some classes of the framework require one or multiple of the following PEAR libraries:

  • Mail_Mime 1.8.1 or newer
  • Net_SMTP 1.7.1 or newer
  • Net_Socket 1.0.12 or newer
  • Net_IDNA2 0.1.1 or newer
  • Auth_SASL 1.0.6 or newer

USAGE

The Roundcube Framework provides a bootstrapping file which registers an autoloader and sets up the environment necessary for the Roundcube classes. In order to make use of the framework, simply include the bootstrap.php file from this directory in your application and start using the classes by simply instantiating them.

If you wanna use more complex functionality like IMAP access with database caching or plugins, the rcube singleton helps you loading the necessary files:

<?php

define('RCUBE_CONFIG_DIR',  '<path-to-config-directory>');
define('RCUBE_PLUGINS_DIR', '<path-to-roundcube-plugins-directory');

require_once '<path-to-roundcube-framework/bootstrap.php';

$rcube = rcube::get_instance(rcube::INIT_WITH_DB | rcube::INIT_WITH_PLUGINS);
$imap = $rcube->get_storage();

// do cool stuff here...

?>

LICENSE

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License (with exceptions for plugins) as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see www.gnu.org/licenses/.

This file forms part of the Roundcube Webmail Framework for which the following exception is added: Plugins which merely make function calls to the Roundcube Webmail Framework, and for that purpose include it by reference shall not be considered modifications of the software.

If you wish to use this file in another project or create a modified version that will not be part of the Roundcube Webmail Framework, you may remove the exception above and use this source code under the original version of the license.

For more details about licensing and the exceptions for skins and plugins see roundcube.net/license

CONTACT

For bug reports or feature requests please refer to the tracking system at Github or subscribe to our mailing list. See roundcube.net/support for details.

You're always welcome to send a message to the project admins: hello(at)roundcube(dot)net