• Stars
    star
    732
  • Rank 61,915 (Top 2 %)
  • Language
    C
  • License
    MIT License
  • Created about 11 years ago
  • Updated over 4 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

ppapi2npapi compatibility layer

About

PPAPI-host NPAPI-plugin adapter.

As you know, Adobe have suspended further development of Flash player plugin for GNU/Linux. Latest available as an NPAPI plugin version 11.2 will get security updates for five years (since its release on May 4th, 2012), but further development have been ceased. Fortunately or not, newer versions are still available for Linux as a part of Chrome browser, where Flash comes bundled in a form of PPAPI plugin. PPAPI or Pepper Plugin API is an interface promoted by Chromium/Chrome team for browser plugins. It's NPAPI-inspired yet significantly different API which have every conceivable function plugin may want. Two-dimensional graphics, OpenGL ES, font rendering, network access, audio, and so on. It's huge, there are 111 groups of functions, called interfaces which todays Chromium browser offers to plugins. Although specs are not final yet, and new interface versions are arising, with some older ones getting deleted; rate of change have significantly slowed down.

For various reasons Firefox developers are not interested now in implementing PPAPI in Firefox. However that does not mean it cannot be done.

The main goal of this project is to get PPAPI (Pepper) Flash player working in Firefox. This can be done in two ways. First one is to implement full PPAPI interface in Firefox itself. Other one is to implement a wrapper, some kind of adapter which will look like browser to PPAPI plugin and look like NPAPI plugin for browser.

First approach requires strong knowledge of Firefox internals, and moreover additional effort to get the code into mainstream. Maintaining a set of patches doesn't look like a good idea. Second approach allows to concentrate on two APIs only. Yes one of them is big, but still graspable. Second way will be used for the project. It will benefit other browsers too, not only Firefox.

Status

Mostly works. Looks like all essential APIs are implemented.

Known issues

described here.

Security note

All available Pepper Plugin API documentation usually accompanied with assertions of enhanced security due to active sandboxing usage. It's worth to note, that API itself doesn't make any sandboxing, it's only allows sandboxed implementations. This particular implementation doesn't implement any sandbox. That means if any malicious code breaks through plugin security, there is no additional barriers. This is the same level of security as NPAPI Flash have.

Install

Project is using cmake (>=2.8.8) build system.

  • Install prerequisites.
    Debian/Ubuntu:
    $ sudo apt-get install cmake gcc g++ pkg-config ragel libasound2-dev \
           libssl-dev libglib2.0-dev libpango1.0-dev libgl1-mesa-dev     \
           libevent-dev libgtk2.0-dev libxrandr-dev libxrender-dev       \
           libxcursor-dev libv4l-dev libgles2-mesa-dev libavcodec-dev    \
           libva-dev libvdpau-dev libdrm-dev libicu-dev
    Fedora:
    $ sudo dnf install cmake gcc gcc-c++ pkgconfig ragel alsa-lib-devel openssl-devel \
           glib2-devel pango-devel mesa-libGL-devel libevent-devel gtk2-devel         \
           libXrandr-devel libXrender-devel libXcursor-devel libv4l-devel             \
           mesa-libGLES-devel  ffmpeg-devel libva-devel libvdpau-devel libdrm-devel   \
           pulseaudio-libs-devel libicu-devel

  • (optional) To enable PulseAudio support, install libpulse-dev.

  • (optional) To enable JACK support, install libjack-jackd2-dev and libsoxr-dev

  • Create a build subdirectory in the root directory, from that folder, call

    $ cmake -DCMAKE_BUILD_TYPE=RelWithDebInfo ..
    $ make
  • Put generated libfreshwrapper-flashplayer.so into browser plugins directory (~/.mozilla/plugins) or install system-wide by calling:
    # make install

By default make install will put plugin(s) to ${CMAKE_INSTALL_PREFIX}/lib${LIB_SUFFIX}/mozilla/plugins. The path could be changed either by changing CMake parameter CMAKE_INSTALL_PREFIX, or by setting MOZPLUGIN_INSTALL_DIR.

When loaded by browser it will search for libpepflashplayer.so in a directories where it can be: in Chrome (stable/beta/unstable) directory, and in /usr/lib/pepperflashplugin-nonfree/ (pepperflashplugin-nonfree puts it there). It should be enough to get it running, but if it doesn't, specify full path in ~/.config/freshwrapper.conf. You may find sample configuration file in /data. It's better to have manifest.json alongside with libpepflashplayer.so, actual Flash version will be taken from that manifest.

Hardware-accelerated video decoding code requires relatively new version of libavcodec (January 2013, version 54.39.0). If you don't have it yet, code won't compile unless you disable hwdec by WITH_HWDEC=0. To do so, change configuration step command to:

    $ cmake -DCMAKE_BUILD_TYPE=RelWithDebInfo -DWITH_HWDEC=0 ..

Note, even if built, hardware-accelerated video decoding is still disabled by default. You need to explicitly enable it in configuration file.

Install / OpenGL|ES 2 support

Although it's better to use system implementation of OpenGL|ES 2, it's still possible to leverage ANGLE GLES2 emulation by adding WITH_GLES2=0 to cmake command line at configuration time (-DWITH_GLES2=0 to be exact). Note, that requires C++11-capable compiler.

License

The MIT License. See LICENSE file for full text.

Directory 3rdparty/ contains source code from 3rd parties which can be distributed under other license terms. See source code for details.

More Repositories

1

apulse

PulseAudio emulation for ALSA
C
605
star
2

libvdpau-va-gl

VDPAU driver with OpenGL/VAAPI backend
C++
155
star
3

fragview

disk fragmentation visualizer based on FIEMAP and FIBMAP ioctls (linux specific)
C++
69
star
4

gmp-widevine

Adapt Widevine CDM to use in Firefox
C++
42
star
5

autofsync

Adaptive fsync with target latency in seconds.
C
23
star
6

nginx-cmake

CMake port of nginx build scripts
CMake
22
star
7

reiserfs-defrag

Offline defragmentation utility for reiserfs (v3.6)
C++
15
star
8

geoip-mmdb

Python MaxMind DB writer
Python
12
star
9

libpdf

libpdf.so from Chromium
C++
9
star
10

jokes

Various code written for jokes
Python
7
star
11

insecure

To overcome 255 bytes name limit (linux), fuse wrapper
C
7
star
12

pdfrog

tag-based document manager with single file storage
Python
4
star
13

readdir-precache

C
3
star
14

pepperflash-crx

Downloads current version of PepperFlash plugin for Chrome OS from Chrome update servers.
Python
3
star
15

ppapi-trace

trace every call plugin or browser make
C
3
star
16

longnamefs

FUSE file system with file names up to 1024 bytes.
C
3
star
17

mips-apk

Homebuilt various Android packages. Mostly for mips target.
3
star
18

utility-kernel-modules

C
3
star
19

flash-test-cases

flash test cases
ActionScript
2
star
20

c10k-benchmark-fixture

http reverse proxy to test c10k
C
2
star
21

pages

HTML
2
star
22

comtrade-toy

Python
2
star
23

configs

1
star
24

nginx-denyfile

Deny subdirectory access by presence of a file
C
1
star
25

utility-scripts

Python
1
star
26

packtpub-rss

Generate RSS feed from Packtpub Book of the Day page
PHP
1
star
27

omini-disasm

static recompilation tool for native-code enhanced Android applications
C
1
star
28

vdpau-doc-unofficial

rendered Doxygen documentation from libvdpau library
HTML
1
star
29

notes

1
star
30

findglyph

find debian font package having specified symbol
C++
1
star
31

apulse-debpkg

Debian packaging scripts for apulse
Makefile
1
star