This repository has been archived by the owner on Jan 26, 2025. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 232
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
OKTA-499818 <<<Jenkins Check-In of Tested SHA: b0d260b for [email protected]>>> Artifact: okta-oidc-js Files changed count: 1 PR Link: #1061
- Loading branch information
1 parent
55b4b16
commit 2a5873a
Showing
1 changed file
with
11 additions
and
136 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,140 +1,15 @@ | ||
# okta-oidc-js | ||
This is a monorepo that contains Okta's OpenID Connect JavaScript resources. | ||
|
||
[data:image/s3,"s3://crabby-images/31621/316218ea76f9e1dc081f94e59eb8b53b1acdd92b" alt="build status"](https://travis-ci.org/okta/okta-oidc-js) | ||
> :x: THIS REPO HAS BEEN RETIRED! | ||
**Table of Contents** | ||
Packages have been moved to their own repos | ||
|
||
- [Getting Started](#getting-started) | ||
- [Packages](#packages) | ||
- [Monorepo](#monorepo) | ||
- [Versioning](#versioning) | ||
- [Public packages](#public-packages) | ||
- [Configuration Reference](#configuration-reference) | ||
- [Testing](#testing) | ||
- [Prerequisites](#prerequisites) | ||
- [Create a SPA](#create-a-spa) | ||
- [Create a Web App](#create-a-web-app) | ||
- [Test an individual package](#test-an-individual-package) | ||
- [Test all packages](#test-all-packages) | ||
- [Contributing](#contributing) | ||
|
||
## Getting Started | ||
|
||
We use Yarn as our node package manager during package development. To install Yarn, check out their [install documentation](https://yarnpkg.com/en/docs/install). | ||
|
||
```bash | ||
# Clone the repo and navigate to it | ||
git clone [email protected]:okta/okta-oidc-js.git | ||
cd okta-oidc-js | ||
|
||
# Install dependencies | ||
yarn install | ||
``` | ||
|
||
## Packages | ||
|
||
### Monorepo | ||
|
||
The okta-oidc-js repo is managed as a **monorepo** using [Lerna](https://lernajs.io/). Each package within the **monorepo** is a separate npm module, each with its own `package.json` and `node_modules` directory. | ||
|
||
Packages are parsed from the `packages` property in [lerna.json](lerna.json), and adhere to this structure: | ||
|
||
```bash | ||
packages/ | ||
configuration-validation | ||
jwt-verifier | ||
``` | ||
|
||
### Versioning | ||
|
||
We've configured Lerna with [independent mode](https://github.com/lerna/lerna/#independent-mode---independent), which means that each package is required to manage its own version number. | ||
|
||
### Public packages | ||
|
||
| Package | Status | Description | | ||
|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------| | ||
| [**configuration-validation**](/packages/configuration-validation) | [data:image/s3,"s3://crabby-images/fbff3/fbff32a1e10cd5bc8850a6e9b8139347700dc801" alt="npm version"](https://www.npmjs.com/package/@okta/configuration-validation) | Standard pattern for validating configuration passed into Okta JavaScript libraries and SDKs. | | ||
| [**jwt-verifier**](https://github.com/okta/okta-jwt-verifier-js) | [data:image/s3,"s3://crabby-images/03457/03457e76b44d9687c1d1926cc9cd2e6d4a80e1d3" alt="npm version"](https://www.npmjs.com/package/@okta/jwt-verifier) | Easily verify JWTs from Okta | | ||
| [**okta-angular**](https://github.com/okta/okta-angular) | [data:image/s3,"s3://crabby-images/ff5b4/ff5b47bcda76574d1abbd65d7fcc786dd3a5f5dc" alt="npm version"](https://www.npmjs.com/package/@okta/okta-angular) | Angular support for Okta. This SDK is located in its [own repository](https://github.com/okta/okta-angular) | | ||
| [**okta-oidc-middleware**](https://github.com/okta/okta-oidc-middleware) | [data:image/s3,"s3://crabby-images/e8083/e808307ba75a5304926524bea9136b2ad6b2bc7f" alt="npm version"](https://www.npmjs.com/package/@okta/oidc-middleware) | Middleware to easily add OpenID Connect to the Node.js framework of your choice. This SDK is located in its [own repository](https://github.com/okta/okta-oidc-middleware) | | ||
| [**okta-react**](https://github.com/okta/okta-react) | [data:image/s3,"s3://crabby-images/feab8/feab824f6cbe2363c26bad790fffa1092f29bc5d" alt="npm version"](https://www.npmjs.com/package/@okta/okta-react) | React support for Okta. This SDK is located in its [own repository](https://github.com/okta/okta-react) | | ||
| [**okta-react-native**](https://github.com/okta/okta-react-native) | [data:image/s3,"s3://crabby-images/0e476/0e476c38997b3e0b9bf4d44d8546d85ee5c8bc0f" alt="npm version"](https://www.npmjs.com/package/@okta/okta-react-native) | React Native support for Okta. This SDK is located in its [own repository](https://github.com/okta/okta-react-native) | | ||
| [**okta-vue**](https://github.com/okta/okta-vue) | [data:image/s3,"s3://crabby-images/4db01/4db01ffe31b0d4609a862ebba90b85bc769f33f5" alt="npm version"](https://www.npmjs.com/package/@okta/okta-vue) | Vue.js support for Okta. This SDK is located in its [own repository](https://github.com/okta/okta-vue) | | ||
|
||
## Configuration Reference | ||
|
||
Each package is configured to look for environment variables based on the application type. | ||
|
||
```bash | ||
# Navigate into a specific package | ||
cd packages/${packageName} | ||
|
||
# Set the following environment variables | ||
# | ||
# ISSUER - your authorization server | ||
# CLIENT_ID - the client ID of your app | ||
# CLIENT_SECRET - the client secret of your app, required for the oidc-middleware package | ||
# USERNAME - username of app user, required for tests | ||
# PASSWORD - password of app user, required for tests | ||
export ISSUER=https://{yourOktaDomain}/oauth2/default | ||
... | ||
``` | ||
|
||
## Testing | ||
|
||
Since the workspace contains libraries for Single-Page and Web Applications, you will need to have created a SPA and Web App in your Okta org. | ||
|
||
### Prerequisites | ||
|
||
#### Create a SPA | ||
|
||
1. Applications > Add Application | ||
2. Select SPA | ||
3. Add the following **login redirect URI**: | ||
- `http://localhost:8080/implicit/callback` | ||
- `http://localhost:8080/pkce/callback` | ||
4. Click Done | ||
5. Users > Add Person | ||
6. Create and activate user | ||
|
||
#### Create a Web App | ||
|
||
1. Applications > Add Application | ||
2. Select Web | ||
3. Add the following **login redirect URI**: | ||
- `http://localhost:8080/authorization-code/callback` | ||
4. Click Done | ||
5. Users > Add Person | ||
6. Create and activate user | ||
|
||
### Test an individual package | ||
|
||
```bash | ||
# Navigate into a specific package | ||
cd packages/${packageName} | ||
|
||
# Run the test suite | ||
yarn test | ||
``` | ||
|
||
### Test all packages | ||
|
||
Define the following environment variables at the project root and run the tests: | ||
|
||
```bash | ||
# Perform exports at the root of the repository | ||
[okta-oidc-js]$ export ISSUER=https://{yourOktaDomain}/oauth2/default | ||
[okta-oidc-js]$ export SPA_CLIENT_ID={SPAClientID} | ||
[okta-oidc-js]$ export WEB_CLIENT_ID={webAppClientID} | ||
[okta-oidc-js]$ export CLIENT_SECRET={webAppClientSecret} | ||
[okta-oidc-js]$ export USERNAME={username} | ||
[okta-oidc-js]$ export PASSWORD={password} | ||
|
||
# Run all tests | ||
[okta-oidc-js]$ yarn test | ||
``` | ||
|
||
## Contributing | ||
|
||
We're happy to accept contributions and PRs! Please see the [contribution guide](/CONTRIBUTING.md) to understand how to structure a contribution. | ||
| Package | Description | | ||
|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------| | ||
| [**configuration-validation**](/packages/configuration-validation) | Standard pattern for validating configuration passed into Okta JavaScript libraries and SDKs. _**This package has been deprecated**_| | ||
| [**jwt-verifier**](https://github.com/okta/okta-jwt-verifier-js) | Easily verify JWTs from Okta This SDK is located in its [own repository](https://github.com/okta/okta-jwt-verifier-js) | | ||
| [**okta-angular**](https://github.com/okta/okta-angular) | Angular support for Okta. This SDK is located in its [own repository](https://github.com/okta/okta-angular) | | ||
| [**okta-oidc-middleware**](https://github.com/okta/okta-oidc-middleware) | Middleware to easily add OpenID Connect to the Node.js framework of your choice. This SDK is located in its [own repository](https://github.com/okta/okta-oidc-middleware) | | ||
| [**okta-react**](https://github.com/okta/okta-react) | React support for Okta. This SDK is located in its [own repository](https://github.com/okta/okta-react) | | ||
| [**okta-react-native**](https://github.com/okta/okta-react-native) | React Native support for Okta. This SDK is located in its [own repository](https://github.com/okta/okta-react-native) | | ||
| [**okta-vue**](https://github.com/okta/okta-vue) | Vue.js support for Okta. This SDK is located in its [own repository](https://github.com/okta/okta-vue) | |