NativePHP is currently in alpha development
Let's get to beta!- Protecting your application and infrastructure
- Secrets and .env
- Files and privileges
- The web servers
- Protecting your users and their data
- When sending data over the network
- The PHP executable
#Security
When building desktop applications it's essential to take your application's security to the next level, both to protect your application and infrastructure, but also to protect your users, their system and their data. This is a complex and wide-reaching topic. Please take time to thoroughly understand everything discussed in this chapter.
Remember that we can't cover everything here either, so please use good judgement when implementing features of your application that allows users to manipulate data on their filesystem or other sources.
#Protecting your application and infrastructure
A major consideration for NativePHP is how it can protect your application.
#Secrets and .env
As your application is being installed on systems outside of your/your organisation's control, it is important to think of the environment that it's in as potentially hostile, which is to say that any secrets, passwords or keys could fall into the hands of someone who might try to abuse them.
This means you should, where possible, use unique keys for each installation, preferring to generate these at first-run or on every run rather than sharing the same key for every user across many installations.
Especially if your application is communicating with any private APIs over the network, we highly recommend that your application and any API use a robust and secure authentication protocol, such as OAuth2, that enables you to create and distribute unique and expiring tokens (an expiration date less than 48 hours in the future is recommended) with a high level of entropy, as this makes them hard to guess and hard to abuse.
If your application allows users to connect their own API keys for a service, you should treat these keys with great care. If you choose to store them anywhere (either in a File or Database), make sure you store them encrypted and decrypt them only when needed.
See Environment Files for details
on how to redact your .env
files at build-time.
#Files and privileges
Your application runs in a privileged state thanks to the PHP runtime being executed as the user who is currently operating the system. This is convenient, but it also comes with risks. Your application has access to everything that the user is authorized to access on the system.
You should limit where you are reading and writing files to the locations your user expects. These are the appdata
folder for the combination of your application and this user and the user's home
directory (and the other user
subdirectories).
All of these can be done simply by using the provided Storage filesystems detailed in Files.
#The web servers
NativePHP works by spinning up web servers on each side of the runtime environment: one on the PHP side to execute your application and another on the runtime side, to interact with the runtime's native environment hooks for the operating system. It then bridges the gap between the two by making authenticated HTTP calls between the two using a pre-shared, dynamic key that is regenerated every time your application starts.
This goes some way to preventing third-party software from snooping/sniffing the connection and 'tinkering' with either your application or the runtime environment. It also ensures that the runtime APIs built for your application will respond only to your application.
You MUST NOT bypass this security measure! If you do, your application will be open to attack from very basic HTTP calls. It is trivial for any installed application to make such calls, or even for your user to be coerced into making them via a web browser (e.g. from a phishing attack).
By default, Laravel's built-in CSRF and CORS protections will go some way to preventing many of these kinds of attacks but you should do all you can to prevent unwanted attack vectors from being made available.
Prevent regular browser access
When you're ready, you should add the PreventRegularBrowserAccess
middleware to your application's global middleware
stack, especially before building your application for production release.
This is NOT done for you.
This ensures that only requests coming from the web view shell that booted your application can make requests into your application.
Append the middleware in your bootstrap/app.php
file:
1use Native\Laravel\Http\Middleware\PreventRegularBrowserAccess;2 3return Application::configure(basePath: dirname(__DIR__))4 // ...5 ->withMiddleware(function (Middleware $middleware) {6 $middleware->append(PreventRegularBrowserAccess::class);7 })8 // ...
#Protecting your users and their data
Equally important is how your app protects users. NativePHP is a complex combination of powerful software and so there are a number of risks associated with its use.
#When sending data over the network
Always use HTTPS to communicate with web services. This ensures that any data sent between your user's device and the service is encrypted in transit.
#The PHP executable
Currently, the bundled PHP executable can be used by any user or application that knows where to find it and has privileges to execute binaries in that location.
This is a potential attack vector that your users ought to be aware of when they are installing other applications. If a user installs an application that they don't trust, it may attempt to use the PHP binary bundled with your application to execute arbitrary code on your user's device. This is known as a Remote Code Execution attack (or RCE).
While this may not directly affect your application (unless it's the target of such an attack), you can still help users to secure their device by reminding them of their responsibility to only install trusted software from reputable vendors.
There's very little that can be done to mitigate this kind of attack in practice, just the same as any application you install now on your device could use any other application installed.
- Protecting your application and infrastructure
- Secrets and .env
- Files and privileges
- The web servers
- Protecting your users and their data
- When sending data over the network
- The PHP executable