Chromium

From NixOS Wiki
Revision as of 19:01, 14 May 2021 by imported>Yvesh (Update GPU acceleration in chromium (pkg flag has been removed))

Note: Firefox requires the Google Hangouts Video plugin but Chromium (37+) doesn't require any plugin to use Google Hangouts.

Per User

It is possible to configure certain features in nixpkgs by creating ~/.nixpkgs/config.nix and setting the options. See below for details on how to set the equivalent options for the system profile when running NixOS.

To install Firefox and Chromium for a user profile you need to create ~/.nixpkgs/config.nix and add the following options:

~/.nixpkgs/config.nix:

{
    allowUnfree = true;

    firefox = {
     enableGoogleTalkPlugin = true;
     enableAdobeFlash = true;
    };

    chromium = {
     enablePepperFlash = true; # Chromium's non-NSAPI alternative to Adobe Flash
    };

}

After these options have been set you need to install the "Wrapper" versions of Firefox:

$ nix-env -i firefox-with-plugins chromium

If you are using a version that does not have a wrapper, you can write one (add to config.nix and install with `nix-env -iA nixpkgs.pkgs.firefox-bin-wrapper` or `nix-env -iA nixos.pkgs.firefox-bin-wrapper`):

  packageOverrides = pkgs: with pkgs; rec {
    # FF bin with plugins
    firefox-bin-wrapper = wrapFirefox { browser = firefox-bin; };
  };

For NixOS

In NixOS you can configure nixpkgs options by adding a nixpkgs.config section to /etc/nixos/configuration.nix. This has no effect on nix-env commands but does apply to packages installed via the environment.systemPackages list. The options are exactly the same as above.

In order to install Firefox with support for plugins, you need to use the "Wrapper" version. For example, in /etc/nixos/configuration.nix environment.systemPackages this would be firefoxWrapper.

To install Firefox and Chromium with Google Talk and Flash in your system profile you can add the following to your configuration.nix file.

/etc/nixos/configuration.nix:

...

nixpkgs.config = {

    allowUnfree = true;

    firefox = {
     enableGoogleTalkPlugin = true;
     enableAdobeFlash = true;
    };

    chromium = {
     enablePepperFlash = true; # Chromium removed support for Mozilla (NPAPI) plugins so Adobe Flash no longer works 
    };

  };

environment.systemPackages = [ pkgs.firefoxWrapper pkgs.chromium ];
...

then run

nixos-rebuild switch

Java

Note: It is not clear whether this section is out of date, and whether any advice in this section ever worked. See https://github.com/NixOS/nixpkgs/issues/84909.

To use Oracle's JRE as a browser's Java implementation, use the option "jre = true;" in the appropriate configuration file as described above. Oracle's JRE must be manually downloaded to comply with its license. These steps are described in the output when you try to install Firefox.

To use IcedTea/OpenJDK as a browser's Java implementation, use the option "icedtea = true;" in the appropriate configuration file as described above. By using this Java implementation, it is possible to avoid a manual step whenever your system's Java implementation is updated or your configuration is used to build a new system.

Enable GPU accelerated video decoding (VA-API)

VA-API is enabled by default now in Chromium. Check chrome://gpu if it is working and if VA is detected. You may need to enable Hardware-accelerated video decode in chrome://flags.

Make sure the required VA-API drivers are installed: Accelerated Video Playback

Make sure your driver works by running: nix-shell -p libva-utils --run vainfo

Gnome Shell extensions

Gnome Shell extensions can be enabled with enableGnomeExtensions = true. It is a mozilla plugin, therefore it does not work currently with Chromium.