నా సైట్ entirely static . ఇది Hugo తో నిర్మించబడింది మరియు Hugo తో హోస్ట్ Zeit . నేను సెటప్ తో చాలా సంతోషంగా ఉన్నాను, నేను తక్షణ బిల్డ్స్ మరియు సూపర్ ఫాస్ట్ CDN'd కంటెంట్ డెలివరీ దగ్గరికి వచ్చేలా మరియు నేను ఏ దేశాన్ని నిర్వహించనందున నేను అవసరమైన అన్ని విషయాలను చేయగలను.
నేను ఈ సైట్ కోసం ఒక simple UI సృష్టించాను మరియు నా podcast creator కూడా క్రొత్త కంటెంట్ని నా podcast creator హోస్ట్ చేసిన సైట్కు త్వరగా పోస్ట్ podcast creator .
So. నేను ఎలా చేసాను?
ఇది నా Github రెపో వ్యతిరేకంగా Firebase Auth కలయిక, ఎడిటర్ JS సవరించడానికి కంటెంట్ సవరించడానికి (అది చక్కగా ఉంది) మరియు Octokat.js repo కట్టుబడి మరియు అప్పుడు Zeit యొక్క Github ఇంటిగ్రేషన్ నా హ్యూగో బిల్డ్ చేయడానికి. ఈ సెట్ అప్ తో, నేను ఒక యూజర్ WordPress వంటి CMS మద్దతు ఒక డేటాబేస్ లో పోస్ట్స్ సృష్టించడానికి ఎలా పోలి ఒక పూర్తిగా స్వీయ హోస్ట్ స్టాటిక్ CMS, కలిగి సామర్థ్యం am.
ఈ పోస్ట్ లో నేను మౌలిక సదుపాయంలో ఒక భాగాన దృష్టి సారించబోతున్నాను - గిథబ్ కు బహుళ ఫైళ్ళను చేస్తున్నందున నేను పని చేయటానికి కొంచెం సమయం పట్టింది.
మొత్తం కోడ్ నా repo చూడవచ్చు.
మీరు Github నేరుగా కట్టుబడి అవసరం వెబ్ UI నిర్మాణ ఉంటే, నేను కనుగొన్న ఉత్తమ లైబ్రరీ Octokat ఉంది - ఇది CORS పనిచేస్తుంది మరియు అది Github API మొత్తం API ఉపరితలం నిర్వహించడానికి తెలుస్తోంది.
చెట్టు, శాఖలు మరియు ఇతర ముక్కలు ఎలా పని చేస్తాయో అర్థం చేసుకోవటానికి వచ్చినప్పుడు జిట్ అనేది ఒక సంక్లిష్ట మృగం కావచ్చు, అందువల్ల నేను కొన్ని నిర్ణయాలు తీసుకున్నాను.
- నేను
heads/master
అని పిలవబడే మాస్టర్ బ్రాంచ్కి మాత్రమేheads/master
. - కొన్ని ఫైల్లు ఎక్కడ నిల్వ చేయబడతాయో నాకు తెలుసు. (హ్యూగో నాకు నిర్ధిష్టమైన డైరెక్టరీ నిర్మాణం కలిగివుంటుంది)
మనసులో, బహుళ ఫైళ్ళతో ఒక నిబద్ధతను సృష్టించటానికి సాధారణ ప్రక్రియ క్రింది విధంగా ఉంది:
రెపో సూచనను పొందండి.
heads/master
శాఖలో చెట్టు యొక్క కొనకు సూచన పొందండి. ప్రతి ఒక్క ఫైల్ కోసం మేము ఒకblob
సృష్టించి, ఆ తరువాతsha
ఐడెంటిఫైయర్,sha
, మోడ్లో మోడ్ లనుsha
.heads/master
ట్రీ యొక్కheads/master
సూచనగా జోడించడానికి అన్నిtree
కలిగి ఉన్న క్రొత్తtree
సృష్టించండి మరియు ఈ చెట్టుకు కొత్తsha
పాయింటర్ను నిల్వ చేయండి.- ఈ కొత్త చెట్టుకు సూచించే
heads/master
మరియు తరువాతheads/master
బ్రాంచ్కిheads/master
.
కోడ్ అందంగా చాలా ఆ ప్రవాహం అనుసరిస్తుంది. నేను కొన్ని ఇన్పుట్లను కోసం మార్గం నిర్మాణం భావించవచ్చు ఎందుకంటే నేను ఫైళ్లు కోసం ఏ క్లిష్టమైన UI లేదా నిర్వహణ నిర్మించడానికి అవసరం లేదు.
const createCommit = async (repositoryUrl, filename, data, images, commitMessage, recording) => {
try {
const token = localStorage.getItem('accessToken');
const github = new Octokat({ 'token': token });
const [user, repoName] = repositoryUrl.split('/');
if(user === null || repoName === null) {
alert('Please specifiy a repo');
return;
}
const markdownPath = `site/content/${filename}.markdown`.toLowerCase();
let repo = await github.repos(user, repoName).fetch();
let main = await repo.git.refs('heads/master').fetch();
let treeItems = [];
for(let image of images) {
let imageGit = await repo.git.blobs.create({ content: image.data, encoding: 'base64' });
let imagePath = `site/static/images/${image.name}`.toLowerCase();
treeItems.push({
path: imagePath,
sha: imageGit.sha,
mode: "100644",
type: "blob"
});
}
if (recording) {
let audioGit = await repo.git.blobs.create({ content: recording.data, encoding: 'base64' });
let audioPath = `site/static/audio/${recording.name}.${recording.extension}`.toLowerCase();
treeItems.push({
path: audioPath,
sha: audioGit.sha,
mode: "100644",
type: "blob"
});
}
let markdownFile = await repo.git.blobs.create({ content: btoa(jsonEncode(data)), encoding: 'base64' });
treeItems.push({
path: markdownPath,
sha: markdownFile.sha,
mode: "100644",
type: "blob"
});
let tree = await repo.git.trees.create({
tree: treeItems,
base_tree: main.object.sha
});
let commit = await repo.git.commits.create({
message: `Created via Web - ${commitMessage}`,
tree: tree.sha,
parents: [main.object.sha]});
main.update({sha: commit.sha})
logToToast('Posted');
} catch (err) {
console.error(err);
logToToast(err);
}
}
మీరు స్టాటిక్ హోస్టింగ్ మాదిరిగానే ఏదైనా చేసినట్లయితే నాకు తెలియజేయండి. పూర్తిగా ఆధునిక తక్కువ హోస్టింగ్ మౌలిక సదుపాయాల కోసం నేను ఆధునిక ఫ్రంటెండ్ను నిర్మించగలనని చాలా సంతోషిస్తున్నాను.
Zeit గురించి ఏమిటి?
బాగా, ఇది ఇప్పుడు అన్ని ఆటోమేటిక్ గా జస్ట్ ఉంది. నేను static-builder
ఆదేశాన్ని అమలు చేయడానికి static-builder
ను ఉపయోగిస్తాను మరియు అది చాలా static-builder
. :)