chromium/base/android/java/src/org/chromium/base/process_launcher/ChildProcessServiceDelegate.java

// Copyright 2017 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

package org.chromium.base.process_launcher;

import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.os.IBinder;
import android.util.SparseArray;

import java.util.List;

/** The interface that embedders should implement to specialize child service creation. */
public interface ChildProcessServiceDelegate {
    /** Invoked when the service was created. This is the first method invoked on the delegate. */
    void onServiceCreated();

    /**
     * Called when the service is bound. Invoked on a background thread.
     * @param intent the intent that started the service.
     */
    void onServiceBound(Intent intent);

    /**
     * Called once the connection has been setup. Invoked on a background thread.
     *
     * @param connectionBundle the bundle pass to the setupConnection call
     * @param clientInterfaces the IBinders interfaces provided by the client
     * @param binderBox an optional binder box which may contain other binders to be unpacked
     */
    void onConnectionSetup(
            Bundle connectionBundle, List<IBinder> clientInterfaces, IBinder binderBox);

    /**
     * Called when the delegate should load the native library.
     *
     * @param hostContext The host context the library should be loaded with (i.e. Chrome).
     */
    void loadNativeLibrary(Context hostContext);

    /**
     * Called when the delegate should preload the native library.
     * Preloading is automatically done during library loading, but can also be called explicitly
     * to speed up the loading. See {@link LibraryLoader#preloadNow()}.
     * @param packageName The package name the library should be preloaded with (i.e.
     * org.chromium.chrome).
     */
    void preloadNativeLibrary(String packageName);

    /**
     * Takes the shared memory region containing read-only relocations, to save memory after loading
     * the native library in the child process.
     * @param bundle potentially holds the description of the shared memory region transferred
     * between processes from one {@link org.chromium.base.library_loader.Linker} to another.
     */
    void consumeRelroBundle(Bundle bundle);

    /**
     * Should return a map that associatesfile descriptors' IDs to keys.
     * This is needed as at the moment we use 2 different stores for the FDs in native code:
     * base::FileDescriptorStore which associates FDs with string identifiers (the key), and
     * base::GlobalDescriptors which associates FDs with int ids.
     * FDs for which the returned map contains a mapping are added to base::FileDescriptorStore with
     * the associated key, all others are added to base::GlobalDescriptors.
     */
    SparseArray<String> getFileDescriptorsIdsToKeys();

    /** Called before the main method is invoked. */
    void onBeforeMain();

    /**
     * The main entry point for the service. This method should block as long as the service should
     * be running.
     */
    void runMain();
}