2021-06-04 11:17:15 +02:00
/** @type {import('@docusaurus/types').DocusaurusConfig} */
module . exports = {
2021-08-17 15:24:37 +02:00
title : 'Unleash' ,
tagline : 'The enterprise ready feature toggle service' ,
url : 'https://docs.getunleash.io' ,
baseUrl : '/' ,
onBrokenLinks : 'throw' ,
onBrokenMarkdownLinks : 'warn' ,
favicon : 'img/favicon.ico' ,
organizationName : 'Unleash' , // Usually your GitHub org/user name.
projectName : 'unleash.github.io' , // Usually your repo name.
trailingSlash : false ,
2022-03-01 17:21:14 +01:00
customFields : {
// expose env vars etc here
unleashProxyUrl : process . env . UNLEASH _PROXY _URL ,
unleashProxyClientKey : process . env . UNLEASH _PROXY _CLIENT _KEY ,
unleashFeedbackTargetUrl : process . env . UNLEASH _FEEDBACK _TARGET _URL ,
environment : process . env . NODE _ENV ,
} ,
2021-06-04 11:17:15 +02:00
themeConfig : {
defaultMode : 'light' ,
disableSwitch : true ,
respectPrefersColorScheme : false ,
2021-06-16 08:52:33 +02:00
algolia : {
2022-07-19 07:57:03 +02:00
appId : 'BH4D9OD16A' ,
2021-08-17 15:24:37 +02:00
apiKey : '9772249a7262b377ac876853d32bd760' ,
indexName : 'getunleash' ,
2021-06-16 08:52:33 +02:00
} ,
2022-10-04 14:13:52 +02:00
announcementBar : {
id : 'strategy-constraints-announcement' ,
content :
'🚀 Unleash brings powerful Constraints feature to OSS users. <a href=https://www.getunleash.io/blog/unleash-brings-powerful-constraints-feature-to-oss-users title="Unleash blog: Constraints are now available to open-source users">Read more</a> →' ,
isCloseable : true ,
} ,
2021-06-04 11:17:15 +02:00
navbar : {
2021-08-17 15:24:37 +02:00
title : 'Unleash' ,
2021-06-04 11:17:15 +02:00
logo : {
2021-08-17 15:24:37 +02:00
alt : 'Unleash logo' ,
src : 'img/logo.svg' ,
2021-06-04 11:17:15 +02:00
} ,
items : [
2021-08-17 15:24:37 +02:00
{
href : 'https://www.getunleash.io/plans' ,
label : 'Unleash Enterprise' ,
position : 'right' ,
} ,
2021-06-04 11:17:15 +02:00
{
href : 'https://github.com/Unleash/unleash' ,
position : 'right' ,
className : 'header-github-link' ,
2022-01-26 12:22:03 +01:00
'aria-label' : 'Unleash GitHub repository' ,
2021-06-04 11:17:15 +02:00
} ,
2021-08-17 15:24:37 +02:00
] ,
2021-06-04 11:17:15 +02:00
} ,
2021-06-04 14:50:52 +02:00
prism : {
2022-01-25 15:19:32 +01:00
additionalLanguages : [
'csharp' ,
2022-02-09 15:54:16 +01:00
'http' ,
'java' ,
2022-01-25 15:19:32 +01:00
'kotlin' ,
'php' ,
2022-02-09 15:54:16 +01:00
'ruby' ,
'swift' ,
2022-01-25 15:19:32 +01:00
] ,
2021-08-17 15:24:37 +02:00
} ,
2021-06-04 11:17:15 +02:00
footer : {
2021-08-17 15:24:37 +02:00
style : 'dark' ,
2021-06-04 11:17:15 +02:00
links : [
{
2021-08-17 15:24:37 +02:00
title : 'Product' ,
2021-06-04 11:17:15 +02:00
items : [
{
2021-08-17 15:24:37 +02:00
label : 'Docs' ,
to : '/' ,
2021-08-11 12:55:56 +02:00
} ,
{
2022-01-26 12:22:03 +01:00
label : 'Unleash on GitHub' ,
2021-08-17 15:24:37 +02:00
href : 'https://github.com/Unleash/unleash' ,
2021-08-11 12:55:56 +02:00
} ,
{
2021-08-17 15:24:37 +02:00
label : 'Roadmap' ,
href : 'https://github.com/orgs/Unleash/projects/5' ,
} ,
] ,
2021-06-04 11:17:15 +02:00
} ,
{
2021-08-17 15:24:37 +02:00
title : 'Community' ,
2021-06-04 11:17:15 +02:00
items : [
{
2021-08-17 15:24:37 +02:00
label : 'Stack Overflow' ,
2022-01-25 15:19:32 +01:00
href : 'https://stackoverflow.com/questions/tagged/unleash' ,
2021-06-04 11:17:15 +02:00
} ,
{
2021-08-17 15:24:37 +02:00
label : 'Slack' ,
2022-05-20 08:17:36 +02:00
href : 'https://slack.unleash.run/' ,
2021-06-04 11:17:15 +02:00
} ,
{
2021-08-17 15:24:37 +02:00
label : 'Twitter' ,
href : 'https://twitter.com/getunleash' ,
} ,
] ,
} ,
2021-06-04 11:17:15 +02:00
] ,
copyright : ` Copyright © ${ new Date ( ) . getFullYear ( ) } Unleash. Built with Docusaurus. ` ,
logo : {
src : 'img/logo.svg' ,
2021-08-17 15:24:37 +02:00
alt : 'Unleash logo' ,
} ,
2021-06-04 11:17:15 +02:00
} ,
2021-08-17 15:24:37 +02:00
image : 'img/logo.png' ,
2021-06-04 11:17:15 +02:00
} ,
presets : [
[
2021-08-17 15:24:37 +02:00
'@docusaurus/preset-classic' ,
2021-06-04 11:17:15 +02:00
{
docs : {
2021-08-17 15:24:37 +02:00
sidebarPath : require . resolve ( './sidebars.js' ) ,
2021-06-04 11:17:15 +02:00
// Please change this to your repo.
2021-08-17 15:24:37 +02:00
editUrl :
2021-12-23 14:12:19 +01:00
'https://github.com/Unleash/unleash/edit/main/website/' ,
2021-08-17 15:24:37 +02:00
routeBasePath : '/' ,
2022-01-03 14:59:47 +01:00
remarkPlugins : [
2022-01-25 15:19:32 +01:00
[
require ( '@docusaurus/remark-plugin-npm2yarn' ) ,
{ sync : true } ,
] ,
] ,
2022-08-12 11:37:57 +02:00
docLayoutComponent : '@theme/DocPage' ,
docItemComponent : '@theme/ApiItem' ,
2021-06-04 11:17:15 +02:00
} ,
theme : {
2021-08-17 15:24:37 +02:00
customCss : require . resolve ( './src/css/custom.css' ) ,
} ,
2022-01-27 13:12:00 +01:00
googleAnalytics : {
trackingID : 'UA-134882379-1' ,
} ,
2021-08-17 15:24:37 +02:00
} ,
] ,
2021-06-04 11:17:15 +02:00
] ,
plugins : [
[
2022-09-14 09:59:18 +02:00
// heads up to anyone making redirects:
//
// remember that redirects only work in production and not in
// development, as mentioned in the docs
// https://docusaurus.io/docs/api/plugins/@docusaurus/plugin-client-redirects/
2021-06-04 11:17:15 +02:00
'@docusaurus/plugin-client-redirects' ,
{
fromExtensions : [ 'html' , 'htm' ] ,
redirects : [
{
2021-06-04 14:38:11 +02:00
to : '/sdks' ,
2021-08-17 15:24:37 +02:00
from : [
'/user_guide/client-sdk' ,
'/client-sdk' ,
'/user_guide/connect_sdk' ,
2022-01-11 09:53:06 +01:00
'/sdks/community' ,
2021-08-17 15:24:37 +02:00
] ,
2021-06-04 11:17:15 +02:00
} ,
2021-06-10 23:15:14 +02:00
{
to : '/user_guide/api-token' ,
2021-08-17 15:24:37 +02:00
from : '/deploy/user_guide/api-token' ,
2021-06-10 23:15:14 +02:00
} ,
{
to : '/sdks/unleash-proxy' ,
2021-08-17 15:24:37 +02:00
from : '/user_guide/native_apps/' ,
2021-06-10 23:15:14 +02:00
} ,
2021-06-04 11:17:15 +02:00
{
to : '/advanced/toggle_variants' ,
2021-08-17 15:24:37 +02:00
from : '/toggle_variants' ,
} ,
2022-01-11 10:36:23 +01:00
{
2022-01-11 10:38:22 +01:00
to : '/integrations' ,
from : '/integrations/integrations' ,
2022-01-11 10:36:23 +01:00
} ,
2022-01-13 11:05:40 +01:00
{
to : '/user_guide/activation_strategy' ,
from : '/user_guide/control_rollout' ,
} ,
2022-02-08 12:11:08 +01:00
{
from : '/advanced/impression_data' ,
to : '/advanced/impression-data' ,
2022-03-01 17:21:14 +01:00
} ,
2022-09-14 09:59:18 +02:00
{
from : '/advanced/audit_log' ,
to : '/reference/event-log' ,
} ,
2021-06-04 11:17:15 +02:00
] ,
2022-01-25 15:19:32 +01:00
createRedirects : function ( toPath ) {
2021-08-17 15:24:37 +02:00
if (
toPath . indexOf ( '/docs/' ) === - 1 &&
toPath . indexOf ( 'index.html' ) === - 1
) {
return ` /docs/ ${ toPath } ` ;
2021-06-04 11:17:15 +02:00
}
2021-08-17 15:24:37 +02:00
} ,
} ,
] ,
Add OpenAPI docs (#1391) (#2066)
## What
This PR (finally 🎉) adds generated OpenAPI docs to the official Unleash documentation. In addition to generating docs when things get merged to main, it also pushes new doc updates every day at 12:00 AM (cron `@daily`).
## Why
Now that we have OpenAPI'd all the things, we can finally start using it. This will allow us to remove hand-written api docs from the documentation and should make sure everything is always kept up to date.
### Generating from us-hosted (Unleash enterprise)
Unleash has several different versions (open source, pro, enterprise). The versions do not necessarily have the exact same api surface. In fact, the enterprise version has a few endpoints that open source does not.
Because we want to have _all_ endpoints listed in the documentation we need to generated the docs from an enterprise spec. Which brings us into the next point:
### The need for scheduled jobs
Regarding the daily scheduled tasks to update the documentation: why do we need that?
The docs are generated from the tip of the main branch. For most of the docs, this is good and something that we want. However, because the OpenAPI docs are generated from the enterprise edition, it _will not be in sync_ with the open source main branch.
Also, we probably do not want the docs to list the current bleeding edge api changes. Instead, we should prefer to use the latest enterprise release (roughly). However, because we don't get notified when this version is released and deployed, we'll instead run the API generation on a daily cadence.
This isn't the perfect solution, but it's simple and gets us 80% of the way there. More intricate solutions can be set up later.
## How
- By adding a scheduled workflow to the generate docs config.
- By adding .gitignore entries for the generated files
There's also some minor changes in styling etc.
## Dependencies
This is dependent on the changes introduced in #2062 having propagated to the enterprise release, which will probably not be for another week or so.
## Discussion
What should the API reference docs url be? I've set it to be `/reference/api/unleash/*` for now, but I'm on the fence about whether it should be `apis` or `api` in there. I also want to get the proxy and other APIs in there as we grow.
-------
## Commits
* docs: style openapi operation buttons
* docs: minor operation badge adjustments
* docs: use permalink to css snippet i copied
* docs: ignore files related to openapi generation
* docs: re-enable openapi docs
* Docs(#1391): prep for integration
* docs(#1391): run docs generation daily
* docs(#1391): add generation step to doc prs too
* docs(#1391): use the US hosted instance to generate docs
* docs(#1391): move doc generation into build command
* docs(#1391): use `/reference/api/*` instead of `/reference/apis/*`
2022-09-19 14:50:24 +02:00
[
'docusaurus-plugin-openapi-docs' ,
{
id : 'api-operations' ,
docsPluginId : 'classic' ,
config : {
server : {
specPath :
#1391: add generated doc cleaning script (#2077)
* #1391: add generated doc cleaning script
## What
The cleaning script replaces all references to the Unleash ushosted instance in the
generated OpenAPI docs. It removes extra path segments (such as leading
`/ushosted` instances) and replaces the ushosted base url with something
user-agnostic.
## Why
When we host the OpenAPI docs in our official documentation, the generated
docs shouldn't necessarily point at _one specific instance_, and especially
not one that the reader is unlikely to ever use. Instead, we can remove all
the bits that are specific to the generation source we use, and make the docs
easier to use. In particular, removing the leading `/ushosted` is likely to
save us loooots of questions.
* #1391: change env var used for generating openapi from localhost
Using NODE_ENV=development doesn't necessarily make sense, so adding
an extra variable sounds reasonable to me.
* #1391: ensure that all generation commands also clean docs
* #1391: change <your-unleash-instance-url> to <your-unleash-url>
* #1391: fix ushosted replacement: not all paths start with /api
* #1391: chore: remove potential `ushosted` ending of api url
In the event that we change the base URL of OpenAPI, so that paths
don't start with `/ushosted/`, the script should still work, changing
those paths into <your-unleash-url> too.
Additionally, remove all instances of `/ushosted` that we find. In the
event that some things switch around or whatever.
2022-09-20 12:43:39 +02:00
process . env . OPENAPI _SOURCE === 'localhost'
Add OpenAPI docs (#1391) (#2066)
## What
This PR (finally 🎉) adds generated OpenAPI docs to the official Unleash documentation. In addition to generating docs when things get merged to main, it also pushes new doc updates every day at 12:00 AM (cron `@daily`).
## Why
Now that we have OpenAPI'd all the things, we can finally start using it. This will allow us to remove hand-written api docs from the documentation and should make sure everything is always kept up to date.
### Generating from us-hosted (Unleash enterprise)
Unleash has several different versions (open source, pro, enterprise). The versions do not necessarily have the exact same api surface. In fact, the enterprise version has a few endpoints that open source does not.
Because we want to have _all_ endpoints listed in the documentation we need to generated the docs from an enterprise spec. Which brings us into the next point:
### The need for scheduled jobs
Regarding the daily scheduled tasks to update the documentation: why do we need that?
The docs are generated from the tip of the main branch. For most of the docs, this is good and something that we want. However, because the OpenAPI docs are generated from the enterprise edition, it _will not be in sync_ with the open source main branch.
Also, we probably do not want the docs to list the current bleeding edge api changes. Instead, we should prefer to use the latest enterprise release (roughly). However, because we don't get notified when this version is released and deployed, we'll instead run the API generation on a daily cadence.
This isn't the perfect solution, but it's simple and gets us 80% of the way there. More intricate solutions can be set up later.
## How
- By adding a scheduled workflow to the generate docs config.
- By adding .gitignore entries for the generated files
There's also some minor changes in styling etc.
## Dependencies
This is dependent on the changes introduced in #2062 having propagated to the enterprise release, which will probably not be for another week or so.
## Discussion
What should the API reference docs url be? I've set it to be `/reference/api/unleash/*` for now, but I'm on the fence about whether it should be `apis` or `api` in there. I also want to get the proxy and other APIs in there as we grow.
-------
## Commits
* docs: style openapi operation buttons
* docs: minor operation badge adjustments
* docs: use permalink to css snippet i copied
* docs: ignore files related to openapi generation
* docs: re-enable openapi docs
* Docs(#1391): prep for integration
* docs(#1391): run docs generation daily
* docs(#1391): add generation step to doc prs too
* docs(#1391): use the US hosted instance to generate docs
* docs(#1391): move doc generation into build command
* docs(#1391): use `/reference/api/*` instead of `/reference/apis/*`
2022-09-19 14:50:24 +02:00
? 'http://localhost:4242/docs/openapi.json'
: 'https://us.app.unleash-hosted.com/ushosted/docs/openapi.json' ,
outputDir : 'docs/reference/api/unleash' ,
sidebarOptions : {
groupPathsBy : 'tag' ,
categoryLinkSource : 'tag' ,
} ,
} ,
} ,
} ,
] ,
2021-08-17 15:24:37 +02:00
] ,
2022-08-12 11:37:57 +02:00
themes : [ 'docusaurus-theme-openapi-docs' ] , // Allows use of @theme/ApiItem and other components
2021-06-04 11:17:15 +02:00
} ;