A picture bed based on GitHub. Provide an HTTP file service through Pages. Upload images using the GitHub API.
npm install github-picbedconst github = require('github-picbed')({
token: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx',
repository: 'https://github.com/imlinhanchao/upload-file'
})
const path = require('path');
router.post('/upload', async (req, res, next) => {
let data = req.files[0].buffer;
let extname = path.extname(req.files[0].originalname);
let upload = await github.upload({ data, extname })
res.json(upload);
})- You need to create an access token in GitHub. Select only
repofor theselect scopes. - Create a repository use to upload files. And then enable GitHub Pages.
async function config({ token, repository });| key | description |
|---|---|
| token | Your GitHub access token. |
| repository | Your repository use to upload files. |
async function isInitialized();bool - true means finish initialize.
async function upload({ data, extname, filename });| key | description |
|---|---|
| data | The file path that you want to upload or the buffer of file. |
| extname | The extname of file. You must set this key if the data is buffer. |
| filename | The filename that you want to upload.(Options) |
| key | description |
|---|---|
| filename | The filename that was eventually uploaded. |
| url | Access URL. |
After configuring the GitHub repository address and access token, it takes about 1 second to get the information of GitHub Pages. Therefore, please do not upload immediately after configuration. You can use isInitialized to check if initialization has been completed. Or use await to wait for the configuration to complete.