GNOME Web was originally named "Epiphany", but was rebranded in 2012 as part of GNOME 3.4.[15] The name Epiphany is still used internally, as its code name,[8] for development and in the source code.[16] The package remains epiphany-browser in Debian[17] (to avoid a name collision with a video game that is also called "Epiphany") and epiphany in Fedora and Arch Linux.[18][19]
Marco Pesenti Gritti, the initiator of Galeon, originally developed Epiphany in 2002 as a fork of Galeon. The fork occurred because of the disagreement between Gritti and the rest of Galeon developers about new features. Gritti regarded Galeon's monolithic design and the number of user-configurable features as factors that were limiting Galeon's maintainability and usability, but the rest of the Galeon developers wanted to add more features.[citation needed]
Around the same time, the GNOME project adopted a set of human interface guidelines, which promoted simplification of user interfaces. As Galeon was oriented towards power users, most developers disapproved. As a result, Gritti created a new browser based on Galeon, with most of the non-critical features removed. He intended Epiphany to comply with the GNOME HIG. As such, Epiphany used the global GNOME theme and other settings from inception.[20][21]
Gritti explained his motivations:
While Mozilla has an excellent rendering engine, its default XUL-based interface is considered to be overcrowded and bloated. Furthermore, on slower processors even trivial tasks such as pulling down a menu is less than responsive.
Epiphany aims to utilize the simplest interface possible for a browser. Keep in mind that simple does not necessarily mean less powerful. We believe the commonly used browsers of today are too big, buggy, and bloated. Epiphany addresses simplicity with a small browser designed for the web—not mail, newsgroups, file management, instant messaging or coffee making. The Unix philosophy is to design small tools that do one thing, and do it well.
[..]
Epiphany's main goal is to be integrated with the gnome desktop. We don't aim to make Epiphany usable outside Gnome. If someone will like to use it anyway, it's just a plus. For example: Making people happy that don't have control center installed is not a good reason to have mime configuration in Epiphany itself.
Galeon continued after the fork, but lost momentum due to the remaining developers' failure to keep up with changes in the Mozilla platform. Galeon development stalled and the developers decided to work on extensions to bring Galeon's advanced features to Epiphany.[21]
Gritti ended his work on Epiphany and a GNOME team led by Xan Lopez, Christian Persch and Jean-François Rameau now direct the project.[23] Gritti died of cancer on May 23, 2015.[24]
Gecko-based
The first version of Epiphany was released on December 24, 2002.[2]
The development of Epiphany was mainly focused on usability improvements compared to major browsers at the time. The most notable was the new text entry widget, which was introduced in version 1.8. The new widget supported icons inside the text area and reduced the screen space needed to present information, while improving GNOME integration.[26]
The next major milestone was version 2.14, which was the first to follow GNOME's version numbering. It also featured network awareness using NetworkManager, smart bookmarks improvements, and the option to build with XULRunner.[citation needed]
The latter was critical. Previously, Epiphany could only use an installed Mozilla web browser as a web engine provider. The XULRunner support made it possible to install Epiphany as the only web browser on the system.[27][28]
WebKit-based
The development process suffered from major problems related to the Gecko backend. Notably, the release cycles of the two projects did not line up efficiently. Additionally, Mozilla increasingly disregarded third-party software that wished to make use of Gecko, until it became viewed as an integrated Firefox component.[23] To address these issues, in July 2007, the Epiphany team added support for WebKit as an alternative rendering engine.[29] On April 1, 2008, the team announced that it would remove the ability to build it using Gecko and proceed using only WebKit.[23]
The size of the team and complexity of porting the browser to WebKit caused version 2.22 to be re-released with bugfixes alongside GNOME 2.24,[30] so the releases stagnated until July 1, 2009, when it was announced that 2.26 would be the final Gecko-based version.[31]
In September 2009, the transition to WebKit was completed as part of GNOME 2.28.[32]
Version history
Developers of GNOME Web maintain a complete and accurate changelog in its official repository that shows complete and detailed changes between all the releases,[33] following table just shows arbitrarily mentioned some notable and important changes:[34][35]
Python bindings, Find toolbar, Favicon and SSLicons displayed in location bar.[26] Gecko 1.8 support. Error messages display in content area. Use of the GNOME printing system.
History preserved for links opened in new tabs.[50]Spell checking support. Page security info dialogue from Certificates extension. New GTK Printing dialog. Stability improvements.[51]
Reduced the amount of user interface chrome. Geolocation support. Switched from text zooming to full content zooming. New download manager. Migration to GTK 3 and GNOME 3 technologies.
A minor update adding support blocking invalid SSL certificates, warning users about mixed content for improved security, adblocker performance improvements and overall small UI improvements and polishing.[71]
Rewritten and improved ad blocker which uses WebKit's content filtering. Web process sandboxing for improved security. Favorite tabs can be pinned.[75] plug-in support removed.[76]
User interface improvements for small screens. Native support for PDF documents. Improved support for handling dark GTK themes. Native viewing of web page source. Removal of vestigial NPAPI support. Support for Service workers. More secure handling of cookies. Security improvements to better isolate sites from each other in a tab process.[77][78]
Encrypted Media Extensions support is not a goal, as the standard does not specify a Content Decryption Module to use, all available modules are proprietary even if licensing is possible, and the system imposes digital rights management that hides what the user's computer is doing to make copying "premium content" difficult. However, Media Source Extensions is supported, as YouTube began to require this technology in November 2018.[86]
Apple, which is the primary corporate backer of WebKit, rejected at least 16 web APIs because they could be used in a fingerprinting attack to help personally identify users and track them, while providing limited or no benefit to the user.[87] As HTML5test checks for most of these APIs, it artificially lowers WebKit's "score" in points (as does lack of DRM support).[citation needed]
Web once supported NPAPI plug-ins, such as Java and Adobe Flash, but support was removed in GNOME 3.34.[76] In the modern web platform, these have fallen out of favor and support has been removed from all major browsers. Flash has been deprecated by Adobe itself.[88] Flash had gained infamy throughout the years for usability and stability issues, incessant security vulnerabilities,[89] its proprietary nature, its ability to let sites deploy particularly obnoxious web ads,[90] and Adobe's poor and inconsistent Linux support.[91] Many of these issues were raised by Steve Jobs, then CEO of Apple, in his essay Thoughts on Flash.[92]
GNOME integration
Web reuses GNOME frameworks and settings,[93][94] including the user interface theme, network settings, and printing. Settings are stored with GSettings and GNOME default applications are used for internet media types handling. The user configures these, centrally, in GNOME's settings app.
The built-in preference manager for Web presents basic browser-specific settings while advanced settings which could radically alter Web's behavior can be changed with utilities such as dconf (command line) and dconf-editor (graphical).[95]
Web follows the GNOME Human Interface Guidelines and platform-wide design decisions.[96] For example, in Web 3.4, the menu for application actions was moved to the GNOME Shell's top panel application menu and the menu bar was replaced with "super menu" button, which triggers the display of window-specific menu entries.[97]
Since GNOME 3.32, Web can adjust to various form factors with the help of Libadwaita.[98] It supports desktop, tablet and phone form factors. ("Narrow Mode").[99]
Ad blocking
Since GNOME 3.18, Web is configured to block ads and pop-ups by default.[73] In GNOME 3.34, the existing ad blocker was removed. This code was only partially functional and had been the source of many bugs. Web adopted the "Content Blockers" system from the WebKit engine.[100][101]
One of the developers, Adrián Pérez de Castro, compared the old and new ad blockers. He found that the switch saved approximately 80 MiB of RAM per browser tab.[102]
Google Safe Browsing and security sandboxing
Since GNOME 3.28, Web has support for Google Safe Browsing, to help prevent users from visiting malicious websites.[83]
Since GNOME 3.34, Web explicitly requires a minimum of WebKitGTK 2.26 or later.[75][103][76] This provides the "Bubblewrap Sandbox"[104] for tab processes, which is intended to prevent malicious websites from hijacking the browser and using it to spy on other tabs or run malicious code on the user's computer. If such code found another exploit in the operating system allowing it to become root, the result could be a disaster for all users of the system.
Making the sandbox a priority was brought on, according to Michael Catanzaro, because he was particularly concerned with the code quality of OpenJPEG and the numerous security problems that had been discovered in it, including many years of failing security reviews by Ubuntu.[105] He further explained that web compatibility requires that sites believe that Web is a major browser. Sending them the user agent of Apple Safari causes fewer broken websites than others (due to sharing the WebKit engine), but also causes caching servers to deliver JPEG 2000 images,[106] of which Safari is the only major browser to support. There is no other usable open source option for JPEG 2000 support. Fixing OpenJPEG, which is the official reference software, will be a massive undertaking that could take years to sort out. Enabling the Bubblewrap Sandbox would cause many vulnerabilities in this and other components to become "minimally useful" to potential attackers.[107]
In GNOME 3.36, Web gained native support for PDF documents by using PDF.js. Michael Catanzaro explained that having websites open Evince to display PDF files was insecure, as it could be used to escape the browser's security sandbox. Since Evince was the last user of NPAPI, this allowed the remaining support code for the obsolete plug-in model (where additional vulnerabilities could be hiding) to be removed. Since the NPAPI support had a hard dependency on X11, moving to PDF.js also allowed that dependency to be dropped.[78]
Since PDF.js internally converts PDF documents so that they can be displayed by the web browser's engine, it does not add security vulnerabilities to the browser the way that compiled plug-ins such as Adobe Acrobat or Evince could.[78]
Bookmark management
While most browsers feature a hierarchical folder-based bookmark system, Web uses categorized bookmarks, where a single bookmark (e.g. this page) can exist in multiple categories (such as "Web Browsers", "GNOME", and "Computer Software").[108] A special category includes bookmarks that have not yet been categorized. Bookmarks, along with browsing history, are accessed from the address bar in find-as-you-type manner.[109]
Smart bookmarks
Another innovative concept supported by Web (though originally from Galeon)[20] is "smart bookmarks". These take a single argument specified from the address bar, or from a textbox in a toolbar.[21]
Since GNOME 3.2, released in September 2011,[110] Web allows creating application launchers for web applications. The subsequent invocation of a launcher brings up a plain site-specific browser (single instance) of Web limited to one domain, with off-site links opening in a normal browser.[111] The launcher created this way is accessible from the desktop and is not limited to GNOME Shell. For instance it may be used with Unity, used on Ubuntu.[112] This feature facilitates the integration of the desktop and World Wide Web, which is a goal of Web's developers.[113] Similar features can be found in the Windows version of Google Chrome. For the same purpose Mozilla Foundation previously developed a standalone application Mozilla Prism, which was superseded by the project Chromeless.[114]
Web applications are managed within the browser's main instance. The applications can be deleted from the page, accessible with a special URIabout:applications. This approach was supposed to be a temporary while a centralized GNOME web application management was to be implemented in GNOME 3.4, but this never happened.[35]
Firefox Sync
Since GNOME 3.26, Web has support for Firefox Sync, which allows users to sync their bookmarks, history, passwords, and open tabs with Firefox Sync, which can then be shared between any copy of Firefox or Web that the user signs into Firefox Sync with.[115]
Extensions
Web once supported extensions and a package was maintained containing the official ones. This was later removed due to problems with stability and maintainability.[citation needed]
The project has expressed an interest in implementing support for the WebExtension add-on format used by Chrome, Firefox, and some other major browsers, if interested contributors can be found.[116] Experimental support for WebExtensions was introduced in GNOME 43.[117]
Reception
In reviewing the WebKit-powered Epiphany 2.28 in September 2009, Ryan Paul of Ars Technica said "Epiphany is quite snappy in GNOME 2.28 and scores 100/100 on the Acid3 test. Using WebKit will help differentiate Epiphany from Firefox, which is shipped as the default browser by most of the major Linux distributors."[32]
In reviewing Epiphany 2.30 in July 2010, Jack Wallen described it as "efficient, but different" and noted its problem with crashes. "When I first started working with Epiphany it crashed on most sites I visited. After doing a little research (and then a little debugging) I realized the issue was with JavaScript. Epiphany (in its current release), for some strange reason, doesn't like JavaScript. The only way around this was to disable JavaScript. Yes this means a lot of features won't work on a lot of sites – but this also means those same sites will load faster and won't be so prone to having issues (like crashing my browser)."[108] Wallen concluded positively about the browser, "Although Epiphany hasn't fully replaced Chrome and Firefox as my one-stop-shop browser, I now use it much more than I would have previously.[108] [It has a] small footprint, fast startup, and clean interface."[108]
In March 2011, Veronica Henry reviewed Epiphany 2.32, saying "To be fair, this would be a hard sell as a primary desktop browser for most users. In fact, there isn't even a setting to let you designate it as your default browser. But for those instance where you need to fire up a lightning-fast browser for quick surfing, Epiphany will do the trick."[118] She further noted, "Though I still use Firefox as my primary browser, lately it seems to run at a snail's pace. So, one of the first things I noticed about Epiphany is how quickly it launches. And subsequent page loads on my system are equally as fast."[118] Henry criticized Epiphany for its short list of extensions, singling out the lack of Firebug as a deficiency.[118] Web instead supports Web Inspector offered by the WebKit engine, which has similar functionality.[59]
In April 2012, Ryan Paul of Ars Technica used Web as an example to his criticism of GNOME 3.4 design decisions: "Aside from the poor initial discoverability of the panel menu, this model works reasonably well for simple applications. [...] Unfortunately, it doesn't scale well in complex applications. The best example of where this approach can pose difficulties is in GNOME's default Web browser. [...] Having the application's functionality split across two completely separate menus does not constitute a usability improvement."[97] This was addressed in later versions, with a single unified menu.
In an October 2016 review, Bertel King Jr. noted on MakeUseOf, "Later versions offer the best integration you will find with GNOME Shell. It lacks the add-ons found in mainstream browsers, but some users will like the minimalism, the speed, and the tab isolation that prevents one misbehaving site from crashing the entire browser."[119]
In an April 2019 review, Bertel King Jr. wrote another article on MakeUseOf, this time reviewing GNOME Web for its Web Applications Mode. He stated, "When you check your email, you’re using a web app. If you open YouTube, Netflix, or Spotify in a browser, again, you’re using a web app. These days, you can replace most of your desktop apps with web apps. [...] GNOME Web provides tools to better integrate web apps with the rest of your desktop, so you can open them via your app launcher and view them in your dock or taskbar. This way they feel more like apps and less like sites." He also praised the security provided by walling off Web Applications from the rest of the browser and each other. Like Mozilla's container feature, this helps prevent sites such as Facebook from seeing what the user is doing in the main browser. It also allows the user to create multiple "apps" for the same site, to easily switch between different accounts.[82]
^"Bodhi Linux 5.1.0 Released". bodhilinux.com. March 25, 2020. Archived from the original on March 26, 2020. Retrieved May 11, 2020. In addition to replacing epad with leafpad, midori with epiphany
^ abThe GNOME Project, September 28 (March 28, 2012), "GNOME 3.4 Release Notes", gnome-announce mailing list, archived from the original on March 30, 2012, retrieved March 28, 2012{{citation}}: CS1 maint: numeric names: authors list (link)
^ ab"π -1", The GNOME Web Browser Developers, March 14, 2006, archived from the original on April 2, 2012, retrieved October 16, 2011
^"1.9.8 released; XULRunner", The GNOME Web Browser Developers, February 27, 2006, archived from the original on June 12, 2007, retrieved October 17, 2011
^Gritti, Marco Pesenti (December 25, 2002), "[Epiphany] Epiphany 0.4", epiphany mailing list, archived from the original on February 2, 2012, retrieved December 14, 2011
^Gritti, Marco Pesenti (April 13, 2003), "[Epiphany] Epiphany 0.5.0", epiphany mailing list, archived from the original on May 29, 2012, retrieved December 14, 2011
^Gritti, Marco Pesenti (May 4, 2003), "[Epiphany] Epiphany 0.6.0", epiphany mailing list, archived from the original on May 29, 2012, retrieved December 14, 2011
^Gritti, Marco Pesenti (June 7, 2003), "[Epiphany] Epiphany 0.7.0", epiphany mailing list, archived from the original on May 29, 2012, retrieved December 14, 2011
^Gritti, Marco Pesenti (August 22, 2003), "[Epiphany] Epiphany 0.9.0", epiphany mailing list, archived from the original on May 29, 2012, retrieved December 14, 2011
^Gritti, Marco Pesenti (September 8, 2003), "[Epiphany] Epiphany 1.0", epiphany mailing list, archived from the original on May 29, 2012, retrieved December 14, 2011
^Gritti, Marco Pesenti (March 15, 2004), "Epiphany 1.2.0", epiphany mailing list, archived from the original on May 29, 2012, retrieved December 14, 2011
^Persch, Christian (September 13, 2004), "Epiphany 1.4.0", epiphany mailing list, archived from the original on May 29, 2012, retrieved December 14, 2011
^Persch, Christian (March 9, 2005), "Epiphany 1.6.0", epiphany mailing list, archived from the original on May 29, 2012, retrieved December 14, 2011
^van Schouwen, Reinout (March 12, 2006), "Epiphany 2.14.0 released!", epiphany mailing list, archived from the original on May 29, 2012, retrieved December 14, 2011
^"Topic suggestions", The GNOME Web Browser Developers, January 22, 2006, archived from the original on April 2, 2012, retrieved October 17, 2011
^"A new stabler stable release", The GNOME Web Browser Developers, January 30, 2007, archived from the original on April 2, 2012, retrieved October 16, 2011
^ abcHatcher, Timothy (September 30, 2008), "Web Inspector Redesign", Webkit developers blogs, archived from the original on October 11, 2011, retrieved October 18, 2011
^Untz, Vincent (April 6, 2011), "GNOME 3.0 Released", gnome-announce mailing list, archived from the original on November 4, 2011, retrieved December 14, 2011
^Clasen, Matthias (September 28, 2011), "GNOME 3.2 Released", gnome-announce mailing list, archived from the original on December 6, 2011, retrieved December 14, 2011
^The GNOME Project, September 26 (September 26, 2012), "GNOME 3.6 Release Notes", gnome-announce mailing list, archived from the original on December 30, 2012, retrieved March 26, 2013{{citation}}: CS1 maint: numeric names: authors list (link)
^The GNOME Project, September 6 (September 6, 2018), "GNOME 3.30 Release Notes", gnome-announce mailing list, archived from the original on November 5, 2021, retrieved October 1, 2019{{citation}}: CS1 maint: numeric names: authors list (link)
^Peterson, Richard (May 2009), Fedora 10 Linux Desktop, San Francisco, United States: Surfing Turtle Press (published June 15, 2008), p. 224, ISBN978-0984103621, archived from the original on March 26, 2015, retrieved October 20, 2016
^"Work is Underway to Make the GNOME Web Browser Mobile Friendly". OMG! Ubuntu!. May 11, 2018. Archived from the original on August 1, 2020. Retrieved May 8, 2020. Web have two modes that I named normal and narrow. The normal mode is Web as you know it, while the narrow mode moves all buttons from the header bar but the hamburger menu to a new action bar at the bottom, letting the windows reach yet unreachable widths.
^"Smart Bookmarks", The GNOME Project, archived from the original on November 30, 2011, retrieved December 14, 2011
^Vitters, Olav; Klapper, André; Day, Allan (September 28, 2011), "GNOME 3.2 Release Notes", The GNOME Project, archived from the original on December 23, 2012, retrieved October 16, 2011