From 44ad41acb11fe95c813f687f349ded2a97903637 Mon Sep 17 00:00:00 2001 From: Alexander Graebe Date: Tue, 22 Sep 2020 13:48:17 -0700 Subject: [PATCH] docs: remove hello hub choice --- next.config.js | 7 +- src/common/navigation.yaml | 1 - src/pages/storage-hubs/hello-hub-choice.md | 278 --------------------- 3 files changed, 6 insertions(+), 280 deletions(-) delete mode 100644 src/pages/storage-hubs/hello-hub-choice.md diff --git a/next.config.js b/next.config.js index de33587f..02cadd8d 100755 --- a/next.config.js +++ b/next.config.js @@ -214,7 +214,7 @@ async function redirects() { }, { source: '/storage-hubs/hello-hub-choice.html', - destination: '/storage-hubs/hello-hub-choice', + destination: '/storage-hubs/overview', permanent: true, }, { @@ -394,6 +394,11 @@ async function redirects() { destination: '/data-storage/indexing-server-extras', permanent: true, }, + { + source: '/storage-hubs/hello-hub-choice', + destination: '/storage-hubs/overview', + permanent: true, + }, ]; } diff --git a/src/common/navigation.yaml b/src/common/navigation.yaml index 160d4b73..9e955981 100644 --- a/src/common/navigation.yaml +++ b/src/common/navigation.yaml @@ -98,7 +98,6 @@ sections: - path: /storage-hubs # this seems out of date, kill? pages: - path: /overview - - path: /hello-hub-choice - path: /gaia-admin - path: /config-schema - path: /digital-ocean-deploy diff --git a/src/pages/storage-hubs/hello-hub-choice.md b/src/pages/storage-hubs/hello-hub-choice.md deleted file mode 100644 index 3212174d..00000000 --- a/src/pages/storage-hubs/hello-hub-choice.md +++ /dev/null @@ -1,278 +0,0 @@ ---- -title: Hello world hub choice -description: 'Storing user data with Blockstack' ---- - -## Introduction - --> The functionality described in this tutorial has been deprecated with the Blockstack Browser. It will continue working only for apps that have not yet upgraded to Blockstack Connect. - -In this tutorial, you build on the Hello, Blockstack Tutorial. You'll modify the authentication code so that it prompts users who have not yet created a Blockstack identity, to choose a hub URL. - --> This tutorial was written on macOS High Sierra 10.13.4. If you use a Windows or Linux system, you can still follow along. However, you will need to "translate" appropriately for your operating system. Additionally, this tutorial assumes you are accessing the Blockstack Browser web application via Chrome. The application you build will also work with a local installation and/or with browsers other than Chrome. - -## About this tutorial and the prerequisites you need - -This tutorial assumes you already set up your environment and tooling as specified in the Hello, Blockstack Tutorial. You should also review that tutorial for basic information about - -## Task 1: Generate an initial Blockstack application - -In this section, you build an initial React.js application called `hello-hub-choice`. - -1. Create the `hello-hub-choice` directory. - - ```bash - mkdir hello-hub-choice - ``` - -2. Change into your new directory. - - ```bash - cd hello-hub-choice - ``` - -3. Use Yeoman and the Blockstack application generator to create your initial `hello-hub-choice` application. - - ```bash - yo blockstack - ``` - - You should see several interactive prompts. - - ```bash - $ yo blockstack - - ... - - ? Are you ready to build a Blockstack app in React? (Y/n) - ``` - -4) Respond to the prompts to populate the initial app. - - After the process completes successfully, you see a prompt similar to the following: - - ```bash - ... - create public/icon-192x192.png - create public/index.html - create public/robots.txt - create public/manifest.json - - Im all done. Running npm install for you to install the required dependencies. If this fails, try running the command yourself. - ``` - -5. Verify that you have version `18.3.0` of blockstack.js or higher. - - ```bash - $ npm ls blockstack - hello-blockstack@0.0.0 /Users/manthony/sampleapps/hello-blockstack - └── blockstack@18.3.0 - ``` - - If you don't have the correct version, install it. - - ```bash - npm install blockstack@18.3.0 - ``` - -Depending on your environment you may have some problems with the `npm` packages. Go ahead and fix these before continuing to the next section. - -## Task 2. Start the server and view the application - -When you start the server, it will create a Node.js server, start it locally, -and open your browser `http://localhost:5000`. From the root of your new application directory: - -1. Start the application server. - - ```bash - npm run start - ``` - -2. Choose **Allow**. - -3. Open your browser to `http://localhost:5000`. - - You should see a simple application: - - ![](/images/sign-in.png) - -4. Leave your new application running and move onto the next section. - -## Task 3: Enable hub selection - -By default, the app generator assumes you want to use the default flow `redirectToSignIn()` method. In this section, you replace that method and use the `makeAuthRequest()` method instead. The `makeAuthRequest()` method takes the following parameters: - -
-
- transitPrivateKey(String = generateAndStoreTransitKey()) -
-
A HEX encoded transit private key.
-
- `redirectURI(String = window.location.origin`)` -
-
Location to redirect the user to after sign in approval.
-
- `manifestURI(String = window.location.origin/manifest.json)` -
-
- Location of this app's manifest file. -
-
- scopes (Array = DEFAULT_SCOPE) -
-
The permissions this app is requesting.
-
- `appDomain(String = window.location.origin)` -
-
The origin of this app.
-
- `expiresAt(Number = nextHour().getTime())` -
-
The time at which this request is no longer valid.
-
- `extraParams(Object = {})` -
-
Any extra parameters to pass to the authenticator. Use this to pass options that aren't part of the Blockstack authentication specification, but might be supported by special authenticators.
-
- -To replace the default login, do the following: - -1. Using your favorite editor, open the `public/app.js` file. -2. Locate the `redirectToSignIn()` method at line 4. -3. Replace `redirectToSignIn()` method with the `blockstack.UserSession.redirectToSignInWithAuthRequest(authRequest)` method. - - ```jsx - var userSession = new UserSession(); - userSession.redirectToSignInWithAuthRequest(authRequest); - ``` - - The `authRequest` is the authentication request generated by `makeAuthRequest()` method. - -4. Immediately above the method you just added and below the `event.preventDefault()` method, construct a String `const` for the `authRequest`: - - ```jsx - const authRequest = userSession.makeAuthRequest( - userSession.generateAndStoreTransitKey(), - 'http://localhost:5000/', - 'http://localhost:5000/manifest.json', - ['store_write', 'publish_data'], - 'http://localhost:5000/', - blockstack.nextHour().getTime(), - { - solicitGaiaHubUrl: true, - } // new options param - ); - ``` - - -> If your app is running a different port than `500`, enter that port instead. - - The extra `solicitGaiaHubUrl` parameter of `true` will cause the Blockstack Browser to prompt new identity creators for a storage hub URL. - -5. Save and close the `public/app.js` file. -6. Make sure your app rebuilds cleanly. - -## Task 4: Try the new authentication flow - -Try your new authentication code. - -1. Refresh the client at `http://localhost:5000/`. -2. Click _Sign in with Blockstack_. - - The Blockstack Browser prompts you to sign in. I you are _not already authenticated_ with the browser, you should see the following: - - ![](/images/not-authenticated.png) - - If you are already authenticated with an existing ID, you can choose that ID - or **Deny**. Choosing an existing ID, signs you into the Hello Blockstack - application, without offering a hub choice. Instead, choose **Deny**. This - ends the authentication process. Then, reset the Blockstack Browser. - -3. Choose **Create new ID**. - - The system prompts you to enter a username. - -4. Enter a name and press **Check Availability**. -5. Press **Continue** after you find an available name you like. -6. Enter a password and chose **Register ID**. - - The system prompts you for a provider. - - ![](/images/provider-prompt.png) - - The default is to user Blockstacks' Gaia hub. - -7. Choose **Use a different provider**. - - The system prompts you for a URL. - - ![](/images/different-provider.png) - -8. Enter a Gaia hub URL. - - If you have one of your own enter it here. You can also just enter the Blockstack URL (`https://hub.blockstack.org`). - -9. Press **Continue**. - - The system takes a moment to check the hub is responsive and establish it in your new identity profile. Then, the system prompts you for an email. - -10. Enter an email and press **Next**. - - The system creates your user and prompts you to continue to your application. - -11. Choose **Go to Hello, Blockstack**. - - The system prompts you to allow Hello Blockstack access. - -12. Grant the access to the DApp. - - You user should be authenticated. - -## How to recommend a Gaia hub URL for new users - -If you want to create specific sign-up flows for your DApp, you can pass a preset Gaia storage hub URL also. For example, you might -do this if you have a corporate client whose employees would all like to use -your application with a company-run Gaia hub. - -To suggest a Gaia hub URL, provide an additional `recommendedGaiaHubUrl` value -alongside the `solicitGaiaHubUrl`, for example: - -```jsx -import { makeAuthRequest, redirectToSignInWithAuthRequest } from 'blockstack'; - -var userSession = new UserSession(); -const authRequest = userSession.makeAuthRequest( - undefined, - undefined, - undefined, - undefined, - undefined, - undefined, - { - solicitGaiaHubUrl: true, - recommendedGaiaHubUrl: 'https://mygaiahub.com', - } -); - -const authRequest = userSession.makeAuthRequest( - generateAndStoreTransitKey(), - 'http://localhost:5000/', - 'http://localhost:5000/manifest.json', - ['store_write', 'publish_data'], - 'http://localhost:5000/', - nextHour().getTime(), - { - solicitGaiaHubUrl: true, //new options param - recommendedGaiaHubUrl: 'https://mygaiahub.com', // new options param - } -); - -userSession.redirectToSignInWithAuthRequest(authRequest); -``` - -Passing these parameters changes the storage hub URL prompt to the following: - -![Gaiastorage](/images/recommended-provider.png) - -## Related information - -[`makeAuthRequest()`](https://blockstack.github.io/blockstack.js/#makeauthrequest) method