summary refs log tree commit diff stats
path: root/svc/post.go
blob: 85804dc8716035307e5f7ad1ec1ce0acae6a1ef5 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
package svc // import "github.com/getwtxt/getwtxt/svc"

import (
	"fmt"
	"net/http"

	"github.com/getwtxt/registry"
)

// Requests to apiEndpointPOSTHandler are passed off to this
// function. apiPostUser then fetches the twtxt data, then if
// it's an individual user's file, adds it. If it's registry
// output, it scrapes the users/urls/statuses from the remote
// registry before adding each user to the local cache.
func apiPostUser(w http.ResponseWriter, r *http.Request) {
	if err := r.ParseForm(); err != nil {
		log400(w, r, "Error Parsing Values: "+err.Error())
		return
	}

	nick := r.FormValue("nickname")
	urls := r.FormValue("url")
	if nick == "" || urls == "" {
		log400(w, r, "Nickname or URL missing")
		return
	}

	uip := getIPFromCtx(r.Context())

	out, remoteRegistry, err := registry.GetTwtxt(urls)
	if err != nil {
		log400(w, r, "Error Fetching twtxt Data: "+err.Error())
		return
	}

	if remoteRegistry {
		remoteRegistries.Mu.Lock()
		remoteRegistries.List = append(remoteRegistries.List, urls)
		remoteRegistries.Mu.Unlock()

		if err := twtxtCache.CrawlRemoteRegistry(urls); err != nil {
			log400(w, r, "Error Crawling Remote Registry: "+err.Error())
			return
		}
		log200(r)
		return
	}

	statuses, err := registry.ParseUserTwtxt(out, nick, urls)
	errLog("Error Parsing User Data: ", err)

	if err := twtxtCache.AddUser(nick, urls, "", uip, statuses); err != nil {
		log400(w, r, "Error Adding User to Cache: "+err.Error())
		return
	}

	log200(r)
	_, err = w.Write([]byte(fmt.Sprintf("200 OK\n")))
	errLog("", err)
}
"w"> #005faf; } .LineNr { } --> </style> <script type='text/javascript'> <!-- /* function to open any folds containing a jumped-to line before jumping to it */ function JumpToLine() { var lineNum; lineNum = window.location.hash; lineNum = lineNum.substr(1); /* strip off '#' */ if (lineNum.indexOf('L') == -1) { lineNum = 'L'+lineNum; } var lineElem = document.getElementById(lineNum); /* Always jump to new location even if the line was hidden inside a fold, or * we corrected the raw number to a line ID. */ if (lineElem) { lineElem.scrollIntoView(true); } return true; } if ('onhashchange' in window) { window.onhashchange = JumpToLine; } --> </script> </head> <body onload='JumpToLine();'> <a href='https://github.com/akkartik/mu/blob/master/049memory_layout.subx'>https://github.com/akkartik/mu/blob/master/049memory_layout.subx</a> <pre id='vimCodeElement'> <span id="L1" class="LineNr">1 </span><span class="subxComment"># Segment addresses aren't really the concern of any other layer, so we'll</span> <span id="L2" class="LineNr">2 </span><span class="subxComment"># define them separately. They're approximate due to fidgety ELF alignment</span> <span id="L3" class="LineNr">3 </span><span class="subxComment"># requirements, so don't get clever assuming variables are at specific</span> <span id="L4" class="LineNr">4 </span><span class="subxComment"># addresses.</span> <span id="L5" class="LineNr">5 </span> <span id="L6" class="LineNr">6 </span>== code 0x09000000 <span id="L7" class="LineNr">7 </span> <span id="L8" class="LineNr">8 </span>== data 0x0a000000 </pre> </body> </html> <!-- vim: set foldmethod=manual : -->