Skip to content

Latest commit

 

History

History
133 lines (117 loc) · 2.8 KB

README.md

File metadata and controls

133 lines (117 loc) · 2.8 KB

BooCat

A universal book search platform which allows you to search several providers by just one-click.

Supported Providers

  • Z-Library
  • Library Genesis
  • Open Library
  • Memory of the World
  • The Online Books Page by UPenn

Tech Stacks

  • .NET 6
  • Azure Function App
  • ASP.NET Core
  • Redis (Available at AspNetWebApi)

API Design

Shared Type

type bookInfo {
    id         : string?
    name       : string
    url        : string
    authors    : string[]?
    publishers : string[]?
    date       : string?
    fileType   : string?
    language   : string?
    fileSize   : string?
}

type errModel {
  msg    : string
  source : string?
}

Single search

Provider::= ZLib | LibGen | Mem | OpenLib | OnlineBooks
API: [GET] /api/{Provider}?name={name}
Response:
    Type: json
    Ok: bookInfo[]
    Err: errModel
Example: [GET] /api/Mem?name=Hello
Result :
        [
          {
            "name": "hello",
            "url": "https://ex1"
          }, {
            "name": "hello2",
            "url": "https://ex1"
          }
        ]
Or     : {"msg": "Timeout"}

AllBooks

type resultModel {
  success: boolean
  books  : bookInfo[]? // if success, books is not null
  err    : errModel?   // else err is not null
}
Provider ::= z | g | m | o | b
ProviderParam ::= provider={Provider}
Param ::= ProviderParam+
API: [GET] /api/AllBooks?name={name}{Param}
Response:
    Type: json
    Ok: Map<Provider, resultModel>
Example: [GET] /api/AllBooks?name=Hello&provider=z&provider=m
Result : {
          "z": {"success": true , "books": []},
          "m": {"success": false, "err"  : {"msg": "Timeout"}
         }

Network Structure

flowchart TB
  cli[Client]
  cdn_cf[CloudFlare]

  cli -- query & request ---> cdn_cf
  cdn_cf -- proxy ---> fe
  cdn_cf -- request/query ---> tm
  cli -- request ---> vm
  subgraph be [Backend]
    direction TB
    tm[Azure Traffic Manager]
    tm -- point ---> vm
    subgraph func [Azure Function]
       direction LR
       f_us[US]
       f_uk[UK]
       f_hk[HK]
    end
    subgraph vm [Azure Virtual Machine for API]
      direction LR
      vm_us[US] -- proxy & cache ---> f_us
      vm_uk[UK] -- proxy & cache ---> f_uk
      vm_hk[HK] -- proxy & cache ---> f_hk
    end
  end
  subgraph fe [Frontend]
    gh[GitHub Page]
  end
  subgraph prov [Provider]
    direction TB
    zlib[Z-Library]
    libgen[Library Genesis]
    mem[Memory of the World]
    openlib[Open Library]
    onlinebooks[The Online Books Page]
  end
  func -- request ---> prov
Loading