* root: initial rename * web: rename custom element prefix * root: rename external functions with pb_ prefix * root: fix formatting * root: replace domain with goauthentik.io * proxy: update path * root: rename remaining prefixes * flows: rename file extension * root: pbadmin -> akadmin * docs: fix image filenames * lifecycle: ignore migration files * ci: copy default config from current source before loading last tagged * *: new sentry dsn * tests: fix missing python3.9-dev package * root: add additional migrations for service accounts created by outposts * core: mark system-created service accounts with attribute * policies/expression: fix pb_ replacement not working * web: fix last linting errors, add lit-analyse * policies/expressions: fix lint errors * web: fix sidebar display on screens where not all items fit * proxy: attempt to fix proxy pipeline * proxy: use go env GOPATH to get gopath * lib: fix user_default naming inconsistency * docs: add upgrade docs * docs: update screenshots to use authentik * admin: fix create button on empty-state of outpost * web: fix modal submit not refreshing SiteShell and Table * web: fix height of app-card and height of generic icon * web: fix rendering of subtext * admin: fix version check error not being caught * web: fix worker count not being shown * docs: update screenshots * root: new icon * web: fix lint error * admin: fix linting error * root: migrate coverage config to pyproject
53 lines
1.7 KiB
TypeScript
53 lines
1.7 KiB
TypeScript
import { gettext } from "django";
|
|
import { customElement } from "lit-element";
|
|
import { Application } from "../../api/application";
|
|
import { PBResponse } from "../../api/client";
|
|
import { TablePage } from "../../elements/table/TablePage";
|
|
|
|
@customElement("ak-application-list")
|
|
export class ApplicationList extends TablePage<Application> {
|
|
pageTitle(): string {
|
|
return gettext("Applications");
|
|
}
|
|
pageDescription(): string {
|
|
return gettext("External Applications which use authentik as Identity-Provider, utilizing protocols like OAuth2 and SAML.");
|
|
}
|
|
pageIcon(): string {
|
|
return gettext("pf-icon pf-icon-applications");
|
|
}
|
|
|
|
apiEndpoint(page: number): Promise<PBResponse<Application>> {
|
|
return Application.list({
|
|
ordering: "order",
|
|
page: page,
|
|
});
|
|
}
|
|
|
|
columns(): string[] {
|
|
return ["Name", "Slug", "Provider", "Provider Type", ""];
|
|
}
|
|
|
|
row(item: Application): string[] {
|
|
return [
|
|
item.name,
|
|
item.slug,
|
|
item.provider.toString(),
|
|
item.provider.toString(),
|
|
`
|
|
<ak-modal-button href="administration/policies/bindings/${item.pk}/update/">
|
|
<ak-spinner-button slot="trigger" class="pf-m-secondary">
|
|
Edit
|
|
</ak-spinner-button>
|
|
<div slot="modal"></div>
|
|
</ak-modal-button>
|
|
<ak-modal-button href="administration/policies/bindings/${item.pk}/delete/">
|
|
<ak-spinner-button slot="trigger" class="pf-m-danger">
|
|
Delete
|
|
</ak-spinner-button>
|
|
<div slot="modal"></div>
|
|
</ak-modal-button>
|
|
`,
|
|
];
|
|
}
|
|
}
|