From 442fe1cbfe51f37107146aad6622f7f3f6dbc832 Mon Sep 17 00:00:00 2001 From: Kian Paimani <5588131+kianenigma@users.noreply.github.com> Date: Wed, 28 Feb 2024 12:45:13 +0000 Subject: [PATCH] (soft) deprecate ocw related pages (#2136) * (soft) deprecate ocw-related pages * add more --- .../md/en/docs/learn/offchain-operations.md | 9 +++++ .../how-to-guides/offchain-workers/index.md | 13 ++++++- .../offchain-http-requests.md | 9 +++++ .../offchain-workers/offchain-indexing.md | 9 +++++ .../offchain-local-storage.md | 9 +++++ .../add-offchain-workers.md | 39 ++++++++++++------- 6 files changed, 71 insertions(+), 17 deletions(-) diff --git a/content/md/en/docs/learn/offchain-operations.md b/content/md/en/docs/learn/offchain-operations.md index 9fa41956f..2161626d1 100644 --- a/content/md/en/docs/learn/offchain-operations.md +++ b/content/md/en/docs/learn/offchain-operations.md @@ -4,6 +4,15 @@ description: Highlights how you can integrate data from offchain sources into th keywords: --- +
+

+ ⚠️ WARNING: This page contains potentially outdated information. Reading it might still be useful, yet we suggest taking it with a grain of salt. +

+

+ Please refer to the `polkadot-sdk-docs` crate for the most up-to-date documentation on this topic. +

+
+ There are many use cases where you might want to query data from an offchain source or process data without using on-chain resources before updating the on-chain state. The conventional way of incorporating offchain data involves connecting to [oracles](/reference/glossary#oracle) to supply the data from some traditional source. Although using oracles is one approach to working with offchain data sources, there are limitations to the security, scalability, and infrastructure efficiency that oracles can provide. diff --git a/content/md/en/docs/reference/how-to-guides/offchain-workers/index.md b/content/md/en/docs/reference/how-to-guides/offchain-workers/index.md index 82725688a..5b93d9815 100644 --- a/content/md/en/docs/reference/how-to-guides/offchain-workers/index.md +++ b/content/md/en/docs/reference/how-to-guides/offchain-workers/index.md @@ -4,13 +4,22 @@ description: Quick reference guides that illustrate how to use offchain workers. keywords: --- +
+

+ ⚠️ WARNING: This page contains potentially outdated information. Reading it might still be useful, yet we suggest taking it with a grain of salt. +

+

+ Please refer to the `polkadot-sdk-docs` crate for the most up-to-date documentation on this topic. +

+
+ The _How-to_ guides in the _Offchain workers_ category illustrate common use cases for offchain operations. - [Make offchain HTTP requests](/reference/how-to-guides/offchain-workers/offchain-http-requests/) - [Offchain local storage](/reference/how-to-guides/offchain-workers/offchain-local-storage/) - [Offchain indexing](/reference/how-to-guides/offchain-workers/offchain-indexing/) -It is important to note that offchain storage is separate from on-chain storage. +It is important to note that offchain storage is separate from on-chain storage. You can't send data collected or processed by an offchain worker directly to on-chain storage. To store any data collected or processed by an offchain worker—that is, to modify the state of the chain—you must enable the offchain worker to send transactions that modify the on-chain storage system. -For examples of how to prepare an offchain worker to send transactions, see [Add offchain workers](/tutorials/build-application-logic/add-offchain-workers/). \ No newline at end of file +For examples of how to prepare an offchain worker to send transactions, see [Add offchain workers](/tutorials/build-application-logic/add-offchain-workers/). diff --git a/content/md/en/docs/reference/how-to-guides/offchain-workers/offchain-http-requests.md b/content/md/en/docs/reference/how-to-guides/offchain-workers/offchain-http-requests.md index a35de4b48..d49818e6e 100644 --- a/content/md/en/docs/reference/how-to-guides/offchain-workers/offchain-http-requests.md +++ b/content/md/en/docs/reference/how-to-guides/offchain-workers/offchain-http-requests.md @@ -9,6 +9,15 @@ keywords: - requests --- +
+

+ ⚠️ WARNING: This page contains potentially outdated information. Reading it might still be useful, yet we suggest taking it with a grain of salt. +

+

+ Please refer to the `polkadot-sdk-docs` crate for the most up-to-date documentation on this topic. +

+
+ Because most blockchains can't access data that's hosted on servers outside of their own network, they typically use external third-party services—**oracles**—to pull information in from or push information out to locations that are outside of the network. For Substrate-based blockchains, **offchain workers** (OCW) provide similar capabilities, but with the advantage of being able to access on-chain state. diff --git a/content/md/en/docs/reference/how-to-guides/offchain-workers/offchain-indexing.md b/content/md/en/docs/reference/how-to-guides/offchain-workers/offchain-indexing.md index 4b5ff5cf8..acfb76126 100644 --- a/content/md/en/docs/reference/how-to-guides/offchain-workers/offchain-indexing.md +++ b/content/md/en/docs/reference/how-to-guides/offchain-workers/offchain-indexing.md @@ -7,6 +7,15 @@ keywords: - indexing --- +
+

+ ⚠️ WARNING: This page contains potentially outdated information. Reading it might still be useful, yet we suggest taking it with a grain of salt. +

+

+ Please refer to the `polkadot-sdk-docs` crate for the most up-to-date documentation on this topic. +

+
+ This guide will step you through how to pass data from an extrinsic to an offchain worker without writing to storage. Occasionally on-chain extrinsics need to pass data to offchain workers with predictable write behavior. diff --git a/content/md/en/docs/reference/how-to-guides/offchain-workers/offchain-local-storage.md b/content/md/en/docs/reference/how-to-guides/offchain-workers/offchain-local-storage.md index 3a5373178..b5d0ebf9f 100644 --- a/content/md/en/docs/reference/how-to-guides/offchain-workers/offchain-local-storage.md +++ b/content/md/en/docs/reference/how-to-guides/offchain-workers/offchain-local-storage.md @@ -8,6 +8,15 @@ keywords: - storage --- +
+

+ ⚠️ WARNING: This page contains potentially outdated information. Reading it might still be useful, yet we suggest taking it with a grain of salt. +

+

+ Please refer to the `polkadot-sdk-docs` crate for the most up-to-date documentation on this topic. +

+
+ This guide will teach you how to use an offchain worker to save retrieved data in local storage for future access. In the last section, we mentioned that offchain workers (**OCW** for short) cannot modify the blockchain state directly, so they have to submit transactions to save their computed results back on-chain. diff --git a/content/md/en/docs/tutorials/build-application-logic/add-offchain-workers.md b/content/md/en/docs/tutorials/build-application-logic/add-offchain-workers.md index a253a3f0b..a7b1ced2c 100644 --- a/content/md/en/docs/tutorials/build-application-logic/add-offchain-workers.md +++ b/content/md/en/docs/tutorials/build-application-logic/add-offchain-workers.md @@ -11,6 +11,15 @@ keywords: - signed payload --- +
+

+ ⚠️ WARNING: This page contains potentially outdated information. Reading it might still be useful, yet we suggest taking it with a grain of salt. +

+

+ Please refer to the `polkadot-sdk-docs` crate for the most up-to-date documentation on this topic. +

+
+ This tutorial illustrates how to modify a pallet to include an offchain worker and configure the pallet and runtime to enable the offchain worker to submit transactions that update the on-chain state. ## Using offchain workers @@ -39,7 +48,7 @@ It is also important to consider that even an unsigned transaction with a signed In most cases, checking whether a transaction was submitted by an offchain worker before writing to storage isn't sufficient to protect the network. Instead of assuming that the offchain worker can be trusted without safeguards, you should intentionally set restrictive permissions that limit access to the process and what it can do. -Remember that unsigned transactions are essentially an **open door** into your runtime. +Remember that unsigned transactions are essentially an **open door** into your runtime. You should only use them after careful consideration of the conditions under which they should be allowed to execute. Without safeguards, malicious actors could impersonate offchain workers and access runtime storage. @@ -80,7 +89,7 @@ To enable offchain workers to send signed transactions: 1. Open the `src/lib.rs` file for your pallet in a text editor. 2. Add the `#[pallet::hooks]` macro and the entry point for offchain workers to the code. - + For example: ```rust @@ -170,7 +179,7 @@ To enable offchain workers to send signed transactions: } ``` - This code enables you to retrieve all signers that this pallet owns. + This code enables you to retrieve all signers that this pallet owns. 8. Use `send_signed_transaction()` to create a signed transaction call: @@ -214,7 +223,7 @@ To enable offchain workers to send signed transactions: 1. Open the `runtime/src/lib.rs` file for the node template in a text editor. 1. Add the `AuthorityId` to the configuration for your pallet and make sure it uses the `TestAuthId` from the `crypto` module: - + ```rust impl pallet_your_ocw_pallet::Config for Runtime { // ... @@ -232,7 +241,7 @@ To enable offchain workers to send signed transactions: ```rust use codec::Encode; use sp_runtime::{generic::Era, SaturatedConversion}; - + // ... impl frame_system::offchain::CreateSignedTransaction for Runtime @@ -321,7 +330,7 @@ Updating the runtime involved the following steps: - Adding the `AuthorityId` to the runtime configuration for your pallet. - Implementing the `CreateSignedTransaction` trait and `create_transaction()` function. - Implementing `SigningTypes` and `SendTransactionTypes` for offchain workers from the `frame_system` pallet. - + However, before your pallet offchain workers can submit signed transactions, you must specify at least one account for the offchain worker to use. To enable the offchain worker to sign transactions, you must generate the account key for the pallet to own and add that key to the node keystore. @@ -352,7 +361,7 @@ pub fn new_partial(config: &Configuration) -> Result { This example manually adds the key for the `Alice` account to the keystore identified by the `KEY_TYPE` defined in your pallet. For a working example, see this sample [service.rs](https://github.com/jimmychu0807/substrate-offchain-worker-demo/blob/v2.0.0/node/src/service.rs#L87-L105) file. -### Using other accounts +### Using other accounts In a production environment, you can use other tools—such as `subkey`—to generate keys that are specifically for offchain workers to use. After you generate one or more keys for offchain workers to own, you can add them to the node keystore by: @@ -361,9 +370,9 @@ After you generate one or more keys for offchain workers to own, you can add the - Passing parameters using the `author_insertKey` RPC method. For example, you can use the [Polkadot/Substrate Portal](https://polkadot.js.org/apps/#/rpc), Polkadot-JS API, or a `curl` command to select the `author_insertKey` method and specify the key type, secret phrase, and public key parameters for the account to use: - + ![Use the `author_insertKey` method to insert an account](/media/images/docs/author_insertKey.png) - + Note that the keyType parameter `demo` in this example matches the `KEY_TYPE` declared in the offchain worker pallet. Now, your pallet is ready to send signed transactions on-chain from offchain workers. @@ -373,11 +382,11 @@ Now, your pallet is ready to send signed transactions on-chain from offchain wor By default, all unsigned transactions are rejected in Substrate. To enable Substrate to accept certain unsigned transactions, you must implement the `ValidateUnsigned` trait for the pallet. -Although you must implement the `ValidateUnsigned` trait to send unsigned transactions, this check doesn't guarantee that **only** offchain workers are able to send the transaction. +Although you must implement the `ValidateUnsigned` trait to send unsigned transactions, this check doesn't guarantee that **only** offchain workers are able to send the transaction. You should always consider the consequences of malicious actors sending these transactions as an attempt to tamper with the state of your chain. Unsigned transactions always represent a potential attack vector that a malicious user could exploit and offchain workers can't be assumed to be a reliable source without additional safeguards. -You should never assume that unsigned transactions can only be submitted by an offchain worker. +You should never assume that unsigned transactions can only be submitted by an offchain worker. By definition, **anyone** can submit them. ### Configure the pallet @@ -386,7 +395,7 @@ To enable offchain workers to send unsigned transactions: 1. Open the `src/lib.rs` file for your pallet in a text editor. 2. Add the [`validate_unsigned`](https://paritytech.github.io/substrate/master/frame_support/attr.pallet.html#validate-unsigned-palletvalidate_unsigned-optional) macro. - + For example: ```rust @@ -420,7 +429,7 @@ To enable offchain workers to send unsigned transactions: ``` 2. Check the calling extrinsics to determine if the call is allowed and return `ValidTransaction` if the call is allowed or `TransactionValidityError` if the call is not allowed. - + For example: ```rust @@ -598,10 +607,10 @@ To make your data structure signable: ``` This example uses [`SignedPayload`](https://paritytech.github.io/substrate/master/frame_system/offchain/trait.SignedPayload.html) to verify that the public key in the payload has the same signature as the one provided. - However, you should note that the code in the example only checks whether the provided `signature` is valid for the `public` key contained inside `payload`. + However, you should note that the code in the example only checks whether the provided `signature` is valid for the `public` key contained inside `payload`. This check doesn't validate whether the signer is an offchain worker or authorized to call the specified function. This simple check wouldn't prevent an unauthorized actor from using the signed payload to modify state. - + For working examples of this code, see the [offchain function call](https://github.com/paritytech/polkadot-sdk/blob/master/substrate/frame/examples/offchain-worker/src/lib.rs#L508-L536) and the implementation of [`ValidateUnsigned`](https://github.com/paritytech/polkadot-sdk/blob/master/substrate/frame/examples/offchain-worker/src/lib.rs#L305-L329). ## Where to go next