🔥 Midjourney API
TT API's Midjourney API is the most stable and cost-effective Midjourney API
Mode
The Midjourney service of TT API supports three modes, fast
, relax
and turbo
.
- Fast mode response time is within 90 seconds
- Relax mode response generally within 10 minutes, depending on the official response
- Turbo mode response time is within 60 seconds
Queue Jobs
The max job in progressing is 10, get more job in progress please contact us
Generate[ /imagine ]
POST
{Domain}/midjourney/v1/imagine
--cref operation must be used with --v 6.0 model
The domain of hold account mode is different from the PPU mode
The imagine endpoint generates up to 4 images from a text prompt. And you can checkout the domain here
Same with the /imagine
command in the midjourney
Headers
Name | Type | Description |
---|---|---|
TT-API-KEY* | String | Your API Key in TT API used for request authorization |
Request Body
Name | Type | Required | Description |
---|---|---|---|
prompt | String | true | Prompt use to generate image. exp: a cat --ar 1:1 |
hookUrl | String | false | Send a request to the address for task completion or failed notification. If not set you need to request fetch endpoint to get result |
mode | String | false | The task mode for generating images, including fast , relax and turbo . If not filled in, the fast mode will be used by default. |
timeout | Int | false | Queue timeout, unit: seconds. limits 300 - 1200. the default timeout is 300 seconds for fast and turbo modeAnd default timeout is 600 seconds for relax mode |
getUImages | Boolean | false | Whether to obtain four small pictures. The optional values are true and false . Default is false . Note: This operation does not actually means U operation on the generated task. |
Example Request
import requests
endpoint = "https://api.ttapi.io/midjourney/v1/imagine"
headers = {
"TT-API-KEY": your_key
}
data = {
"prompt": "a cute cat",
"model": "fast",
"hookUrl": ""
}
response = requests.post(endpoint, headers=headers, json=data)
print(response.status_code)
print(response.json())
Example Response
{
"status": "SUCCESS",
"message": "",
"data": {
"jobId": "afa774a3-1aee-5aba-4510-14818d6875e4"
}
}
Action[ U1-U4 V1-V4...]
POST
{Domain}/midjourney/v1/action
This endpoint integrates all button operations of midjourney, and uses the jobId returned in the previous step to determine which task to operate. For details on supported enums. And you can checkout the domain here
Headers
Name | Type | Description |
---|---|---|
TT-API-KEY* | String | Your API Key in TT API used for request authorization |
Request Body
Name | Type | Required | Description |
---|---|---|---|
jobId | String | true | The jobId in prev request |
action | String | true | Action you need Eg: upsample1 means U1 variation1 means V1 For more please refer to |
hookUrl | String | false | Send a request to the address for task completion or failed notification. If not set you need to request fetch endpoint to get response |
timeout | Int | false | Request timeout, unit: seconds. If not filled in, the default timeout is 300 seconds |
getUImages | Boolean | false | Whether to obtain four small pictures. The optional values are true and false . Default is false . Note: This operation does not actually means U operation on the generated task. |
Example Request
import requests
endpoint = "https://api.ttapi.io/midjourney/v1/action"
headers = {
"TT-API-KEY": your_key
}
data = {
"jobId": "afa774a3-1aee-5aba-4510-14818d6875e4",
"action": "upsample1",
"hookUrl": ""
}
response = requests.post(endpoint, headers=headers, json=data)
print(response.status_code)
print(response.json())
Example Response
{
"status": "SUCCESS",
"message": "",
"data": {
"jobId": "afa774a3-1aee-5aba-4510-14818d6875e4"
}
}
Seeds[ --seed ]
POST
{Domain}/midjourney/v1/seed
Get the seeds
form midjourney image, refer to the midjourney's docs (opens in a new tab) for usage. And you can checkout the domain here
Headers
Name | Type | Description |
---|---|---|
TT-API-KEY* | String | Your API Key in TT API used for request authorization |
Request Body
Name | Type | Required | Description |
---|---|---|---|
jobId | String | true | The jobId in prev request |
hookUrl | String | false | Send a request to the address for task completion or failed notification. If not set you need to request fetch endpoint to get response |
timeout | Int | false | Request timeout, unit: seconds. If not filled in, the default timeout is 300 seconds |
Example Request
import requests
endpoint = "https://api.ttapi.io/midjourney/v1/seed"
headers = {
"TT-API-KEY": your_key
}
data = {
"jobId": "afa774a3-1aee-5aba-4510-14818d6875e4",
"hookUrl": ""
}
response = requests.post(endpoint, headers=headers, json=data)
print(response.status_code)
print(response.json())
Example Response
{
"status": "SUCCESS",
"message": "",
"data": {
"jobId": "afa774a3-1aee-5aba-4510-14818d6875e4"
}
}
Blend[ /blend ]
POST
{Domain}/midjourney/v1/blend
Upload 2-5 images and combine them into a new image based on the concept and aesthetic of each image. And you can checkout the domain here
Headers
Name | Type | Description |
---|---|---|
TT-API-KEY* | String | Your API Key in TT API used for request authorization |
Request Body
Name | Type | Required | Description |
---|---|---|---|
imgBase64Array | Array | true | Base64 array of images that will be used to generate mixed images Array length is 2-5 Eg: [ "", ""] |
dimensions | String | false | Scale of generated image, including PORTRAIT, SQUARE, LANDSCAPE. If not filled in, SQUARE is used by default.PORTRAIT corresponds to the ratio 2:3 SQUARE corresponding ratio 1:1 LANDSCAPE corresponds to a ratio of 3:2 |
mode | String | false | The task mode for generating images, including fast , relax and turbo . If not filled in, the fast mode will be used by default. |
hookUrl | String | false | Send a request to the address for task completion or failed notification. If not set you need to request fetch endpoint to get response |
timeout | Int | false | Request timeout, unit: seconds. If not filled in, the default timeout is 300 seconds |
Example Request
import requests
endpoint = "https://api.ttapi.io/midjourney/v1/blend"
headers = {
"TT-API-KEY": your_key
}
data = {
"imgBase64Array": ["",""],
"dimensions": "SQUARE",
"mode": "fast",
"hookUrl": ""
}
response = requests.post(endpoint, headers=headers, json=data)
print(response.status_code)
print(response.json())
Example Response
{
"status": "SUCCESS",
"message": "",
"data": {
"jobId": "afa774a3-1aee-5aba-4510-14818d6875e4"
}
Describe[ /describe ]
POST
{Domain}/midjourney/v1/describe
Upload an image and generate four prompts based on the image. And you can checkout the domain here
Headers
Name | Type | Description |
---|---|---|
TT-API-KEY* | String | Your API Key in TT API used for request authorization |
Request Body
Name | Type | Required | Description |
---|---|---|---|
base64 | String | true | base64 encoding of image Eg:  |
String | false | fast , relax and turbo . If not filled in, the fast mode will be used by default. | |
hookUrl | String | false | Send a request to the address for task completion or failed notification. If not set you need to request fetch endpoint to get response |
timeout | Int | false | Request timeout, unit: seconds. If not filled in, the default timeout is 300 seconds |
Example Request
import requests
endpoint = "https://api.ttapi.io/midjourney/v1/blend"
headers = {
"TT-API-KEY": your_key
}
data = {
"base64": ,
"mode": "fast",
"hookUrl": ""
}
response = requests.post(endpoint, headers=headers, json=data)
print(response.status_code)
print(response.json())
Example Response
{
"status": "SUCCESS",
"message": "",
"data": {
"jobId": "afa774a3-1aee-5aba-4510-14818d6875e4"
}
Inpaint[ Vary(region) ]
POST
{Domain}/midjourney/v1/inpaint
Partial modifies of the image. And you can checkout the domain here
Headers
Name | Type | Description |
---|---|---|
TT-API-KEY* | String | Your API Key in TT API used for request authorization |
Request Body
Name | Type | Required | Description |
---|---|---|---|
jobId | String | true | The jobId in prev request |
mask | String | true | The base64 content is a black and white film of the same size as the original image. The white part is the circled part of the redrawn image, and the rest is black. and not contains 'data:image/png;base64' |
prompt | String | false | Drawing prompt for selected areas |
hookUrl | String | false | Send a request to the address for task completion or failed notification. If not set you need to request fetch endpoint to get response |
timeout | Int | false | Request timeout, unit: seconds. If not filled in, the default timeout is 300 seconds |
Example Request
import requests
endpoint = "https://api.ttapi.io/midjourney/v1/inpaint"
headers = {
"TT-API-KEY": your_key
}
data = {
"jobId": "afa774a3-1aee-5aba-4510-14818d6875e4",
"prompt": "white background",
"mask": "UklGRrw0AABXRUJQVlA4WAoAAAAgAAAA..."
"hookUrl": ""
}
response = requests.post(endpoint, headers=headers, json=data)
print(response.status_code)
print(response.json())
Example Response
{
"status": "SUCCESS",
"message": "",
"data": {
"jobId": "afa774a3-1aee-5aba-4510-14818d6875e4"
}
}
Fetch Job
GET/POST
{Domain}/midjourney/v1/fetch
to fetch the job result, Be careful not to request this interface with high concurrency to avoid being mistaken for an attack..
And you can checkout the domain here
Headers
Name | Type | Description |
---|---|---|
TT-API-KEY* | String | Your API Key in TT API used for request authorization |
Request Body / Query params
Name | Type | Required | Description |
---|---|---|---|
jobId | String | true | The jobId in prev request |
Example Request
import requests
endpoint = "https://api.ttapi.io/midjourney/v1/fetch"
headers = {
"TT-API-KEY": your_key
}
data = {
"jobId": "afa774a3-1aee-5aba-4510-14818d6875e4",
}
response = requests.post(endpoint, headers=headers, json=data)
print(response.status_code)
print(response.json())
Example Response
The result returned by the fetch endpoint has the same data structure as the result returned by hookUrl, as follows
Prompt Checker
POST
https://api.ttapi.io/midjourney/v1/promptCheck
Check whether the prompt is compliant. This endpoint is a free endpoint.
Headers
Name | Type | Description |
---|---|---|
TT-API-KEY* | String | Your API Key in TT API used for request authorization |
Request Body
Name | Type | Required | Description |
---|---|---|---|
prompt | String | true | sexy girl |
Example Request
import requests
endpoint = "https://api.ttapi.io/midjourney/v1/promptCheck"
headers = {
"TT-API-KEY": your_key
}
data = {
"prompt": "sexy girl",
}
response = requests.post(endpoint, headers=headers, json=data)
print(response.status_code)
print(response.json())
Example Response
{
"status": "SUCCESS", // SUCCESS or FAILED
"message": "success",
"data": "Prompt verification successful."
}
Async callback & fetch json
{
"status": "SUCCESS",
"jobId": "f5850038-90a3-8a97-0476-107ea4b8dac4",
"message": "success",
"data": {
"actions": "imagine",
"jobId": "f5850038-90a3-8a97-0476-107ea4b8dac4",
"progress": "100",
"prompt": "Soccer star Max Kruse and Jan-Peter Jachtmann victims of €528,695 poker scam, German soccer star Max Kruse and WSOP Main Event finalist Jan-Peter Jachtmann are among the players who have been swindled out of €528,695., poker, realistic --ar 1280:720",
"discordImage": "https://cdn.discordapp.com/attachments/1107938555931656214/1176340921227423844/voyagel_Soccer_star_Max_Kruse_and_Jan-Peter_Jachtmann_victims_o_c513a87b-eed3-4a3b-ab97-6be4dbc3ea99.png?ex=656e83da&is=655c0eda&hm=6e06a1dec3c6c1be209799884681969878eabb81ce81f8db22d54480379fcd9b&",
"cdnImage": "http://127.0.0.1/8080/pics/452020f2-6793-4525-a1b5-472cac439610.png",
"width": 1632,
"height": 2912,
"hookUrl": "",
"components": [
"upsample1",
"upsample2",
"upsample3",
"upsample4",
"variation1",
"variation2",
"variation3",
"variation4"
],
"seed":"",
"images":[
"https://cdnb.ttapi.io/2024-04-02/27024084bcd54b1c38d085d11d8dc841037a2262ebeda29b3f67b741441f6736.png",
"https://cdnb.ttapi.io/2024-04-02/e15e39f6eb39191fdf3f176f8c979b6e57254114a8bfea826e30f23850d0d485.png",
"https://cdnb.ttapi.io/2024-04-02/4b7910497a0d79d0155cd8b33eea313425cf2b809efef4b6ba3960aa1c2bd484.png",
"https://cdnb.ttapi.io/2024-04-02/98b162a1da713eef23c3cfd5f166aee8e4ee09f8cf1f7bbc24bf72990eb80adf.png"
],
"quota": 3
}
}
Return body description
Starting from December 1, 2023, the cdn image link returned by discord will expire after in 24 - 72 hours.
name | value |
---|---|
status | PENDING_QUEUE ON_QUEUE SUCCESS FAILED |
progess | Completeness : 0-100 |
components | allow the 'action params' in next action endpoint |
discordImage | Discord cdn image url |
images | CDN address of TTAPI, four small pictures generated by the imagine command.TTAPI will be kept for at least one month without expiration. |
Action Used In action endpoint
For specific usage of related operations, you can read Midjourney’s official doc (opens in a new tab) in detail.
action | description |
---|---|
upsample1 | Button UI - U4 Same as upsample2, upsample3, upsample4 |
variation1 | Button VI - V4 Same as variation2, variation3, variation4 |
high_variation | Button Vary (Strong) Make drastic changes to your image |
low_variation | Button Vary (Subtle) Make small changes to the image |
upscale2 | Button **Upscale(2x) ** Image magnification 2 times |
upscale4 | Button **Upscale(4x) ** Image magnification 4 times |
zoom_out_2 | Button Zoom Out 2x The Zoom Out option expands the canvas of the enlarged image without changing the original image, filling the new space based on the prompt and the initial image. |
zoom_out_1_5 | Button Zoom Out 1.5x The Zoom Out option expands the canvas of the enlarged image without changing the original image, filling the new space based on the prompt and the initial image. |
pan_left | Button ⬅️➡️⬆️⬇️ Same as pan_right, pan_up, pan_down |
upscale_creative | Button Upscale(Creative) Only exists in v6 mode |
upscale_subtle | Button Upscale(Subtle) Only exists in v6 mode |
reroll | Button 🔄 Regenerate image |
redo_upscale2 | Button Redo Upscale(2x) Re-execute the image magnification 2 times |
redo_upscale4 | Button Redo Upscale(4x) Re-execute the image magnification 4 times |
make_square | Button Make Square Change the image to a square image |
redo_upscale_subtle | Button Redo Upscale(Subtle) Re-execute Upscale(Subtle) Only exists in v6 mode |
redo_upscale_creative | Button Redo Upscale(Creative) Re-execute Upscale(Creative) Only exists in v6 mode |