.. _netscript_sleeveapi:

Netscript Sleeve API
=========================
Netscript provides the following API for interacting with the game's
:ref:`Duplicate Sleeve <gameplay_duplicatesleeves>` mechanic.

The Sleeve API is **not** immediately available to the player and must be unlocked
later in the game.

.. warning:: This page contains spoilers for the game

The Sleeve API is unlocked in BitNode-10. If you are in BitNode-10, you will
automatically gain access to this API. Otherwise, you must have Source-File 10 in
order to use this API in other BitNodes

**Sleeve API functions must be accessed through the 'sleeve' namespace**

In :ref:`netscript1`::

    sleeve.synchronize(0);
    sleeve.commitCrime(0, "shoplift");

In :ref:`netscriptjs`::

    ns.sleeve.synchronize(0);
    ns.sleeve.commitCrime(0, "shoplift");

.. toctree::
    :caption: API Functions:

    getNumSleeves() <sleeveapi/getNumSleeves>
    getSleeveStats() <sleeveapi/getSleeveStats>
    getInformation() <sleeveapi/getInformation>
    getTask() <sleeveapi/getTask>
    setToShockRecovery() <sleeveapi/setToShockRecovery>
    setToSynchronize() <sleeveapi/setToSynchronize>
    setToCommitCrime() <sleeveapi/setToCommitCrime>
    setToFactionWork() <sleeveapi/setToFactionWork>
    setToCompanyWork() <sleeveapi/setToCompanyWork>
    setToUniversityCourse() <sleeveapi/setToUniversityCourse>
    setToGymWorkout() <sleeveapi/setToGymWorkout>
    travel() <sleeveapi/travel>
    getSleeveAugmentations() <sleeveapi/getSleeveAugmentations>
    getSleevePurchasableAugs() <sleeveapi/getSleevePurchasableAugs>
    purchaseSleeveAug() <sleeveapi/purchaseSleeveAug>

.. _netscript_sleeveapi_referencingaduplicatesleeve:

Referencing a Duplicate Sleeve
------------------------------
Most of the functions in the Sleeve API perform an operation on a single Duplicate
Sleeve. In order to specify which Sleeve the operation should be performed on,
a numeric index is used as an identifier. The index should follow array-notation, such
that the first Duplicate Sleeve has an index of 0, the second Duplicate Sleeve has
an index of 1, and so on.

The order of the Duplicate Sleeves matches the order on the UI page.

Examples
--------

**Basic example usage**::

    for (var i = 0; i < sleeve.getNumSleeves(); i++) {
        sleeve.setToShockRecovery(i);
    }

    sleep(10 * 60 * 60); // wait 10h

    for (var i = 0; i < sleeve.getNumSleeves(); i++) {
        sleeve.setToSynchronize(i);
    }

    sleep(10*60*60); // wait 10h

    for (var i = 0; i < sleeve.getNumSleeves(); i++) {
        sleeve.setToCommitCrime(i, 'shoplift');
    }