Skip to content

Commit

Permalink
chore: upgrade pnpm, pkgs, and fix format
Browse files Browse the repository at this point in the history
  • Loading branch information
yordis committed Apr 13, 2024
1 parent 862df4b commit 95fec9d
Show file tree
Hide file tree
Showing 70 changed files with 4,043 additions and 6,933 deletions.
4 changes: 2 additions & 2 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -30,10 +30,10 @@ jobs:
with:
version: 8

- name: Setup Node.js 18.x
- name: Setup Node.js 20.x
uses: actions/setup-node@v3
with:
node-version: 18.x
node-version: 20.x

- uses: pnpm/action-setup@v2
name: Install pnpm
Expand Down
3 changes: 3 additions & 0 deletions .prettierignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
.next/
dist/
**/src/proto/
2 changes: 1 addition & 1 deletion CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ export $(cat ./apps/login/.env.acceptance | xargs)
### Developing Against Your ZITADEL Cloud Instance

Configure your shell by exporting the following environment variables:

```sh
export ZITADEL_API_URL=<your cloud instance URL here>
export ZITADEL_ORG_ID=<your service accounts organization id here>
Expand Down Expand Up @@ -93,5 +94,4 @@ In apps/login, these commands also spin up the application and a ZITADEL gRPC AP
If you want to run the integration tests standalone against an environment of your choice, navigate to ./apps/login, [configure your shell as you like](# Developing Against Your ZITADEL Cloud Instance) and run `pnpm test:integration:run` or `pnpm test:integration:open`.
Then you need to lifecycle the mock process using the command `pnpm mock` or the more fine grained commands `pnpm mock:build`, `pnpm mock:build:nocache`, `pnpm mock:run` and `pnpm mock:destroy`.


That's it! 🎉
34 changes: 17 additions & 17 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ Each package and app is 100% [TypeScript](https://www.typescriptlang.org/).

### Login

The login is currently in a work in progress state.
The login is currently in a work in progress state.
The goal is to implement a login UI, using the session API of ZITADEL, which also implements the OIDC Standard and is ready to use for everyone.

In the first phase we want to have a MVP login ready with the OIDC Standard and a basic feature set. In a second step the features will be extended.
Expand All @@ -45,7 +45,7 @@ This list should show the current implementation state, and also what is missing
You can already use the current state, and extend it with your needs.

- [x] Local User Registration (with Password)
- [ ] User Registration and Login with external Provider
- [ ] User Registration and Login with external Provider
- [ ] Google
- [ ] GitHub
- [ ] GitHub Enterprise
Expand All @@ -67,21 +67,21 @@ You can already use the current state, and extend it with your needs.
- [ ] Domain Discovery
- [ ] Branding
- OIDC Standard
- [ ] Authorization Code Flow with PKCE
- [ ] AuthRequest `hintUserId`
- [ ] AuthRequest `loginHint`
- [ ] AuthRequest `prompt`
- [x] Login
- [x] Select Account
- [ ] Consent
- [ ] Create
- Scopes
- [ ] `openid email profile address``
- [ ] `offline access`
- [ ] `urn:zitadel:iam:org:idp:id:{idp_id}`
- [ ] `urn:zitadel:iam:org:project:id:zitadel:aud`
- [ ] `urn:zitadel:iam:org:id:{orgid}`
- [ ] AuthRequest UI locales
- [ ] Authorization Code Flow with PKCE
- [ ] AuthRequest `hintUserId`
- [ ] AuthRequest `loginHint`
- [ ] AuthRequest `prompt`
- [x] Login
- [x] Select Account
- [ ] Consent
- [ ] Create
- Scopes
- [ ] `openid email profile address``
- [ ] `offline access`
- [ ] `urn:zitadel:iam:org:idp:id:{idp_id}`
- [ ] `urn:zitadel:iam:org:project:id:zitadel:aud`
- [ ] `urn:zitadel:iam:org:id:{orgid}`
- [ ] AuthRequest UI locales

## Tooling

Expand Down
8 changes: 4 additions & 4 deletions apps/login/__test__/PasswordComplexity.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -30,14 +30,14 @@ describe("<PasswordComplexity/>", () => {
requiresSymbol: false,
resourceOwnerType: 0, // ResourceOwnerType.RESOURCE_OWNER_TYPE_UNSPECIFIED,
}}
/>
/>,
);
});
if (expectSVGTitle === false) {
it(`should not render the feedback element`, async () => {
await waitFor(() => {
expect(
screen.queryByText(feedbackElementLabel)
screen.queryByText(feedbackElementLabel),
).not.toBeInTheDocument();
});
});
Expand All @@ -46,12 +46,12 @@ describe("<PasswordComplexity/>", () => {
await waitFor(async () => {
const svg = within(
screen.getByText(feedbackElementLabel)
.parentElement as HTMLElement
.parentElement as HTMLElement,
).findByRole("img");
expect(await svg).toHaveTextContent(expectSVGTitle);
});
});
}
}
},
);
});
2 changes: 1 addition & 1 deletion apps/login/app/(login)/accounts/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ async function loadSessions(): Promise<Session[]> {
if (ids && ids.length) {
const response = await listSessions(
server,
ids.filter((id: string | undefined) => !!id)
ids.filter((id: string | undefined) => !!id),
);
return response?.sessions ?? [];
} else {
Expand Down
6 changes: 3 additions & 3 deletions apps/login/app/(login)/idp/[provider]/success/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -63,18 +63,18 @@ const PROVIDER_MAPPING: {

function retrieveIDPIntent(
id: string,
token: string
token: string,
): Promise<RetrieveIdentityProviderIntentResponse> {
const userService = user.getUser(server);
return userService.retrieveIdentityProviderIntent(
{ idpIntentId: id, idpIntentToken: token },
{}
{},
);
}

function createUser(
provider: ProviderSlug,
info: IDPInformation
info: IDPInformation,
): Promise<string> {
const userData = PROVIDER_MAPPING[provider](info);
const userService = user.getUser(server);
Expand Down
4 changes: 2 additions & 2 deletions apps/login/app/(login)/idp/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,13 +14,13 @@ import {

function getIdentityProviders(
server: ZitadelServer,
orgId?: string
orgId?: string,
): Promise<IdentityProvider[] | undefined> {
const settingsService = settings.getSettings(server);
return settingsService
.getActiveIdentityProviders(
orgId ? { ctx: { orgId } } : { ctx: { instance: true } },
{}
{},
)
.then((resp: GetActiveIdentityProvidersResponse) => {
return resp.identityProviders;
Expand Down
4 changes: 2 additions & 2 deletions apps/login/app/(login)/loginname/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,13 +16,13 @@ import {

function getIdentityProviders(
server: ZitadelServer,
orgId?: string
orgId?: string,
): Promise<IdentityProvider[] | undefined> {
const settingsService = settings.getSettings(server);
return settingsService
.getActiveIdentityProviders(
orgId ? { ctx: { orgId } } : { ctx: { instance: true } },
{}
{},
)
.then((resp: GetActiveIdentityProvidersResponse) => {
return resp.identityProviders;
Expand Down
2 changes: 1 addition & 1 deletion apps/login/app/(login)/passkey/add/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ export default async function Page({
async function loadSession(loginName?: string) {
const recent = await getMostRecentCookieWithLoginname(
loginName,
organization
organization,
);
return getSession(server, recent.id, recent.token).then((response) => {
if (response?.session) {
Expand Down
4 changes: 2 additions & 2 deletions apps/login/app/(login)/passkey/login/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -26,11 +26,11 @@ export default async function Page({

async function loadSessionByLoginname(
loginName?: string,
organization?: string
organization?: string,
) {
const recent = await getMostRecentCookieWithLoginname(
loginName,
organization
organization,
);
return getSession(server, recent.id, recent.token).then((response) => {
if (response?.session) {
Expand Down
2 changes: 1 addition & 1 deletion apps/login/app/(login)/password/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ export default async function Page({
async function loadSession(loginName?: string, organization?: string) {
const recent = await getMostRecentCookieWithLoginname(
loginName,
organization
organization,
);

return getSession(server, recent.id, recent.token).then((response) => {
Expand Down
2 changes: 1 addition & 1 deletion apps/login/app/(login)/register/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ export default async function Page({
const legal = await getLegalAndSupportSettings(server, organization);
const passwordComplexitySettings = await getPasswordComplexitySettings(
server,
organization
organization,
);

const branding = await getBrandingSettings(server, organization);
Expand Down
4 changes: 2 additions & 2 deletions apps/login/app/api/loginname/route.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ export async function POST(request: NextRequest) {
userId,
undefined,
undefined,
authRequestId
authRequestId,
)
.then((session) => {
if (session.factors?.user?.id) {
Expand All @@ -43,7 +43,7 @@ export async function POST(request: NextRequest) {
} else {
return NextResponse.json(
{ message: "Could not find user" },
{ status: 404 }
{ status: 404 },
);
}
});
Expand Down
4 changes: 2 additions & 2 deletions apps/login/app/api/passkeys/route.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ export async function POST(request: NextRequest) {
const session = await getSession(
server,
sessionCookie.id,
sessionCookie.token
sessionCookie.token,
);

const domain: string = request.nextUrl.hostname;
Expand All @@ -40,7 +40,7 @@ export async function POST(request: NextRequest) {
} else {
return NextResponse.json(
{ details: "could not get session" },
{ status: 500 }
{ status: 500 },
);
}
} else {
Expand Down
6 changes: 3 additions & 3 deletions apps/login/app/api/passkeys/verify/route.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ export async function POST(request: NextRequest) {
const session = await getSession(
server,
sessionCookie.id,
sessionCookie.token
sessionCookie.token,
);

const userId = session?.session?.factors?.user?.id;
Expand All @@ -29,7 +29,7 @@ export async function POST(request: NextRequest) {
passkeyId,
passkeyName,
publicKeyCredential,
userId
userId,
)
.then((resp) => {
return NextResponse.json(resp);
Expand All @@ -40,7 +40,7 @@ export async function POST(request: NextRequest) {
} else {
return NextResponse.json(
{ details: "could not get session" },
{ status: 500 }
{ status: 500 },
);
}
} else {
Expand Down
2 changes: 1 addition & 1 deletion apps/login/app/api/registeruser/route.ts
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ export async function POST(request: NextRequest) {
user.userId,
password,
undefined,
authRequestId
authRequestId,
).then((session) => {
return NextResponse.json({
userId: user.userId,
Expand Down
28 changes: 15 additions & 13 deletions apps/login/app/api/session/route.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ export async function POST(request: NextRequest) {
userId,
idpIntent,
organization,
authRequestId
authRequestId,
).then((session) => {
return NextResponse.json(session);
});
Expand All @@ -41,15 +41,15 @@ export async function POST(request: NextRequest) {
password,
undefined,
organization,
authRequestId
authRequestId,
).then((session) => {
return NextResponse.json(session);
});
}
} else {
return NextResponse.json(
{ details: "Session could not be created" },
{ status: 500 }
{ status: 500 },
);
}
}
Expand Down Expand Up @@ -78,12 +78,14 @@ export async function PUT(request: NextRequest) {
return Promise.reject(error);
})
: loginName
? getSessionCookieByLoginName(loginName, organization).catch((error) => {
return Promise.reject(error);
})
: getMostRecentSessionCookie().catch((error) => {
return Promise.reject(error);
});
? getSessionCookieByLoginName(loginName, organization).catch(
(error) => {
return Promise.reject(error);
},
)
: getMostRecentSessionCookie().catch((error) => {
return Promise.reject(error);
});

const domain: string = request.nextUrl.hostname;

Expand All @@ -98,7 +100,7 @@ export async function PUT(request: NextRequest) {
password,
webAuthN,
challenges,
authRequestId
authRequestId,
).then((session) => {
return NextResponse.json({
sessionId: session.id,
Expand All @@ -113,7 +115,7 @@ export async function PUT(request: NextRequest) {
} else {
return NextResponse.json(
{ details: "Request body is missing" },
{ status: 400 }
{ status: 400 },
);
}
}
Expand All @@ -137,14 +139,14 @@ export async function DELETE(request: NextRequest) {
.catch((error) => {
return NextResponse.json(
{ details: "could not set cookie" },
{ status: 500 }
{ status: 500 },
);
});
})
.catch((error) => {
return NextResponse.json(
{ details: "could not delete session" },
{ status: 500 }
{ status: 500 },
);
});
} else {
Expand Down
Loading

0 comments on commit 95fec9d

Please sign in to comment.