Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .release-please-manifest.json
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
{
".": "0.2.2"
".": "0.3.0"
}
8 changes: 4 additions & 4 deletions .stats.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
configured_endpoints: 12
openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/parallel-web%2Fparallel-sdk-496d0afc77bafdc8f4208d3ddd767c3101d91ffb933b9b6bfcef5f489cc175a6.yml
openapi_spec_hash: 730e697fec302b9310d4495c1f82802d
config_hash: f9aa4d901581aaf70789dd0bc1b84597
configured_endpoints: 13
openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/parallel-web%2Fparallel-sdk-e853fc79f3b41f00b3934fcc2e4c2813aa9f38528548f5f596e2b11ea833019b.yml
openapi_spec_hash: 34ed7e373927037fce6fd33d9bb60389
config_hash: ae63572e3769dcd1b11e587f039e211a
13 changes: 13 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,18 @@
# Changelog

## 0.3.0 (2025-10-21)

Full Changelog: [v0.2.2...v0.3.0](https://github.com/parallel-web/parallel-sdk-python/compare/v0.2.2...v0.3.0)

### Features

* **api:** Add /v1beta/extract ([df40ff5](https://github.com/parallel-web/parallel-sdk-python/commit/df40ff551e5a5e91576066de4c8216e3bd7e1bb1))


### Chores

* bump `httpx-aiohttp` version to 0.1.9 ([4da4812](https://github.com/parallel-web/parallel-sdk-python/commit/4da4812c00f76d6613eb14b388b84171ceee074d))

## 0.2.2 (2025-10-16)

Full Changelog: [v0.2.1...v0.2.2](https://github.com/parallel-web/parallel-sdk-python/compare/v0.2.1...v0.2.2)
Expand Down
10 changes: 9 additions & 1 deletion api.md
Original file line number Diff line number Diff line change
Expand Up @@ -40,11 +40,19 @@ Convenience methods:
Types:

```python
from parallel.types.beta import SearchResult, WebSearchResult
from parallel.types.beta import (
ExcerptSettings,
ExtractError,
ExtractResponse,
ExtractResult,
SearchResult,
WebSearchResult,
)
```

Methods:

- <code title="post /v1beta/extract">client.beta.<a href="./src/parallel/resources/beta/beta.py">extract</a>(\*\*<a href="src/parallel/types/beta/beta_extract_params.py">params</a>) -> <a href="./src/parallel/types/beta/extract_response.py">ExtractResponse</a></code>
- <code title="post /v1beta/search">client.beta.<a href="./src/parallel/resources/beta/beta.py">search</a>(\*\*<a href="src/parallel/types/beta/beta_search_params.py">params</a>) -> <a href="./src/parallel/types/beta/search_result.py">SearchResult</a></code>

## TaskRun
Expand Down
4 changes: 2 additions & 2 deletions pyproject.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[project]
name = "parallel-web"
version = "0.2.2"
version = "0.3.0"
description = "The official Python library for the Parallel API"
dynamic = ["readme"]
license = "MIT"
Expand Down Expand Up @@ -39,7 +39,7 @@ Homepage = "https://github.com/parallel-web/parallel-sdk-python"
Repository = "https://github.com/parallel-web/parallel-sdk-python"

[project.optional-dependencies]
aiohttp = ["aiohttp", "httpx_aiohttp>=0.1.8"]
aiohttp = ["aiohttp", "httpx_aiohttp>=0.1.9"]

[tool.rye]
managed = true
Expand Down
2 changes: 1 addition & 1 deletion requirements-dev.lock
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ httpx==0.28.1
# via httpx-aiohttp
# via parallel-web
# via respx
httpx-aiohttp==0.1.8
httpx-aiohttp==0.1.9
# via parallel-web
idna==3.4
# via anyio
Expand Down
2 changes: 1 addition & 1 deletion requirements.lock
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ httpcore==1.0.9
httpx==0.28.1
# via httpx-aiohttp
# via parallel-web
httpx-aiohttp==0.1.8
httpx-aiohttp==0.1.9
# via parallel-web
idna==3.4
# via anyio
Expand Down
2 changes: 1 addition & 1 deletion src/parallel/_version.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.

__title__ = "parallel"
__version__ = "0.2.2" # x-release-please-version
__version__ = "0.3.0" # x-release-please-version
184 changes: 179 additions & 5 deletions src/parallel/resources/beta/beta.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,13 @@

from __future__ import annotations

from typing import Optional
from typing import List, Optional
from typing_extensions import Literal

import httpx

from ..._types import Body, Omit, Query, Headers, NotGiven, SequenceNotStr, omit, not_given
from ..._utils import maybe_transform, async_maybe_transform
from ..._utils import is_given, maybe_transform, strip_not_given, async_maybe_transform
from .task_run import (
TaskRunResource,
AsyncTaskRunResource,
Expand All @@ -33,9 +33,11 @@
async_to_raw_response_wrapper,
async_to_streamed_response_wrapper,
)
from ...types.beta import beta_search_params
from ...types.beta import beta_search_params, beta_extract_params
from ..._base_client import make_request_options
from ...types.beta.search_result import SearchResult
from ...types.beta.extract_response import ExtractResponse
from ...types.beta.parallel_beta_param import ParallelBetaParam
from ...types.shared_params.source_policy import SourcePolicy

__all__ = ["BetaResource", "AsyncBetaResource"]
Expand Down Expand Up @@ -69,15 +71,89 @@ def with_streaming_response(self) -> BetaResourceWithStreamingResponse:
"""
return BetaResourceWithStreamingResponse(self)

def extract(
self,
*,
urls: SequenceNotStr[str],
excerpts: beta_extract_params.Excerpts | Omit = omit,
fetch_policy: Optional[beta_extract_params.FetchPolicy] | Omit = omit,
full_content: beta_extract_params.FullContent | Omit = omit,
objective: Optional[str] | Omit = omit,
search_queries: Optional[SequenceNotStr[str]] | Omit = omit,
betas: List[ParallelBetaParam] | Omit = omit,
# Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
# The extra values given here take precedence over values defined on the client or passed to this method.
extra_headers: Headers | None = None,
extra_query: Query | None = None,
extra_body: Body | None = None,
timeout: float | httpx.Timeout | None | NotGiven = not_given,
) -> ExtractResponse:
"""
Extracts relevant content from specific web URLs.

To access this endpoint, pass the `parallel-beta` header with the value
`search-extract-2025-10-10`.

Args:
excerpts: Include excerpts from each URL relevant to the search objective and queries.
Note that if neither objective nor search_queries is provided, excerpts are
redundant with full content.

fetch_policy: Fetch policy.

Determines when to return content from the cache (faster) vs fetching live
content (fresher).

full_content: Include full content from each URL. Note that if neither objective nor
search_queries is provided, excerpts are redundant with full content.

objective: If provided, focuses extracted content on the specified search objective.

search_queries: If provided, focuses extracted content on the specified keyword search queries.

betas: Optional header to specify the beta version(s) to enable.

extra_headers: Send extra headers

extra_query: Add additional query parameters to the request

extra_body: Add additional JSON properties to the request

timeout: Override the client-level default timeout for this request, in seconds
"""
extra_headers = {
**strip_not_given({"parallel-beta": ",".join(str(e) for e in betas) if is_given(betas) else not_given}),
**(extra_headers or {}),
}
return self._post(
"/v1beta/extract",
body=maybe_transform(
{
"urls": urls,
"excerpts": excerpts,
"fetch_policy": fetch_policy,
"full_content": full_content,
"objective": objective,
"search_queries": search_queries,
},
beta_extract_params.BetaExtractParams,
),
options=make_request_options(
extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
),
cast_to=ExtractResponse,
)

def search(
self,
*,
max_chars_per_result: Optional[int] | Omit = omit,
max_results: Optional[int] | Omit = omit,
objective: Optional[str] | Omit = omit,
processor: Literal["base", "pro"] | Omit = omit,
processor: Optional[Literal["base", "pro"]] | Omit = omit,
search_queries: Optional[SequenceNotStr[str]] | Omit = omit,
source_policy: Optional[SourcePolicy] | Omit = omit,
betas: List[ParallelBetaParam] | Omit = omit,
# Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
# The extra values given here take precedence over values defined on the client or passed to this method.
extra_headers: Headers | None = None,
Expand Down Expand Up @@ -109,6 +185,8 @@ def search(

This policy governs which sources are allowed/disallowed in results.

betas: Optional header to specify the beta version(s) to enable.

extra_headers: Send extra headers

extra_query: Add additional query parameters to the request
Expand All @@ -117,6 +195,10 @@ def search(

timeout: Override the client-level default timeout for this request, in seconds
"""
extra_headers = {
**strip_not_given({"parallel-beta": ",".join(str(e) for e in betas) if is_given(betas) else not_given}),
**(extra_headers or {}),
}
return self._post(
"/v1beta/search",
body=maybe_transform(
Expand Down Expand Up @@ -165,15 +247,89 @@ def with_streaming_response(self) -> AsyncBetaResourceWithStreamingResponse:
"""
return AsyncBetaResourceWithStreamingResponse(self)

async def extract(
self,
*,
urls: SequenceNotStr[str],
excerpts: beta_extract_params.Excerpts | Omit = omit,
fetch_policy: Optional[beta_extract_params.FetchPolicy] | Omit = omit,
full_content: beta_extract_params.FullContent | Omit = omit,
objective: Optional[str] | Omit = omit,
search_queries: Optional[SequenceNotStr[str]] | Omit = omit,
betas: List[ParallelBetaParam] | Omit = omit,
# Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
# The extra values given here take precedence over values defined on the client or passed to this method.
extra_headers: Headers | None = None,
extra_query: Query | None = None,
extra_body: Body | None = None,
timeout: float | httpx.Timeout | None | NotGiven = not_given,
) -> ExtractResponse:
"""
Extracts relevant content from specific web URLs.

To access this endpoint, pass the `parallel-beta` header with the value
`search-extract-2025-10-10`.

Args:
excerpts: Include excerpts from each URL relevant to the search objective and queries.
Note that if neither objective nor search_queries is provided, excerpts are
redundant with full content.

fetch_policy: Fetch policy.

Determines when to return content from the cache (faster) vs fetching live
content (fresher).

full_content: Include full content from each URL. Note that if neither objective nor
search_queries is provided, excerpts are redundant with full content.

objective: If provided, focuses extracted content on the specified search objective.

search_queries: If provided, focuses extracted content on the specified keyword search queries.

betas: Optional header to specify the beta version(s) to enable.

extra_headers: Send extra headers

extra_query: Add additional query parameters to the request

extra_body: Add additional JSON properties to the request

timeout: Override the client-level default timeout for this request, in seconds
"""
extra_headers = {
**strip_not_given({"parallel-beta": ",".join(str(e) for e in betas) if is_given(betas) else not_given}),
**(extra_headers or {}),
}
return await self._post(
"/v1beta/extract",
body=await async_maybe_transform(
{
"urls": urls,
"excerpts": excerpts,
"fetch_policy": fetch_policy,
"full_content": full_content,
"objective": objective,
"search_queries": search_queries,
},
beta_extract_params.BetaExtractParams,
),
options=make_request_options(
extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
),
cast_to=ExtractResponse,
)

async def search(
self,
*,
max_chars_per_result: Optional[int] | Omit = omit,
max_results: Optional[int] | Omit = omit,
objective: Optional[str] | Omit = omit,
processor: Literal["base", "pro"] | Omit = omit,
processor: Optional[Literal["base", "pro"]] | Omit = omit,
search_queries: Optional[SequenceNotStr[str]] | Omit = omit,
source_policy: Optional[SourcePolicy] | Omit = omit,
betas: List[ParallelBetaParam] | Omit = omit,
# Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
# The extra values given here take precedence over values defined on the client or passed to this method.
extra_headers: Headers | None = None,
Expand Down Expand Up @@ -205,6 +361,8 @@ async def search(

This policy governs which sources are allowed/disallowed in results.

betas: Optional header to specify the beta version(s) to enable.

extra_headers: Send extra headers

extra_query: Add additional query parameters to the request
Expand All @@ -213,6 +371,10 @@ async def search(

timeout: Override the client-level default timeout for this request, in seconds
"""
extra_headers = {
**strip_not_given({"parallel-beta": ",".join(str(e) for e in betas) if is_given(betas) else not_given}),
**(extra_headers or {}),
}
return await self._post(
"/v1beta/search",
body=await async_maybe_transform(
Expand All @@ -237,6 +399,9 @@ class BetaResourceWithRawResponse:
def __init__(self, beta: BetaResource) -> None:
self._beta = beta

self.extract = to_raw_response_wrapper(
beta.extract,
)
self.search = to_raw_response_wrapper(
beta.search,
)
Expand All @@ -254,6 +419,9 @@ class AsyncBetaResourceWithRawResponse:
def __init__(self, beta: AsyncBetaResource) -> None:
self._beta = beta

self.extract = async_to_raw_response_wrapper(
beta.extract,
)
self.search = async_to_raw_response_wrapper(
beta.search,
)
Expand All @@ -271,6 +439,9 @@ class BetaResourceWithStreamingResponse:
def __init__(self, beta: BetaResource) -> None:
self._beta = beta

self.extract = to_streamed_response_wrapper(
beta.extract,
)
self.search = to_streamed_response_wrapper(
beta.search,
)
Expand All @@ -288,6 +459,9 @@ class AsyncBetaResourceWithStreamingResponse:
def __init__(self, beta: AsyncBetaResource) -> None:
self._beta = beta

self.extract = async_to_streamed_response_wrapper(
beta.extract,
)
self.search = async_to_streamed_response_wrapper(
beta.search,
)
Expand Down
Loading