Download and unzip the WASI SDK 19.0.
Examples in upcoming steps will assume this is placed in /usr/local/wasi-sdk-19.0
.
The following command will create an order discount Function at extensions/order-discount-cpp
, using our generic Wasm boilerplate.
npm run generate extension -- --type order_discounts --template wasm --name order-discount-cpp
Replace the contents of extensions/order-discount-cpp/input.graphql
with the following from GitHub:
You need to inform Shopify about the UI paths for configuring your function. These paths are already provided by the app template you used.
In shopify.function.extension.toml
, replace the [ui.paths]
section with the following:
[ui.paths]
create = "/discount/:functionId/new"
details = "/discount/:functionId/:id"
You also need to inform Shopify about where to find GraphQL variable values that will be used when executing your input query.
Add the following to shopify.function.extension.toml
:
[input.variables]
namespace = "$app:polyglot-functions"
key = "function-configuration"
You also need to inform the Shopify CLI about how to build your C++ wasm module, and where to expect the build output.
In shopify.function.extension.toml
, replace the [build]
section with the following:
[build]
command = "/usr/local/wasi-sdk-19.0/bin/clang++ -O3 -fno-exceptions -flto -std=c++20 --sysroot=/usr/local/wasi-sdk-19.0/share/wasi-sysroot src/main.cpp -o main.wasm"
path = "main.wasm"
Adjust the command as needed for your WASI SDK path. Note that it appears twice. You may also create a build script (example) and invoke that instead as your command (example).
Create a src/main.cpp
file and implement the following function logic, outputting appropriate JSON for an order discount function result.
IF customer has VIP metafield with a value of 'true'
AND products in their cart with tag X have a total of more than $Y
THEN discount the order by Z%
Hint: You can find a completed example on GitHub:
This example uses the json_struct header library to parse and output JSON.
cd extensions/order-discount-cpp
shopify.function.extension.toml
:npm run function:build
FunctionResult
GraphQL type:npm run function:validate
npm run function:preview
Use the following steps, selecting the order-discount-cpp
discount type, and using C++
as your discount code.
cd ../..
npm run deploy
npm run dev
executing in a terminal window.The workshop app includes a test script which will execute all the function wasm modules you have created so far, and print a comparison of their instruction count and binary size.
cd ../..
npm run function:test-all
You put the "plus" in C++! Onto another language?
Thanks to Elad Kishon for paving the way for this example.