# cPanel API 2 Functions - LangMods::pre_run

Warning:
The cPanel API 2 system is deprecated. We **strongly** recommend that you use [UAPI](/cpanel/introduction) instead of cPanel API 2.

## Description

This function updates the indexes and actions for a cPanel-supported language.

Warning:
We **strongly** recommend that you use [UAPI](/cpanel/introduction/) instead of cPanel API 2. However, no equivalent UAPI function exists.

Note:
We recommend that you run this function after you run cPanel API 2's [`LangMods::setup`](/cpanel-api-2/cpanel-api-2-modules-langmods/cpanel-api-2-functions-langmods-setup) function.

## Examples

WHM API (JSON)


```undefined syntaxhighlighter-pre
https://hostname.example.com:2087/cpsess##########/json-api/cpanel?cpanel_jsonapi_user=user&cpanel_jsonapi_apiversion=2&cpanel_jsonapi_module=LangMods&cpanel_jsonapi_func=pre_run&lang=perl
```

Note:
For more information, read our [Calls from the WHM API](/whm/use-whm-api-to-call-cpanel-api-and-uapi) documentation.

LiveAPI PHP Class


```undefined syntaxhighlighter-pre
my $cpliveapi = Cpanel::LiveAPI->new(); # Connect to cPanel - only do this once.

# Retrieve magic status for perl on example.com.
my $get_magic_status = $cpliveapi->api2(
    'LangMods', 'pre_run',
        array(
        'lang'          => 'perl',
        )
  );
```

Note:
For more information, read our [Guide to the LiveAPI System](/guides/guide-to-the-liveapi-system/#guide-to-the-liveapi-system).

LiveAPI Perl Module


```undefined syntaxhighlighter-pre
$cpanel = new CPANEL(); // Connect to cPanel - only do this once.

// Retrieve magic status for perl on example.com.
$get_magic_status = $cpanel->api2(
    'LangMods', 'pre-run',
    {
        'lang'      => 'perl',
    }
 );
```

Note:
For more information, read our [Guide to the LiveAPI System](/guides/guide-to-the-liveapi-system/#guide-to-the-liveapi-system).

cPanel Tag System (deprecated)

Warnings:
- cPanel tags are **deprecated**. We **strongly** recommend that you **only** use the [LiveAPI](/guides/guide-to-the-liveapi-system) system to call the cPanel APIs. Examples are **only** present in order to help developers move from the old cPanel tag system to our [LiveAPI](/guides/guide-to-the-liveapi-system).
- cPanel API 2 calls that use cPanel tags vary in code syntax and in their output.
- For more information, read our [Deprecated cPanel Tag Usage](/cpanel-api-2/cpanel-api-2-deprecate-cpanel-tag-usage/) documentation.


Command Line


```undefined syntaxhighlighter-pre
cpapi2 --user=username LangMods pre_run lang=perl
```

div
Notes:

- You **must** URI-encode values.
- `username` represents your account-level username.
- You **must** include the `--user=username` option.
- For more information and additional output options, read our [Guide to cPanel API 2](/cpanel-api-2/) documentation or run the `cpapi2 --help` command.
- If you run CloudLinux™, you **must** use the full path of the `cpapi2` command:

```undefined syntaxhighlighter-pre
/usr/local/cpanel/bin/cpapi2
```


br
Output (JSON)


```undefined syntaxhighlighter-pre
{  
   "cpanelresult":{  
      "apiversion":2,
      "func":"pre_run",
      "data":[  
         {  
            "status":1,
            "result":"Updating channel \"pear.php.net\"\nChannel \"pear.php.net\" is up to date\n"
         }
      ],
      "event":{  
         "result":1
      },
      "module":"LangMods"
   }
}
```

Note:
Use cPanel's *[API Shell](https://docs.cpanel.net/cpanel/advanced/api-shell-for-cpanel)* interface (*cPanel >> Home >> Advanced >> API Shell*) to directly test cPanel API calls.

## Parameters

table
thead
tr
th
Parameter
th
Type
th
Description
th
Possible values
th
Example
tbody
tr
td
code
lang
td
em
string
td
p
strong
Required
p
The scripting language's short name.
td
p
An available scripting language's short name.
p
The 
a
code
LangMods::langlist
 function returns possible values.
td
code
perl
## Returns

table
thead
tr
th
strong
Return
th
strong
bType
th
strong
Description
th
strong
Possible values
th
strong
Example
tbody
tr
td
code
status
td
em
Boolean
td
p
Whether the function succeeded.
td
ul
li
code
1
 — The function succeeded.
li
code
0
 — The function failed.
td
code
1
tr
td
code
result
td
em
string
td
The action that the system performed.
td
A string value.
td
code
Updating channel \
"
pear.php.net\
"
\nChannel \
"
pear.php.net\
"
 is up to date\n
tr
td
code
reason
td
em
string
td
p
A reason for failure.
p
This function only returns a value if there was an error.
td
span
A string that describes the error.
td
code
This is an error message.
tr
td
code
result
td
em
Boolean
td
p
Whether the function succeeded.
td
ul
li
code
1
 — The function succeeded.
li
code
0
 — The function failed.
td
code
1