A picture bed based on GitHub. Provide an HTTP file service through Pages. Upload images using the GitHub API.
npm install github-picbed
const 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
repo
for 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.