Our engineering teams have released a number of cool new features and improvements over the last month. As always, see our Docs for the complete details of each new feature and our Examples for more guidance.
New Authorization Options
Vendia Share now supports multiple forms of authorization to a Node within a Uni.
API Keys
For those who prefer to create and use API Keys for authorization, this can now be performed through the Share UI, the Share GraphQL API, or the Share CLI. A Node can now support multiple API Keys and each key can have a unique expiration time.
share node add-api-key \
--uni 'my-uni-name' \
--node 'my-node-name' \
--name 'my-api-key-name' \
--expiry '2022-08-31'
When using an API Key, place the value of the key in the Authorization
header when submitting GraphQL requests to the Node to which the API Key is associated.
curl 'https://xxxxxxx.execute-api.us-west-2.amazonaws.com/graphql/' \
-H 'Authorization: MY_API_KEY_HERE' \
-H 'content-type: application/json' \
-H 'accept: application/json' \
--data-raw '{"query":"query blocksQuery { listVendia_BlockItems { Vendia_BlockItems { blockId blockHash } }}","variables":null,"operationName":"blocksQuery"}' \
--compressed
JWTs
For those who prefer to use JSON Web Tokens (JWTs) for authorization, this can now be configured through the Share UI or the Share GraphQL API. JWT authorization requires a small handful of configuration properties, from which your Vendia Share Node can perform all the necessary JWT verifications needed on subsequent GraphQL API calls.
When using a JWT, place the value of the key in the Authorization
header when submitting GraphQL requests to the Node whose configuration reflects the identity provider that issued the JWT. Note the Bearer
prefix in the Authorization
header value below.
curl 'https://xxxxxxx.execute-api.us-west-2.amazonaws.com/graphql/' \
-H 'Authorization: Bearer MY_JWT_HERE' \
-H 'content-type: application/json' \
-H 'accept: application/json' \
--data-raw '{"query":"query blocksQuery { listVendia_BlockItems { Vendia_BlockItems { blockId blockHash } }}","variables":null,"operationName":"blocksQuery"}' \
--compressed
With the release of these new authorization options comes the end of the legacy authorization options previously supported.
Sorting Results
The ability to sort results based on a field was a frequent request from our users over the last few quarters. We ranked your feedback (in ascending order) and got to work!
Now, any indexed field can be used to sort the results returned by a list
operation. For example, if the name
field of the Inventory
entity is indexed, the list of products can be returned in order by name:
GraphQL
query OrderedInventoryList {
list_InventoryItems(limit: 100, order: {name: DESC}) {
_InventoryItems {
name
price
quantity
}
}
}
Client SDK
Even better, the Vendia Share Client SDK makes sorting extremely simple.
const orderedProducts = await entities.inventory.list({ limit: 100, order: { name: 'DESC' } })
Schema Evolution
Because indexes can now be used to sort results, we've also made it easier to manage indexes (i.e. add and remove) during scheme evolution.
Share CLI
You can now remove an index, which was previously deemed a breaking change, using the --allow-breaking-change=INDEX_REMOVED
flag available through the share uni evolve
CLI command. This allows a user to add or remove an index simply and easily, likely enabling filtering and sorting on the fields of most interest to your users and applications.
Share UI
Likewise, the Share UI has been enhanced to allow schema evolution from the Schema view of a Uni.
<img src="https://d24nhiikxn5jns.cloudfront.net/optimized/user-images.githubusercontent.com..85032783..186989144-3b7a7b3a-6d70-4a80-a084-a69ba0f79d9f.png" style=" min-width: auto; display: block;">
Schema Evolution in Share UI
The Share UI view also includes a very helpful "diff" feature that allows you visually inspect a schema change priory to confirming the schema evolution.
<img src="https://d24nhiikxn5jns.cloudfront.net/optimized/user-images.githubusercontent.com..85032783..186988253-4f150aa6-17dd-45e9-89eb-c0591d7dff07.png" style=" min-width: auto; display: block;">
Schema Diffs in Share UI
Control Plane and Data Plane Geo-Blocking
To help protect our customers, Vendia Share's Control Plane and all of its operations are now inaccessible to traffic originating from a set of high-risk countries. This technique, known as geo-blocking, blocks traffic originating from IP addresses in specified geographic regions.
This same mechanism is now also in place on our Enterprise customers' Data Planes (i.e. protecting the GraphQL interfaces of your Nodes).
This additional layer of protection is one of many security mechanisms in place to keep your Vendia account, your Unis, and the data in your Unis safe.
Improved Ingestion and Consensus Performance
Vendia Share heavily leverages the serverless services of the major public cloud service providers. The scale, resilience, and performance of those services is unmatched and, as a result, so is Vendia Share's own scale, resilience, and performance.
Over the last month, we've made substantial improvements to the throughput available to our customers. This includes both ingestion performance (i.e., the number of transactions accepted by a Node in a given time period) and consensus performance (i.e., the number of transactions ledgered across a Uni in a given time period). We have successfully increased ingestion performance and consensus performance by 10x and will continue to optimize our internal ingestion and consensus implementation to maximize the value of the serverless capabilities on which Vendia Share is built.
For more information about Vendia Share's current and near-term performance targets, as well as the real-time data sharing workloads for which Share is unmatched, contact us.
Developer Tooling
For those who are new to Share, you may find these packages helpful as you explore these new and improved Share features:
<ul style="grid-area: auto / 1 / auto / auto; font-size: 15px; font-weight: 400; width: auto; color: rgb(51, 51, 51); font-family: quicksand; white-space-collapse: collapse; ">