Jump to content
horst

WireMailSmtp

Recommended Posts

I'm have some config problems with Wire Mail SMTP on a online website

My provider is One.com and after a online chat with the support, all my settings are correct: 

  • smtp hostname: send.one.com
  • smtp port 465
  • use SSL  yes
  • correct smtp user 
  • correct smtp password

With an email-client (Thunderbird) I get access, not with "Test settings now" of Wire Mail SMTP:

error:

  • ERROR: SMTP settings did not work
  • could not connect to the host "send.one.com": connection time out

Has anyone any idea?

Share this post


Link to post
Share on other sites

Perhaps try ports 2525 or 587 in case they work? It's worth the effort, this module + Mandrill is a superb combination. Good luck.

  • Like 1

Share this post


Link to post
Share on other sites

Thx Alan, I already tried these ports, unfortunately, the error stays

Share this post


Link to post
Share on other sites

I'm have some config problems with Wire Mail SMTP on a online website

My provider is One.com and after a online chat with the support, all my settings are correct: 

  • smtp hostname: send.one.com
  • smtp port 465
  • use SSL  yes
  • correct smtp user 
  • correct smtp password

With an email-client (Thunderbird) I get access, not with "Test settings now" of Wire Mail SMTP:

error:

  • ERROR: SMTP settings did not work
  • could not connect to the host "send.one.com": connection time out

Has anyone any idea?

When you tried with the Thunderbird, was it on the same machine as the website is? Or the other way round: have you tried this settings and testconnection from an install on your localhost? If not, you also have to check if the server where your site is hosted has no outgoing firewall restrictions that get in your way.

If the install is on an online machine, you can use the php library here in the spoiler. I often use this for quick checks on hosting machines to see if I'm able to reach other machines, ports, services from there. It is a pure PHP lib to ping severs on specified ports with defined transports.

<?php
/*
    Author: Paul Aitken
    Creation Date: June 2003
    Contact: paul at phat-land com
    Class: Server Status
    Description: A class to check if certain service(s) are running

    Added functionality for checking via Gateways / Proxies
    by Horst Nogajski, January 2004
*/

// This code is Free for non-commercial use

class serverstatus
{
    // PUBLIC
    var $transport      = 'tcp';  // tcp udp ssl tls
    var $service;
    var $ip;
    var $port;
    var $local_ip         = 0;
    var $local_port     = 0;
    var $timeout;

    // PRIVATE
    var $errno;
    var $errstr;
    var $status;
    var $local_status     = TRUE;

    // CONSTRUCTOR: Can set Timeout
    function serverstatus($timeout=5)
    {
        $this->timeout = $timeout;
    }

    // PUBLIC: set Transport
    function set_Transport($t='tcp')
    {
        $valid = array('tcp','udp','ssl','tls','sslv2','sslv3'); // sslv3 ab PHP-5.0.2, alle anderen ab PHP-4.3.0
        if(in_array(strtolower($t),$valid))
        {
            $this->transport = $t;
        }
        else
        {
            $this->transport = 'tcp';
        }
    }

    // PUBLIC: Check Server
    function status_check($ip, $port, $service='', $local_ip=0, $local_port=0)
    {
        $this->service = $service;
        $this->ip = $ip;
        $this->port = $port;
        $this->local_ip = $local_ip;
        $this->local_port = $local_port;
        $this->local_status = TRUE;

        if($this->local_ip > 0 && $this->local_port > 0)
        {
            $this->local_status = FALSE;
            $this->check_local();
        }

        if($this->local_status)
        {
            $this->check_remote();
        }

        return $this->status;
    }

    // PUBLIC: Return Status
    function status_display($short=FALSE,$html=TRUE)
    {
        if(!$this->local_status)
        {
            // a local Gateway or Proxy which must be used is down!
            $filler = ' ';
            for($i=1;$i<10-strlen(trim($this->local_port));$i++) $filler.=' ';
            if($html)
            {
                return $short ? "-(<b>".$this->local_ip.":".$this->local_port."</b>) Gateway for ".$this->service." is <b>down</b>" : "- The local Gateway or Proxy for ".$this->service." is down, (".$this->local_ip.":".$this->local_port.")<br>\n";
            }
            else
            {
                return $short ? "- (".$this->local_ip.":".$this->local_port."){$filler}Gateway for ".$this->service." is down" : "- The local Gateway or Proxy for ".$this->service." is down, (".$this->local_ip.":".$this->local_port.")\r\n";
            }
        }
        else
        {
            $filler = ' ';
            for($i=1;$i<6-strlen(trim($this->port));$i++) $filler.=' ';
            if($this->status)
            {
                // It's TRUE (UP)
                if($html)
                {
                    return $short ? "+ (<b>".$this->port."</b>) ". $this->service." is <b>up</b>" : "+ The service <b>".$this->service."</b> is <b>up</b> and running. IP: <b>".$this->ip."</b> Port: <b>".$this->port."</b><BR>\n";
                }
                else
                {
                    return $short ? "+ UP   (".$this->port.")".$filler.$this->service : "+ The service ".$this->service." is up and running. IP: ".$this->ip." Port: ".$this->port."\r\n";
                }
            }
            else
            {
                // It's FALSE (DOWN)
                if($html)
                {
                    return $short ? "  (<b>".$this->port."</b>) ".$this->service." is <b>down</b>" : "- The service <b>".$this->service."</b> is currently <b>down</b>. IP: <b>".$this->ip."</b> Port: <b>".$this->port."</b><BR>\n";
                }
                else
                {
                    return $short ? "  DOWN (".$this->port.")".$filler.$this->service : "- The service ".$this->service." is currently down. IP: ".$this->ip." Port: ".$this->port."\r\n";
                }
            }
        }
        flush();
    }


    // PRIVATE: Check GATEWAY
    function check_local()
    {
        $this->local_status = ($sock = @fsockopen($this->transport.'://'.$this->local_ip, $this->local_port, $this->errno, $this->errstr, $this->timeout)) ? TRUE : FALSE;
        #if($sock!==FALSE) fclose($sock);
        $sock = NULL;
        unset($sock);
    }

    // PRIVATE: Check SERVER
    function check_remote()
    {
        $this->status = ($sock = @fsockopen($this->transport.'://'.$this->ip, $this->port, $this->errno, $this->errstr, $this->timeout)) ? TRUE : FALSE;
        #if($sock!==FALSE) fclose($sock);
        $sock = NULL;
        unset($sock);
    }

}



$ip = gethostbyname('send.one.com');
$port = 465;
$status = new serverstatus(20);
$status->set_Transport('ssl');  // you also can test / use: 'ssl','tls','sslv2','sslv3' 
$status->status_check($ip, $port, 'SMTP');
echo $status->status_display(false,false);
 

Share this post


Link to post
Share on other sites

My website is online, hosted by One.com, thunderbird is on my own machine

The spoiler-script  shows the message "The service SMTP is currently down. IP: adress  Port: 465". Thx horst for this excellent script. 

I had an hour chat with One.com Chat Support, where they suggested to change ports, SSL off, ...  (what I tried before).  Then I discoverd that SSL in my configuration panel was not activated.  The chat support said it must be activated, and after a few hours waiting, still the same error-messages.

thx cstevensjr, alan and horst, the search goes on

 

Share this post


Link to post
Share on other sites

If the script says the service is down, this only mean that it couldn't connect to the target server. So, when on the website server the outgoing request is blocked (firewall), this would also result in the same error message. If you have email / smtp accounts on other servers, e.g. gmail, hotmail or what ever, I suggest try to connect to them via the test script and see if it is possible.

And good luck! :)

  • Like 1

Share this post


Link to post
Share on other sites

Eureka, connection problem is solved

When a script is used for sending SMTP (One.com):

  • Server: NOT send.one.com  -> mailout.one.com
  • Port: 25
  • SSL: no
  • Authentication: no

With the 'spoiler-script' of Horst, no errors and in with my old website jusing AcyMailing (Joomla), it's also working fine now.

In Wire Mail SMTP, following error stays. I left SMTP user and SMTP is blank, but I assume that Wire Mail SMTP is always checking authentication??

  • server does not require authentication
  • ERROR: SMTP settings did not work

Share this post


Link to post
Share on other sites

I've recently moved my website to another server and now wiremailsmtp doesn't work anymore, it display this message:
 

Warning: stream_socket_enable_crypto(): Peer certificate CN=`email-smtp.eu-west-1.amazonaws.com' did not match expected CN=`52.19.6.114' in /home/sodd/public_html/site/modules/WireMailSmtp/smtp_classes/smtp.php on line 1255

any idea? thanks

Share this post


Link to post
Share on other sites

It is a certificate that doesn't match. This has not directly to do with the module but with the server (certificate). An expected IP (52.19.6.114) doesn't match.

The IP (52.19.6.114) is mapped to the hostname "ec2-52-19-6-114.eu-west-1.compute.amazonaws.com"

and the hostname (email-smtp.eu-west-1.amazonaws.com) resolves to IP "52.30.192.168".

So this is something that you need to sort out with the hosting company.

  • Like 4

Share this post


Link to post
Share on other sites

Successfully tested with PW 3.0 today! :)

  • Like 8

Share this post


Link to post
Share on other sites

A small contribution:  Add an option to have ability to use Self-Signed Certificate on a given SMTP server with WireMailSmtp and PHP >= 5.6
 
What PHP say - source : https://secure.php.net/manual/en/migration56.openssl.php
 

Stream wrappers now verify peer certificates and host names by default when using SSL/TLS.

 
 
HOWTO:
-----------
 
1) In file smtp.php, class smtp_class, we add a member variable and a small function :

/* Allow self signed certificate */
var $smtp_certificate = false;
Function AllowSelfSignedCertificate($allow = false)
{
        $version=explode(".",function_exists("phpversion") ? phpversion() : "3.0.7");
        $php_version=intval($version[0])*1000000+intval($version[1])*1000+intval($version[2]);
        if($php_version<5006000)
            return;
        if($allow) {
		stream_context_set_option($this->connection, 'ssl', 'verify_peer', false);
		stream_context_set_option($this->connection, 'ssl', 'allow_self_signed', true);
	}
	else
	{
		stream_context_set_option($this->connection, 'ssl', 'verify_peer', true);
		stream_context_set_option($this->connection, 'ssl', 'allow_self_signed', false);
	}
}

 
and, in the Connect() method, call the function just in before we check for the result of stream_socket_enable_crypto :
 
Find : 

$this->OutputDebug('Starting TLS cryptograpic protocol');
				
if(!($success = stream_socket_enable_crypto($this->connection, 1, STREAM_CRYPTO_METHOD_TLS_CLIENT)))

Replace to

$this->OutputDebug('Starting TLS cryptograpic protocol');

$this->AllowSelfSignedCertificate($this->smtp_certificate);

if(!($success = stream_socket_enable_crypto($this->connection, 1, STREAM_CRYPTO_METHOD_TLS_CLIENT))

2) In the file smtp_message.php, class smtp_message_class, add a member variable :

/* Allow Self Signed Certificate */
var $smtp_certificate = 0;

In the method StartSendingMessage() , assign the new member variable:

$this->smtp->smtp_certificate = $this->smtp_certificate;

 
3) In the file WireMailSmtpAdaptator, class hnsmtp, add a member variable :

private $smtp_certificate   = false;

and in the method set_var_val(), add a case smtp_certificate for our checkbox :
Find :

case 'smtp_ssl':
case 'smtp_start_tls':
case 'smtp_debug':
case 'smtp_html_debug':

Replace :

case 'smtp_certificate':
case 'smtp_ssl':
case 'smtp_start_tls':
case 'smtp_debug':
case 'smtp_html_debug':

In the class constructor, add :

$this->emailMessage->smtp_certificate           = $this->smtp_certificate;

4) In the WireMailSmtpConfig.php file, add a field :
 
add : 

$field = $modules->get('InputfieldCheckbox');
$field->attr('name', 'smtp_certificate');
$field->label = __('PHP >= 5.6 - Allow self signed certificate');
$field->attr('value', $data['smtp_certificate']);
$field->attr('checked', $data['smtp_certificate'] ? 'checked' : '');
$fieldset->add($field);

5) In the WireMailSmtp.module file, add a settings to the getDefaultdata() :
Find :

'valid_recipients'         => ''     // email addresses of valid recipients. String that we convert to array at runtime.

Add after (take care of comma ','):

'smtp_certificate'		   => 0		  // allow or not self signed certificate (PHP >= 5.6)

 
Result :

1455460292-capture.png

Hope it help. Sorry for my english ^_^

  • Like 6

Share this post


Link to post
Share on other sites

@flydev: many thanks for your contribution, I have added it to the module by following your perfect guidance step by step. Very Nice. So, I have not tested it because I have no server with a Self-Signed Certificate at hand. But I very likely trust someones code who is able to contribute PHP code backwards compatible from PHP 5.6 to PHP 3.0! :lol:^-^

$version=explode(".",function_exists("phpversion") ? phpversion() : "3.0.7");
  • Like 3

Share this post


Link to post
Share on other sites

Cool !  but...  I forgot the following line in step 3, class hnsmtp; In the constructor we need to add

$this->emailMessage->smtp_certificate           = $this->smtp_certificate;

I edited my previous post containing the instructions.

Nice module and thanks for the update, I tested it right now and it work like a charm!

  • Like 2

Share this post


Link to post
Share on other sites

Getting this error while sending mail and when testing settings (gmail) on dev verion 3.0.10. On localhost works fine, any idea? When uninstall wire mail smtp module, regular php wire mail works fine

SQLSTATE[HY000]: General error: 2006 MySQL

server has gone away

Share this post


Link to post
Share on other sites

Just wondering if anyone has tried this Module with MailGun?

I'm planning moving all my Mandarill App based settings to MailGun and at the moment mails are tested positive but no emails are recieved by me or even logged in my MailGun control panel.

Thanks

Share this post


Link to post
Share on other sites

Hey Adrian. I did thanks.
I'll open another thread as my issue seems to be now unrelated to WMSMTP

Share this post


Link to post
Share on other sites

Hi,

it is possible to set the WireMailSmtp config settings at runtime and send email using different settings for each user?

Thank you

Share this post


Link to post
Share on other sites

Yes you can read and write modules config data via PWs API for all modules. Please refer to the docs, or search the forum via google for something like $modules->get("WireMailSMTP")-> getConfigData(), or readConfigData() ? and ->writeConfigData($data).

Sorry, I'm on mobile and cannot provide links or exact code snippets ATM. :)

----

EDIT:

you can use this:

$data = wire('modules')->getModuleConfigData("WireMailSmtp");

// or, regarding on scope,
$data = $modules->getModuleConfigData("WireMailSmtp");

after modifying, you can write it back:

wire('modules')->saveModuleConfigData("WireMailSmtp", $data);

// or

$modules->saveModuleConfigData("WireMailSmtp", $data);

Edited by horst
added code snippets
  • Like 1

Share this post


Link to post
Share on other sites

I wonder if someone could give me an idea how to use the attachment aspect to WireMailSmtp? I am doing a simple form that allows the upload of pdf's only. I am unsure how to access the file size, type, etc. so that I can sanitize things a bit.

Thanks in advance.

Edited by kongondo
No need to start a new topic for a module that has its own support forum + have a look at page 1 of this thread

Share this post


Link to post
Share on other sites

Thanks Kongondo. By the way, page 1 doesn't answer this question (unless I am being a complete dunce!)

Share this post


Link to post
Share on other sites

Thanks Kongondo. By the way, page 1 doesn't answer this question (unless I am being a complete dunce!)

It does:

attachment ($filename) - add attachment file(s) - string or array()

$mail = wireMail(); 
$mail->attachment($filename); // string $filename or array $filenames

what means: you can add any single file path as a string with the attachment() method, or you can add multiple files at once with its pathes stored in an array.

Everything else, e.g. how you submit your form and / or upload the files, does not belong to WireMailSmtp. For this, you may find information and examples on php.net. :)

Edited by horst
  • Like 2

Share this post


Link to post
Share on other sites

Attachments work very well using this mailer. I'm using it to send out event photos to purchasers - nice, nice, nice. Thanks for the work on this, Horst!

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Recently Browsing   0 members

    No registered users viewing this page.

  • Similar Content

    • By Gadgetto
      SnipWire - Snipcart integration for ProcessWire
      Snipcart is a powerful 3rd party, developer-first HTML/JavaScript shopping cart platform. SnipWire is the missing link between Snipcart and the content management framework ProcessWire.
      With SnipWire, you can quickly turn any ProcessWire site into a Snipcart online shop. The SnipWire plugin helps you to get your store up and running in no time. Detailed knowledge of the Snipcart system is not required.
      SnipWire is free and open source licensed under Mozilla Public License 2.0! A lot of work and effort has gone into development. It would be nice if you could donate an amount to support further development:

      Status update links (inside this thread) for SnipWire development
      2020-04-06 -- SnipWire 0.8.6 (beta) released! Adds support for Snipcart subscriptions and also fixes some problems 2020-03-21 -- SnipWire 0.8.5 (beta) released! Improves SnipWires webhooks interface and provides some other fixes and additions 2020-03-03 -- SnipWire 0.8.4 (beta) released! Improves compatibility for Windows based Systems. 2020-03-01 -- SnipWire 0.8.3 (beta) released! The installation and uninstallation process has been heavily revised. 2020-02-08 -- SnipWire 0.8.2 (beta) released! Added a feature to change the cart and catalogue currency by GET, POST or SESSION param 2020-02-03 -- SnipWire 0.8.1 (beta) released! All custom classes moved into their own namespaces. 2020-02-01 -- SnipWire is now available via ProcessWire's module directory! 2020-01-30 -- SnipWire 0.8.0 (beta) first public release! (module just submitted to the PW modules directory) 2020-01-28 -- added Custom Order Fields feature (first SnipWire release version is near!) 2020-01-21 -- Snipcart v3 - when will the new cart system be implemented? 2020-01-19 -- integrated taxes provider finished (+ very flexible shipping taxes handling) 2020-01-14 -- new date range picker, discount editor, order notifiactions, order statuses, and more ... 2019-11-15 -- orders filter, order details, download + resend invoices, refunds 2019-10-18 -- list filters, REST API improvements, new docs platform, and more ... 2019-08-08 -- dashboard interface, currency selector, managing Orders, Customers and Products, Added a WireTabs, refinded caching behavior 2019-06-15 -- taxes provider, shop templates update, multiCURL implementation, and more ... 2019-06-02 -- FieldtypeSnipWireTaxSelector 2019-05-25 -- SnipWire will be free and open source Plugin Key Features
      Fast and simple store setup Full integration of the Snipcart dashboard into the ProcessWire backend (no need to leave the ProcessWire admin area) Browse and manage orders, customers, discounts, abandoned carts, and more Multi currency support Custom order and cart fields Process refunds and send customer notifications from within the ProcessWire backend Process Abandoned Carts + sending messages to customers from within the ProcessWire backend Complete Snipcart webhooks integration (all events are hookable via ProcessWire hooks) Integrated taxes provider (which is more flexible then Snipcart own provider) Useful Links
      SnipWire in PW modules directory SnipWire Docs (please note that the documentation is a work in progress) SnipWire @GitHub (feature requests and suggestions for improvement are welcome - I also accept pull requests) Snipcart Website  
      ---- INITIAL POST FROM 2019-05-25 ----
       
    • By bernhard
      #######################
      Please use the new RockFinder2
      #######################
      WHY?
      This module was built to fill the gap between simple $pages->find() operations and complex SQL queries.
      The problem with $pages->find() is that it loads all pages into memory and that can be a problem when querying multiple thousands of pages. Even $pages->findMany() loads all pages into memory and therefore is a lot slower than regular SQL.
      The problem with SQL on the other hand is, that the queries are quite complex to build. All fields are separate tables, some repeatable fields use multiple rows for their content that belong to only one single page, you always need to check for the page status (which is not necessary on regular find() operations and therefore nobody is used to that).
      In short: It is far too much work to efficiently and easily get an array of data based on PW pages and fields and I need that a lot for my RockGrid module to build all kinds of tabular data.

      Basic Usage

       
      Docs & Download
      https://modules.processwire.com/modules/rock-finder/
      https://github.com/BernhardBaumrock/RockFinder
       
      Changelog
      180817, v1.0.6, support for joining multiple finders 180810, v1.0.5, basic support for options fields 180528, v1.0.4, add custom select statement option 180516, change sql query method, bump version to 1.0.0 180515, multilang bugfix 180513, beta release <180513, preview/discussion took place here: https://processwire.com/talk/topic/18983-rocksqlfinder-highly-efficient-and-flexible-sql-finder-module/
    • By MoritzLost
      TrelloWire
      This is a module that allows you to automatically create Trello cards for ProcessWire pages and update them when the pages are updated. This allows you to setup connected workflows. Card properties and change handling behaviour can be customized through the extensive module configuration. Every action the module performs is hookable, so you can modify when and how cards are created as much as you need to. The module also contains an API-component that makes it easy to make requests to the Trello API and build your own connected ProcessWire-Trello workflows.
      Features
      All the things the module can do for you without any custom code: Create a new card on Trello whenever a page is added or published (you can select applicable templates). Configure the target board, target list, name and description for new cards. Add default labels and checklists to the card. Update the card whenever the page is updated (optional). When the status of the card changes (published / unpublished, hidden / unhidden, trashed / restored or deleted), move the card to a different list or archive or delete it (configurable). You can extend this through hooks in many ways: Modifiy when and how cards are created. Modify the card properties (Target board & list, title, description, et c.) before they are sent to Trello. Create your own workflows by utilizing an API helper class with many convenient utility methods to access the Trello API directly. Feedback & Future Plans
      Let me know what you think! In particular:
      If you find any bugs report them here or on Github, I'll try to fix them. This module was born out of a use-case for a client project where we manage new form submissions through Trello. I'm not sure how many use-cases there are for this module. If you do use it, tell me about it! The Trello API is pretty extensive, I'll try to add some more helper methods to the TrelloWireApi class (let me know if you need anything in particular). I'll think about how the module can support different workflows that include Twig – talk to me if you have a use-case! Next steps could be a dashboard to manage pages that are connected to a Trello card, or a new section in the settings tab to manage the Trello connection. But it depends on whether there is any interest in this 🙂 Links
      Repository on Github Complete module documentation (getting started, configuration & API documentation) [Module directory pending approval] Module configuration

    • By MoritzLost
      Process Cache Control
      This module provides a simple solution to clearing all your cache layers at once, and an extensible interface to perform various cache-related actions.
      The simple motivation behind this module was that I was tired of manually clearing caches in several places after deploying a change on a live site. The basic purpose of this module is a simple Clear all caches link in the Setup menu which clears out all caches, no matter where they hide. You can customize what exactly the module does through it's configuration menu:
      Expire or delete all cache entries in the database, or selectively clear caches by namespace ($cache API) Clear the the template render cache. Clear out specific folders inside your site's cache directory (/site/assets/cache) Clear the ProCache page render cache (if your site is using ProCache) Refresh version strings for static assets to bust client-side browser caches (this requires some setup, see the full documentation for details). This is the basic function of the module. However, you can also add different cache management action through the API and execute them through the module's interface. For this advanced usage, the module provides:
      An interface to see all available cache actions and execute them. A system log and logging output on the module page to see verify what the module is doing. A CacheControlTools class with utility functions to clear out different caches. An API to add cache actions, execute them programmatically and even modify the default action. Permission management, allowing you granular control over which user roles can execute which actions. The complete documentation can be found in the module's README.
      Plans for improvements
      If there is some interest in this, I plan to expand this to a more general cache management solution. I particular, I would like to add additional cache actions. Some ideas that came to mind:
      Warming up the template render cache for publicly accessible pages. Removing all active user sessions. Let me know if you have more suggestions!
      Links
      https://github.com/MoritzLost/ProcessCacheControl ProcessCacheControl in the Module directory CHANGELOG in the repository Screenshots


    • By Macrura
      PrevNextTabs Module
      Github: https://github.com/outflux3/PrevNextTabs
      Processwire helper modules for adding page navigation within the editor.
      Overview
      This is a very simple module that adds Previous and Next links inline with the tabs on the page editor. Hovering over the tab shows the title of the previous or next page (using the admin's built in jqueryUI tooltips.)
      Usage
      This module is typically used during development where you or your editors need to traverse through pages for the purpose of proofing, flagging and/or commenting. Rather than returning to the page tree or lister, they can navigate with these links.
      Warnings
      If you are using PW version 2.6.1 or later, the system will prevent you from leaving the page if you have unsaved edits.
      For earlier versions, to avoid accidentally losing changes made to a page that might occur if a user accidentally clicks on one of these, make sure to have the Form Save Reminder module installed.
      http://modules.processwire.com/modules/prev-next-tabs/
×
×
  • Create New...