mirror of
https://github.com/sourcebot-dev/sourcebot.git
synced 2025-12-12 20:35:24 +00:00
Sourcebot V4 introduces authentication, performance improvements and code navigation. Checkout the [migration guide](https://docs.sourcebot.dev/self-hosting/upgrade/v3-to-v4-guide) for information on upgrading your instance to v4. ### Changed - [**Breaking Change**] Authentication is now required by default. Notes: - When setting up your instance, email / password login will be the default authentication provider. - The first user that logs into the instance is given the `owner` role. ([docs](https://docs.sourcebot.dev/docs/more/roles-and-permissions)). - Subsequent users can request to join the instance. The `owner` can approve / deny requests to join the instance via `Settings` > `Members` > `Pending Requests`. - If a user is approved to join the instance, they are given the `member` role. - Additional login providers, including email links and SSO, can be configured with additional environment variables. ([docs](https://docs.sourcebot.dev/self-hosting/configuration/authentication)). - Clicking on a search result now takes you to the `/browse` view. Files can still be previewed by clicking the "Preview" button or holding `Cmd` / `Ctrl` when clicking on a search result. [#315](https://github.com/sourcebot-dev/sourcebot/pull/315) ### Added - [Sourcebot EE] Added search-based code navigation, allowing you to jump between symbol definition and references when viewing source files. [Read the documentation](https://docs.sourcebot.dev/docs/search/code-navigation). [#315](https://github.com/sourcebot-dev/sourcebot/pull/315) - Added collapsible filter panel. [#315](https://github.com/sourcebot-dev/sourcebot/pull/315) ### Fixed - Improved scroll performance for large numbers of search results. [#315](https://github.com/sourcebot-dev/sourcebot/pull/315)
26 lines
936 B
TypeScript
26 lines
936 B
TypeScript
'use server';
|
|
|
|
import { listRepositories } from "@/features/search/listReposApi";
|
|
import { NextRequest } from "next/server";
|
|
import { isServiceError } from "@/lib/utils";
|
|
import { serviceErrorResponse } from "@/lib/serviceError";
|
|
import { StatusCodes } from "http-status-codes";
|
|
import { ErrorCode } from "@/lib/errorCodes";
|
|
|
|
export const GET = async (request: NextRequest) => {
|
|
const domain = request.headers.get("X-Org-Domain");
|
|
const apiKey = request.headers.get("X-Sourcebot-Api-Key") ?? undefined;
|
|
if (!domain) {
|
|
return serviceErrorResponse({
|
|
statusCode: StatusCodes.BAD_REQUEST,
|
|
errorCode: ErrorCode.MISSING_ORG_DOMAIN_HEADER,
|
|
message: "Missing X-Org-Domain header",
|
|
});
|
|
}
|
|
|
|
const response = await listRepositories(domain, apiKey);
|
|
if (isServiceError(response)) {
|
|
return serviceErrorResponse(response);
|
|
}
|
|
return Response.json(response);
|
|
}
|