Skip to content

Commit

Permalink
fix(core): change api "older" rules
Browse files Browse the repository at this point in the history
  • Loading branch information
zoobestik committed Nov 27, 2024
1 parent aefcb4b commit c4df275
Show file tree
Hide file tree
Showing 4 changed files with 15 additions and 10 deletions.
8 changes: 5 additions & 3 deletions .teamcity/builds/apiReferences/BuildApiPages.kt
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,7 @@ abstract class BuildApiPages(
stepBuildHtml()?.also { step -> step(step) }
stepNoRobots(pagesRoot)?.also { step -> step(step) }
stepCopyDokkaApiResult(apiId, pagesRoot)?.also { step -> step(step) }
stepNoRobots(pagesRoot)?.also { step -> step(step) }
stepSitemapGenerate(pagesRoot)?.also { step -> step(step) }
}

Expand Down Expand Up @@ -136,10 +137,11 @@ fun scriptGenerateSitemap(pagesRoot: String = DEFAULT_DOKKA_PATH): BuildStep = s
fun scriptNoRobots(pagesRoot: String, block: ScriptBuildStep.() -> Unit = {}) = ScriptBuildStep {
name = "Add no robots for older versions"
workingDir = pagesRoot
//language=bash
//language=sh
scriptContent = """
#!/bin/sh
find . -type f -path "*/api/*/older/*.html" -exec sed -i -E 's/(<head[^>]*>)/\1<meta name="robots" content="noindex, nofollow">/g' {} \;
# replace with print
# find . -type f \( -regex "^./\d\+\.\d\+\(\.\d\)\?/.\+\.html${'$'}" \) -exec echo {} \; -exec sed -i -E 's/(<head[^>]*>)/\1<meta name="robots" content="noindex, nofollow">/g' {} \;
find . -type f \( -regex "^./\d\+\.\d\+\(\.\d\)\?/.\+\.html${'$'}" \) -exec sed -i -E 's/(<head[^>]*>)/\1<meta name="robots" content="noindex, nofollow">/g' {} \;
""".trimIndent()
dockerImage = "alpine"
}.apply(block)
2 changes: 0 additions & 2 deletions robots.txt
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,3 @@ Host: kotlinlang.org

# Sitemaps
sitemap: https://kotlinlang.org/sitemap_index.xml

Disallow: /api/core/older/*
9 changes: 5 additions & 4 deletions scripts/doindex/analyzer/index.ts
Original file line number Diff line number Diff line change
@@ -1,20 +1,21 @@
import { env } from 'node:process';
import { mkdir } from 'node:fs/promises';
import { EventEmitter } from 'events'
import { EventEmitter } from 'events';

import { DIST_FOLDER, REPORT_FOLDER } from '../lib/files/index.js';
import { execFilesTask, Filter } from '../lib/files/execTask.js';
import { writeReports } from './reports/write.js';
import { Metadata } from './metadata.js';
import { isApiPreviousVersion } from '../lib/files/type.js';

console.time('Data successfully built');

const TASK_PATH = import.meta.dirname + '/task';

function preFilterFiles({ relativePath: path }: Parameters<Filter>[0]) {
const isSkip = (
// optimize by path "api/core/older" takes more than 1 minute only for filesystem iteration
(path.startsWith('api/') && (path.endsWith('/older'))) ||
// optimize by path "api/core/1.2.3/" takes more than 1 minute only for filesystem iteration
isApiPreviousVersion(path) ||
path === 'spec' ||
path === 'api/latest'
);
Expand All @@ -25,7 +26,7 @@ function preFilterFiles({ relativePath: path }: Parameters<Filter>[0]) {

let result: Metadata[] = [];

EventEmitter.defaultMaxListeners = 15
EventEmitter.defaultMaxListeners = 15;

await execFilesTask(
DIST_FOLDER, TASK_PATH,
Expand Down
6 changes: 5 additions & 1 deletion scripts/doindex/lib/files/type.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,10 @@ export type FileType =
| 'Page_Community' | 'Page_Documentation' | 'Page_LegacyDocumentation'
| 'Iframe' | 'Redirect' | 'Hidden' | 'Unknown';

export function isApiPreviousVersion(url: string) {
return url.match(/^api\/[^/]+\/(\d+\.\d+(\.\d+)?)(\/|$)/)?.[1];
}

export async function getType(url: string, filePath: string): Promise<[FileType, CheerioAPI | null]> {
if (url.endsWith('/package-list') || url.endsWith('index.yml')) return ['File_Text', null];
if (url.endsWith('.pdf')) return ['File_Pdf', null];
Expand Down Expand Up @@ -47,7 +51,7 @@ export async function getType(url: string, filePath: string): Promise<[FileType,
if (url.startsWith('api/latest/')) pageType = url.includes('jvm/stdlib') ? 'Page_API_stdlib' : 'Page_API_test';
else if (url.endsWith('/navigation.html') && $(':is(.sideMenu, .sideMenuPart) .sideMenuPart').length)
pageType = 'Iframe';
else if (url.includes('/older/')) return ['Page_API_Deprecated', $];
else if (isApiPreviousVersion(url)) return ['Page_API_Deprecated', $];
else pageType = 'Page_API';
}

Expand Down

0 comments on commit c4df275

Please sign in to comment.