void __attribute__ ((format (printf, 2, 3))) astman_append(struct mansession *s, const char *fmt, ...);
+/*! \brief Determinie if a manager session ident is authenticated */
+int astman_is_authed(uint32_t ident);
+
/*! \brief Called by Asterisk initialization */
int init_manager(void);
return wkspace;
}
+static uint32_t manid_from_vars(struct ast_variable *sid) {
+ uint32_t mngid;
+
+ while (sid && strcmp(sid->name, "mansession_id"))
+ sid = sid->next;
+
+ if (!sid || sscanf(sid->value, "%x", &mngid) != 1)
+ return 0;
+
+ return mngid;
+}
+
static struct ast_str *static_callback(struct ast_tcptls_session_instance *ser, const struct ast_http_uri *urih, const char *uri, enum ast_http_method method, struct ast_variable *vars, struct ast_variable *headers, int *status, char **title, int *contentlength)
{
char *path;
if (S_ISDIR(st.st_mode)) {
goto out404;
- }
+ }
if ((fd = open(path, O_RDONLY)) < 0) {
goto out403;
}
+ if (strstr(path, "/private/") && !astman_is_authed(manid_from_vars(vars))) {
+ goto out403;
+ }
+
ast_strftime(buf, sizeof(buf), "%a, %d %b %Y %H:%M:%S %Z", ast_localtime(&tv, &tm, "GMT"));
fprintf(ser->f, "HTTP/1.1 200 OK\r\n"
"Server: Asterisk/%s\r\n"
}
}
- if (urih) {
+ if (method == AST_HTTP_POST && !astman_is_authed(manid_from_vars(vars))) {
+ out = ast_http_error((*status = 403),
+ (*title = ast_strdup("Access Denied")),
+ NULL, "Sorry, I cannot let you do that, Dave.");
+ } else if (urih) {
*static_content = urih->static_content;
out = urih->callback(ser, urih, uri, method, vars, headers, status, title, contentlength);
AST_RWLIST_UNLOCK(&uris);
* the value of the mansession_id cookie (0 is not valid and means
* a session on the AMI socket).
*/
-static struct mansession *find_session(uint32_t ident)
+static struct mansession *find_session(uint32_t ident, int incinuse)
{
struct mansession *s;
AST_LIST_TRAVERSE(&sessions, s, list) {
ast_mutex_lock(&s->__lock);
if (s->managerid == ident && !s->needdestroy) {
- ast_atomic_fetchadd_int(&s->inuse, 1);
+ ast_atomic_fetchadd_int(&s->inuse, incinuse ? 1 : 0);
break;
}
ast_mutex_unlock(&s->__lock);
return s;
}
+int astman_is_authed(uint32_t ident)
+{
+ int authed;
+ struct mansession *s;
+
+ if (!(s = find_session(ident, 0)))
+ return 0;
+
+ authed = (s->authenticated != 0);
+
+ ast_mutex_unlock(&s->__lock);
+
+ return authed;
+}
+
int astman_verify_session_readpermissions(uint32_t ident, int perm)
{
int result = 0;
}
}
- if (!(s = find_session(ident))) {
+ if (!(s = find_session(ident, 1))) {
/* Create new session.
* While it is not in the list we don't need any locking
*/