Files
AFFiNE-Mirror/packages/backend/server/src/schema.gql

427 lines
9.7 KiB
GraphQL

# ------------------------------------------------------
# THIS FILE WAS AUTOMATICALLY GENERATED (DO NOT MODIFY)
# ------------------------------------------------------
input CreateCheckoutSessionInput {
coupon: String
idempotencyKey: String!
plan: SubscriptionPlan = Pro
recurring: SubscriptionRecurring = Yearly
successCallbackLink: String
}
"""
A date-time string at UTC, such as 2019-12-03T09:54:33Z, compliant with the date-time format.
"""
scalar DateTime
type DeleteAccount {
success: Boolean!
}
type DocHistoryType {
id: String!
timestamp: DateTime!
workspaceId: String!
}
"""The type of workspace feature"""
enum FeatureType {
Copilot
EarlyAccess
UnlimitedWorkspace
}
type HumanReadableQuotaType {
blobLimit: String!
historyPeriod: String!
memberLimit: String!
name: String!
storageQuota: String!
}
type InvitationType {
"""Invitee information"""
invitee: UserType!
"""User information"""
user: UserType!
"""Workspace information"""
workspace: InvitationWorkspaceType!
}
type InvitationWorkspaceType {
"""Base64 encoded avatar"""
avatar: String!
id: ID!
"""Workspace name"""
name: String!
}
type InviteUserType {
"""User accepted"""
accepted: Boolean!
"""User avatar url"""
avatarUrl: String
"""User created date"""
createdAt: DateTime
"""User email"""
email: String
"""User email verified"""
emailVerified: DateTime
"""User password has been set"""
hasPassword: Boolean
id: ID!
"""Invite id"""
inviteId: String!
"""User name"""
name: String
"""User permission in workspace"""
permission: Permission!
}
enum InvoiceStatus {
Draft
Open
Paid
Uncollectible
Void
}
type LimitedUserType {
"""User email"""
email: String!
"""User password has been set"""
hasPassword: Boolean
}
type Mutation {
acceptInviteById(inviteId: String!, sendAcceptMail: Boolean, workspaceId: String!): Boolean!
addToEarlyAccess(email: String!): Int!
addWorkspaceFeature(feature: FeatureType!, workspaceId: String!): Int!
cancelSubscription(idempotencyKey: String!): UserSubscription!
changeEmail(token: String!): UserType!
changePassword(newPassword: String!, token: String!): UserType!
"""Create a subscription checkout link of stripe"""
checkout(idempotencyKey: String!, recurring: SubscriptionRecurring!): String! @deprecated(reason: "use `createCheckoutSession` instead")
"""Create a subscription checkout link of stripe"""
createCheckoutSession(input: CreateCheckoutSessionInput!): String!
"""Create a stripe customer portal to manage payment methods"""
createCustomerPortal: String!
"""Create a new workspace"""
createWorkspace(init: Upload): WorkspaceType!
deleteAccount: DeleteAccount!
deleteBlob(hash: String!, workspaceId: String!): Boolean!
deleteWorkspace(id: String!): Boolean!
invite(email: String!, permission: Permission!, sendInviteMail: Boolean, workspaceId: String!): String!
leaveWorkspace(sendLeaveMail: Boolean, workspaceId: String!, workspaceName: String!): Boolean!
publishPage(mode: PublicPageMode = Page, pageId: String!, workspaceId: String!): WorkspacePage!
recoverDoc(guid: String!, timestamp: DateTime!, workspaceId: String!): DateTime!
"""Remove user avatar"""
removeAvatar: RemoveAvatar!
removeEarlyAccess(email: String!): Int!
removeWorkspaceFeature(feature: FeatureType!, workspaceId: String!): Int!
resumeSubscription(idempotencyKey: String!): UserSubscription!
revoke(userId: String!, workspaceId: String!): Boolean!
revokePage(pageId: String!, workspaceId: String!): Boolean! @deprecated(reason: "use revokePublicPage")
revokePublicPage(pageId: String!, workspaceId: String!): WorkspacePage!
sendChangeEmail(callbackUrl: String!, email: String!): Boolean!
sendChangePasswordEmail(callbackUrl: String!, email: String!): Boolean!
sendSetPasswordEmail(callbackUrl: String!, email: String!): Boolean!
sendVerifyChangeEmail(callbackUrl: String!, email: String!, token: String!): Boolean!
setBlob(blob: Upload!, workspaceId: String!): String!
setWorkspaceExperimentalFeature(enable: Boolean!, feature: FeatureType!, workspaceId: String!): Boolean!
sharePage(pageId: String!, workspaceId: String!): Boolean! @deprecated(reason: "renamed to publicPage")
signIn(email: String!, password: String!): UserType!
signUp(email: String!, name: String!, password: String!): UserType!
updateSubscriptionRecurring(idempotencyKey: String!, recurring: SubscriptionRecurring!): UserSubscription!
"""Update workspace"""
updateWorkspace(input: UpdateWorkspaceInput!): WorkspaceType!
"""Upload user avatar"""
uploadAvatar(avatar: Upload!): UserType!
}
"""User permission in workspace"""
enum Permission {
Admin
Owner
Read
Write
}
"""The mode which the public page default in"""
enum PublicPageMode {
Edgeless
Page
}
type Query {
checkBlobSize(size: SafeInt!, workspaceId: String!): WorkspaceBlobSizes! @deprecated(reason: "no more needed")
collectAllBlobSizes: WorkspaceBlobSizes! @deprecated(reason: "use `user.storageUsage` instead")
"""Get current user"""
currentUser: UserType
earlyAccessUsers: [UserType!]!
"""Update workspace"""
getInviteInfo(inviteId: String!): InvitationType!
"""Get is owner of workspace"""
isOwner(workspaceId: String!): Boolean!
"""List blobs of workspace"""
listBlobs(workspaceId: String!): [String!]! @deprecated(reason: "use `workspace.blobs` instead")
listWorkspaceFeatures(feature: FeatureType!): [WorkspaceType!]!
prices: [SubscriptionPrice!]!
"""Get public workspace by id"""
publicWorkspace(id: String!): WorkspaceType!
"""server config"""
serverConfig: ServerConfigType!
"""Get user by email"""
user(email: String!): UserOrLimitedUser
"""Get workspace by id"""
workspace(id: String!): WorkspaceType!
"""Get all accessible workspaces for current user"""
workspaces: [WorkspaceType!]!
}
type QuotaQueryType {
blobLimit: SafeInt!
historyPeriod: SafeInt!
humanReadable: HumanReadableQuotaType!
memberLimit: SafeInt!
name: String!
storageQuota: SafeInt!
usedSize: SafeInt!
}
type RemoveAvatar {
success: Boolean!
}
"""
The `SafeInt` scalar type represents non-fractional signed whole numeric values that are considered safe as defined by the ECMAScript specification.
"""
scalar SafeInt @specifiedBy(url: "https://www.ecma-international.org/ecma-262/#sec-number.issafeinteger")
type ServerConfigType {
"""server base url"""
baseUrl: String!
"""enabled server features"""
features: [ServerFeature!]!
"""server flavor"""
flavor: String! @deprecated(reason: "use `features`")
"""server identical name could be shown as badge on user interface"""
name: String!
"""server version"""
version: String!
}
enum ServerFeature {
Payment
}
enum SubscriptionPlan {
Enterprise
Free
Pro
SelfHosted
Team
}
type SubscriptionPrice {
amount: Int!
currency: String!
plan: SubscriptionPlan!
type: String!
yearlyAmount: Int!
}
enum SubscriptionRecurring {
Monthly
Yearly
}
enum SubscriptionStatus {
Active
Canceled
Incomplete
IncompleteExpired
PastDue
Paused
Trialing
Unpaid
}
type TokenType {
refresh: String!
sessionToken: String
token: String!
}
input UpdateWorkspaceInput {
id: ID!
"""is Public workspace"""
public: Boolean
}
"""The `Upload` scalar type represents a file upload."""
scalar Upload
type UserInvoice {
amount: Int!
createdAt: DateTime!
currency: String!
id: String!
lastPaymentError: String
link: String
plan: SubscriptionPlan!
reason: String!
recurring: SubscriptionRecurring!
status: InvoiceStatus!
updatedAt: DateTime!
}
union UserOrLimitedUser = LimitedUserType | UserType
type UserQuota {
blobLimit: SafeInt!
historyPeriod: SafeInt!
humanReadable: UserQuotaHumanReadable!
memberLimit: Int!
name: String!
storageQuota: SafeInt!
}
type UserQuotaHumanReadable {
blobLimit: String!
historyPeriod: String!
memberLimit: String!
name: String!
storageQuota: String!
}
type UserSubscription {
canceledAt: DateTime
createdAt: DateTime!
end: DateTime!
id: String!
nextBillAt: DateTime
plan: SubscriptionPlan!
recurring: SubscriptionRecurring!
start: DateTime!
status: SubscriptionStatus!
trialEnd: DateTime
trialStart: DateTime
updatedAt: DateTime!
}
type UserType {
"""User avatar url"""
avatarUrl: String
"""User created date"""
createdAt: DateTime
"""User email"""
email: String!
"""User email verified"""
emailVerified: DateTime
"""User password has been set"""
hasPassword: Boolean
id: ID!
"""Get user invoice count"""
invoiceCount: Int!
invoices(skip: Int, take: Int = 8): [UserInvoice!]!
"""User name"""
name: String!
quota: UserQuota
subscription: UserSubscription
token: TokenType!
}
type WorkspaceBlobSizes {
size: SafeInt!
}
type WorkspacePage {
id: String!
mode: PublicPageMode!
public: Boolean!
workspaceId: String!
}
type WorkspaceType {
"""Available features of workspace"""
availableFeatures: [FeatureType!]!
"""List blobs of workspace"""
blobs: [String!]!
"""Blobs size of workspace"""
blobsSize: Int!
"""Workspace created date"""
createdAt: DateTime!
"""Enabled features of workspace"""
features: [FeatureType!]!
histories(before: DateTime, guid: String!, take: Int): [DocHistoryType!]!
id: ID!
"""member count of workspace"""
memberCount: Int!
"""Members of workspace"""
members(skip: Int, take: Int): [InviteUserType!]!
"""Owner of workspace"""
owner: UserType!
"""Permission of current signed in user in workspace"""
permission: Permission!
"""is Public workspace"""
public: Boolean!
"""Public pages of a workspace"""
publicPages: [WorkspacePage!]!
"""quota of workspace"""
quota: QuotaQueryType!
"""Shared pages of workspace"""
sharedPages: [String!]! @deprecated(reason: "use WorkspaceType.publicPages")
}