{
  "openapi": "3.0.1",
  "info": {
    "title": "EU Academic Jobs: PhD, Postdoc & Research Positions",
    "description": "All PhD, postdoc, professor, and research positions from 5 major EU portals — EURES, DAAD, EuroScienceJobs, UniversityPositions, INOMICS — in one deduplicated dataset. Keyword, country, and date filters; academic-only mode drops corporate noise. Weekly scheduled runs surface only new postings.",
    "version": "1.0",
    "x-build-id": "ADVTFk7oQtKDcYhMO"
  },
  "servers": [
    {
      "url": "https://api.apify.com/v2"
    }
  ],
  "paths": {
    "/acts/scholarstack~eu-academic-research-jobs-aggregator/run-sync-get-dataset-items": {
      "post": {
        "operationId": "run-sync-get-dataset-items-scholarstack-eu-academic-research-jobs-aggregator",
        "x-openai-isConsequential": false,
        "summary": "Executes an Actor, waits for its completion, and returns Actor's dataset items in response.",
        "tags": [
          "Run Actor"
        ],
        "requestBody": {
          "required": true,
          "content": {
            "application/json": {
              "schema": {
                "$ref": "#/components/schemas/inputSchema"
              }
            }
          }
        },
        "parameters": [
          {
            "name": "token",
            "in": "query",
            "required": true,
            "schema": {
              "type": "string"
            },
            "description": "Enter your Apify token here"
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    },
    "/acts/scholarstack~eu-academic-research-jobs-aggregator/runs": {
      "post": {
        "operationId": "runs-sync-scholarstack-eu-academic-research-jobs-aggregator",
        "x-openai-isConsequential": false,
        "summary": "Executes an Actor and returns information about the initiated run in response.",
        "tags": [
          "Run Actor"
        ],
        "requestBody": {
          "required": true,
          "content": {
            "application/json": {
              "schema": {
                "$ref": "#/components/schemas/inputSchema"
              }
            }
          }
        },
        "parameters": [
          {
            "name": "token",
            "in": "query",
            "required": true,
            "schema": {
              "type": "string"
            },
            "description": "Enter your Apify token here"
          }
        ],
        "responses": {
          "200": {
            "description": "OK",
            "content": {
              "application/json": {
                "schema": {
                  "$ref": "#/components/schemas/runsResponseSchema"
                }
              }
            }
          }
        }
      }
    },
    "/acts/scholarstack~eu-academic-research-jobs-aggregator/run-sync": {
      "post": {
        "operationId": "run-sync-scholarstack-eu-academic-research-jobs-aggregator",
        "x-openai-isConsequential": false,
        "summary": "Executes an Actor, waits for completion, and returns the OUTPUT from Key-value store in response.",
        "tags": [
          "Run Actor"
        ],
        "requestBody": {
          "required": true,
          "content": {
            "application/json": {
              "schema": {
                "$ref": "#/components/schemas/inputSchema"
              }
            }
          }
        },
        "parameters": [
          {
            "name": "token",
            "in": "query",
            "required": true,
            "schema": {
              "type": "string"
            },
            "description": "Enter your Apify token here"
          }
        ],
        "responses": {
          "200": {
            "description": "OK"
          }
        }
      }
    }
  },
  "components": {
    "schemas": {
      "inputSchema": {
        "type": "object",
        "properties": {
          "keywords": {
            "title": "Keywords",
            "type": "array",
            "description": "Search keywords. Multiple keywords are combined with OR — a job matching ANY keyword is kept (e.g. ['biology', 'chemistry'] returns biology OR chemistry jobs). Use a multi-word entry like 'machine learning' to match that phrase. Matching is done by each portal's own search engine, so results are relevance-ranked rather than requiring the exact word in the title. Leave empty to return all jobs.",
            "default": [
              "research"
            ],
            "items": {
              "type": "string"
            }
          },
          "countries": {
            "title": "Countries",
            "type": "array",
            "description": "ISO-2 country codes to filter by (e.g. ['DE', 'NL', 'FR']). Leave empty for all EU countries. Supported: DE, NL, FR, AT, CH, BE, SE, DK, FI, NO, IT, ES, PL, CZ, HU, PT, IE, GR, RO, SK, SI, HR, LU, EE, LV, LT, GB.",
            "default": [
              "DE"
            ],
            "items": {
              "type": "string"
            }
          },
          "translateKeywords": {
            "title": "Auto-translate keywords",
            "type": "boolean",
            "description": "When enabled, your keywords are automatically expanded into their equivalents in the languages of the countries you select — e.g. 'research' also matches 'recherche' (FR), 'Forschung' (DE), 'onderzoek' (NL), 'ricerca' (IT), 'investigación' (ES). This surfaces local-language postings an English-only search would miss (jobs in France jumped from 2 to 100+ in testing). Recognised terms include research, researcher, postdoc, PhD, professor, scientist, and the main fields (biology, chemistry, physics, etc.); unrecognised keywords are searched as-is. Turn off for exact-keyword matching only.",
            "default": true
          },
          "euresKeywordScope": {
            "title": "EURES keyword scope",
            "enum": [
              "title",
              "everywhere"
            ],
            "type": "string",
            "description": "How EURES matches your keywords. 'Title only' (recommended) returns only jobs with the keyword in the job title — far more relevant. 'Everywhere' matches the keyword anywhere in the listing (title, description, employer name), returning many more but loosely-related / noisy results (e.g. 'machine learning' matches 200,000+ jobs). Only affects the EURES source; the other portals are already topic-specific.",
            "default": "title"
          },
          "academicOnly": {
            "title": "Academic positions only",
            "type": "boolean",
            "description": "If enabled, results are post-filtered to keep only jobs whose title or institution suggests an academic / research role (PhD, postdoc, researcher, professor, university, Max Planck, Helmholtz, CNRS, etc.). Recommended ON — otherwise EURES will return corporate R&D and unrelated jobs.",
            "default": true
          },
          "maxResultsPerSource": {
            "title": "Max results per source",
            "minimum": 1,
            "maximum": 5000,
            "type": "integer",
            "description": "Maximum number of results to collect from each source portal (applied after the academic filter). Raise this to get more results — portals like EURES have thousands of listings. Note: the total a portal shows on its website is unfiltered; with 'Academic positions only' on, the actual academic count is much lower.",
            "default": 300
          },
          "maxTotalResults": {
            "title": "Max total results (overall cap)",
            "minimum": 0,
            "type": "integer",
            "description": "Global cap across all sources after dedup. Set to 0 for no overall cap.",
            "default": 0
          },
          "enabledSources": {
            "title": "Enabled sources",
            "type": "array",
            "description": "Which source portals to scrape. Valid values: eures, daad, eurosciencejobs, universitypositions, inomics.",
            "default": [
              "eures",
              "daad",
              "eurosciencejobs",
              "universitypositions",
              "inomics"
            ],
            "items": {
              "type": "string"
            }
          },
          "postedWithinDays": {
            "title": "Posted within days",
            "minimum": 0,
            "type": "integer",
            "description": "Only return jobs posted within this many days. Set to 0 to disable filtering. Applied across all sources where a postedDate is available.",
            "default": 0
          },
          "incrementalMode": {
            "title": "Incremental mode",
            "type": "boolean",
            "description": "If enabled, only returns jobs not seen in previous runs. Uses a key-value store to track seen jobs across runs.",
            "default": false
          },
          "proxyConfiguration": {
            "title": "Proxy configuration",
            "type": "object",
            "description": "Optional Apify proxy settings. Recommended when running large crawls to avoid IP-based rate limiting on INOMICS and EuroScienceJobs.",
            "default": {
              "useApifyProxy": false
            }
          },
          "debug": {
            "title": "Debug logging",
            "type": "boolean",
            "description": "Show detailed diagnostic logs (per-request URLs, page-by-page progress). Off by default to keep the run log clean. Enable only for troubleshooting.",
            "default": false
          }
        }
      },
      "runsResponseSchema": {
        "type": "object",
        "properties": {
          "data": {
            "type": "object",
            "properties": {
              "id": {
                "type": "string"
              },
              "actId": {
                "type": "string"
              },
              "userId": {
                "type": "string"
              },
              "startedAt": {
                "type": "string",
                "format": "date-time",
                "example": "2025-01-08T00:00:00.000Z"
              },
              "finishedAt": {
                "type": "string",
                "format": "date-time",
                "example": "2025-01-08T00:00:00.000Z"
              },
              "status": {
                "type": "string",
                "example": "READY"
              },
              "meta": {
                "type": "object",
                "properties": {
                  "origin": {
                    "type": "string",
                    "example": "API"
                  },
                  "userAgent": {
                    "type": "string"
                  }
                }
              },
              "stats": {
                "type": "object",
                "properties": {
                  "inputBodyLen": {
                    "type": "integer",
                    "example": 2000
                  },
                  "rebootCount": {
                    "type": "integer",
                    "example": 0
                  },
                  "restartCount": {
                    "type": "integer",
                    "example": 0
                  },
                  "resurrectCount": {
                    "type": "integer",
                    "example": 0
                  },
                  "computeUnits": {
                    "type": "integer",
                    "example": 0
                  }
                }
              },
              "options": {
                "type": "object",
                "properties": {
                  "build": {
                    "type": "string",
                    "example": "latest"
                  },
                  "timeoutSecs": {
                    "type": "integer",
                    "example": 300
                  },
                  "memoryMbytes": {
                    "type": "integer",
                    "example": 1024
                  },
                  "diskMbytes": {
                    "type": "integer",
                    "example": 2048
                  }
                }
              },
              "buildId": {
                "type": "string"
              },
              "defaultKeyValueStoreId": {
                "type": "string"
              },
              "defaultDatasetId": {
                "type": "string"
              },
              "defaultRequestQueueId": {
                "type": "string"
              },
              "buildNumber": {
                "type": "string",
                "example": "1.0.0"
              },
              "containerUrl": {
                "type": "string"
              },
              "usage": {
                "type": "object",
                "properties": {
                  "ACTOR_COMPUTE_UNITS": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATASET_READS": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATASET_WRITES": {
                    "type": "integer",
                    "example": 0
                  },
                  "KEY_VALUE_STORE_READS": {
                    "type": "integer",
                    "example": 0
                  },
                  "KEY_VALUE_STORE_WRITES": {
                    "type": "integer",
                    "example": 1
                  },
                  "KEY_VALUE_STORE_LISTS": {
                    "type": "integer",
                    "example": 0
                  },
                  "REQUEST_QUEUE_READS": {
                    "type": "integer",
                    "example": 0
                  },
                  "REQUEST_QUEUE_WRITES": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATA_TRANSFER_INTERNAL_GBYTES": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATA_TRANSFER_EXTERNAL_GBYTES": {
                    "type": "integer",
                    "example": 0
                  },
                  "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                    "type": "integer",
                    "example": 0
                  },
                  "PROXY_SERPS": {
                    "type": "integer",
                    "example": 0
                  }
                }
              },
              "usageTotalUsd": {
                "type": "number",
                "example": 0.00005
              },
              "usageUsd": {
                "type": "object",
                "properties": {
                  "ACTOR_COMPUTE_UNITS": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATASET_READS": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATASET_WRITES": {
                    "type": "integer",
                    "example": 0
                  },
                  "KEY_VALUE_STORE_READS": {
                    "type": "integer",
                    "example": 0
                  },
                  "KEY_VALUE_STORE_WRITES": {
                    "type": "number",
                    "example": 0.00005
                  },
                  "KEY_VALUE_STORE_LISTS": {
                    "type": "integer",
                    "example": 0
                  },
                  "REQUEST_QUEUE_READS": {
                    "type": "integer",
                    "example": 0
                  },
                  "REQUEST_QUEUE_WRITES": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATA_TRANSFER_INTERNAL_GBYTES": {
                    "type": "integer",
                    "example": 0
                  },
                  "DATA_TRANSFER_EXTERNAL_GBYTES": {
                    "type": "integer",
                    "example": 0
                  },
                  "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                    "type": "integer",
                    "example": 0
                  },
                  "PROXY_SERPS": {
                    "type": "integer",
                    "example": 0
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}