# Moroccan Passport

```markdown
This API provides Data Extraction for Moroccan Travel Passport documents.
```

## <mark style="color:blue;">Moroccan Passport OCR</mark>

<mark style="color:green;">`POST`</mark> `https://valifystage.com/api/v1/ocr/`&#x20;

#### Headers

| Name           | Type   | Description            |
| -------------- | ------ | ---------------------- |
| Content-Type   | string | application/json       |
| Authentication | string | bearer \<access-token> |

#### Request Body

<table><thead><tr><th width="144.5999755859375">Name</th><th width="70.60003662109375">Type</th><th width="316.4000244140625">Description</th><th>Notes</th></tr></thead><tbody><tr><td>document_type</td><td>string</td><td>mar_passport</td><td></td></tr><tr><td>data</td><td>object</td><td>Object containing the parameters below:<br><code>{</code> <br>  <code>img: &#x3C;base64 str>,</code><br>  <code>bundle_key: &#x3C;str>,</code><br>  <code>lang: &#x3C;str></code> <br><code>}</code></td><td>Please note that<code>img</code> cannot be empty (i.e., missing or an empty string <code>""</code>).</td></tr></tbody></table>

**Status Codes**

{% tabs %}
{% tab title="✅200 Successful" %}

```python
{
    "result": {
        "first_name": {
            "arabic": <string>,
            "latin": <string>
        },
        "family_name": {
            "arabic": <string>,
            "latin": <string>
        },
        "nationality": {
            "arabic": <string>,
            "latin": <string>
        },
        "sex": <string>,
        "place_of_birth": <string>,
        "date_of_issue": <string>,
        "date_of_expiry": <string>,
        "authority": <string>,
        "residence": <string>,
        "date_of_birth": <string>,
        "type": <string>,
        "code": <string>,
        "passport_no": <string>,
        "id_card_no": <string>
    },
    "transaction_id": <string>,
    "trials_remaining": <int>
}
```

{% endtab %}

{% tab title="400 Missing input data" %}

```python
{
    "message": "Bad Request – invalid request received (e.g. missing Bundle key, required parameters or invalid json) | Make sure all the required parameters are included"
}
```

{% endtab %}

{% tab title="401 Invalid bundle key" %}

```python
{
    "message": "Unauthorized – your Bundle key is invalid"
}
```

{% endtab %}

{% tab title="403 Access token error" %}

```python
{
    "message": "Forbidden – specified access_token could not be found"
}
```

{% endtab %}

{% tab title="404 Check the endpoint" %}

```python
{
    "message": "Not Found"
}
```

{% endtab %}

{% tab title="415 The format should be base64" %}

```python
{
    "message": "Unsupported Media Type"
}
```

{% endtab %}

{% tab title="422 Check Valify error codes" %}

```python
{
    "message": "<error-description>",
    "error_code": <valify-error-code>
}
```

{% endtab %}

{% tab title="500 Contact us" %}

```python
{
    "message": "Internal Server Error"
}
```

{% endtab %}
{% endtabs %}

{% tabs %}
{% tab title="🐍Python" %}

```python
import requests
import base64

def base64_encode(file_name):
    with open(file_name, "rb") as image_file:
        encoded_string = base64.b64encode(image_file.read()).decode()
        return encoded_string
    return ""

front_image = base64_encode('<image path>') # Place your front image here
back_image = base64_encode('<image path>') # Place your back image here
token = "<token>" # Place your token here
data = {
    'document_type': 'mar_passport', 
    'data':
    {   
        'img': <'passport_base_64_img'>
        'bundle_key': '<bundle key>', # Place your bundle key here
        'lang': '<str>' # optional, default: en
    }
}

r = requests.post("https://<base-url>/api/v1/ocr/",
        json=data,
        headers={'Authorization': 'Bearer %s' % token}
    )
                      
print(r.json())
```

{% endtab %}
{% endtabs %}
