> For clean Markdown of any page, append .md to the page URL.
> For a complete documentation index, see https://partner.ninjatrader.com/llms.txt.
> For AI client integration (Claude Code, Cursor, etc.), connect to the MCP server at https://partner.ninjatrader.com/_mcp/server.

# Create Evaluation Users

POST https://live.tradovateapi.com/v1/user/createevaluationusers
Content-Type: application/json

### Batch create up to 100 Organization users at once.

<Info>Requests with `firstName` and `lastName` fields exceeding a combined 60 characters are rejected, despite each field individually allowing up to 64 characters.</Info>

A higher level B2B Partner operation that can help to greatly reduce your application's API usage footprint. This call is able to batch the functionality of several calls at once for each EvaluationUser configuration object provided:
- Provide a `tradovateSubscriptionPlanId` integer value matching one of your Organization-specific Tradovate Subscription Plans to assign that membership to the created user without invoking an additional call.
- Provide an `entitlementIds` integer array to pre-assign entitlement subscriptions with matching IDs to the user. One common use case is to assign your Organization-specific TradingView addon for a user.

It is strongly advised to use this endpoint when creating new accounts to minimize API traffic.

***Note***: This endpoint replaces [/user/signUpOrganizationMember](/api/rest-api-endpoints/users/sign-up-organization-member), [/user/addTradovateSubscription](/api/rest-api-endpoints/users/add-tradovate-subscription), and [/userPlugin/addEntitlementSubscription](/api/rest-api-endpoints/users/add-entitlement-subscription).

Reference: https://partner.ninjatrader.com/eval/api/rest-api-endpoints/users/create-evaluation-users

## OpenAPI Specification

```yaml
openapi: 3.1.0
info:
  title: eval
  version: 1.0.0
paths:
  /user/createevaluationusers:
    post:
      operationId: create-evaluation-users
      summary: Create Evaluation Users
      description: >-
        ### Batch create up to 100 Organization users at once.


        <Info>Requests with `firstName` and `lastName` fields exceeding a
        combined 60 characters are rejected, despite each field individually
        allowing up to 64 characters.</Info>


        A higher level B2B Partner operation that can help to greatly reduce
        your application's API usage footprint. This call is able to batch the
        functionality of several calls at once for each EvaluationUser
        configuration object provided:

        - Provide a `tradovateSubscriptionPlanId` integer value matching one of
        your Organization-specific Tradovate Subscription Plans to assign that
        membership to the created user without invoking an additional call.

        - Provide an `entitlementIds` integer array to pre-assign entitlement
        subscriptions with matching IDs to the user. One common use case is to
        assign your Organization-specific TradingView addon for a user.


        It is strongly advised to use this endpoint when creating new accounts
        to minimize API traffic.


        ***Note***: This endpoint replaces
        [/user/signUpOrganizationMember](/api/rest-api-endpoints/users/sign-up-organization-member),
        [/user/addTradovateSubscription](/api/rest-api-endpoints/users/add-tradovate-subscription),
        and
        [/userPlugin/addEntitlementSubscription](/api/rest-api-endpoints/users/add-entitlement-subscription).
      tags:
        - subpackage_users
      parameters:
        - name: Authorization
          in: header
          description: Bearer authentication
          required: true
          schema:
            type: string
      responses:
        '200':
          description: CreateEvaluationUsersResponse
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/CreateEvaluationUsersResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/CreateEvaluationUsers'
servers:
  - url: https://live.tradovateapi.com/v1
    description: https://live.tradovateapi.com/v1
components:
  schemas:
    EvaluationUser:
      type: object
      properties:
        name:
          type: string
        email:
          type: string
        password:
          type: string
        firstName:
          type: string
        lastName:
          type: string
        tradovateSubscriptionPlanId:
          type: integer
          format: int64
        entitlementIds:
          type: array
          items:
            type: integer
            format: int64
      required:
        - name
        - email
        - password
        - firstName
        - lastName
      title: EvaluationUser
    CreateEvaluationUsers:
      type: object
      properties:
        users:
          type: array
          items:
            $ref: '#/components/schemas/EvaluationUser'
      required:
        - users
      title: CreateEvaluationUsers
    CreateEvaluationUserResponse:
      type: object
      properties:
        errorText:
          type: string
        userId:
          type: integer
          format: int64
      title: CreateEvaluationUserResponse
    CreateEvaluationUsersResponse:
      type: object
      properties:
        errorText:
          type: string
          description: Non-empty if the request failed
        results:
          type: array
          items:
            $ref: '#/components/schemas/CreateEvaluationUserResponse'
      required:
        - results
      title: CreateEvaluationUsersResponse
  securitySchemes:
    bearer_access_token:
      type: http
      scheme: bearer

```

## Examples



**Request**

```json
{
  "users": [
    {
      "name": "string",
      "email": "string",
      "password": "string",
      "firstName": "string",
      "lastName": "string"
    }
  ]
}
```

**Response**

```json
{
  "results": [
    {
      "errorText": "string",
      "userId": 1
    }
  ],
  "errorText": "string"
}
```

**SDK Code**

```python
import requests

url = "https://live.tradovateapi.com/v1/user/createevaluationusers"

payload = { "users": [
        {
            "name": "string",
            "email": "string",
            "password": "string",
            "firstName": "string",
            "lastName": "string"
        }
    ] }
headers = {
    "Authorization": "Bearer <token>",
    "Content-Type": "application/json"
}

response = requests.post(url, json=payload, headers=headers)

print(response.json())
```

```javascript
const url = 'https://live.tradovateapi.com/v1/user/createevaluationusers';
const options = {
  method: 'POST',
  headers: {Authorization: 'Bearer <token>', 'Content-Type': 'application/json'},
  body: '{"users":[{"name":"string","email":"string","password":"string","firstName":"string","lastName":"string"}]}'
};

try {
  const response = await fetch(url, options);
  const data = await response.json();
  console.log(data);
} catch (error) {
  console.error(error);
}
```

```go
package main

import (
	"fmt"
	"strings"
	"net/http"
	"io"
)

func main() {

	url := "https://live.tradovateapi.com/v1/user/createevaluationusers"

	payload := strings.NewReader("{\n  \"users\": [\n    {\n      \"name\": \"string\",\n      \"email\": \"string\",\n      \"password\": \"string\",\n      \"firstName\": \"string\",\n      \"lastName\": \"string\"\n    }\n  ]\n}")

	req, _ := http.NewRequest("POST", url, payload)

	req.Header.Add("Authorization", "Bearer <token>")
	req.Header.Add("Content-Type", "application/json")

	res, _ := http.DefaultClient.Do(req)

	defer res.Body.Close()
	body, _ := io.ReadAll(res.Body)

	fmt.Println(res)
	fmt.Println(string(body))

}
```

```ruby
require 'uri'
require 'net/http'

url = URI("https://live.tradovateapi.com/v1/user/createevaluationusers")

http = Net::HTTP.new(url.host, url.port)
http.use_ssl = true

request = Net::HTTP::Post.new(url)
request["Authorization"] = 'Bearer <token>'
request["Content-Type"] = 'application/json'
request.body = "{\n  \"users\": [\n    {\n      \"name\": \"string\",\n      \"email\": \"string\",\n      \"password\": \"string\",\n      \"firstName\": \"string\",\n      \"lastName\": \"string\"\n    }\n  ]\n}"

response = http.request(request)
puts response.read_body
```

```java
import com.mashape.unirest.http.HttpResponse;
import com.mashape.unirest.http.Unirest;

HttpResponse<String> response = Unirest.post("https://live.tradovateapi.com/v1/user/createevaluationusers")
  .header("Authorization", "Bearer <token>")
  .header("Content-Type", "application/json")
  .body("{\n  \"users\": [\n    {\n      \"name\": \"string\",\n      \"email\": \"string\",\n      \"password\": \"string\",\n      \"firstName\": \"string\",\n      \"lastName\": \"string\"\n    }\n  ]\n}")
  .asString();
```

```php
<?php
require_once('vendor/autoload.php');

$client = new \GuzzleHttp\Client();

$response = $client->request('POST', 'https://live.tradovateapi.com/v1/user/createevaluationusers', [
  'body' => '{
  "users": [
    {
      "name": "string",
      "email": "string",
      "password": "string",
      "firstName": "string",
      "lastName": "string"
    }
  ]
}',
  'headers' => [
    'Authorization' => 'Bearer <token>',
    'Content-Type' => 'application/json',
  ],
]);

echo $response->getBody();
```

```csharp
using RestSharp;

var client = new RestClient("https://live.tradovateapi.com/v1/user/createevaluationusers");
var request = new RestRequest(Method.POST);
request.AddHeader("Authorization", "Bearer <token>");
request.AddHeader("Content-Type", "application/json");
request.AddParameter("application/json", "{\n  \"users\": [\n    {\n      \"name\": \"string\",\n      \"email\": \"string\",\n      \"password\": \"string\",\n      \"firstName\": \"string\",\n      \"lastName\": \"string\"\n    }\n  ]\n}", ParameterType.RequestBody);
IRestResponse response = client.Execute(request);
```

```swift
import Foundation

let headers = [
  "Authorization": "Bearer <token>",
  "Content-Type": "application/json"
]
let parameters = ["users": [
    [
      "name": "string",
      "email": "string",
      "password": "string",
      "firstName": "string",
      "lastName": "string"
    ]
  ]] as [String : Any]

let postData = JSONSerialization.data(withJSONObject: parameters, options: [])

let request = NSMutableURLRequest(url: NSURL(string: "https://live.tradovateapi.com/v1/user/createevaluationusers")! as URL,
                                        cachePolicy: .useProtocolCachePolicy,
                                    timeoutInterval: 10.0)
request.httpMethod = "POST"
request.allHTTPHeaderFields = headers
request.httpBody = postData as Data

let session = URLSession.shared
let dataTask = session.dataTask(with: request as URLRequest, completionHandler: { (data, response, error) -> Void in
  if (error != nil) {
    print(error as Any)
  } else {
    let httpResponse = response as? HTTPURLResponse
    print(httpResponse)
  }
})

dataTask.resume()
```