JOBSEARCHER

Software Engineer (AI-Native)

ARCHIVED
UserpilotAustin, TXJune 26th, 2026

We can't find an active application page for this role right now. It may reopen or be listed elsewhere. Use Next Steps to search for an active apply link and similar live jobs.

About UserpilotUserpilot is a leading product analytics and user engagement platform used by product teams at hundreds of companies to understand, segment, and activate their users. The product spans a performant JavaScript SDK that runs inside customers’ web apps, a Chrome Extension for building in-app UI without code, and a React dashboard that handles complex real-time data - all backed by a distributed Elixir/Phoenix backend that sustains hundreds of thousands of concurrent WebSocket connections, high-throughput Kafka event ingestion, and real-time content delivery at scale.We move fast, we ship often, and we believe the best engineers care as much about the product they’re enabling as the systems and interfaces they build.The RoleThis is a full-stack, AI-native role. You’ll work across the entire product from the React dashboard and embedded SDK down to the Elixir services and real-time pipelines, and you’ll do it in a spec-driven, agent-assisted way. You’ll also help build the AI-powered features our customers use, not just use AI to build everything else.We’ve stopped treating frontend and backend as separate jobs. We hire engineers who can follow a problem wherever it leads, and who use AI tooling to go deeper and faster rather than to paper over gaps in judgment.What You’ll Work OnThe Userpilot dashboard: a React monorepo (Nx + Vite + Yarn Workspaces) with 50+ product domains, shared design-system components, and live analytics viewsThe JavaScript SDK: a lightweight, performance-critical script embedded in customer applications that renders personalized UI experiencesReal-time backend services: the Elixir/Phoenix channels, Kafka consumers, ClickHouse write buffers, and RabbitMQ-backed integrations that ingest analytics events and make them available for queries and engagement triggers in near real-timeWebSocket infrastructure: the persistent connections that keep hundreds of thousands of concurrent users in syncAI-powered product features: LLM-driven personalization, streaming experiences, and in-product intelligence, including the non-deterministic UI and backend states they requireAgentic development infra: the AGENTS.md, CLAUDE.md, DESIGN.md, slash commands, and architectural rules that make AI coding tools safe and effective across both a complex React codebase and a strict Elixir/OTP oneWhat You’ll DoDesign, build, and operate features end-to-end - from accessible React/TypeScript UI through to the Elixir/Phoenix services, pipelines, and data stores behind themBuild AI-powered product features and the infrastructure around them - streaming responses, AI-driven personalization, and the guardrails that make non-deterministic behavior safe in productionCare about performance on both sides - bundle size, rendering efficiency, and Core Web Vitals on the frontend; throughput, correctness, and reliability in distributed real-time backendsTranslate product specs and design mockups into production features, using the right tool for the job - React Query, Redux, and Saga on the client; OTP patterns, queues, and write buffers on the serverWork in a spec-driven flow - read and contribute to PRDs that drive both human and AI-assisted implementationContribute to the team’s agentic infrastructure - AGENTS.md, CLAUDE.md, DESIGN.md, slash commands, and .rules/ - so AI tooling understands our codebase as well as the humans doReview code for architectural consistency and maintainability across the stack - including making sure agent-generated code respects the same boundaries human-written code does - and expect the same in returnWhat We’re Looking ForRequired3+ years building and shipping production software, with hands-on experience on both the frontend and backend of real applicationsFrontend: production React + TypeScript - solid component design, hooks, rendering behavior, and experience with server/client state management (React Query, Redux, or Redux-Saga)Backend: strong CS fundamentals (data structures, algorithms, software design) and professional experience building services in a high-level language (Elixir, Ruby, Python, Go, or similar), including work with databases, queues, or real-time systemsAI features: experience building or integrating LLM-powered features - streaming responses, AI-driven personalization, or otherwise designing for non-deterministic behaviorAI-native workflow: you use AI coding agents (Claude Code, Cursor) as a real part of how you build - prompting for scaffolding, reviewing output critically, and knowing when to push backStrong product sense and judgment - you care about the user experience and about system correctness in equal measureSelf-management and a continuous-improvement mindset - we don’t over-prescribe how the work gets doneBonus PointsElixir and the Phoenix framework with OTP - it’s what our backend runs on, and its patterns (supervision trees, cache invariants, channel rules) exist for good reasonsBuilding and operating reliable real-time systems at scale and knowing what “reliable” actually means in productionKafka, RabbitMQ, ClickHouse, Broadway, or similar high-throughput data toolingMUI or design-system experience - we build on top of MUI with a custom layer (Blueprint)Monorepo tooling (Nx, Turborepo, or similar)Chrome Extension development, or SDK / embeddable-script work with size and performance constraintsFamiliarity with spec-driven development - writing or working from specs that drive both human and AI implementation, and knowing what makes a good oneContributing to developer experience or agentic infra - agent context files (AGENTS.md, CLAUDE.md), runbooks, architectural decision records, slash commands, linting rules, scaffoldingOptimizing cloud and infrastructure costs through caching or more efficient data processingTechnical leadership on an engineering teamOpen source contributionsWriting tests (unit, integration, e2e) - we won’t gate on it, but we’ll noticeOur StackFrontend: React 18, TypeScript, Vite, Nx, Yarn WorkspacesState management: React Query, Redux, Redux-SagaDesign system: MUI-based component library with a custom layer (Blueprint) on topBackend: Elixir 1.14+, OTP, Phoenix 1.7Databases: ClickHouse (analytics), MySQL (primary)Messaging: Kafka (kafka_ex), RabbitMQ (amqp), BroadwayInfrastructure: AWS, Kubernetes, DockerBackground jobs: ObanAI: LLM-powered product features (streaming, AI-driven personalization); Claude Code / Cursor for agentic developmentCI: GitHub ActionsWhat “Agentic Engineering” Means HereWe’re not just using AI to write code faster; we’re changing how we build, and AI-powered features are part of the product itself. Two things are true at once: coding agents help us ship, and our customers increasingly use AI features we’ve built. Both demand the same discipline.Features start with a written spec - a PRD that captures intent and constraints - not a two-line ticket, whether the implementer is a human or an agentCoding agents (Claude Code, Cursor) do the scaffolding; engineers own the architecture, the review, and the judgment callsOur patterns are encoded explicitly. Every umbrella app and product domain has an AGENTS.md capturing what it does, the patterns it uses, and the mistakes to avoid - so an agent working on core doesn’t violate a cache invariant or write directly to ClickHouse, and an agent on the dashboard doesn’t break a design contractCode review isn’t only about correctness - it’s about making sure agent-generated code respects architectural boundaries the same way human-written code has to, on both the React and Elixir/OTP sidesDX is a product: if a new engineer (or an AI agent) can’t understand a domain from its documentation and rules, that’s a bug we fixBuilding AI features means designing for non-determinism - streaming, retries, evals, and graceful failure - and holding it to the same reliability bar as the rest of the platformYou don’t need to have done all of this at your last job. But you should be genuinely curious about it, comfortable moving across the whole stack, and excited to help shape how we build.EEO StatementUserpilot is an equal opportunity employer. We do not discriminate on the basis of race, color, religion, sex, sexual orientation, gender identity, national origin, age, disability, veteran status, or any other characteristic protected by applicable law. All qualified applicants will receive consideration for employment.Visa/Work AuthorizationApplicants must be legally authorized to work in the United States. We are not able to sponsor or take over sponsorship of an employment visa at this time.