diff --git a/packages/dynamite/lib/src/openapi_builder.dart b/packages/dynamite/lib/src/openapi_builder.dart index ed26cdce..4cd6efe1 100644 --- a/packages/dynamite/lib/src/openapi_builder.dart +++ b/packages/dynamite/lib/src/openapi_builder.dart @@ -395,6 +395,12 @@ class OpenAPIBuilder implements Builder { ..type = refer('Map?') ..named = true, ), + Parameter( + (final b) => b + ..name = 'userAgent' + ..type = refer('String?') + ..named = true, + ), Parameter( (final b) => b ..name = 'httpClient' @@ -427,7 +433,7 @@ class OpenAPIBuilder implements Builder { }, ''' : ''} }; - this.httpClient = httpClient ?? HttpClient(); + this.httpClient = (httpClient ?? HttpClient())..userAgent = userAgent; '''), ), ) diff --git a/packages/nextcloud/lib/src/client.dart b/packages/nextcloud/lib/src/client.dart index 803bd6bd..4d924364 100644 --- a/packages/nextcloud/lib/src/client.dart +++ b/packages/nextcloud/lib/src/client.dart @@ -16,9 +16,9 @@ class NextcloudClient extends Client { 'OCS-APIRequest': 'true', 'Accept': 'application/json', 'Accept-Language': language, - 'User-Agent': userAgentOverride ?? appType.userAgent, }..removeWhere((final _, final value) => value == null)) .cast(), + userAgent: userAgentOverride ?? appType.userAgent, authentication: username != null && password != null ? HttpBasicAuthentication( username: username, diff --git a/packages/nextcloud/lib/src/nextcloud.openapi.dart b/packages/nextcloud/lib/src/nextcloud.openapi.dart index 5c4e956f..d61ca963 100644 --- a/packages/nextcloud/lib/src/nextcloud.openapi.dart +++ b/packages/nextcloud/lib/src/nextcloud.openapi.dart @@ -93,6 +93,7 @@ class Client { Client( this.baseURL, { Map? baseHeaders, + String? userAgent, HttpClient? httpClient, this.cookieJar, this.authentication, @@ -105,7 +106,7 @@ class Client { ...authentication!.headers, }, }; - this.httpClient = httpClient ?? HttpClient(); + this.httpClient = (httpClient ?? HttpClient())..userAgent = userAgent; } final String baseURL;