feat: Improve OAuth error handling and frontend sync behavior#10626
Conversation
|
Important Review skippedAuto incremental reviews are disabled on this repository. Please check the settings in the CodeRabbit UI or the You can disable this status message by setting the WalkthroughIntroduces MCP Composer orchestration with rollback safety, port management, and error handling across backend and frontend. Backend adds composer start/stop orchestration with auth settings rollback on failure, per-project error tracking, and robust process management with retry logic. Frontend adds OAuth auto-sync, per-project cache scoping, and loading state tracking for composer startup. Changes
Sequence DiagramsequenceDiagram
participant Client as Client/API
participant MCP_API as mcp_projects.py
participant Auth_DB as Auth Settings (DB)
participant Composer as MCP Composer Service
participant Process as OS Process
Client->>MCP_API: PATCH auth settings
MCP_API->>Auth_DB: Load original_auth_settings
Auth_DB-->>MCP_API: original_auth_settings
MCP_API->>Composer: start_project_composer(max_retries=3)
Note over Composer: Retry Loop (max_retries)
Composer->>Composer: _ensure_port_available()
alt Port Conflict
Composer->>Process: Kill existing process
Process-->>Composer: Killed
else Port Available
Composer->>Composer: Proceed
end
Composer->>Process: Start MCP process
alt Process Starts Successfully
Process-->>Composer: Process PID
Composer->>Composer: Register port/PID mapping
Composer-->>MCP_API: Success + URL
MCP_API->>Auth_DB: Commit auth settings
MCP_API-->>Client: 200 OK
else Process Fails
Process-->>Composer: Error
Composer->>Composer: Extract error message
Composer->>Composer: set_last_error(project_id, error_msg)
Composer-->>MCP_API: Error object
alt Max Retries Exceeded
MCP_API->>Auth_DB: Rollback to original_auth_settings
MCP_API-->>Client: 400 Error (with error details)
else Retry Available
Composer->>Process: Retry startup
end
end
Estimated code review effort🎯 4 (Complex) | ⏱️ ~60 minutes
Possibly related PRs
Suggested labels
Suggested reviewers
Pre-merge checks and finishing touchesImportant Pre-merge checks failedPlease resolve all errors before merging. Addressing warnings is optional. ❌ Failed checks (1 error, 3 warnings)
✅ Passed checks (3 passed)
Tip 📝 Customizable high-level summaries are now available in beta!You can now customize how CodeRabbit generates the high-level summary in your pull requests — including its content, structure, tone, and formatting.
Example instruction:
Note: This feature is currently in beta for Pro-tier users, and pricing will be announced later. Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out. Comment |
Codecov Report❌ Patch coverage is ❌ Your project status has failed because the head coverage (39.97%) is below the target coverage (60.00%). You can increase the head coverage or adjust the target coverage. Additional details and impacted files@@ Coverage Diff @@
## main #10626 +/- ##
==========================================
+ Coverage 31.51% 32.15% +0.64%
==========================================
Files 1364 1364
Lines 62085 62474 +389
Branches 9180 9249 +69
==========================================
+ Hits 19564 20090 +526
+ Misses 41604 41372 -232
- Partials 917 1012 +95
Flags with carried forward coverage won't be shown. Click here to find out more.
🚀 New features to boost your workflow:
|
There was a problem hiding this comment.
Actionable comments posted: 5
Caution
Some comments are outside the diff and can’t be posted inline due to platform limitations.
⚠️ Outside diff range comments (2)
src/lfx/src/lfx/services/mcp_composer/service.py (1)
74-98: Persistlast_errorfor all MCPComposer startup failures, not just port/startup retriesThe per-project
last_errortracking is a good addition, but currently it’s only updated in a few paths:
- When
_ensure_port_availableraisesMCPComposerPortError, you storeself._last_errors[project_id] = e.message.- When all retries in
_do_start_project_composerfail, you storeself._last_errors[project_id] = last_error.message.- On success you call
self.clear_last_error(project_id).However, several early failure paths in
_do_start_project_composerraiseMCPComposerConfigError(no auth settings, invalid/missing port, missing host, or_validate_oauth_settingsfailures) before any of those assignments, soget_last_errorwill remain unset or stale for those cases. That undermines the “persist MCP Composer service errors per project for UI display” goal.To make error reporting consistent, consider centralizing this in
start_project_composer:
- Wrap the
await self._do_start_project_composer(...)call in atry/except MCPComposerErrorblock.- In the
except, callself.set_last_error(project_id, e.message)and re-raise.- Inside
_do_start_project_composer, useset_last_errorrather than assigningself._last_errors[...]directly for the port/retry paths, and keepclear_last_erroron success.This way every
MCPComposerError, including configuration issues, reliably updateslast_errorfor theget_project_composer_urlendpoint to surface.Also applies to: 984-1015, 1050-1072, 1142-1157
src/frontend/src/controllers/API/queries/mcp/use-patch-flows-mcp.ts (1)
44-82: Fix options override so internal cache updates always run inusePatchFlowsMCPThe per-project mutation key and targeted invalidations look good, but the options wiring here is fragile:
const mutation = mutate(["usePatchFlowsMCP", params.project_id], patchFlowMCP, { onSuccess: (data, variables, context) => { /* internal updates */ }, onSettled: () => { /* invalidate per-project flows */ }, ...options, });Because
...optionscomes last, any caller that passesoptions.onSuccessoroptions.onSettledwill completely replace the internal handlers, so:
auth_settingswon't be updated in theuseGetFlowsMCPcache.project-composer-urland the per-projectuseGetFlowsMCPqueries won't be invalidated.
usePatchInstallMCPuses the safer pattern (...optionsfirst, then anonSuccessthat also callsoptions?.onSuccess), which is what we want here too.A minimal fix:
- const mutation: UseMutationResult< - PatchFlowMCPResponse, - any, - PatchFlowMCPRequest - > = mutate(["usePatchFlowsMCP", params.project_id], patchFlowMCP, { - onSuccess: (data, variables, context) => { + const mutation: UseMutationResult< + PatchFlowMCPResponse, + any, + PatchFlowMCPRequest + > = mutate(["usePatchFlowsMCP", params.project_id], patchFlowMCP, { + ...options, + onSuccess: (data, variables, context) => { const authSettings = (variables as PatchFlowMCPRequest).auth_settings; const currentMCPData = queryClient.getQueryData([ "useGetFlowsMCP", params.project_id, ]); if (currentMCPData && authSettings !== undefined) { queryClient.setQueryData(["useGetFlowsMCP", params.project_id], { ...currentMCPData, auth_settings: authSettings, }); } queryClient.invalidateQueries({ queryKey: ["project-composer-url", params.project_id], }); - if (options?.onSuccess) { - options.onSuccess(data, variables, context); - } + options?.onSuccess?.(data, variables, context); }, - onSettled: () => { - queryClient.invalidateQueries({ - queryKey: ["useGetFlowsMCP", params.project_id], - }); - }, - ...options, + onSettled: (data, error, variables, context) => { + queryClient.invalidateQueries({ + queryKey: ["useGetFlowsMCP", params.project_id], + }); + options?.onSettled?.(data, error, variables, context); + }, });This ensures the internal cache updates/invalidation always run while still honoring any callbacks provided via
options.
🧹 Nitpick comments (10)
src/lfx/tests/unit/custom/custom_component/test_component.py (2)
117-117: Consider moving the import to module level.While functionally correct, importing
AsyncMockinside the function is unconventional. Consider moving it to the top of the file alongside the otherunittest.mockimports for better code organization.Apply this diff to move the import:
from typing import Any -from unittest.mock import MagicMock +from unittest.mock import AsyncMock, MagicMock import pytestAnd remove the import from inside the function:
async def test_send_message_without_database(): - from unittest.mock import AsyncMock - component = Component()
132-140: Consider adding assertions to verify the mock behavior.The test could be strengthened by:
- Asserting that
result.idis set to verify the mock worked correctly- Using
assert_called_once_with(message)instead of justassert_called_once()to verify the correct argument was passedApply this diff to add the assertions:
result = await component.send_message(message) assert isinstance(result, Message) assert result.text == "Hello" assert result.sender == "User" assert result.sender_name == "Test" + assert result.id == "test-message-id" # Verify the message was stored (mock was called) - component._store_message.assert_called_once() + component._store_message.assert_called_once_with(message) # The focus is on testing the message handling logic, not the database persistence layer assert event_manager.on_message.calledsrc/frontend/src/modals/authModal/index.tsx (1)
81-101: OAuth auto-sync logic looks correct; consider clearing URLs when port is emptiedThe
handleAuthFieldChangeauto-sync foroauthHost/oauthPortcorrectly derivesoauthServerUrlandoauthCallbackPathand aligns with the new tests and desired re-sync behavior when host/port change.One minor UX edge case: when the user clears the Port field (empty string), the existing
oauthServerUrl/oauthCallbackPathare left pointing at the old port. Consider clearing or updating those fields whenportbecomes empty so the form doesn’t display a now-invalid URL.src/backend/base/langflow/api/v1/mcp_projects.py (2)
411-424: Auth rollback + composer orchestration mostly solid; consider clarifying behavior and rollback intentThe new flow around
original_auth_settings,should_handle_mcp_composer, and the commit-at-end pattern makes sense and aligns with the PR goals:
- Expected
MCPComposerErrorcases persist auth settings and surface an error payload while not rolling back, which lets the UI show composer failures without losing OAuth config.- Unexpected exceptions roll back via
project.auth_settings = original_auth_settingsand a raisedHTTPException, so the session context should abort without committing changes.A couple of tweaks worth considering:
Clarify commit semantics vs. comment
The comment
# Only commit if composer started successfully (or wasn't needed)is slightly misleading: in theMCPComposerErrorbranch you intentionally do commit auth changes even when composer fails, to satisfy “persist settings, show error” behavior.Consider updating the comment to reflect the actual intent, e.g.:
# Commit project/auth changes unless an unexpected error occurred # (composer startup failures are persisted so the UI can show errors)Make rollback intent explicit
You currently snapshot
original_auth_settings = project.auth_settingsand then on unexpected errors do:project.auth_settings = original_auth_settings raise HTTPException(...)Given the surrounding
session_scope, the transaction will be rolled back anyway, but this assignment may give a false sense of “guaranteed rollback” ifhandle_auth_settings_updatemutates the dict in place.If you genuinely need an in-process rollback before the session context rolls back, consider copying the structure:
import copy original_auth_settings = copy.deepcopy(project.auth_settings) if project.auth_settings else NoneOtherwise, you could drop the manual assignment and rely purely on the transaction rollback for clarity.
Also applies to: 447-524
777-790: Per-project composerlast_errorexposure works; confirm whether errors should be one-shot or persistentThe new behavior in
get_project_composer_urlto:
- Return a stored
last_errorwhenshould_use_mcp_composer(project)isFalse, and- Clear
last_erroronly after a successful composer URL retrievalis coherent with the idea of “remember the last OAuth failure even if composer is currently not usable”.
Two points to double-check:
Lifetime of
last_errorwhen composer is permanently disabledIf MCP Composer is turned off globally after a failure,
should_use_mcp_composerwill remainFalseandlast_errorwill never be cleared by this endpoint. That’s probably fine, but consider whether the UI expects this to behave like a one-shot error (cleared after displaying once) versus a persistent banner until the next successful OAuth/composer run.Symmetry with other paths that clear
last_errorYou clear
last_errorexplicitly on:
- successful start in the PATCH handler, and
- explicit OAuth disable (stop-composer branch).
Confirm that these three places (PATCH success, OAuth disable, composer-url success) cover all the scenarios you care about, and that you don’t need to clear
last_errorwhen auth type changes away from OAuth through other flows.If the current behavior is intentional, this is good; if not, adding an explicit clear (or documenting persistence) would avoid surprises later.
Also applies to: 804-808
src/frontend/src/pages/MainPage/pages/homePage/hooks/useMcpServer.ts (1)
1-2: Confirm thatuseQueryClientshares the same QueryClient used insideUseRequestProcessorYou now call
useQueryClient()directly and use it toremoveQueriesfor["project-composer-url", projectId], whileusePatchFlowsMCPinternally gets its ownqueryClientfromUseRequestProcessor.If
UseRequestProcessoris also usinguseQueryClientunder the hood, this is fine. If it creates its own QueryClient instance, you’d end up clearing queries on a different client than the one the mutation is invalidating, which would be confusing and could leave stale data around.Please double-check that:
UseRequestProcessorand this hook are wired to the same React Query client (i.e., they both operate within the sameQueryClientProviderand use the same underlying instance).- The query key you remove (
["project-composer-url", projectId]) exactly matches the one used inuseGetProjectComposerUrl.If they are aligned, this pattern is good; if not, consider exposing
queryClientfromUseRequestProcessorand reusing that instead of callinguseQueryClienthere.Also applies to: 48-48, 209-221
src/lfx/tests/unit/services/settings/test_mcp_composer.py (2)
21-38: Port-availability tests may be slightly flaky due to hard-coded portsUsing fixed high ports (59999, 59998) is usually fine but can still collide with other processes on CI, causing intermittent failures.
Consider making the “free port” test more robust by letting the OS allocate a port and then testing it after closing the socket, e.g.:
with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s: s.bind(("localhost", 0)) free_port = s.getsockname()[1] assert mcp_service._is_port_available(free_port) is TrueThis reduces the chance of port collisions across environments.
127-176: Auth-config change detection tests align with_has_auth_config_changedbehaviorThese tests cover the main branches of
_has_auth_config_changed(port changes, identical configs, auth_type change, both/oneNone) and match the documented implementation that compares OAuth-prefixed keys and relevant fields.You might later add a case for subtle normalization differences (e.g., whitespace or int vs. str for ports) to exercise
_normalize_config_value, but the current set already exercises the core logic well.src/lfx/tests/unit/services/settings/test_mcp_composer_windows.py (2)
182-374: Windows temp-file and non-Windows pipe handling tests are thorough and aligned with the service designThe temp-file tests cover:
- Windows path:
NamedTemporaryFileusage and ensuringsubprocess.Popenreceives real file handles instead ofPIPE.- Async reading and cleanup via
_read_process_output_and_extract_error, verifying both contents and that temp files are removed.- Successful-start path cleaning up temp files after
_start_project_composer_processreturns.- Non-Windows path: asserting that stdout/stderr use
subprocess.PIPEwhenplatform.system()is not"Windows".These tests exercise both success and failure/cleanup paths and match the Windows-specific design in the service snippets. The use of real temp files for the read/cleanup tests is appropriate and keeps behavior close to production.
473-523: Retry robustness test nicely covers zombie-cleanup failures
test_zombie_cleanup_failure_is_non_fatal_during_retrysets up:
- A first
_start_project_composer_processattempt that raisesMCPComposerStartupError._kill_zombie_mcp_processesraising an exception.- A second attempt that succeeds.
Asserting that
call_count == 2and thatproject_idis present inproject_composersconfirms that:
- Zombie cleanup errors do not abort retries.
- Success on a later attempt still leads to proper tracking.
The async side-effect function for
_start_project_composer_processis a good pattern here.
📜 Review details
Configuration used: Path: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (11)
src/backend/base/langflow/api/v1/mcp_projects.py(7 hunks)src/backend/base/langflow/main.py(1 hunks)src/frontend/src/controllers/API/queries/mcp/use-patch-flows-mcp.ts(2 hunks)src/frontend/src/controllers/API/queries/mcp/use-patch-install-mcp.ts(1 hunks)src/frontend/src/modals/authModal/__tests__/AuthModal.test.tsx(1 hunks)src/frontend/src/modals/authModal/index.tsx(1 hunks)src/frontend/src/pages/MainPage/pages/homePage/hooks/useMcpServer.ts(6 hunks)src/lfx/src/lfx/services/mcp_composer/service.py(13 hunks)src/lfx/tests/unit/custom/custom_component/test_component.py(1 hunks)src/lfx/tests/unit/services/settings/test_mcp_composer.py(1 hunks)src/lfx/tests/unit/services/settings/test_mcp_composer_windows.py(1 hunks)
🧰 Additional context used
🧠 Learnings (2)
📚 Learning: 2025-08-05T22:51:27.961Z
Learnt from: edwinjosechittilappilly
Repo: langflow-ai/langflow PR: 0
File: :0-0
Timestamp: 2025-08-05T22:51:27.961Z
Learning: The TestComposioComponentAuth test in src/backend/tests/unit/components/bundles/composio/test_base_composio.py demonstrates proper integration testing patterns for external API components, including real API calls with mocking for OAuth completion, comprehensive resource cleanup, and proper environment variable handling with pytest.skip() fallbacks.
Applied to files:
src/lfx/tests/unit/services/settings/test_mcp_composer.pysrc/frontend/src/modals/authModal/__tests__/AuthModal.test.tsxsrc/lfx/tests/unit/custom/custom_component/test_component.py
📚 Learning: 2025-06-23T12:46:42.048Z
Learnt from: CR
Repo: langflow-ai/langflow PR: 0
File: .cursor/rules/frontend_development.mdc:0-0
Timestamp: 2025-06-23T12:46:42.048Z
Learning: Custom React Flow node types should be implemented as memoized components, using Handle components for connection points and supporting optional icons and labels.
Applied to files:
src/frontend/src/pages/MainPage/pages/homePage/hooks/useMcpServer.ts
🧬 Code graph analysis (7)
src/lfx/tests/unit/services/settings/test_mcp_composer.py (1)
src/lfx/src/lfx/services/mcp_composer/service.py (5)
MCPComposerPortError(38-39)_is_port_available(99-115)_kill_process_on_port(117-238)_has_auth_config_changed(793-824)_do_start_project_composer(962-1156)
src/frontend/src/modals/authModal/__tests__/AuthModal.test.tsx (1)
src/frontend/src/components/common/genericIconComponent/index.tsx (1)
render(157-159)
src/frontend/src/pages/MainPage/pages/homePage/hooks/useMcpServer.ts (3)
src/frontend/src/controllers/API/queries/mcp/use-get-flows-mcp.ts (1)
useGetFlowsMCP(13-36)src/frontend/src/controllers/API/queries/mcp/use-patch-flows-mcp.ts (1)
usePatchFlowsMCP(27-85)src/frontend/src/customization/feature-flags.ts (1)
ENABLE_MCP_COMPOSER(20-21)
src/lfx/tests/unit/custom/custom_component/test_component.py (2)
src/lfx/src/lfx/custom/custom_component/component.py (2)
_store_message(1636-1646)send_message(1578-1634)src/lfx/src/lfx/schema/message.py (1)
Message(34-299)
src/lfx/tests/unit/services/settings/test_mcp_composer_windows.py (1)
src/lfx/src/lfx/services/mcp_composer/service.py (4)
_kill_zombie_mcp_processes(240-399)_read_process_output_and_extract_error(506-579)start_project_composer(907-960)_read_stream_non_blocking(581-620)
src/lfx/src/lfx/services/mcp_composer/service.py (1)
src/backend/base/langflow/services/deps.py (1)
get_settings_service(124-137)
src/backend/base/langflow/api/v1/mcp_projects.py (3)
src/lfx/src/lfx/services/mcp_composer/service.py (5)
MCPComposerService(69-1392)clear_last_error(95-97)MCPComposerError(27-35)set_last_error(91-93)get_last_error(87-89)src/backend/base/langflow/services/deps.py (1)
get_service(32-54)src/backend/base/langflow/services/schema.py (1)
ServiceType(4-22)
⏰ Context from checks skipped due to timeout of 90000ms. You can increase the timeout in your CodeRabbit configuration to a maximum of 15 minutes (900000ms). (13)
- GitHub Check: Lint Backend / Run Mypy (3.10)
- GitHub Check: Run Backend Tests / Unit Tests - Python 3.10 - Group 4
- GitHub Check: Run Backend Tests / Unit Tests - Python 3.10 - Group 1
- GitHub Check: Run Backend Tests / Unit Tests - Python 3.10 - Group 2
- GitHub Check: Run Backend Tests / Unit Tests - Python 3.10 - Group 5
- GitHub Check: Run Frontend Tests / Determine Test Suites and Shard Distribution
- GitHub Check: Run Backend Tests / LFX Tests - Python 3.10
- GitHub Check: Run Backend Tests / Unit Tests - Python 3.10 - Group 3
- GitHub Check: Run Backend Tests / Integration Tests - Python 3.10
- GitHub Check: Run Frontend Unit Tests / Frontend Jest Unit Tests
- GitHub Check: Test Starter Templates
- GitHub Check: Update Component Index
- GitHub Check: Optimize new Python code in this PR
🔇 Additional comments (6)
src/frontend/src/modals/authModal/__tests__/AuthModal.test.tsx (1)
1-275: Comprehensive and aligned test coverage for OAuth auto-syncThe test suite thoroughly covers the new OAuth auto-sync behavior (host/port, callback, manual overrides, save payload, existing settings, and non-OAuth types) and matches the component’s logic. This should give good confidence in the new flow.
src/lfx/src/lfx/services/mcp_composer/service.py (1)
99-239: Port/process ownership and startup monitoring look robust and conservativeThe new helpers for port/process handling and startup monitoring (
_is_port_available,_kill_process_on_port,_kill_zombie_mcp_processes,_is_port_used_by_another_project,_ensure_port_available,_read_process_output_and_extract_error,_read_stream_non_blocking,_start_project_composer_process) form a coherent lifecycle:
- Only kill processes when they’re explicitly associated with the current project (
_port_to_project/_pid_to_project) or, on Windows, clearly identified as MCP Composer zombies.- Avoid killing unknown external processes on occupied ports, instead surfacing clear
MCPComposerPortErrormessages.- Use temp files for stdout/stderr on Windows to avoid pipe deadlocks and clean them up in all success/error paths.
- Monitor startup with repeated port checks and non-blocking log reads, producing structured error logs with obfuscated secrets.
This is well-structured for cross-platform safety and observability; no changes needed here.
Also applies to: 240-415, 622-699, 1158-1377
src/frontend/src/controllers/API/queries/mcp/use-patch-install-mcp.ts (1)
46-58: Per-project keying and options composition look good inusePatchInstallMCPThe updated mutation key
["usePatchInstallMCP", params.project_id]and per-project invalidation of["useGetInstalledMCP", params.project_id]are correct. Spreading...optionsbefore the customonSuccesswhile still callingoptions?.onSuccesskeeps internal cache behavior intact even when callers pass their own callbacks—this is the pattern worth mirroring inusePatchFlowsMCP.src/lfx/tests/unit/services/settings/test_mcp_composer.py (1)
178-321: Port-change handling and port-ownership tests look consistent with the service orchestrationThe restart and port-ownership tests here are well-structured:
test_port_change_triggers_restartcorrectly seedsproject_composersand asserts_do_stop_project_composeris invoked when auth config (port) changes.test_port_in_use_by_own_project_triggers_killvalidates the “own project owns port” path via_port_to_projectand ensures_kill_process_on_portis called after an initial “in use” check.test_port_in_use_by_unknown_process_raises_errormatches the documented_ensure_port_availablebehavior of raisingMCPComposerPortErrorfor untracked ports with a user-facing message.Mocks use
AsyncMockfor service coroutines, and the tests focus on control-flow effects, not implementation details, which is appropriate here.src/lfx/tests/unit/services/settings/test_mcp_composer_windows.py (2)
376-439: Startup timeout and retry-parameter tests correctly pin the intended behavior
test_startup_timeout_is_80_secondsasserts the defaults onstart_project_composer(max_startup_checks=40,startup_delay=2.0), matching the intended 80s timeout.test_retry_with_increased_timeoutpatches_start_project_composer_processto always fail and then checks that each retry passes through the expectedmax_startup_checksandstartup_delayvalues, accounting for both positional and keyword argument calls.The combination gives good protection against accidental changes to startup timing semantics.
441-471: Stream-reading avoidance tests look accurate for Windows vs Unix behaviorThe tests for
_read_stream_non_blockingcorrectly reflect the implementation:
- On Windows, it should immediately return
""and never touch the stream (peek()/readline()), which is whattest_read_stream_non_blocking_returns_empty_on_windowsasserts.- On Unix-like systems, patching
select.selectand verifying thatreadline()is used and the decoded content is returned matches the documented non-blocking behavior.This gives good coverage of a subtle, platform-specific code path.
| mcp_composer_service: MCPComposerService = cast( | ||
| MCPComposerService, get_service(ServiceType.MCP_COMPOSER_SERVICE) | ||
| ) | ||
| mcp_composer_service.clear_last_error(str(project_id)) |
There was a problem hiding this comment.
Do we also need to clear this if the auth settings changed to None or API Key?
There was a problem hiding this comment.
the logic already covers all cases where OAuth is disabled.
I don't think it's necessary to change it..
|
|
||
| if (port) { | ||
| newFields.oauthServerUrl = `http://${host}:${port}`; | ||
| newFields.oauthCallbackPath = `http://${host}:${port}/auth/idaas/callback`; |
There was a problem hiding this comment.
I don't believe this is the correct behavior (though, it is cool).
Callback can be any user-defined string, no?
There was a problem hiding this comment.
agree! fixed!
now only auto-populates callback path if empty (initial setup convenience), otherwise preserves user's custom value
| ] = {} # Track active start tasks to cancel them when new request arrives | ||
| self._port_to_project: dict[int, str] = {} # Track which project is using which port | ||
| self._pid_to_project: dict[int, str] = {} # Track which PID belongs to which project | ||
| self._last_errors: dict[str, str] = {} # Track last error message per project for UI display |
There was a problem hiding this comment.
I'm starting to think we should have a fourth auth settings state: Failed, which ensures no mcp server is started for this project, and can store the last error state.
There was a problem hiding this comment.
hey @jordanrfrazier ,
We've already implemented something similar with the instant error detection improvements in this PR.
Now we can see error feedback almost in runtime.
| # Also kill any process that might be using the old port | ||
| if existing_port: | ||
| try: | ||
| await asyncio.wait_for(self._kill_process_on_port(existing_port), timeout=5.0) |
There was a problem hiding this comment.
The kill_process method is worrisome to me - I can imagine a situation where the composer started on a port then user manually stopped MCP Composer. Then, user started up another application (could be anything) on the same port.
Then, Langflow gets here and kills user's process.
Very serious issue, imo, so we should brainstorm if we have any other options here. (We also may have a similar situation with _do_stop_project_composer?)
There was a problem hiding this comment.
Good catch, but this scenario is already protected against. The code only kills processes that Langflow itself started and is actively tracking via self._port_to_project.
For the scenario you described:
- User manually stops MCP Composer
- User starts another application on the same port
- Langflow tries to restart MCP Composer
What actually happens:
- At line 728-732 in _ensure_port_available(), we detect that the port is in use by an unknown process (not in our tracking)
- We explicitly refuse to kill it for security reasons
- We raise MCPComposerPortError asking the user to choose a different port
else:
# Port is in use by unknown process - don't kill it (security concern)
await logger.aerror(
f"Port {port} is in use by an unknown process (not owned by Langflow). "
f"Will not kill external application for security reasons."
)
raise MCPComposerPortError(...)
We only kill processes when:
- The port is owned by the same project trying to restart (line 710) - safe because it's our own stuck process
- The port is in existing_port (line 1083) - which comes from our internal tracking, meaning we started it
The tracking ensures we never kill external applications. If a process isn't in self._port_to_project or self.project_composers, we treat it as external and refuse to touch it.
|
Merged #10644 in here |
* docs: Improve README Quickstart section and add dark mode logo (#10358) * Improve README Quickstart section and reorganize installation options - Add prominent Desktop download section before Quickstart - Remove $ symbols from shell commands to fix copy button functionality - Add clear 'Run from source' option with make run_cli for developers - Improve Docker installation instructions with usage details - Move security warnings to after installation options for better flow - Remove redundant star/issues badges These changes address common user confusion when trying to run Langflow, especially for developers who clone the repo first and then struggle with the package installation instructions. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com> * Add dark mode logo support - Added picture element for automatic dark/light mode logo switching - Dark mode shows blue background logo, light mode shows black logo 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com> * Final README improvements - Made 'Other install options' a proper section with emoji - Updated deployment section with rocket emoji - Fixed single-line formatting for subsections - Added new star animation gif - Changed 'tool' to 'platform' in description * Improve Desktop download section messaging - Made text more concise and action-oriented - Changed download emoji from arrow to inbox - Removed redundant 'built-in' and bold formatting - Cleaner parenthetical for OS availability * Revise README for Langflow Desktop and deployment info Updated sections for clarity and added details about Langflow Desktop and deployment options. * Revert star gif to GitHub attachment URL Testing if local file path issue or markdown previewer issue * Apply suggestion from @mendonk * Apply suggestion from @mendonk * Apply suggestion from @mendonk * Apply suggestion from @mendonk * readme-changes * Apply suggestion from @mendonk --------- Co-authored-by: Claude <noreply@anthropic.com> Co-authored-by: Mendon Kissling <59585235+mendonk@users.noreply.github.com> Co-authored-by: Gabriel Luiz Freitas Almeida <gabriel@langflow.org> * fix: require active user for monitor endpoints (#10568) Require active user for monitor endpoints * refactor: Reorganize sidebar categories (#10180) * Reorganize sidebar categories * finishing touches * templates * ruff check fix * merge fix * filter out knowledge when ff'd off * BE tests * [autofix.ci] apply automated fixes * more test fixes * integration test fix * Unit tests * more test fixes * reorg tests * [autofix.ci] apply automated fixes * update ui tests * [autofix.ci] apply automated fixes * mcp and playwright tests * [autofix.ci] apply automated fixes * BE test fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * test fix --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Edwin Jose <edwin.jose@datastax.com> * fix(agent): handle missing message id for disconnected agents (#10560) * fix(agent): handle missing message id for disconnected agents * [autofix.ci] apply automated fixes * will this update comp index * comp index --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Jordan Frazier <jordan.frazier@datastax.com> * fix: Langflow logo on home page when s3 is enabled (#10352) * fixed and added tests * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * fix(playground): preserve timer start time when playground is reopened (#10516) * Fix playground timer * add jest unit tests --------- Co-authored-by: cristhianzl <cristhian.lousa@gmail.com> * fix: MCP component auto reset issue in non Tool Mode (#10440) * Optimize tool dropdown handling and output processing Improves logic for updating tool dropdown options by checking if the server has changed and whether tool mode is active, reducing unnecessary updates. Adds a process_output_item method to parse tool output as JSON when appropriate, enhancing output handling. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * Update component_index.json * Update Nvidia Remix.json * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Update component_index.json * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * use cache enabled even for the no tool mode * Update component_index.json * [autofix.ci] apply automated fixes * Update Nvidia Remix.json * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * Add Notion integration components to index Updated component_index.json to include new Notion integration components: AddContentToPage, NotionDatabaseProperties, NotionListPages, NotionPageContent, NotionPageCreator, NotionPageUpdate, and NotionSearch. These components provide functionality for interacting with Notion databases and pages, including querying, creating, updating, and retrieving content. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * fix: add selector to let dropdown load add Select a tool selector to let dropdown load before interacting * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Update MCPToolsComponent code and metadata Updated the code and code_hash for MCPToolsComponent in Nvidia Remix starter project and synchronized the component_index.json to reflect the latest code and metadata. This ensures consistency and includes recent improvements or fixes to the MCPToolsComponent implementation. --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Adam Aghili <Adam.Aghili@ibm.com> * fix: Switch to browser-compatible MathJax import (#10563) add browser support to rehype package build * feat: patch icons to support dark theme and Composio Slack component fix. (#10577) * feat: add Composio Components & logos tweak * Display name consistency * update init * fix: format * fix: suggested changes by Mike * feat: add Composio Components & logos tweak * Display name consistency * update init * fix: format * fix: suggested changes by Mike * updates components JSON * fix: format * updates components JSON * Remove unnecessary blank lines in __init__.py Cleaned up formatting by deleting extra blank lines in the _dynamic_imports dictionary for improved readability. * Update component_index.json * Update component_index.json * Update component_index.json * Update component_index.json * fix: Slack component issue * fix: icons update to support dark theme * fix: Klaviyo imports * Update component_index.json --------- Co-authored-by: Edwin Jose <edwin.jose@datastax.com> * feat: add toolkit_versions and updated composio and composio_langchain versions. (#10578) * feat: added toolkit versions and updated composio and composio_langchain packages * fix: format --------- Co-authored-by: Edwin Jose <edwin.jose@datastax.com> * fix: marked required fields for fields with MultilineInput input types. (#10579) fix: marked required fields with MultilineInputs Co-authored-by: Edwin Jose <edwin.jose@datastax.com> * feat: replaced initiate method with link method. (#10580) feat: replaced .initiate() with .link() Co-authored-by: Edwin Jose <edwin.jose@datastax.com> * feat: Add ALTK Agent with tool validation and comprehensive tests (#10587) * Add ALTK Agent with tool validation and comprehensive tests - Added agent-lifecycle-toolkit~=0.4.1 dependency to pyproject.toml - Implemented ALTKBaseAgent with comprehensive error handling and tool validation - Added ALTKToolWrappers for SPARC integration and tool execution safety - Created ALTK Agent component with proper LangChain integration - Added comprehensive test suite covering tool validation, conversation context, and edge cases - Fixed docstring formatting to comply with ruff linting standards * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * minor fix to execute_tool that was left out. * Fixes following coderabbitai comments. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * Update component_index.json * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Add custom message to dict conversion in ValidatedTool * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Add Notion integration components to index Updated component_index.json to include new Notion integration components: AddContentToPage, NotionDatabaseProperties, NotionListPages, NotionPageContent, NotionPageCreator, NotionPageUpdate, and NotionSearch. These components provide functionality for interacting with Notion databases and pages, including querying, creating, updating, and retrieving content. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) --------- Co-authored-by: Koren Lazar <koren.lazar@ibm.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Edwin Jose <edwin.jose@datastax.com> * feat: Add MCP server config sanitization for sensitive data (#10552) add clean mcp config function * feat: Implement dynamic model discovery system (#10523) * add dynamic model request * add description to groq * add cache folder to store cache models json * change git ignore description * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * add comprehensive tests for Groq dynamic model discovery - Add 101 unit tests covering success, error, and edge cases - Test model discovery, caching, tool calling detection - Test fallback models and backward compatibility - Add support for real GROQ_API_KEY from environment - Fix all lint errors and improve code quality * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * fix Python 3.10 compatibility - replace UTC with timezone.utc Python 3.10 doesn't have datetime.UTC, need to use timezone.utc instead * fix pytest hook signature - use config instead of _config * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * fix conftest config.py * fix timezone UTC on tests * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * feat: remove `code` from Transactions to reduce clutter in logs (#10400) * refactor: remove code from transaction model inputs * refactor: remove code from transaction model inputs * tests: add tests to make sure code is not added to transactions data * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * refactor: improve code removal from logs with explicit dict copying --------- Co-authored-by: Edwin Jose <edwin.jose@datastax.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * refactor(service_manager): implement lazy initalization of service manager (#8828) * refactor: implement lazy initialization for ServiceManager with thread safety - Replaced direct instantiation of ServiceManager with a lazy initialization approach using a global variable and threading lock. - Updated the public API to expose `get_service_manager` for retrieving the singleton instance. - Ensured thread-safe access to the ServiceManager instance to prevent issues during module import. * refactor: update service manager imports to use get_service_manager - Replaced direct imports of service_manager with get_service_manager in multiple files to ensure consistent access to the singleton instance. - This change enhances code clarity and maintains the lazy initialization approach for the ServiceManager. * refactor: remove deprecated Enhanced ServiceManager implementation * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * refactor: implement thread-safe lazy initialization for ServiceManager * feat: add filelock dependency in lfx * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * update component index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * feat: new release for cuga component (#10591) * feat: new release of cuga * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * fix: address review * fix: fixed more bugs * fix: build component index * [autofix.ci] apply automated fixes * fix: update test * chore: update component index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * ci: upgrade playwright to 1.56 and fix second time imports (#10284) * chore: update Playwright and related dependencies to version 1.56.0 in package.json and package-lock.json * refactor: update addLegacyComponents function to improve selector checks - Replaced the expect assertion with a waitForSelector call to ensure the sidebar legacy switch is checked, enhancing reliability in tests. - Updated import statement for Page from "@playwright/test" for consistency with current practices. * fix playwright imports * chore: update Playwright version in CI workflow to 1.56.0 for consistency with project dependencies * refactor: enhance lockFlow and unlockFlow functions for improved visibility checks - Replaced isVisible calls with waitFor to ensure elements are visible before proceeding, enhancing test reliability. - Removed unnecessary waitForTimeout calls to streamline the flow execution process. * test(playwright): add validation for settings menu header text * refactor(playwright): improve lock flow test with expect assertions * refactor(playwright): simplify legacy component toggle validation * feat: adds Component Inputs telemetry (#10254) * feat: Introduce telemetry tracking for sensitive field types Added a new set of field types that should not be tracked in telemetry due to their sensitive nature, including PASSWORD, AUTH, FILE, CONNECTION, and MCP. Updated relevant input classes to ensure telemetry tracking is disabled for these sensitive fields, enhancing data privacy and security. * feat: Enhance telemetry payloads with additional fields and serialization support Added new fields to the ComponentPayload and ComponentInputsPayload classes, including component_id and component_run_id, to improve telemetry data tracking. Introduced a serialize_input_values function to handle JSON serialization of component input values, ensuring robust handling of input data for telemetry purposes. * feat: Implement telemetry input tracking and caching Added functionality to track and cache telemetry input values within the Component class. Introduced a method to determine if inputs should be tracked based on sensitivity and an accessor for retrieving cached telemetry data, enhancing the robustness of telemetry handling. * feat: Add logging for component input telemetry Introduced a new method, log_package_component_inputs, to the TelemetryService for logging telemetry data related to component inputs. This enhancement improves the tracking capabilities of the telemetry system, allowing for more detailed insights into component interactions. * feat: Enhance telemetry logging for component execution Added functionality to log component input telemetry both during successful execution and error cases. Introduced a unique component_run_id for each execution to improve tracking. This update ensures comprehensive telemetry data collection, enhancing the robustness of the telemetry system. * feat: Extend telemetry payload tests and enhance serialization Added tests for the new component_id and component_run_id fields in ComponentPayload and ComponentInputsPayload classes. Introduced a new test suite for ComponentInputTelemetry, covering serialization of various data types and handling of edge cases. This update improves the robustness and coverage of telemetry data handling in the system. * fix: Update default telemetry tracking behavior in BaseInputMixin Changed the default value of track_in_telemetry from True to False in the BaseInputMixin class. Updated documentation to clarify that telemetry tracking is now opt-in and can be explicitly enabled for individual input types, enhancing data privacy and control. * fix: Update telemetry tracking defaults for input types Modified the default value of `track_in_telemetry` for various input classes to enhance data privacy. Regular inputs now default to False, while safe inputs like `IntInput` and `BoolInput` default to True, ensuring explicit opt-in for telemetry tracking. Updated related tests to reflect these changes. * feat: add chunk_index and total_chunks fields to ComponentInputsPayload This commit adds two new optional fields to ComponentInputsPayload: - chunk_index: Index of this chunk in a split payload sequence - total_chunks: Total number of chunks in the split sequence Both fields default to None and use camelCase aliases for serialization. This is Task 1 of the telemetry query parameter splitting implementation. Tests included: - Verify fields exist and can be set - Verify camelCase serialization aliases work correctly - Verify fields default to None when not provided Generated with Claude Code (https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com> * refactor: update ComponentInputsPayload to support automatic splitting of oversized inputs This commit enhances the ComponentInputsPayload class by implementing functionality to automatically split input values into multiple chunks if they exceed the maximum URL size limit. Key changes include: - Added methods for calculating URL size, truncating oversized values, and splitting payloads. - Updated component_inputs field to accept a dictionary instead of a string for better handling of input values. - Improved documentation for the ComponentInputsPayload class to reflect the new splitting behavior and usage examples. These changes aim to improve telemetry data handling and ensure compliance with URL length restrictions. * refactor: enhance log_package_component_inputs to handle oversized payloads This commit updates the log_package_component_inputs method in the TelemetryService class to split component input payloads into multiple requests if they exceed the maximum URL size limit. Key changes include: - Added logic to split the payload using the new split_if_needed method. - Each chunk is queued separately for telemetry logging. These improvements ensure better handling of telemetry data while adhering to URL length restrictions. * refactor: centralize maximum telemetry URL size constant This commit introduces a centralized constant, MAX_TELEMETRY_URL_SIZE, to define the maximum URL length for telemetry GET requests. Key changes include: - Added MAX_TELEMETRY_URL_SIZE constant to schema.py for better maintainability. - Updated split_if_needed method in ComponentInputsPayload to use the new constant instead of a hardcoded value. - Adjusted the TelemetryService to reference the centralized constant for URL size limits. These changes enhance code clarity and ensure consistent handling of URL size limits across the telemetry service. * refactor: update ComponentInputsPayload tests to use dictionary inputs This commit modifies the tests for ComponentInputsPayload to utilize a dictionary for component inputs instead of a serialized JSON string. Key changes include: - Renamed the test method to reflect the new input type. - Removed unnecessary serialization steps and assertions related to JSON strings. - Added assertions to verify the correct handling of dictionary inputs. These changes streamline the testing process and improve clarity in how component inputs are represented. * test: add integration tests for telemetry service payload splitting This commit introduces integration tests for the TelemetryService to verify its handling of large and small payloads. Key changes include: - Added tests to ensure large payloads are split into multiple chunks and queued correctly. - Implemented a test to confirm that small payloads are not split and result in a single queued event. - Created a mock settings service for testing purposes. These tests enhance the reliability of the telemetry service by ensuring proper payload management. * test: enhance ComponentInputsPayload tests with additional scenarios This commit expands the test suite for ComponentInputsPayload by adding various scenarios to ensure robust handling of input payloads. Key changes include: - Introduced tests for calculating URL size, ensuring it returns a positive integer and accounts for encoding. - Added tests to verify the splitting logic for large payloads, including checks for chunk metadata and preservation of fixed fields. - Implemented property-based tests using Hypothesis to validate that all chunks respect the maximum URL size and preserve original data. These enhancements improve the reliability and coverage of the ComponentInputsPayload tests, ensuring proper functionality under various conditions. * [autofix.ci] apply automated fixes * optimize query param encoding Co-authored-by: codeflash-ai[bot] <148906541+codeflash-ai[bot]@users.noreply.github.com> * refactor: extract telemetry logging logic into a separate function This commit introduces a new function, _log_component_input_telemetry, to centralize the logic for logging component input telemetry. The function is called in two places within the generate_flow_events function, improving code readability and maintainability by reducing duplication. This change enhances the clarity of telemetry handling in the flow generation process. * refactor: optimize truncation logic in ComponentInputsPayload This commit refines the truncation logic for input values in the ComponentInputsPayload class. The previous binary search method for string values has been simplified, allowing for direct truncation of both string and non-string values. This change enhances code clarity and maintains functionality while ensuring optimal handling of oversized inputs. * refactor: update telemetry tracking logic to respect opt-in flag This commit modifies the telemetry tracking logic in the Component class to change the default behavior of the `track_in_telemetry` attribute from True to False. This adjustment enhances user privacy by requiring explicit consent for tracking input objects in telemetry. The change ensures that sensitive field types are still auto-excluded from tracking, maintaining the integrity of the telemetry data. * refactor: update tests to use dictionary format for component inputs This commit modifies the integration tests for telemetry payload validation and component input telemetry to utilize dictionaries for component inputs instead of serialized JSON strings. Key changes include: - Updated assertions to compare dictionary inputs directly. - Enhanced clarity and maintainability of the test cases by removing unnecessary serialization steps. These changes improve the representation of component inputs in tests, aligning with recent refactoring efforts. * [autofix.ci] apply automated fixes * refactor: specify type for current_chunk_inputs in ComponentInputsPayload This commit updates the type annotation for the current_chunk_inputs variable in the ComponentInputsPayload class to explicitly define it as a dictionary. This change enhances code clarity and maintainability by providing better type information for developers working with the code. * test: add component_id to ComponentPayload tests This commit enhances the test cases for the ComponentPayload class by adding a component_id parameter to various initialization tests. The updates ensure that the component_id is properly tested across different scenarios, including valid parameters, error messages, and edge cases. This change improves the robustness of the tests and aligns with recent updates to the ComponentPayload structure. * [autofix.ci] apply automated fixes * feat: add component_id to ComponentPayload in build_vertex function * fix: update MAX_TELEMETRY_URL_SIZE to 2048 and adjust related tests This commit increases the maximum URL size for telemetry GET requests from 2000 to 2048 bytes to align with Scarf's specifications. Corresponding test assertions have been updated to reference the new constant, ensuring consistency across the codebase. * [autofix.ci] apply automated fixes * feat(telemetry): add track_in_telemetry field to starter project configurations * refactor(telemetry): remove unused blank line in test imports * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * update starter templates * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) --------- Co-authored-by: Claude <noreply@anthropic.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: codeflash-ai[bot] <148906541+codeflash-ai[bot]@users.noreply.github.com> * fix(telemetry): resolve cyclic import in telemetry service (#10598) * fix(telemetry): resolve cyclic import by moving get_email_model * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * feat: Add gpt-5.1 model to Language models (#10590) * Add gpt-5.1 model to starter projects Added 'gpt-5.1' to the list of available models in all starter project JSON files to support the new model version. This update ensures users can select gpt-5.1 in agent configurations. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Update component_index.json * [autofix.ci] apply automated fixes * Update component_index.json * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * fix: Use the proper Embeddings import for Qdrant vector store (#10613) * Use the proper Embeddings import for Qdrant vector store * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- Co-authored-by: Madhavan <cxo@ibm.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * fix: Ensure split text test is more robust (#10622) * fix: Ensure split text test is more robust * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * docs: security notice (#10555) * docs-security-notice * Apply suggestions from code review Co-authored-by: April I. Murphy <36110273+aimurphy@users.noreply.github.com> * code-review * link-to-security-bulletin * Apply suggestions from code review Co-authored-by: April I. Murphy <36110273+aimurphy@users.noreply.github.com> --------- Co-authored-by: April I. Murphy <36110273+aimurphy@users.noreply.github.com> * fix: use issubclass in the pool creation (#10232) * use issubclass in the pool creation * [autofix.ci] apply automated fixes * add poolclass pytests * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- Co-authored-by: Hamza Rashid <74062092+HzaRashid@users.noreply.github.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: cristhianzl <cristhian.lousa@gmail.com> * docs: OpenAPI spec version upgraded from 1.6.5 to 1.6.8 (#10627) Co-authored-by: github-merge-queue <118344674+github-merge-queue@users.noreply.github.com> Co-authored-by: Mendon Kissling <59585235+mendonk@users.noreply.github.com> * chore: Fix indentation on bundles-docling.mdx (#10640) * feat: make it possible to load graphs using `get_graph` function in scripts (#9913) * feat: Enhance graph loading functionality to support async retrieval - Updated `load_graph_from_script` to be an async function, allowing for the retrieval of the graph via an async `get_graph` function if available. - Implemented fallback to the existing `graph` variable for backward compatibility. - Enhanced `find_graph_variable` to identify both `get_graph` function definitions and `graph` variable assignments, improving flexibility in script handling. * feat: Update load_graph_from_script to support async graph retrieval - Refactored `load_graph_from_script` to be an async function, enabling the use of an async `get_graph` function for graph retrieval. - Implemented a fallback mechanism to access the `graph` variable for backward compatibility. - Enhanced error handling to provide clearer messages when neither `graph` nor `get_graph()` is found in the script. * feat: Refactor simple_agent.py to support async graph creation - Introduced an async `get_graph` function to handle the initialization of components and graph creation without blocking. - Updated the logging configuration and component setup to be part of the async function, improving the overall flow and responsiveness. - Enhanced documentation for the `get_graph` function to clarify its purpose and return type. * feat: Update serve_command and run functions to support async graph loading - Refactored `serve_command` to be an async function using `syncify`, allowing for non-blocking execution. - Updated calls to `load_graph_from_path` and `load_graph_from_script` within `serve_command` and `run` to await their results, enhancing performance and responsiveness. - Improved overall async handling in the CLI commands for better integration with async workflows. * feat: Refactor load_graph_from_path to support async execution - Changed `load_graph_from_path` to an async function, enabling non-blocking graph loading. - Updated the call to `load_graph_from_script` to use await, improving performance during graph retrieval. - Enhanced the overall async handling in the CLI for better integration with async workflows. * feat: Enhance async handling in simple_agent and related tests - Updated `get_graph` function in `simple_agent.py` to utilize async component initialization for improved responsiveness. - Modified test cases in `test_simple_agent_in_lfx_run.py` to validate the async behavior of `get_graph`. - Refactored various test functions across multiple files to support async execution, ensuring compatibility with the new async workflows. - Improved documentation for async functions to clarify their purpose and usage. * docs: Implement async get_graph function for improved component initialization - Introduced an async `get_graph` function in `README.md` to facilitate non-blocking component initialization. - Enhanced the logging configuration and component setup within the async function, ensuring a smoother flow. - Updated documentation to clarify the purpose and return type of the `get_graph` function, aligning with the async handling improvements. * refactor: reorder imports in simple_agent test file * style: reorder imports in simple_agent test file * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * update component index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * feat: Add custom download node function (#10659) * add custom download node * use download node * feat: Add type check before issubclass in service discovery (#10636) * Add type check before issubclass in service discovery Added an isinstance(obj, type) check before issubclass to prevent errors when inspecting module members for Service and ServiceFactory subclasses. This improves robustness when dynamically importing services and factories. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * docs: readme update (#10657) * dep-management * are * fix: minor redesign of guardrails for disabling components in LF Astra cloud (#10662) * create cloud validation util file disable local_db if in astra cloud disable split_video if in astra cloud disable video_file component if in astra cloud ruff (video_file.py) correct the error message in video_file.py disable mem0 and composio in astra cloud update astra disable component util fn name to be more descriptive add tests for disabling components minor docs patch remove component disable check in places that interact with building the component index replace init test with execution in composio unit test suite remove dotenv from validate_cloud * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * fix: prevent autofix workflow loop from bot commits (#10673) fix(ci): prevent autofix workflow loop from bot commits * fix(lfx-dev): reload specific modules while preserving index cache (#10629) * fix(lfx-dev): reload specific modules while preserving index cache * refactor: restructure component loading with strategy pattern for dev mode * fix: improve cache loading error handling in component index loading * refactor: reorganize CUGA and ALTK components into single-element bundles (#10671) * moved cuga and altk * reverted starter templates * [autofix.ci] apply automated fixes * updated import * [autofix.ci] apply automated fixes * revert starter templates * fixed some python tests * fix: update import assertions for backward compatibility in dynamic import tests * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * fix: update import paths for set_advanced_true and get_parent_agent_inputs in test_helper_functions --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * feat: fix cuga component with new release (#10646) * bufix(cuga_agent): fixed no output chat bug * fix: remove structured output feature * fix: stablize component * fix: chat output component not working * fix: add strategy flag * fix: update cuga version * feat: add component index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * update some imports to use lfx * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * fix: update review * chore: build component index * chore: build component * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * fix(cuga): ensure message id exists when not connected to output * fix: component result id on chat output * chore: fix component index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Revert test_agent_component.py back to origin/main * fix: remove unwanted tests * chore: new build index * [autofix.ci] apply automated fixes * fix: update test * chore: build index * [autofix.ci] apply automated fixes * fix: update package of cuga * chore: build component index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * update comp index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * trying comp index again? * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes --------- Co-authored-by: Offer Akrabi <offer.akrabi@il.ibm.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Jordan Frazier <jordan.frazier@datastax.com> * fix: Add IBM watsonx.ai support to EmbeddingModel (#10677) * Add IBM watsonx.ai support to EmbeddingModel Added IBM watsonx.ai as a supported provider in EmbeddingModelComponent, updated dependencies and code to integrate ibm_watsonx_ai and pydantic. Updated starter project and component index metadata to reflect new dependencies and code changes. * update watsonx default models * update index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Update test_embedding_model_component.py * Update component_index.json * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * fix: rename LLM router to LLM selector (#10650) * fix: rename LLM router to LLM selector * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * fix: rename LLMRouter component to LLMSelector * fix: resolved merge conflicts * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * fix: resolved merge conflicts * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * fix: refactor file name * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * fix: resolve merge conflict * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * fix: resolve merge conflict * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * Fix: add environment variable flag to log alembic to stdout (#10620) * fix: add flag to log alembic to stdout fix indentation refine docs mypy (db service.py) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * fix: move sql database to data source category (#10651) * fix: move sql database to data source category * [autofix.ci] apply automated fixes * fix: resolve merge conflict --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * fix: fixes YouTube Icon name in lazyloadingMapping (#10628) * fix lazyloadingMapping component name * fix: merge conflicts * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes * fix: resolve merge conflict --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * Fix: rename sidebar category flow controls to flow control (#10649) * rename sidebar category flow controls to flow control * fix: addressed PR comments * fix: expose logger functions at module level for backwards comp (#10670) * Expose logger functions at module level for backwards comp * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * feat: agentic UX (#10567) * Add empty __init__.py files for agentic modules Created empty __init__.py files in agentic, core, tools, and utils directories to initialize them as Python packages. * Add agentic template search utilities and tests Introduces a new agentic utilities module for Langflow, including template search, tag extraction, and template count functions. Adds a README, demo script, and comprehensive unit tests for template search functionality. * Add Langflow Agentic MCP server with FastMCP tools Introduces a new MCP (Model Context Protocol) server for Langflow agentic tools using FastMCP. Adds server, CLI, example usage, tests, and comprehensive documentation. Exposes four MCP tools: search_templates, get_template, list_all_tags, and count_templates, enabling AI assistants to query and filter Langflow templates programmatically. * Handle unparameterized list types in schema inputs Adds support for unparameterized list annotations by treating them as lists of strings when converting schemas to Langflow inputs. This ensures nullable array schemas without explicit item types are handled gracefully. * Refactor search_templates to simplify parameters Removed the 'tags' parameter from the search_templates function and set a default value for 'fields'. Updated the call to list_templates to match the new signature, streamlining template search functionality. * Add output item processing for tool results Introduced process_output_item to handle tool output items, attempting to parse text-type items as JSON. This improves downstream handling of tool outputs by converting JSON strings to dictionaries when possible. * Refactor knowledge base path initialization Replaces direct settings access with a lazy-loading function for the knowledge bases root path in Knowledge Ingestion and Knowledge Retrieval starter projects. This improves reliability and consistency when accessing the knowledge base directory, and updates all usages to the new helper function. * Update component_index.json * Add IBM watsonx.ai support to starter projects Introduces IBM watsonx.ai as a selectable model provider in multiple starter project JSONs. Adds new input fields for 'base_url', 'project_id', and 'max_output_tokens' to support IBM watsonx.ai integration. Updates agent component code to handle new provider and its required parameters. * Add Ollama to supported LLM providers in starter projects Ollama has been added as a supported provider alongside Anthropic, Google Generative AI, OpenAI, and IBM watsonx.ai in all starter project JSON files. This expands the available options for LLM integration in initial setup templates. * Update Ollama model input constants and logic Refactored model_input_constants.py to update the OLLAMA_MODEL_INPUTS and OLLAMA_MODEL_INPUTS_MAP. Modified ollama.py to use the new input mapping and improved input handling for Ollama components. * Add flow creation from template MCP tool Introduces a new MCP tool for creating flows from starter templates in Langflow Agentic. Adds the utility function `create_flow_from_template_and_get_link` and exposes it via the FastMCP server, allowing users to create flows by template id and receive a UI link. Updates imports and documentation accordingly. * Add component search utilities and MCP tools to server Introduces new component search and retrieval tools to the MCP server, including endpoints for searching, listing, and counting components. Adds support functions in support.py for data normalization and a new component_search.py utility module. Updates the Nvidia Remix starter project to use the latest MCPToolsComponent code. * Add flow graph visualization utilities Introduces async utility functions for generating ASCII and text representations of flow graphs, as well as metadata summaries. These utilities support fetching flows by ID or name, error handling, and integration with Langflow's graph and logging modules. * Add flow component operations utilities and MCP tools Introduces flow component management utilities in `flow_component.py` for retrieving, updating, and listing component field values. Exposes new MCP tools in `server.py` for accessing component details, field values, updating fields, and listing all fields within a flow component. * Add SystemMessageGen flow and update MCPTools Introduces SystemMessageGen.json flow for agentic system message generation and updates MCPTools component logic in flow_component.py to support new flow structure and tool handling. * feat: init aiButton create an aiButton that opens the prompt modal for demoing add multiinput mixin * Update component_index.json * Refactor SystemMessageGen flow and remove unused init files Updated SystemMessageGen.json to support custom instructions, OpenAI model configuration, and improved agent settings. Removed unused __init__.py files from agentic, core, tools, and utils directories to clean up the codebase. * update to the mcp component * Add verify_ssl option to MCPToolsComponent Introduces a 'verify_ssl' boolean input to MCPToolsComponent for controlling SSL certificate verification in HTTPS connections. The option is added to the server config if not present, allowing users to disable verification for development or testing with self-signed certificates. * Optimize tool dropdown handling and output processing Improves logic for updating tool dropdown options by checking if the server has changed and whether tool mode is active, reducing unnecessary updates. Adds a process_output_item method to parse tool output as JSON when appropriate, enhancing output handling. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * feat: init onclick assistant prompt generation first pass at on button click generate input and auto fill a field * Replace MCPTools with Prompt Template in SystemMessageGen flow Updated the SystemMessageGen.json flow to use the Prompt Template and Parser components instead of MCPTools. Adjusted edges, nodes, and component configurations to reflect the new prompt-based workflow, removing tool selection and execution logic in favor of prompt generation and parsing. * Update SystemMessageGen flow and frontend dependencies Refactored edge connections and metadata in SystemMessageGen.json to improve flow logic and updated endpoint name. Added new optional and peer dependencies to package-lock.json, including @mapbox/node-pre-gyp and related packages, to support canvas and other modules. * Update user authentication in simplified_run_flow endpoint Replaces the dependency on api_key_security with CurrentActiveUser for the api_key_user parameter in the simplified_run_flow endpoint. This change is part of a TODO to create a new endpoint and may affect how user authentication is handled. * feat: hook everything up and have onclick prompt hook up commit * Add auto-configuration for Agentic MCP server Introduces utilities and startup logic to automatically configure the Langflow Agentic MCP server for all users when the agentic experience is enabled. Adds a new settings flag `agentic_experience` to control this feature, and updates the main server startup to trigger configuration. This enables agentic tools for flow/component operations, template search, and graph visualization in MCP clients. * Enable agentic MCP server and improve initialization Set agentic_experience to True by default in settings. Refactor agentic MCP server initialization in main.py to run in the background with a delay and retry logic, improving startup reliability. Update function calls to use 'current_user' instead of 'user' in agentic_mcp.py for consistency. * Update user authentication in simplified_run_flow Modified the api_key_user parameter to accept either CurrentActiveUser or UserRead from api_key_security, supporting both Bearer and session authentication methods. * revert the apikeu_user changes * test new api endpoint * Refactor agent flow and update component inputs Updated SystemMessageGen.json to refactor edge connections and node IDs for agentic flow. Added 'base_url' as a required input, enabled 'ai_enabled' for agent description, and replaced static memory input handling with dynamic retrieval via get_base_inputs(). Also improved tool callback setup and updated code hash and last_updated metadata. * Improve agentic flow creation and updating logic Enhances the agentic flow setup to extract flow_id and endpoint_name from JSON, update existing flows by ID or endpoint_name, and create new flows if they don't exist. Adds detailed logging and ensures flows are up-to-date in the user's Langflow Assistant folder. * chore: aibutton clean up * chore: add assistant store * Update SystemMessageGen.json * Update agentic_mcp.py * Update component_index.json * Fix agent input extraction from Message objects Agents now correctly extract and use the text content from Message objects, rather than passing the entire object or its string representation. This resolves issues where agents received verbose message representations instead of just the intended string input, and includes improved handling for multimodal content. Corresponding unit and integration tests have been added to verify this behavior for both OpenAI and Anthropic agents. * Add TemplateAssistant Langflow flow definition Introduces TemplateAssistant.json, a comprehensive Langflow flow configuration for agentic workflows. This flow integrates AstraDB, MCP Tools, and user input/output nodes, enabling document ingestion, search, and tool orchestration within the Langflow backend. * Improve MCPToolsComponent server/tool config refresh Refactored MCPToolsComponent to better handle tool and server config refreshes, especially when the MCP server changes. Added logic to avoid unnecessary clearing of tool inputs and options, and improved caching and UI update behavior for tool selection. Also updated related flow and starter project JSON files to reflect these changes. * auto add Global Variables for Agentic Experience * chore: clean up and get button working again * cleanup .md * fix:ruff, Refactor agentic utils and improve error handling Introduces shared default field lists for template/component search, refactors exception handling to use logger and add finally/else blocks, and improves type hinting with TYPE_CHECKING. Updates file opening to use Path objects, enhances error logging in template search, and removes the unused test_template_search.py file. * fix:ruff Expand exception handling in agentic MCP utilities Broadened exception handling in agentic MCP server and variable management functions to catch specific errors such as HTTPException, SQLAlchemyError, and common system exceptions. This improves robustness and error logging during server configuration, removal, and variable initialization. * aka-clean-up-1 * Remove duplicate process_output_item method Deleted two redundant definitions of the process_output_item method from MCPToolsComponent to clean up the code and prevent confusion. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes * Refactor service usage and improve project deletion logging Refactored login API to reuse a single settings service instance. Enhanced logging and error messaging when attempting to delete the Langflow Assistant folder. Minor variable usage cleanup in agentic flows setup and agent component test. * [autofix.ci] apply automated fixes (attempt 2/3) * Update test_template_search.py * Handle specific exceptions in agentic flow loading Updated the exception handling in load_agentic_flows to catch only OSError and orjson.JSONDecodeError instead of all exceptions, improving error specificity and logging. * Update component_index.json * [autofix.ci] apply automated fixes * revert loading setting service * Update login.py * Update SystemMessageGen.json * Update TemplateAssistant.json * [autofix.ci] apply automated fixes * Update constants.py * chore: seperate templateassistant and sysmessgen seperate templateassistant and sysmessgen frontend queries * chore: add header feature flag * use feature flag for all ui * [autofix.ci] apply automated fixes * package-lcok update * [autofix.ci] apply automated fixes * chore: LANGFLOW_AGENTIC_EXPERIENCE fe ff name * Update login.py * lint fix * [autofix.ci] apply automated fixes * Update component_index.json * chore: fix adjust-screan-view click * chore: same force issue as adjust-screen-view * chore: playwright pass 2 * revert package-lock * add type to langflow_modules * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * Handle TypeError in class-based serialization Adds a try-except block to catch TypeError when checking issubclass for objects that are types but not proper classes, such as typing special forms. This prevents serialization errors for generic aliases and similar constructs. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * Refactor type handling in field update and serialization Changed 'new_value' parameter type to str in update_flow_component_field for stricter typing. Simplified exception handling in serialize by removing unnecessary try/except around issubclass checks for class-based Pydantic types. --------- Co-authored-by: Adam Aghili <Adam.Aghili@ibm.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * ci: bump actions/checkout to v6 (#10697) * feat: Improve OAuth error handling and frontend sync behavior (#10626) * updates for version comp * migrate mcp composer fix to main * migrate mcp composer fix to main * version constraints * go back to pydantic 2.11 * remove logging * directly pin to new version * add instant feedback on error * improve callback function behavior ux * fix tests and mypy issues * bump mcp composer version * fixed latest version mcp * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * revert pydantic changes * computed models pydantic fix * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- Co-authored-by: Jordan Frazier <jordan.frazier@datastax.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Hamza Rashid <hzarashid@gmail.com> * fix: Fix TypeError when LANGFLOW_ENABLE_LOG_RETRIEVAL is enabled (#10681) * fix serialize issue when LANGFLOW_ENABLE_LOG_RETRIEVAL is true * add logger tests * [autofix.ci] apply automated fixes * add multiple buffer checker * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * use serialize instead * [autofix.ci] apply automated fixes --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Edwin Jose <edwin.jose@datastax.com> * docs: update component documentation links to individual pages * Revert "docs: update component documentation links to individual pages" This reverts commit 1da51d4ccba9458506da6ff5b1ab7af23f09c2b6. * test: catch import errors upfront (#10632) * Convert to async and ruff-friendly print * Implement the checking into existing test file itself * Remove the newly introduced lfx test which is now incorporated into existing tests * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Run make build_component_index after merging latest from main * [autofix.ci] apply automated fixes * Revert "docs: update component documentation links to individual pages" This reverts commit 1da51d4ccba9458506da6ff5b1ab7af23f09c2b6. * build component index after origin/main merge into feature branch * [autofix.ci] apply automated fixes --------- Co-authored-by: Madhavan <cxo@ibm.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Mendon Kissling <59585235+mendonk@users.noreply.github.com> * feat: Support appending files when saving (#10631) * feat: Support appending files when saving * Update save_file.py * Update News Aggregator.json * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Update save_file.py * Update save_file.py * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes * Overwrite existing file if append mode is true * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Update test_mcp_servers_file.py * [autofix.ci] apply automated fixes * Update save_file.py * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * chore: Update pip and setuptools version constraints (#10708) * update setuptools and pip * remove from lfx pypoetry * feat: Display node name in download error message (#10707) add component name on download error * feat: Add Message Support for Input of Loop Component (#10160) * feat: Add support for messages in Loop Component * feat: Add Message support for input of Loop Component * [autofix.ci] apply automated fixes * Update src/frontend/src/utils/reactflowUtils.ts Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com> * [autofix.ci] apply automated fixes * More cleanup of looping * Fix ruff errors * [autofix.ci] apply automated fixes * Update loop-component.spec.ts * Make loop types generic * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Fixes from gabriel review * [autofix.ci] apply automated fixes --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com> Co-authored-by: Gabriel Luiz Freitas Almeida <gabriel@langflow.org> * fix: Support tool mode in File Component properly (#10520) * Support tool mode in dynamic outputs * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Tool mode and ruff fixes * Template updates * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Update test_mcp_servers_file.py * Revert "Update test_mcp_servers_file.py" This reverts commit 25f24d0d8aa5a7c95c913f862d86513749195ad1. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * add possibility for the agent to access the processed output file * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: cristhianzl <cristhian.lousa@gmail.com> Co-authored-by: Carlos Coelho <80289056+carlosrcoelho@users.noreply.github.com> * docs: include regex for sanitized input types (#10712) include-regex-for-sanitized-input * feat: Version 1.2 - comprehensive database migration guidelines using… (#10519) * feat: Version 1.2 - comprehensive database migration guidelines using the Expand-Contract pattern * Update src/backend/base/langflow/alembic/DB-MIGRATION-GUIDE.MD Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * fix: Cleanup text and typos * feat: Implement migration validation workflow and add migration validator scripts * Update src/backend/base/langflow/alembic/migration_validator.py Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/backend/base/langflow/alembic/migration_validator.py Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/backend/base/langflow/alembic/migration_validator.py Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * fix: moved the test_migrations directory to under tests * feat: Added migration validator to pre-commit check. * fix: improved test performance. * fix: optimized attribute resolution in migration validator * feat: add comprehensive tests for migration validator and guidelines * fix: Lint is complaining about shebang declared but not being used. * fix: Shebang reinstated. * Update src/backend/base/langflow/alembic/DB-MIGRATION-GUIDE.MD Co-authored-by: Copilot <175728472+Copilot@users.…
* docs: Improve README Quickstart section and add dark mode logo (#10358) * Improve README Quickstart section and reorganize installation options - Add prominent Desktop download section before Quickstart - Remove $ symbols from shell commands to fix copy button functionality - Add clear 'Run from source' option with make run_cli for developers - Improve Docker installation instructions with usage details - Move security warnings to after installation options for better flow - Remove redundant star/issues badges These changes address common user confusion when trying to run Langflow, especially for developers who clone the repo first and then struggle with the package installation instructions. 🤖 Generated with [Claude Code](https://claude.ai/code) * Add dark mode logo support - Added picture element for automatic dark/light mode logo switching - Dark mode shows blue background logo, light mode shows black logo 🤖 Generated with [Claude Code](https://claude.ai/code) * Final README improvements - Made 'Other install options' a proper section with emoji - Updated deployment section with rocket emoji - Fixed single-line formatting for subsections - Added new star animation gif - Changed 'tool' to 'platform' in description * Improve Desktop download section messaging - Made text more concise and action-oriented - Changed download emoji from arrow to inbox - Removed redundant 'built-in' and bold formatting - Cleaner parenthetical for OS availability * Revise README for Langflow Desktop and deployment info Updated sections for clarity and added details about Langflow Desktop and deployment options. * Revert star gif to GitHub attachment URL Testing if local file path issue or markdown previewer issue * Apply suggestion from @mendonk * Apply suggestion from @mendonk * Apply suggestion from @mendonk * Apply suggestion from @mendonk * readme-changes * Apply suggestion from @mendonk --------- * fix: require active user for monitor endpoints (#10568) Require active user for monitor endpoints * refactor: Reorganize sidebar categories (#10180) * Reorganize sidebar categories * finishing touches * templates * ruff check fix * merge fix * filter out knowledge when ff'd off * BE tests * [autofix.ci] apply automated fixes * more test fixes * integration test fix * Unit tests * more test fixes * reorg tests * [autofix.ci] apply automated fixes * update ui tests * [autofix.ci] apply automated fixes * mcp and playwright tests * [autofix.ci] apply automated fixes * BE test fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * test fix --------- * fix(agent): handle missing message id for disconnected agents (#10560) * fix(agent): handle missing message id for disconnected agents * [autofix.ci] apply automated fixes * will this update comp index * comp index --------- * fix: Langflow logo on home page when s3 is enabled (#10352) * fixed and added tests * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- * fix(playground): preserve timer start time when playground is reopened (#10516) * Fix playground timer * add jest unit tests --------- * fix: MCP component auto reset issue in non Tool Mode (#10440) * Optimize tool dropdown handling and output processing Improves logic for updating tool dropdown options by checking if the server has changed and whether tool mode is active, reducing unnecessary updates. Adds a process_output_item method to parse tool output as JSON when appropriate, enhancing output handling. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * Update component_index.json * Update Nvidia Remix.json * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Update component_index.json * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * use cache enabled even for the no tool mode * Update component_index.json * [autofix.ci] apply automated fixes * Update Nvidia Remix.json * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * Add Notion integration components to index Updated component_index.json to include new Notion integration components: AddContentToPage, NotionDatabaseProperties, NotionListPages, NotionPageContent, NotionPageCreator, NotionPageUpdate, and NotionSearch. These components provide functionality for interacting with Notion databases and pages, including querying, creating, updating, and retrieving content. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * fix: add selector to let dropdown load add Select a tool selector to let dropdown load before interacting * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Update MCPToolsComponent code and metadata Updated the code and code_hash for MCPToolsComponent in Nvidia Remix starter project and synchronized the component_index.json to reflect the latest code and metadata. This ensures consistency and includes recent improvements or fixes to the MCPToolsComponent implementation. --------- * fix: Switch to browser-compatible MathJax import (#10563) add browser support to rehype package build * feat: patch icons to support dark theme and Composio Slack component fix. (#10577) * feat: add Composio Components & logos tweak * Display name consistency * update init * fix: format * fix: suggested changes by Mike * feat: add Composio Components & logos tweak * Display name consistency * update init * fix: format * fix: suggested changes by Mike * updates components JSON * fix: format * updates components JSON * Remove unnecessary blank lines in __init__.py Cleaned up formatting by deleting extra blank lines in the _dynamic_imports dictionary for improved readability. * Update component_index.json * Update component_index.json * Update component_index.json * Update component_index.json * fix: Slack component issue * fix: icons update to support dark theme * fix: Klaviyo imports * Update component_index.json --------- * feat: add toolkit_versions and updated composio and composio_langchain versions. (#10578) * feat: added toolkit versions and updated composio and composio_langchain packages * fix: format --------- * fix: marked required fields for fields with MultilineInput input types. (#10579) fix: marked required fields with MultilineInputs * feat: replaced initiate method with link method. (#10580) feat: replaced .initiate() with .link() * feat: Add ALTK Agent with tool validation and comprehensive tests (#10587) * Add ALTK Agent with tool validation and comprehensive tests - Added agent-lifecycle-toolkit~=0.4.1 dependency to pyproject.toml - Implemented ALTKBaseAgent with comprehensive error handling and tool validation - Added ALTKToolWrappers for SPARC integration and tool execution safety - Created ALTK Agent component with proper LangChain integration - Added comprehensive test suite covering tool validation, conversation context, and edge cases - Fixed docstring formatting to comply with ruff linting standards * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * minor fix to execute_tool that was left out. * Fixes following coderabbitai comments. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * Update component_index.json * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Add custom message to dict conversion in ValidatedTool * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Add Notion integration components to index Updated component_index.json to include new Notion integration components: AddContentToPage, NotionDatabaseProperties, NotionListPages, NotionPageContent, NotionPageCreator, NotionPageUpdate, and NotionSearch. These components provide functionality for interacting with Notion databases and pages, including querying, creating, updating, and retrieving content. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) --------- * feat: Add MCP server config sanitization for sensitive data (#10552) add clean mcp config function * feat: Implement dynamic model discovery system (#10523) * add dynamic model request * add description to groq * add cache folder to store cache models json * change git ignore description * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * add comprehensive tests for Groq dynamic model discovery - Add 101 unit tests covering success, error, and edge cases - Test model discovery, caching, tool calling detection - Test fallback models and backward compatibility - Add support for real GROQ_API_KEY from environment - Fix all lint errors and improve code quality * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * fix Python 3.10 compatibility - replace UTC with timezone.utc Python 3.10 doesn't have datetime.UTC, need to use timezone.utc instead * fix pytest hook signature - use config instead of _config * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * fix conftest config.py * fix timezone UTC on tests * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) --------- * feat: remove `code` from Transactions to reduce clutter in logs (#10400) * refactor: remove code from transaction model inputs * refactor: remove code from transaction model inputs * tests: add tests to make sure code is not added to transactions data * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * refactor: improve code removal from logs with explicit dict copying --------- * refactor(service_manager): implement lazy initalization of service manager (#8828) * refactor: implement lazy initialization for ServiceManager with thread safety - Replaced direct instantiation of ServiceManager with a lazy initialization approach using a global variable and threading lock. - Updated the public API to expose `get_service_manager` for retrieving the singleton instance. - Ensured thread-safe access to the ServiceManager instance to prevent issues during module import. * refactor: update service manager imports to use get_service_manager - Replaced direct imports of service_manager with get_service_manager in multiple files to ensure consistent access to the singleton instance. - This change enhances code clarity and maintains the lazy initialization approach for the ServiceManager. * refactor: remove deprecated Enhanced ServiceManager implementation * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * refactor: implement thread-safe lazy initialization for ServiceManager * feat: add filelock dependency in lfx * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * update component index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- * feat: new release for cuga component (#10591) * feat: new release of cuga * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * fix: address review * fix: fixed more bugs * fix: build component index * [autofix.ci] apply automated fixes * fix: update test * chore: update component index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- * ci: upgrade playwright to 1.56 and fix second time imports (#10284) * chore: update Playwright and related dependencies to version 1.56.0 in package.json and package-lock.json * refactor: update addLegacyComponents function to improve selector checks - Replaced the expect assertion with a waitForSelector call to ensure the sidebar legacy switch is checked, enhancing reliability in tests. - Updated import statement for Page from "@playwright/test" for consistency with current practices. * fix playwright imports * chore: update Playwright version in CI workflow to 1.56.0 for consistency with project dependencies * refactor: enhance lockFlow and unlockFlow functions for improved visibility checks - Replaced isVisible calls with waitFor to ensure elements are visible before proceeding, enhancing test reliability. - Removed unnecessary waitForTimeout calls to streamline the flow execution process. * test(playwright): add validation for settings menu header text * refactor(playwright): improve lock flow test with expect assertions * refactor(playwright): simplify legacy component toggle validation * feat: adds Component Inputs telemetry (#10254) * feat: Introduce telemetry tracking for sensitive field types Added a new set of field types that should not be tracked in telemetry due to their sensitive nature, including PASSWORD, AUTH, FILE, CONNECTION, and MCP. Updated relevant input classes to ensure telemetry tracking is disabled for these sensitive fields, enhancing data privacy and security. * feat: Enhance telemetry payloads with additional fields and serialization support Added new fields to the ComponentPayload and ComponentInputsPayload classes, including component_id and component_run_id, to improve telemetry data tracking. Introduced a serialize_input_values function to handle JSON serialization of component input values, ensuring robust handling of input data for telemetry purposes. * feat: Implement telemetry input tracking and caching Added functionality to track and cache telemetry input values within the Component class. Introduced a method to determine if inputs should be tracked based on sensitivity and an accessor for retrieving cached telemetry data, enhancing the robustness of telemetry handling. * feat: Add logging for component input telemetry Introduced a new method, log_package_component_inputs, to the TelemetryService for logging telemetry data related to component inputs. This enhancement improves the tracking capabilities of the telemetry system, allowing for more detailed insights into component interactions. * feat: Enhance telemetry logging for component execution Added functionality to log component input telemetry both during successful execution and error cases. Introduced a unique component_run_id for each execution to improve tracking. This update ensures comprehensive telemetry data collection, enhancing the robustness of the telemetry system. * feat: Extend telemetry payload tests and enhance serialization Added tests for the new component_id and component_run_id fields in ComponentPayload and ComponentInputsPayload classes. Introduced a new test suite for ComponentInputTelemetry, covering serialization of various data types and handling of edge cases. This update improves the robustness and coverage of telemetry data handling in the system. * fix: Update default telemetry tracking behavior in BaseInputMixin Changed the default value of track_in_telemetry from True to False in the BaseInputMixin class. Updated documentation to clarify that telemetry tracking is now opt-in and can be explicitly enabled for individual input types, enhancing data privacy and control. * fix: Update telemetry tracking defaults for input types Modified the default value of `track_in_telemetry` for various input classes to enhance data privacy. Regular inputs now default to False, while safe inputs like `IntInput` and `BoolInput` default to True, ensuring explicit opt-in for telemetry tracking. Updated related tests to reflect these changes. * feat: add chunk_index and total_chunks fields to ComponentInputsPayload This commit adds two new optional fields to ComponentInputsPayload: - chunk_index: Index of this chunk in a split payload sequence - total_chunks: Total number of chunks in the split sequence Both fields default to None and use camelCase aliases for serialization. This is Task 1 of the telemetry query parameter splitting implementation. Tests included: - Verify fields exist and can be set - Verify camelCase serialization aliases work correctly - Verify fields default to None when not provided Generated with Claude Code (https://claude.com/claude-code) * refactor: update ComponentInputsPayload to support automatic splitting of oversized inputs This commit enhances the ComponentInputsPayload class by implementing functionality to automatically split input values into multiple chunks if they exceed the maximum URL size limit. Key changes include: - Added methods for calculating URL size, truncating oversized values, and splitting payloads. - Updated component_inputs field to accept a dictionary instead of a string for better handling of input values. - Improved documentation for the ComponentInputsPayload class to reflect the new splitting behavior and usage examples. These changes aim to improve telemetry data handling and ensure compliance with URL length restrictions. * refactor: enhance log_package_component_inputs to handle oversized payloads This commit updates the log_package_component_inputs method in the TelemetryService class to split component input payloads into multiple requests if they exceed the maximum URL size limit. Key changes include: - Added logic to split the payload using the new split_if_needed method. - Each chunk is queued separately for telemetry logging. These improvements ensure better handling of telemetry data while adhering to URL length restrictions. * refactor: centralize maximum telemetry URL size constant This commit introduces a centralized constant, MAX_TELEMETRY_URL_SIZE, to define the maximum URL length for telemetry GET requests. Key changes include: - Added MAX_TELEMETRY_URL_SIZE constant to schema.py for better maintainability. - Updated split_if_needed method in ComponentInputsPayload to use the new constant instead of a hardcoded value. - Adjusted the TelemetryService to reference the centralized constant for URL size limits. These changes enhance code clarity and ensure consistent handling of URL size limits across the telemetry service. * refactor: update ComponentInputsPayload tests to use dictionary inputs This commit modifies the tests for ComponentInputsPayload to utilize a dictionary for component inputs instead of a serialized JSON string. Key changes include: - Renamed the test method to reflect the new input type. - Removed unnecessary serialization steps and assertions related to JSON strings. - Added assertions to verify the correct handling of dictionary inputs. These changes streamline the testing process and improve clarity in how component inputs are represented. * test: add integration tests for telemetry service payload splitting This commit introduces integration tests for the TelemetryService to verify its handling of large and small payloads. Key changes include: - Added tests to ensure large payloads are split into multiple chunks and queued correctly. - Implemented a test to confirm that small payloads are not split and result in a single queued event. - Created a mock settings service for testing purposes. These tests enhance the reliability of the telemetry service by ensuring proper payload management. * test: enhance ComponentInputsPayload tests with additional scenarios This commit expands the test suite for ComponentInputsPayload by adding various scenarios to ensure robust handling of input payloads. Key changes include: - Introduced tests for calculating URL size, ensuring it returns a positive integer and accounts for encoding. - Added tests to verify the splitting logic for large payloads, including checks for chunk metadata and preservation of fixed fields. - Implemented property-based tests using Hypothesis to validate that all chunks respect the maximum URL size and preserve original data. These enhancements improve the reliability and coverage of the ComponentInputsPayload tests, ensuring proper functionality under various conditions. * [autofix.ci] apply automated fixes * optimize query param encoding * refactor: extract telemetry logging logic into a separate function This commit introduces a new function, _log_component_input_telemetry, to centralize the logic for logging component input telemetry. The function is called in two places within the generate_flow_events function, improving code readability and maintainability by reducing duplication. This change enhances the clarity of telemetry handling in the flow generation process. * refactor: optimize truncation logic in ComponentInputsPayload This commit refines the truncation logic for input values in the ComponentInputsPayload class. The previous binary search method for string values has been simplified, allowing for direct truncation of both string and non-string values. This change enhances code clarity and maintains functionality while ensuring optimal handling of oversized inputs. * refactor: update telemetry tracking logic to respect opt-in flag This commit modifies the telemetry tracking logic in the Component class to change the default behavior of the `track_in_telemetry` attribute from True to False. This adjustment enhances user privacy by requiring explicit consent for tracking input objects in telemetry. The change ensures that sensitive field types are still auto-excluded from tracking, maintaining the integrity of the telemetry data. * refactor: update tests to use dictionary format for component inputs This commit modifies the integration tests for telemetry payload validation and component input telemetry to utilize dictionaries for component inputs instead of serialized JSON strings. Key changes include: - Updated assertions to compare dictionary inputs directly. - Enhanced clarity and maintainability of the test cases by removing unnecessary serialization steps. These changes improve the representation of component inputs in tests, aligning with recent refactoring efforts. * [autofix.ci] apply automated fixes * refactor: specify type for current_chunk_inputs in ComponentInputsPayload This commit updates the type annotation for the current_chunk_inputs variable in the ComponentInputsPayload class to explicitly define it as a dictionary. This change enhances code clarity and maintainability by providing better type information for developers working with the code. * test: add component_id to ComponentPayload tests This commit enhances the test cases for the ComponentPayload class by adding a component_id parameter to various initialization tests. The updates ensure that the component_id is properly tested across different scenarios, including valid parameters, error messages, and edge cases. This change improves the robustness of the tests and aligns with recent updates to the ComponentPayload structure. * [autofix.ci] apply automated fixes * feat: add component_id to ComponentPayload in build_vertex function * fix: update MAX_TELEMETRY_URL_SIZE to 2048 and adjust related tests This commit increases the maximum URL size for telemetry GET requests from 2000 to 2048 bytes to align with Scarf's specifications. Corresponding test assertions have been updated to reference the new constant, ensuring consistency across the codebase. * [autofix.ci] apply automated fixes * feat(telemetry): add track_in_telemetry field to starter project configurations * refactor(telemetry): remove unused blank line in test imports * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * update starter templates * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) --------- * fix(telemetry): resolve cyclic import in telemetry service (#10598) * fix(telemetry): resolve cyclic import by moving get_email_model * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) --------- * feat: Add gpt-5.1 model to Language models (#10590) * Add gpt-5.1 model to starter projects Added 'gpt-5.1' to the list of available models in all starter project JSON files to support the new model version. This update ensures users can select gpt-5.1 in agent configurations. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Update component_index.json * [autofix.ci] apply automated fixes * Update component_index.json * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- * fix: Use the proper Embeddings import for Qdrant vector store (#10613) * Use the proper Embeddings import for Qdrant vector store * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- * fix: Ensure split text test is more robust (#10622) * fix: Ensure split text test is more robust * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- * docs: security notice (#10555) * docs-security-notice * Apply suggestions from code review * code-review * link-to-security-bulletin * Apply suggestions from code review --------- * fix: use issubclass in the pool creation (#10232) * use issubclass in the pool creation * [autofix.ci] apply automated fixes * add poolclass pytests * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- * docs: OpenAPI spec version upgraded from 1.6.5 to 1.6.8 (#10627) * chore: Fix indentation on bundles-docling.mdx (#10640) * feat: make it possible to load graphs using `get_graph` function in scripts (#9913) * feat: Enhance graph loading functionality to support async retrieval - Updated `load_graph_from_script` to be an async function, allowing for the retrieval of the graph via an async `get_graph` function if available. - Implemented fallback to the existing `graph` variable for backward compatibility. - Enhanced `find_graph_variable` to identify both `get_graph` function definitions and `graph` variable assignments, improving flexibility in script handling. * feat: Update load_graph_from_script to support async graph retrieval - Refactored `load_graph_from_script` to be an async function, enabling the use of an async `get_graph` function for graph retrieval. - Implemented a fallback mechanism to access the `graph` variable for backward compatibility. - Enhanced error handling to provide clearer messages when neither `graph` nor `get_graph()` is found in the script. * feat: Refactor simple_agent.py to support async graph creation - Introduced an async `get_graph` function to handle the initialization of components and graph creation without blocking. - Updated the logging configuration and component setup to be part of the async function, improving the overall flow and responsiveness. - Enhanced documentation for the `get_graph` function to clarify its purpose and return type. * feat: Update serve_command and run functions to support async graph loading - Refactored `serve_command` to be an async function using `syncify`, allowing for non-blocking execution. - Updated calls to `load_graph_from_path` and `load_graph_from_script` within `serve_command` and `run` to await their results, enhancing performance and responsiveness. - Improved overall async handling in the CLI commands for better integration with async workflows. * feat: Refactor load_graph_from_path to support async execution - Changed `load_graph_from_path` to an async function, enabling non-blocking graph loading. - Updated the call to `load_graph_from_script` to use await, improving performance during graph retrieval. - Enhanced the overall async handling in the CLI for better integration with async workflows. * feat: Enhance async handling in simple_agent and related tests - Updated `get_graph` function in `simple_agent.py` to utilize async component initialization for improved responsiveness. - Modified test cases in `test_simple_agent_in_lfx_run.py` to validate the async behavior of `get_graph`. - Refactored various test functions across multiple files to support async execution, ensuring compatibility with the new async workflows. - Improved documentation for async functions to clarify their purpose and usage. * docs: Implement async get_graph function for improved component initialization - Introduced an async `get_graph` function in `README.md` to facilitate non-blocking component initialization. - Enhanced the logging configuration and component setup within the async function, ensuring a smoother flow. - Updated documentation to clarify the purpose and return type of the `get_graph` function, aligning with the async handling improvements. * refactor: reorder imports in simple_agent test file * style: reorder imports in simple_agent test file * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * update component index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- * feat: Add custom download node function (#10659) * add custom download node * use download node * feat: Add type check before issubclass in service discovery (#10636) * Add type check before issubclass in service discovery Added an isinstance(obj, type) check before issubclass to prevent errors when inspecting module members for Service and ServiceFactory subclasses. This improves robustness when dynamically importing services and factories. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes --------- * docs: readme update (#10657) * dep-management * are * fix: minor redesign of guardrails for disabling components in LF Astra cloud (#10662) * create cloud validation util file disable local_db if in astra cloud disable split_video if in astra cloud disable video_file component if in astra cloud ruff (video_file.py) correct the error message in video_file.py disable mem0 and composio in astra cloud update astra disable component util fn name to be more descriptive add tests for disabling components minor docs patch remove component disable check in places that interact with building the component index replace init test with execution in composio unit test suite remove dotenv from validate_cloud * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- * fix: prevent autofix workflow loop from bot commits (#10673) fix(ci): prevent autofix workflow loop from bot commits * fix(lfx-dev): reload specific modules while preserving index cache (#10629) * fix(lfx-dev): reload specific modules while preserving index cache * refactor: restructure component loading with strategy pattern for dev mode * fix: improve cache loading error handling in component index loading * refactor: reorganize CUGA and ALTK components into single-element bundles (#10671) * moved cuga and altk * reverted starter templates * [autofix.ci] apply automated fixes * updated import * [autofix.ci] apply automated fixes * revert starter templates * fixed some python tests * fix: update import assertions for backward compatibility in dynamic import tests * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * fix: update import paths for set_advanced_true and get_parent_agent_inputs in test_helper_functions --------- * feat: fix cuga component with new release (#10646) * bufix(cuga_agent): fixed no output chat bug * fix: remove structured output feature * fix: stablize component * fix: chat output component not working * fix: add strategy flag * fix: update cuga version * feat: add component index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * update some imports to use lfx * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * fix: update review * chore: build component index * chore: build component * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * fix(cuga): ensure message id exists when not connected to output * fix: component result id on chat output * chore: fix component index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Revert test_agent_component.py back to origin/main * fix: remove unwanted tests * chore: new build index * [autofix.ci] apply automated fixes * fix: update test * chore: build index * [autofix.ci] apply automated fixes * fix: update package of cuga * chore: build component index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * update comp index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * trying comp index again? * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes --------- * fix: Add IBM watsonx.ai support to EmbeddingModel (#10677) * Add IBM watsonx.ai support to EmbeddingModel Added IBM watsonx.ai as a supported provider in EmbeddingModelComponent, updated dependencies and code to integrate ibm_watsonx_ai and pydantic. Updated starter project and component index metadata to reflect new dependencies and code changes. * update watsonx default models * update index * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Update test_embedding_model_component.py * Update component_index.json * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- * fix: rename LLM router to LLM selector (#10650) * fix: rename LLM router to LLM selector * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * fix: rename LLMRouter component to LLMSelector * fix: resolved merge conflicts * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * fix: resolved merge conflicts * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * fix: refactor file name * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * fix: resolve merge conflict * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * fix: resolve merge conflict * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) --------- * Fix: add environment variable flag to log alembic to stdout (#10620) * fix: add flag to log alembic to stdout fix indentation refine docs mypy (db service.py) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- * fix: move sql database to data source category (#10651) * fix: move sql database to data source category * [autofix.ci] apply automated fixes * fix: resolve merge conflict --------- * fix: fixes YouTube Icon name in lazyloadingMapping (#10628) * fix lazyloadingMapping component name * fix: merge conflicts * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes * fix: resolve merge conflict --------- * Fix: rename sidebar category flow controls to flow control (#10649) * rename sidebar category flow controls to flow control * fix: addressed PR comments * fix: expose logger functions at module level for backwards comp (#10670) * Expose logger functions at module level for backwards comp * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes --------- * feat: agentic UX (#10567) * Add empty __init__.py files for agentic modules Created empty __init__.py files in agentic, core, tools, and utils directories to initialize them as Python packages. * Add agentic template search utilities and tests Introduces a new agentic utilities module for Langflow, including template search, tag extraction, and template count functions. Adds a README, demo script, and comprehensive unit tests for template search functionality. * Add Langflow Agentic MCP server with FastMCP tools Introduces a new MCP (Model Context Protocol) server for Langflow agentic tools using FastMCP. Adds server, CLI, example usage, tests, and comprehensive documentation. Exposes four MCP tools: search_templates, get_template, list_all_tags, and count_templates, enabling AI assistants to query and filter Langflow templates programmatically. * Handle unparameterized list types in schema inputs Adds support for unparameterized list annotations by treating them as lists of strings when converting schemas to Langflow inputs. This ensures nullable array schemas without explicit item types are handled gracefully. * Refactor search_templates to simplify parameters Removed the 'tags' parameter from the search_templates function and set a default value for 'fields'. Updated the call to list_templates to match the new signature, streamlining template search functionality. * Add output item processing for tool results Introduced process_output_item to handle tool output items, attempting to parse text-type items as JSON. This improves downstream handling of tool outputs by converting JSON strings to dictionaries when possible. * Refactor knowledge base path initialization Replaces direct settings access with a lazy-loading function for the knowledge bases root path in Knowledge Ingestion and Knowledge Retrieval starter projects. This improves reliability and consistency when accessing the knowledge base directory, and updates all usages to the new helper function. * Update component_index.json * Add IBM watsonx.ai support to starter projects Introduces IBM watsonx.ai as a selectable model provider in multiple starter project JSONs. Adds new input fields for 'base_url', 'project_id', and 'max_output_tokens' to support IBM watsonx.ai integration. Updates agent component code to handle new provider and its required parameters. * Add Ollama to supported LLM providers in starter projects Ollama has been added as a supported provider alongside Anthropic, Google Generative AI, OpenAI, and IBM watsonx.ai in all starter project JSON files. This expands the available options for LLM integration in initial setup templates. * Update Ollama model input constants and logic Refactored model_input_constants.py to update the OLLAMA_MODEL_INPUTS and OLLAMA_MODEL_INPUTS_MAP. Modified ollama.py to use the new input mapping and improved input handling for Ollama components. * Add flow creation from template MCP tool Introduces a new MCP tool for creating flows from starter templates in Langflow Agentic. Adds the utility function `create_flow_from_template_and_get_link` and exposes it via the FastMCP server, allowing users to create flows by template id and receive a UI link. Updates imports and documentation accordingly. * Add component search utilities and MCP tools to server Introduces new component search and retrieval tools to the MCP server, including endpoints for searching, listing, and counting components. Adds support functions in support.py for data normalization and a new component_search.py utility module. Updates the Nvidia Remix starter project to use the latest MCPToolsComponent code. * Add flow graph visualization utilities Introduces async utility functions for generating ASCII and text representations of flow graphs, as well as metadata summaries. These utilities support fetching flows by ID or name, error handling, and integration with Langflow's graph and logging modules. * Add flow component operations utilities and MCP tools Introduces flow component management utilities in `flow_component.py` for retrieving, updating, and listing component field values. Exposes new MCP tools in `server.py` for accessing component details, field values, updating fields, and listing all fields within a flow component. * Add SystemMessageGen flow and update MCPTools Introduces SystemMessageGen.json flow for agentic system message generation and updates MCPTools component logic in flow_component.py to support new flow structure and tool handling. * feat: init aiButton create an aiButton that opens the prompt modal for demoing add multiinput mixin * Update component_index.json * Refactor SystemMessageGen flow and remove unused init files Updated SystemMessageGen.json to support custom instructions, OpenAI model configuration, and improved agent settings. Removed unused __init__.py files from agentic, core, tools, and utils directories to clean up the codebase. * update to the mcp component * Add verify_ssl option to MCPToolsComponent Introduces a 'verify_ssl' boolean input to MCPToolsComponent for controlling SSL certificate verification in HTTPS connections. The option is added to the server config if not present, allowing users to disable verification for development or testing with self-signed certificates. * Optimize tool dropdown handling and output processing Improves logic for updating tool dropdown options by checking if the server has changed and whether tool mode is active, reducing unnecessary updates. Adds a process_output_item method to parse tool output as JSON when appropriate, enhancing output handling. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * feat: init onclick assistant prompt generation first pass at on button click generate input and auto fill a field * Replace MCPTools with Prompt Template in SystemMessageGen flow Updated the SystemMessageGen.json flow to use the Prompt Template and Parser components instead of MCPTools. Adjusted edges, nodes, and component configurations to reflect the new prompt-based workflow, removing tool selection and execution logic in favor of prompt generation and parsing. * Update SystemMessageGen flow and frontend dependencies Refactored edge connections and metadata in SystemMessageGen.json to improve flow logic and updated endpoint name. Added new optional and peer dependencies to package-lock.json, including @mapbox/node-pre-gyp and related packages, to support canvas and other modules. * Update user authentication in simplified_run_flow endpoint Replaces the dependency on api_key_security with CurrentActiveUser for the api_key_user parameter in the simplified_run_flow endpoint. This change is part of a TODO to create a new endpoint and may affect how user authentication is handled. * feat: hook everything up and have onclick prompt hook up commit * Add auto-configuration for Agentic MCP server Introduces utilities and startup logic to automatically configure the Langflow Agentic MCP server for all users when the agentic experience is enabled. Adds a new settings flag `agentic_experience` to control this feature, and updates the main server startup to trigger configuration. This enables agentic tools for flow/component operations, template search, and graph visualization in MCP clients. * Enable agentic MCP server and improve initialization Set agentic_experience to True by default in settings. Refactor agentic MCP server initialization in main.py to run in the background with a delay and retry logic, improving startup reliability. Update function calls to use 'current_user' instead of 'user' in agentic_mcp.py for consistency. * Update user authentication in simplified_run_flow Modified the api_key_user parameter to accept either CurrentActiveUser or UserRead from api_key_security, supporting both Bearer and session authentication methods. * revert the apikeu_user changes * test new api endpoint * Refactor agent flow and update component inputs Updated SystemMessageGen.json to refactor edge connections and node IDs for agentic flow. Added 'base_url' as a required input, enabled 'ai_enabled' for agent description, and replaced static memory input handling with dynamic retrieval via get_base_inputs(). Also improved tool callback setup and updated code hash and last_updated metadata. * Improve agentic flow creation and updating logic Enhances the agentic flow setup to extract flow_id and endpoint_name from JSON, update existing flows by ID or endpoint_name, and create new flows if they don't exist. Adds detailed logging and ensures flows are up-to-date in the user's Langflow Assistant folder. * chore: aibutton clean up * chore: add assistant store * Update SystemMessageGen.json * Update agentic_mcp.py * Update component_index.json * Fix agent input extraction from Message objects Agents now correctly extract and use the text content from Message objects, rather than passing the entire object or its string representation. This resolves issues where agents received verbose message representations instead of just the intended string input, and includes improved handling for multimodal content. Corresponding unit and integration tests have been added to verify this behavior for both OpenAI and Anthropic agents. * Add TemplateAssistant Langflow flow definition Introduces TemplateAssistant.json, a comprehensive Langflow flow configuration for agentic workflows. This flow integrates AstraDB, MCP Tools, and user input/output nodes, enabling document ingestion, search, and tool orchestration within the Langflow backend. * Improve MCPToolsComponent server/tool config refresh Refactored MCPToolsComponent to better handle tool and server config refreshes, especially when the MCP server changes. Added logic to avoid unnecessary clearing of tool inputs and options, and improved caching and UI update behavior for tool selection. Also updated related flow and starter project JSON files to reflect these changes. * auto add Global Variables for Agentic Experience * chore: clean up and get button working again * cleanup .md * fix:ruff, Refactor agentic utils and improve error handling Introduces shared default field lists for template/component search, refactors exception handling to use logger and add finally/else blocks, and improves type hinting with TYPE_CHECKING. Updates file opening to use Path objects, enhances error logging in template search, and removes the unused test_template_search.py file. * fix:ruff Expand exception handling in agentic MCP utilities Broadened exception handling in agentic MCP server and variable management functions to catch specific errors such as HTTPException, SQLAlchemyError, and common system exceptions. This improves robustness and error logging during server configuration, removal, and variable initialization. * aka-clean-up-1 * Remove duplicate process_output_item method Deleted two redundant definitions of the process_output_item method from MCPToolsComponent to clean up the code and prevent confusion. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes * Refactor service usage and improve project deletion logging Refactored login API to reuse a single settings service instance. Enhanced logging and error messaging when attempting to delete the Langflow Assistant folder. Minor variable usage cleanup in agentic flows setup and agent component test. * [autofix.ci] apply automated fixes (attempt 2/3) * Update test_template_search.py * Handle specific exceptions in agentic flow loading Updated the exception handling in load_agentic_flows to catch only OSError and orjson.JSONDecodeError instead of all exceptions, improving error specificity and logging. * Update component_index.json * [autofix.ci] apply automated fixes * revert loading setting service * Update login.py * Update SystemMessageGen.json * Update TemplateAssistant.json * [autofix.ci] apply automated fixes * Update constants.py * chore: seperate templateassistant and sysmessgen seperate templateassistant and sysmessgen frontend queries * chore: add header feature flag * use feature flag for all ui * [autofix.ci] apply automated fixes * package-lcok update * [autofix.ci] apply automated fixes * chore: LANGFLOW_AGENTIC_EXPERIENCE fe ff name * Update login.py * lint fix * [autofix.ci] apply automated fixes * Update component_index.json * chore: fix adjust-screan-view click * chore: same force issue as adjust-screen-view * chore: playwright pass 2 * revert package-lock * add type to langflow_modules * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * Handle TypeError in class-based serialization Adds a try-except block to catch TypeError when checking issubclass for objects that are types but not proper classes, such as typing special forms. This prevents serialization errors for generic aliases and similar constructs. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * Refactor type handling in field update and serialization Changed 'new_value' parameter type to str in update_flow_component_field for stricter typing. Simplified exception handling in serialize by removing unnecessary try/except around issubclass checks for class-based Pydantic types. --------- * ci: bump actions/checkout to v6 (#10697) * feat: Improve OAuth error handling and frontend sync behavior (#10626) * updates for version comp * migrate mcp composer fix to main * migrate mcp composer fix to main * version constraints * go back to pydantic 2.11 * remove logging * directly pin to new version * add instant feedback on error * improve callback function behavior ux * fix tests and mypy issues * bump mcp composer version * fixed latest version mcp * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * revert pydantic changes * computed models pydantic fix * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- * fix: Fix TypeError when LANGFLOW_ENABLE_LOG_RETRIEVAL is enabled (#10681) * fix serialize issue when LANGFLOW_ENABLE_LOG_RETRIEVAL is true * add logger tests * [autofix.ci] apply automated fixes * add multiple buffer checker * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * use serialize instead * [autofix.ci] apply automated fixes --------- * docs: update component documentation links to individual pages * Revert "docs: update component documentation links to individual pages" This reverts commit 1da51d4ccba9458506da6ff5b1ab7af23f09c2b6. * test: catch import errors upfront (#10632) * Convert to async and ruff-friendly print * Implement the checking into existing test file itself * Remove the newly introduced lfx test which is now incorporated into existing tests * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Run make build_component_index after merging latest from main * [autofix.ci] apply automated fixes * Revert "docs: update component documentation links to individual pages" This reverts commit 1da51d4ccba9458506da6ff5b1ab7af23f09c2b6. * build component index after origin/main merge into feature branch * [autofix.ci] apply automated fixes --------- * feat: Support appending files when saving (#10631) * feat: Support appending files when saving * Update save_file.py * Update News Aggregator.json * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Update save_file.py * Update save_file.py * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes * Overwrite existing file if append mode is true * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Update test_mcp_servers_file.py * [autofix.ci] apply automated fixes * Update save_file.py * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- * chore: Update pip and setuptools version constraints (#10708) * update setuptools and pip * remove from lfx pypoetry * feat: Display node name in download error message (#10707) add component name on download error * feat: Add Message Support for Input of Loop Component (#10160) * feat: Add support for messages in Loop Component * feat: Add Message support for input of Loop Component * [autofix.ci] apply automated fixes * Update src/frontend/src/utils/reactflowUtils.ts * [autofix.ci] apply automated fixes * More cleanup of looping * Fix ruff errors * [autofix.ci] apply automated fixes * Update loop-component.spec.ts * Make loop types generic * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Fixes from gabriel review * [autofix.ci] apply automated fixes --------- * fix: Support tool mode in File Component properly (#10520) * Support tool mode in dynamic outputs * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Tool mode and ruff fixes * Template updates * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * Update test_mcp_servers_file.py * Revert "Update test_mcp_servers_file.py" This reverts commit 25f24d0d8aa5a7c95c913f862d86513749195ad1. * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * add possibility for the agent to access the processed output file * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) --------- * docs: include regex for sanitized input types (#10712) include-regex-for-sanitized-input * feat: Version 1.2 - comprehensive database migration guidelines using… (#10519) * feat: Version 1.2 - comprehensive database migration guidelines using the Expand-Contract pattern * Update src/backend/base/langflow/alembic/DB-MIGRATION-GUIDE.MD * fix: Cleanup text and typos * feat: Implement migration validation workflow and add migration validator scripts * Update src/backend/base/langflow/alembic/migration_validator.py * Update src/backend/base/langflow/alembic/migration_validator.py * Update src/backend/base/langflow/alembic/migration_validator.py * fix: moved the test_migrations directory to under tests * feat: Added migration validator to pre-commit check. * fix: improved test performance. * fix: optimized attribute resolution in migration validator * feat: add comprehensive tests for migration validator and guidelines * fix: Lint is complaining about shebang declared but not being used. * fix: Shebang reinstated. * Update src/backend/base/langflow/alembic/DB-MIGRATION-GUIDE.MD Co-authored-by: Copilot <175728472+Copilot@users.… Co-authored-by: Rodrigo Nader <rodrigosilvanader@gmail.com> Co-authored-by: Claude <noreply@anthropic.com> Co-authored-by: Mendon Kissling <59585235+mendonk@users.noreply.github.com> Co-authored-by: Gabriel Luiz Freitas Almeida <gabriel@langflow.org> Co-authored-by: Jordan Frazier <122494242+jordanrfrazier@users.noreply.github.com> Co-authored-by: Mike Fortman <michael.fortman@datastax.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Edwin Jose <edwin.jose@datastax.com> Co-authored-by: Jordan Frazier <jordan.frazier@datastax.com> Co-authored-by: Deon Sanchez <69873175+deon-sanchez@users.noreply.github.com> Co-authored-by: Tejas Kumar <tejas.kumar@datastax.com> Co-authored-by: cristhianzl <cristhian.lousa@gmail.com> Co-authored-by: Adam Aghili <Adam.Aghili@ibm.com> Co-authored-by: Uday Sidagana <129588963+Uday-sidagana@users.noreply.github.com> Co-authored-by: Koren Lazar <44236526+korenLazar@users.noreply.github.com> Co-authored-by: Koren Lazar <koren.lazar@ibm.com> Co-authored-by: Sami Marreed <sami.marreed@ibm.com> Co-authored-by: codeflash-ai[bot] <148906541+codeflash-ai[bot]@users.noreply.github.com> Co-authored-by: Madhavan <msmygit@users.noreply.github.com> Co-authored-by: Madhavan <cxo@ibm.com> Co-authored-by: Eric Hare <ericrhare@gmail.com> Co-authored-by: April I. Murphy <36110273+aimurphy@users.noreply.github.com> Co-authored-by: ming <itestmycode@gmail.com> Co-authored-by: Hamza Rashid <74062092+HzaRashid@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: github-merge-queue <118344674+github-merge-queue@users.noreply.github.com> Co-authored-by: Himavarsha <40851462+HimavarshaVS@users.noreply.github.com> Co-authored-by: Offer Akrabi <offer.akrabi@il.ibm.com> Co-authored-by: keval shah <kevalvirat@gmail.com> Co-authored-by: Rej Ect <99460023+rejected-l@users.noreply.github.com> Co-authored-by: Hamza Rashid <hzarashid@gmail.com> Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com> Co-authored-by: Carlos Coelho <80289056+carlosrcoelho@users.noreply.github.com> Co-authored-by: Rico Furtado <hfurtado@gmail.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: Cristhian Zanforlin <criszl@192.168.15.88> Co-authored-by: Wallgau <46035189+Wallgau@users.noreply.github.com> Co-authored-by: Olfa Maslah <olfamaslah@Olfas-MacBook-Pro.local> Co-authored-by: Cristhian Zanforlin <criszl@MacBook-Pro-di-Cristhian.local> Co-authored-by: Olfa Maslah <olfamaslah@macbookpro.war.can.ibm.com> Co-authored-by: kiran-kate <40038037+kiran-kate@users.noreply.github.com> Co-authored-by: olayinkaadelakun <olayinka.adelakun@ibm.com> Co-authored-by: Olayinka Adelakun <olayinkaadelakun@Olayinkas-MacBook-Pro.local> Co-authored-by: Olayinka Adelakun <olayinkaadelakun@mac.war.can.ibm.com> Co-authored-by: Joao Paulo Ramos <joao.oramos11@gmail.com> Co-authored-by: phact <estevezsebastian@gmail.com> Co-authored-by: Steve Haertel <stevehaertel@users.noreply.github.com> Co-authored-by: Steve Haertel <shaertel@ca.ibm.com> Co-authored-by: Simon Steinbeiß <simon.steinbeiss@elfenbeinturm.at> Co-authored-by: Mike Pawlowski <mpawlow@ca.ibm.com> Co-authored-by: Viktor Avelino <64113566+viktoravelino@users.noreply.github.com> Co-authored-by: himavarshagoutham <himavarshajan17@gmail.com> Co-authored-by: Jason Tsay <jsntsay@gmail.com> Co-authored-by: andifilhohub <115162146+andifilhohub@users.noreply.github.com> Co-authored-by: Ali Saleh <saleh.a@turing.com> Co-authored-by: Copilot <198982749+Copilot@users.noreply.github.com> Co-authored-by: phact <1313220+phact@users.noreply.github.com> Co-authored-by: avonian <ara@soundstage.fm> Co-authored-by: Ara Kevonian <avonian@users.noreply.github.com> Co-authored-by: Adam-Aghili <149833988+Adam-Aghili@users.noreply.github.com> Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: Lucas Democh <ldgoularte@gmail.com> Co-authored-by: Jason Tsay <jason.tsay@ibm.com> Co-authored-by: Lucas Oliveira <62335616+lucaseduoli@users.noreply.github.com> Co-authored-by: Janardan Singh Kavia <janardankavia@ibm.com> Co-authored-by: Janardan S Kavia <janardanskavia@mac.myfiosgateway.com> Co-authored-by: Lucas Oliveira <lucas.edu.oli@hotmail.com> Co-authored-by: Rodrigo Nader <rodrigonader@MacBook-Pro-de-Rodrigo.local> Co-authored-by: Janardan S Kavia <janardanskavia@Janardans-MacBook-Pro.local> Co-authored-by: Janardan S Kavia <janardanskavia@mac.war.can.ibm.com> Co-authored-by: Antônio Alexandre Borges Lima <104531655+AntonioABLima@users.noreply.github.com> Co-authored-by: Antônio Alexandre Borges Lima <antonio@Antonios-MacBook-Pro.local> Co-authored-by: Debojit Kaushik <Kaushik.debojit@gmail.com> Co-authored-by: Debojit Kaushik <debojitkaushik@Debojits-MacBook-Pro.local> Co-authored-by: necrophcodr <necrophcodr@users.noreply.github.com> Co-authored-by: Phil Nash <philnash@gmail.com>
This pull request introduces several improvements and bug fixes to both the backend and frontend of the project, focusing on more robust handling of MCP Composer errors, improved synchronization of OAuth settings in the authentication modal, and better frontend cache management. The changes enhance user feedback during authentication issues, ensure correct UI state synchronization, and improve test coverage for OAuth field auto-sync behavior.
Backend improvements to MCP Composer error handling and commit logic:
get_project_composer_urlendpoint now returns the last error if OAuth setup previously failed, even if OAuth is currently disabled for the project. [1] [2]ResourceWarninglogs from SSE connections in the backend to reduce log clutter.Frontend improvements to OAuth authentication modal and cache management:
AuthModalnow auto-synchronizes the Server URL and Callback Path fields whenever the OAuth Host or Port fields are changed, ensuring consistent and user-friendly configuration. Manual edits are preserved unless fields are changed again.Frontend cache and query management:
useMcpServerhook adds state for tracking slow composer responses and waiting status, laying the groundwork for better user feedback during long-running operations. [1] [2] [3]Summary by CodeRabbit
New Features
Bug Fixes
Tests