There are several design decisions, typically for performance and security that impose some limitations on developers who may be used to certain practices. We've tried to document practical limitations of Altis, with rationale to assist developers in writing more bug free, optimized code on Altis.
The root filesystem outside of the uploads directory (returned by
wp_upload_dir()) is not writable on Altis. It's also possible to use
sys_get_temp_dir() to write to the temporary filesystem when needed. This is to protect code-base integrity, and prevent malicious code being able to adjust the code base in the event of a security breach.
As such, plugin and WordPress Core updates can not be performed from within the WordPress Admin, and should always instead be made via the GitHub repository as a code change.
On Altis the uploads directory is a remote stream wrapper, this means you should not perform filesystem reads excessively. For example, no page render should cause a filesystem read. Store any details you need to render a page about a file in the database.
This also means the
wp_is_mobile function will not work as intended, and should not be used.
Due to caching rules, the HTTP Referer header is not available in PHP. Any requirement for the referrer should be passed as a
POST parameter on the referring page.
Direct access to PHP files is not allowed on Altis, outside of
/wp-admin/*. For example, a request for
https://example.com/wp-content/plugins/my-plugin.php will fail. All requests for PHP should be routed via WordPress' rewrite rules or similar.
All web requests are subject to a 60 second maximum execution. Anything that requires more time than this should be offloaded to a background cron task using
wp_schedule_single_event() or similar.
We do not support requests for custom PHP modules. The PHP modules we have installed are listed on the specifications page. Contact Human Made to discuss the inclusion of other modules in this list.
WP_filesystem WordPress API is not currently supported on Altis, this is typically only used in plugin / WordPress Core updates which should instead be performed by GitHub Pull Requests.