Skip to content

Commit

Permalink
add register functionality
Browse files Browse the repository at this point in the history
  • Loading branch information
aumetra committed May 1, 2024
1 parent b692a19 commit 69f20b6
Show file tree
Hide file tree
Showing 5 changed files with 203 additions and 99 deletions.
2 changes: 2 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
[profile.dev.package]
backtrace = { opt-level = 3 }
num-bigint-dig = { opt-level = 3 }
taplo = { debug-assertions = false } # A debug assertion will make the xtask panic with too long trailing comments

# The profile that 'cargo dist' will build with
Expand Down
5 changes: 5 additions & 0 deletions kitsune-fe/houdini.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,11 @@ const config = {
},
plugins: {
'houdini-svelte': {}
},
scalars: {
DateTime: {
type: 'Date'
}
}
};

Expand Down
226 changes: 130 additions & 96 deletions kitsune-fe/schema.graphql
Original file line number Diff line number Diff line change
@@ -1,30 +1,30 @@
schema {
query: RootQuery
mutation: RootMutation
query: RootQuery
mutation: RootMutation
}

type Account {
avatar: MediaAttachment
createdAt: DateTime!
displayName: String
header: MediaAttachment
id: UUID!
locked: Boolean!
note: String
posts(after: String, before: String, first: Int, last: Int): PostConnection!
updatedAt: DateTime!
url: String!
username: String!
avatar: MediaAttachment
createdAt: DateTime!
displayName: String
header: MediaAttachment
id: UUID!
locked: Boolean!
note: String
posts(after: String, before: String, first: Int, last: Int): PostConnection!
updatedAt: DateTime!
url: String!
username: String!
}

enum CaptchaBackend {
H_CAPTCHA
M_CAPTCHA
H_CAPTCHA
M_CAPTCHA
}

type CaptchaInfo {
backend: CaptchaBackend!
key: String!
backend: CaptchaBackend!
key: String!
}

"""
Expand All @@ -38,99 +38,133 @@ format, but it is always normalized to the UTC (Z) offset, e.g.
scalar DateTime

type Instance {
captcha: CaptchaInfo
characterLimit: Int!
description: String!
domain: String!
localPostCount: Int!
name: String!
registrationsOpen: Boolean!
userCount: Int!
version: String!
captcha: CaptchaInfo
characterLimit: Int!
description: String!
domain: String!
localPostCount: Int!
name: String!
registrationsOpen: Boolean!
userCount: Int!
version: String!
}

type MediaAttachment {
blurhash: String
contentType: String!
createdAt: DateTime!
description: String
id: UUID!
uploader: Account!
url: String!
blurhash: String
contentType: String!
createdAt: DateTime!
description: String
id: UUID!
uploader: Account!
url: String!
}

type OAuth2Application {
createdAt: DateTime!
id: UUID!
name: String!
redirectUri: String!
secret: String!
updatedAt: DateTime!
createdAt: DateTime!
id: UUID!
name: String!
redirectUri: String!
secret: String!
updatedAt: DateTime!
}

"""Information about pagination in a connection"""
"""
Information about pagination in a connection
"""
type PageInfo {
"""When paginating forwards, the cursor to continue."""
endCursor: String

"""When paginating forwards, are there more items?"""
hasNextPage: Boolean!

"""When paginating backwards, are there more items?"""
hasPreviousPage: Boolean!

"""When paginating backwards, the cursor to continue."""
startCursor: String
"""
When paginating forwards, the cursor to continue.
"""
endCursor: String

"""
When paginating forwards, are there more items?
"""
hasNextPage: Boolean!

"""
When paginating backwards, are there more items?
"""
hasPreviousPage: Boolean!

"""
When paginating backwards, the cursor to continue.
"""
startCursor: String
}

type Post {
account: Account!
attachments: [MediaAttachment!]!
content: String!
createdAt: DateTime!
id: UUID!
isSensitive: Boolean!
subject: String
updatedAt: DateTime!
url: String!
visibility: Visibility!
account: Account!
attachments: [MediaAttachment!]!
content: String!
createdAt: DateTime!
id: UUID!
isSensitive: Boolean!
subject: String
updatedAt: DateTime!
url: String!
visibility: Visibility!
}

type PostConnection {
"""A list of edges."""
edges: [PostEdge!]!

"""A list of nodes."""
nodes: [Post!]!

"""Information to aid in pagination."""
pageInfo: PageInfo!
"""
A list of edges.
"""
edges: [PostEdge!]!

"""
A list of nodes.
"""
nodes: [Post!]!

"""
Information to aid in pagination.
"""
pageInfo: PageInfo!
}

"""An edge in a connection."""
"""
An edge in a connection.
"""
type PostEdge {
"""A cursor for use in pagination"""
cursor: String!

"""The item at the end of the edge"""
node: Post!
"""
A cursor for use in pagination
"""
cursor: String!

"""
The item at the end of the edge
"""
node: Post!
}

type RootMutation {
createPost(content: String!, isSensitive: Boolean!, visibility: Visibility!): Post!
deletePost(id: UUID!): UUID!
registerOauthApplication(name: String!, redirectUri: String!): OAuth2Application!
registerUser(captchaToken: String, email: String!, password: String!, username: String!): User!
updateUser(avatar: Upload, displayName: String, header: Upload, locked: Boolean, note: String): Account!
createPost(content: String!, isSensitive: Boolean!, visibility: Visibility!): Post!
deletePost(id: UUID!): UUID!
registerOauthApplication(name: String!, redirectUri: String!): OAuth2Application!
registerUser(captchaToken: String, email: String!, password: String!, username: String!): User!
updateUser(
avatar: Upload
displayName: String
header: Upload
locked: Boolean
note: String
): Account!
}

type RootQuery {
getAccountById(id: UUID!): Account
getPostById(id: UUID!): Post!
homeTimeline(after: String, before: String, first: Int, last: Int): PostConnection!
instance: Instance!
myAccount: Account!
publicTimeline(after: String, before: String, first: Int, last: Int, onlyLocal: Boolean! = true): PostConnection!
getAccountById(id: UUID!): Account
getPostById(id: UUID!): Post!
homeTimeline(after: String, before: String, first: Int, last: Int): PostConnection!
instance: Instance!
myAccount: Account!
publicTimeline(
after: String
before: String
first: Int
last: Int
onlyLocal: Boolean! = true
): PostConnection!
}

"""
Expand All @@ -148,17 +182,17 @@ scalar UUID
scalar Upload

type User {
account: Account!
createdAt: DateTime!
email: String!
id: UUID!
updatedAt: DateTime!
username: String!
account: Account!
createdAt: DateTime!
email: String!
id: UUID!
updatedAt: DateTime!
username: String!
}

enum Visibility {
FOLLOWER_ONLY
MENTION_ONLY
PUBLIC
UNLISTED
FOLLOWER_ONLY
MENTION_ONLY
PUBLIC
UNLISTED
}
2 changes: 1 addition & 1 deletion kitsune-fe/src/client.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { HoudiniClient } from '$houdini';

export default new HoudiniClient({
url: 'http://localhost:5000/graphql'
url: `${import.meta.env.VITE_BACKEND_URL ?? ''}/graphql`

// uncomment this to configure the network call (for things like authentication)
// for more information, please visit here: https://www.houdinigraphql.com/guides/authentication
Expand Down
67 changes: 65 additions & 2 deletions kitsune-fe/src/routes/+page.svelte
Original file line number Diff line number Diff line change
@@ -1,10 +1,63 @@
<script lang="ts">
import { graphql } from '$houdini';
import Button from '$lib/components/Button.svelte';
import { onMount } from 'svelte';
let registerButtonDisabled = $state(false);
onMount(() => {
// TODO: Authenticated check and redirect to home timeline
});
async function handleRegister(
event: SubmitEvent & { currentTarget: EventTarget & HTMLFormElement }
) {
event.preventDefault();
const data = new FormData(event.currentTarget);
const username = data.get('username');
const email = data.get('email');
const password = data.get('password');
const passwordConfirmation = data.get('confirm-password');
if (!username) {
alert('Missing username');
return;
} else if (!email) {
alert('Missing email');
return;
} else if (!password) {
alert('Missing password');
return;
} else if (!passwordConfirmation || passwordConfirmation !== password) {
alert('Password mismatch');
return;
}
const register = graphql(`
mutation Register($username: String!, $email: String!, $password: String!) {
registerUser(username: $username, email: $email, password: $password) {
username
createdAt
}
}
`);
try {
const response = await register.mutate({
username: username as string,
email: email as string,
password: password as string
});
if (response.errors) {
alert('Failed to register:\n' + response.errors.map((error) => error.message).concat('\n'));
} else {
alert('Registered!');
}
} catch (ex: unknown) {}
}
</script>

<div class="landing-page">
Expand All @@ -25,7 +78,13 @@
</div>

<div class="top-section-right">
<form class="register-form">
<form
class="register-form"
onsubmit={(e) => {
registerButtonDisabled = true;
handleRegister(e).finally(() => (registerButtonDisabled = false));
}}
>
<label>
Username
<br /><input type="text" name="username" />
Expand All @@ -47,7 +106,11 @@
</label>

<p>
<Button class="register-button" onclick={() => console.log('register')}>
<Button
class="register-button"
onclick={() => console.log('register')}
disabled={registerButtonDisabled}
>
Register
</Button>
</p>
Expand Down

0 comments on commit 69f20b6

Please sign in to comment.