Backend for reading and writing data and uploading files in GitHub repositories.

Hierarchy (view full)

Constructors

Properties

accessToken: any
apiKey: any
authPopup: Window
clientId: any
data: any
options: any
permissions: any
rawData: string
ready: Promise<void>
ref: any
source: string
user: any
_all: any[] = []
api: {
    get: ((ref) => string);
    put: ((ref) => string);
    user: {
        fields: {
            avatar: string;
            name: string[];
            url: (() => string);
            username: string;
        };
        get: string;
    };
} = ...

Type declaration

  • get: ((ref) => string)
      • (ref): string
      • Parameters

        • ref: any

        Returns string

  • put: ((ref) => string)
      • (ref): string
      • Parameters

        • ref: any

        Returns string

  • user: {
        fields: {
            avatar: string;
            name: string[];
            url: (() => string);
            username: string;
        };
        get: string;
    }
    • fields: {
          avatar: string;
          name: string[];
          url: (() => string);
          username: string;
      }
      • avatar: string
      • name: string[]
      • url: (() => string)
          • (): string
          • Returns string

      • username: string
    • get: string
apiDomain: string = "https://api.github.com/"
authProvider: string = "https://auth.madata.dev"

Auth Provider to use. This is only relevant for OAuthBackend, but specifying here as Backend is the only class users import.

capabilities: {
    auth: boolean;
    put: boolean;
    upload: boolean;
} = ...

Type declaration

  • auth: boolean
  • put: boolean
  • upload: boolean
defaultFormat: string = "JSON"
defaultPermissions: {
    read: boolean;
} = ...

Type declaration

  • read: boolean
defaults: {
    branch: any;
    owner: any;
    path: string;
    repo: string;
} = ...

Type declaration

  • branch: any
  • owner: any
  • path: string
  • repo: string
fileBased: boolean = true
hooks: Hooks = hooks
oAuth: string = "https://github.com/login/oauth/authorize"
phrases: {
    no_write_permission: ((ref) => string);
} = ...

Type declaration

  • no_write_permission: ((ref) => string)
      • (ref): string
      • Parameters

        • ref: any

        Returns string

urls: string[] = ...

Accessors

  • get authProviderServices(): Promise<any>
  • services.json from the auth provider will be cached here. You could also set this manually to avoid the network request.

    Returns Promise<any>

    Member

  • get host(): any
  • Return the hostname of the first URL pattern in the urls array, if not variable. This is used to facilitate relative URLs when constructing Backends directly. Subclasses with variable hostnames can override this.

    Returns any

  • get title(): string
  • Returns string

Methods

  • Abstract

    Show authentication UI to the user. Must be implemented by subclasses.

    Parameters

    • o: any

    Returns Promise<any>

  • Fork a repo, or return a fork if one already exists

    Parameters

    • Optional ref: any = ...
    • Optional options: options = {}

    Returns Promise<any>

  • Get a public URL for a file in a repo

    Parameters

    • path: any = ...
    • __namedParameters: {
          ref: any;
      } = {}
      • ref: any

    Returns Promise<any>

  • Find forks of a repo by the current user

    Parameters

    • repoInfo: any = ...

    Returns any

    repoInfo object about the fork or null

  • Parameters

    • ref: any = ...
    • __namedParameters: {
          sha: any;
      } = {}
      • sha: any

    Returns Promise<any>

  • Get info about the current user, if logged in. Subclasses are generally expected to override this.

    Returns Promise<any>

    • User info
  • Is current user authenticated? Synchronous because it must not trigger any API calls, use passiveLogin() for that

    Returns boolean

  • Higher-level method for reading data from the backend. Subclasses should usually NOT override this method.

    Parameters

    • url: string

      URL to fetch, if different from that provided in the constructor

    • Rest ...args: any[]

    Returns any

    • Data from the backend as a JSON object, null if not found
  • Parameters

    • data: any
    • __namedParameters: {
          ref: any;
      } = {}
      • ref: any

    Returns Promise<any>

  • Abstract

    Try to authenticate a previously authenticated user (i.e. without showing any login UI).

    Returns Promise<void>

  • Parameters

    • ref: any = ...
    • __namedParameters: {
          https_enforced: boolean;
      } = {}
      • https_enforced: boolean

    Returns Promise<any>

  • Saves a file to the backend.

    Parameters

    • data: any
    • path: string = {}

      Optional file path

    Returns Promise<any>

    A promise that resolves when the file is saved.

  • Helper for making OAuth requests with JSON-based APIs.

    Parameters

    • call: string

      API endpoint

    • Optional data: any

      Data to send with the request

    • Optional method: string = "GET"

      HTTP method

    • Optional req: {
          headers: any;
          responseType: string;
      }

      Extra request options

      • headers: any

        Extra headers

      • responseType: string

        Response type

    Returns Promise<any>

    • JSON response
  • Higher-level method for writing data to the backend. Subclasses should usually NOT override this method.

    Parameters

    • data: any

      Data to write to the backend

    • Optional o: any = {}

      Options object

    Returns any

    • If successful, info about the stored data
  • Parameters

    • data: any
    • __namedParameters: {
          ref: any;
      } = {}
      • ref: any

    Returns Promise<any>

  • Sync the logged in user, i.e. log in passively when another backend has logged in and log out when another backend has logged out. Generally intended to be used for backends with the same authentication mechanism. Syncing is not two-way, you need to call this on the other backend as well to make it so.

    Parameters

    Returns void

  • Update an existing backend instance with new parameters

    Parameters

    • url: string

      Same as constructor

    • o: any

      Same as constructor

    Returns void

  • Return the appropriate backend(s) for this url

    Parameters

    • url: string

      URL describing the storage location

    • Optional o: {
          existing: Backend | Backend[];
      } = {}

      Options object to be passed to the backend

      • existing: Backend | Backend[]

        Existing backend object(s) to re-use if possible

    Returns any

Generated using TypeDoc