Etheryte 9 hours ago

Of all the syntax options they could've gone with, they settled on what I would say is arguably the worst. If you want a one-liner, decorators are widely used across different languages and Typescript supports them as well.

  • MrJohz 8 hours ago

    Decorators don't work for functions, unfortunately, so wouldn't work in this case. You'd need to add a bunch of class boilerplate to make it work.

    JavaScript didn't have a lot of great options for this kind of statically-declared metaprogramming, which is why the "use X"; syntax has become so popular in various spaces. It's definitely not my favourite approach, but I don't think there's any clear "best" solution here.

    • halflife 8 hours ago

      You can use generator fns to achieve the exact same thing without magic strings or bundles. And the bonus is that you can debug it.

    • Etheryte 8 hours ago

      Since this magic string requires a preprocessor step anyway, there's no reason they couldn't make it a decorator that works on functions. I don't see the problem?

      • ngruhn 8 hours ago

        But then it's not valid TypeScript anymore. So all the other tooling breaks: syntax highlighting, LSP, Linter, ...

        • Etheryte 6 hours ago

          Looking at the AST [0], this doesn't seem to be the case. Since Typescript already supports decorators in other contexts, it successfully parses everything and identifies the decorator to boot. Since you're working in a preprocessor context anyway, there's a number of options to make all of this work well together.

          [0] https://ts-ast-viewer.com/#code/GYVwdgxgLglg9mABMOcAUBKRBvAU...

          • Noghartt 5 hours ago

            Instead of decorators, it could be just a higher-order function. Which could handle it easily and in any scenario that interchanges between TS/JS.

            • Etheryte 5 hours ago

              Well yes, that's the sane way anyone would reach for first, but that's clearly not new-age enough by Vercel's standards, so here we are. Similar to the other magic string interactions, all of this is a roundabout way of introducing platform lock-in.

  • tom1337 9 hours ago

    Yea but it's a vercel product and they also pushed the 'use server' and 'use client' directives and probably want to build on them.

    • bn-l 6 hours ago

      Absolutely bizarre decisions.

      • 1oooqooq 2 hours ago

        better then when they try to contribute to react with proper functions like useActionState and ship so many cripling bugs the dev just leave the issues on read.

  • javcasas 9 hours ago

    My bad, this is open telemetry stuff to check the status of your servers, not for vendors to extract as much data as they can from you.

    > I'm trying to find how they implemented the "use workflow" thing, and before I could find it I already found https://github.com/vercel/workflow/blob/main/packages/core/s...

    > Telemetry is part of the core.

    > Yuck.

    • nakovet 9 hours ago

      It's on the landing page, there is not even a standalone mode yet, so you can't use it with node.js you need to use with Next.js. All to say, it's just early alpha preview, I would wait the project to mature before considering using it anywhere.

      • javcasas 9 hours ago

        My bad, this is open telemetry stuff to check the status of your servers, not for the vendor to slurp as much data from you as possible.

        • evilduck 8 hours ago

          This is Open Telemetry functions you're referencing. Being able to trace, profile and debug your own code that's executing in a highly distributed environment is a pretty useful thing. This isn't (necessarily) user behavior telemetry.

          At least understand what you're looking at before getting the ick.

          • javcasas 8 hours ago

            That's fair. I'm too accustomed to seeing the other type of telemetry shoved in all over the place.

        • skrebbel 8 hours ago

          Good luck running a server without any sort of telemetry. How will you debug stuff without logs and traces? Seems to me that the priorities are with practical, real everyday engineering concerns.

    • oompydoompy74 8 hours ago

      It’s apparently an swc compiler plugin.

  • ajkjk 9 hours ago

    or no-op functions like useWorkflow() (with some kind of stub that prevents dead code elimination).

halflife 9 hours ago

So vercel is adamant on making nextjs apps behavior completely unpredictable and hidden behind tons of magic code?

At least in any other framework library I can just command click and see why things are not working, place breakpoints and even modify code.

  • lopatin 6 hours ago

    It’s a great business model with epic lock in. Bored front end devs keep indulging / enabling it so why stop?

AgentME 7 hours ago

This seems pretty similar to Cloudflare Workflows (https://developers.cloudflare.com/workflows/), but with code-rewriting to use syntax magic (functions annotated with "use workflow" and "use step") instead of Cloudflare's `step.do` and `step.sleep` function calls. (I think I lightly prefer Cloudflare's model for not relying on a code-rewriting step, partly because I think it's easier for programmers to see what's going on in the system.) Workflow's Hooks are similar to Cloudflare's `step.waitForEvent` + `instance.sendEvent`. It's kind of exciting to see this programming model get more popular. I wonder if the ecosystem can evolve into a standardized model.

  • tonyhb 4 hours ago

    Actually, both Vercel and Cloudflare are based off of the API that we built at https://inngest.com (disclaimer, I'm a founder).

    I strongly believe that being obvious about steps with `step.run` is important: it improves o11y, makes things explicit, and you can see transactional boundaries.

bern4444 an hour ago

> For instance, Math.random and Date constructors are fixed in workflow runs, so you are safe to use them and the framework ensures that the values don't change across replays.

How do you create an environment where everything is deterministic? Do they invoke every supported non deterministic function when creating the environment and rewrite those functions to return the values from the environment's creation time? Is there something more complex happening?

tom1337 9 hours ago

So at it's core this is "just" a toolkit to add automatic retries to functions inside another function? I don't know if the audience Vercel is targetig knows about idempotency as well as they should before plastering all their functions with "use workflow".

I guess in the end it's another abstraction layer for queues or state machines and another way to lock you into Vercel.

qianli_cs 3 hours ago

I'm excited about this because durable workflows are really important for making AI applications production ready :) Disclaimer: I'm working on DBOS, a durable workflow library built on Postgres, which looks complementary to this.

I asked their main developer Dillon about the data/durability layer and also the compilation step. I wonder if adding a "DBOS World" will be feasible. That way, you get Postgres-backed durable workflows, queues, messaging, streams, etc all in one package, while the "use workflow" interface remains the same.

Here is the response from Dillon, and I hope it's useful for the discussion here:

> "The primary datastore is dynamodb and is designed to scale to support tens of thousands of v0 size tenants running hundreds of thousands of concurrent workflows and steps."

> "That being said, you don't need to use Vercel as a backend to use the workflow SDK - we have created a interface for anyone to implements called 'World' that you can use any tech stack for https://github.com/vercel/workflow/blob/main/packages/world/..."

> "you will require a compiler step as that's what picks up 'use workflow' and 'use step` and applies source transformations. The node.js run time limitations only apply to the outer wrapper function w/ `use workflow`"

trevor-e 7 hours ago

So this seems similar to https://temporal.io/, am I reading this right? I used that briefly a few years ago and it was pretty nice at the time. It did make some features much easier to model like their welcome email example. Would love to hear from someone with extensive temporal experience, iirc the only drawback was on the infra side of things.

  • oulipo2 6 hours ago

    And to DBOS too

zzixp 8 hours ago

This is actually pretty cool. We have a similar custom library at Xbox that's used extensively across all of our services.

I do wish that there was some kind of self-hostable World implementation at launch. If other PAAS providers jump onto this, I could see this sticking around.

  • schniz 6 hours ago

    Hi I’m Gal from the team. Thanks! We did ship a reference Postgres implementation. It would receive more love now that we open sourced, but we can’t call it “production ready” without running it in production.

    But we did have convos in the last couple of days on what we can do next on the pg world ;D

  • lloydatkinson 8 hours ago

    Azures Durable Task Framework or something else? I guess there’s nothing public on it, which is a shame because it sounds interesting

TimTheTinker 8 hours ago

I'd rather be explicit about what's going on at each step. That way idempotent functions can be handled differently, retry limits can be applied, and no separate preprocessor is required.

    export async function welcome(userId: string) {
      const user = await retry(() => getUser(userId));
      const { subject, body } = await retry(() => generateEmail({
        name: user.name, plan: user.plan
      }));
      const { status } = await retry(() => sendEmail({
        to: user.email,
        subject,
        body,
      }), 2);
      return { status, subject, body };
    }
game_the0ry 4 hours ago

Guillermo + Vercel should slow down and concentrate more on fixing the bugs with nextjs instead of adding more features no one asked for.

pavel_lishin 8 hours ago

Am I stupid, or does the page not actually explain that workflow is?

  • davey48016 8 hours ago

    It doesn't explain it on the landing page. Even skimming their docs, it seems like you mostly have to infer the purpose of this based on the features.

jadbox 2 hours ago

"Next.js only" Thanks, no thanks. Neat idea though. (I'm mostly using Bun+React)

drawfloat 9 hours ago

Use client and use server aren’t great, but the fact they had to be declared at the top of a file was at least clear.

Starting to scatter magic strings throughout a code base feels like a real step back.

  • c-hendricks 8 hours ago

    There's nothing about "use server" that requires it to be at the top of the file though, it can go in function bodies and you have a typed RPC method.

    I think "use client" is the only one that has to go at the top of a file.

    • TimReynolds 6 hours ago

      You are correct. Use server can be slapped in many places

0xb0565e486 9 hours ago

Somewhat related since this about "workflows" and not cloud function, but are there any practical benefits to cloud functions other than the fact that it's cheaper for the providers as they don't have to run an entire bespoke runtime for every customer/application?

dangoodmanUT 8 hours ago

im becoming increasinglymore convinced that workflows are the wrong model

just build state machines folks

  • rubenfiszel 6 hours ago

    workflows is just short for state machine DSL

    • dangoodmanUT 5 hours ago

      but with history length and replay determinism landmines

fullstackchris an hour ago

I can almost with 100% certainty see this being one of those things that ultimately, after years of just blantantly ignoring something as simple as basic syntax rules, being redefined to something that is actually valid JavaScript / TypeScript.

lloydjones 7 hours ago

"use turnMyBrainOff";

"use blackBoxWrapperForEverything";

oulipo2 6 hours ago

It's not really clear how you "update" a workflow/step method?

What happens if you saw a bug, or you want to update and change a workflow? Is there a way to discard / upgrade the existing in-memory workflows that are being executed (and correspond to the previous version) so they are now "updated"?

LewisJEllis 7 hours ago

can anyone point to the "Durable" part?

looking at the docs and examples, I see Workflows and Steps and Retries, but I don't see any Durable yet. none of the examples really make it clear how or where anything gets stored

khalic 8 hours ago

This seems... bad, inelegant.

  • lioeters 5 hours ago

    Not only is it ugly in terms of language design, the feature depends on over-engineered frameworks like Next.js and Nitro. Magic string literals that rewrite your functions? No thanks.

ssijak 8 hours ago

Lost me at "use workflow" directive. This and Next16 expanding the set of directives just makes me question if I'm the mad man for thinking they are absolutely terrible.

nawgz 4 hours ago

Docs seem really underbaked.

- where does the state and telemetry get stored?

- if something is sleeping for 7 days, and you release a new version in that time, what is invoked?

- how do you configure retries? Looks like it retries forever

And I echo the hatred of the magic strings. Terrible dx

8note 7 hours ago

well that's some scary typescript syntax. i didnt know a string constant at the top of a function could change the operation.

or is this some extra compilation step to rewrite the code?

  • art0rz 7 hours ago

    "use strict" has been around since 2009. That being said, this is not a TypeScript or React feature but yet another black box magic NextJS feature to try to lock you into the Vercel ecosystem.

  • koolba 7 hours ago

    Must be some compile step. Reminds me of “use strict”.

quacky_batak 9 hours ago

i hate the new pattern of using these magic strings everywhere. “use workflow”, “use client”, etc etc.

I don’t like having custom bundler logic for my code.

  • javcasas 9 hours ago

    Custom bundler + telemetry already included. Smells way too much like Microsoft, too much like lock-in with a deal that gets worse and worse.

  • brazukadev 8 hours ago

    "don't use next"

    "don't use react"

    • nawgz an hour ago

      Please, bundling React with Next is completely foolish. React is open, battle-hardened, type safe, and well-documented, while Next is... a vendor lock-in trojan horse targeting low-knowledge developers with concepts that seem beginner-friendly.

      I can understand making legit criticisms of React, no doubt the hooks transition had some issues and the library has a high level of complexity without a clear winner in the state management domain, but pretending React is peddling shit like "use workflow" is frankly low effort.

      • fullstackchris an hour ago

        Just shows you how absolutely little people know about the web ecosystem - most people heard something once or twice from someone else and just assume its true - to make matters worse, you have the typical HN "vanilla html and js only!!!" bandwagon which, if you try to use for any serious web application will only lead you down a path of much pain and suffering. I've commented many times in many other threads that I just don't get it; I probably never will.