How to connect to HubSpot CMS via FTP
FTP is not available for users with two-factor authentication (2FA) or single sign-on (SSO) enabled. The [beta] CLI does work with 2FA, we advise using OAuth2 for better security.
The HubSpot FTP service runs on port 3200 at the hostname ftp.hubapi.com. The initial connection is in cleartext, but before the login password is sent, the connection MUST be upgraded to TLS. Clients should be configured for FTP-SSL with explicit auth. The login and password is the same as your app.hubspot.com login. Passive mode must be enabled.
Alternatively, you can connect with Implicit SSL on port 3201. In addition to the control port, the HubSpot FTP service uses a range of data ports. Each transfer gets randomly assigned a data port for the upload or download. In case you need to open up data ports for company firewalls, HubSpot's data ports are in the range 3203-3299.
There are two methods for providing secure FTP services - FTPS (FTP with SSL) and SFTP. HubSpot supports FTPS only.
Edit connection settings
Ensure that the connection is set to use TLS/SSL.
In the Host or Server field, enter ftp.hubapi.com.
Enter 3200 for the port. If you prefer Implicit SSL, the port should be set to 3201.
Enter your HubSpot username and password. You must be a HubSpot user in an account to connect via FTP.
Connect to the server. Once successfully connected, you should see a folder called "portals."
In the "portals" folder contains a HubID directory for each portal that your user is authorized in. Each of these HubID directories contains three subfolders:
- files - assets uploaded to File Manager.
The assets in the "designs" folder will match the folder structure in your Design Manager in the finder. Changes made to the folder structure or individual assets in FTP will be reflected in your Design Manager.
To create a new coded module, make a new directory with the .module extension. This will automatically create a new custom module. New modules created via FTP will be compatible with page and blog templates by default.
At this time the designs folder does not support drag and drop templates.
Connect with cURL
You can also connect with cURL using this command:
curl -v ftp://ftp.hubapi.com:3200/ --ftp-ssl --user email@example.com
Local HubL Server + FTP
You can use the Local HubL Server with an FTP client to sync both the local and remote 'custom' directories. This workflow allows you to develop templates and CSS files locally, while still uploading them to your HubSpot account. To learn more, check out this article.
If you are unable to connect via FTP, check the log messages for the client. If your settings match those described above and the connection is consistently timing out, the connection is mostly being blocked by your network firewall. Make sure your firewall is not blocking the ports used by HubSpot's FTP.
Learn more about local development with HubSpot CMS
We have a CLI for developing locally with HubSpot, it does not have the same 2FA limitation, and provides helpers for doing common tasks like creating custom modules.
There is a good forum thread on this topic 👉 "Can you set up local development on HubSpot CMS?"
You can also ask questions to the community in the CMS Developer Slack.