mirror of
https://github.com/matrix-org/dendrite.git
synced 2025-12-28 09:13:09 -06:00
More logical naming, clean up a bit
This commit is contained in:
parent
6a880df844
commit
b50694eb8f
|
|
@ -217,8 +217,8 @@ func createRoom(
|
||||||
roomAlias = fmt.Sprintf("#%s:%s", r.RoomAliasName, cfg.Matrix.ServerName)
|
roomAlias = fmt.Sprintf("#%s:%s", r.RoomAliasName, cfg.Matrix.ServerName)
|
||||||
// check it's free TODO: This races but is better than nothing
|
// check it's free TODO: This races but is better than nothing
|
||||||
hasAliasReq := roomserverAPI.GetRoomIDForAliasRequest{
|
hasAliasReq := roomserverAPI.GetRoomIDForAliasRequest{
|
||||||
Alias: roomAlias,
|
Alias: roomAlias,
|
||||||
ShouldHitAppservice: false,
|
IncludeAppservices: false,
|
||||||
}
|
}
|
||||||
|
|
||||||
var aliasResp roomserverAPI.GetRoomIDForAliasResponse
|
var aliasResp roomserverAPI.GetRoomIDForAliasResponse
|
||||||
|
|
|
||||||
|
|
@ -61,9 +61,12 @@ func DirectoryRoom(
|
||||||
var res roomDirectoryResponse
|
var res roomDirectoryResponse
|
||||||
|
|
||||||
// Query the roomserver API to check if the alias exists locally.
|
// Query the roomserver API to check if the alias exists locally.
|
||||||
queryReq := roomserverAPI.GetRoomIDForAliasRequest{Alias: roomAlias, ShouldHitAppservice: true}
|
queryReq := &roomserverAPI.GetRoomIDForAliasRequest{
|
||||||
var queryRes roomserverAPI.GetRoomIDForAliasResponse
|
Alias: roomAlias,
|
||||||
if err = rsAPI.GetRoomIDForAlias(req.Context(), &queryReq, &queryRes); err != nil {
|
IncludeAppservices: true,
|
||||||
|
}
|
||||||
|
queryRes := &roomserverAPI.GetRoomIDForAliasResponse{}
|
||||||
|
if err = rsAPI.GetRoomIDForAlias(req.Context(), queryReq, queryRes); err != nil {
|
||||||
util.GetLogger(req.Context()).WithError(err).Error("rsAPI.GetRoomIDForAlias failed")
|
util.GetLogger(req.Context()).WithError(err).Error("rsAPI.GetRoomIDForAlias failed")
|
||||||
return jsonerror.InternalServerError()
|
return jsonerror.InternalServerError()
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -53,9 +53,12 @@ func RoomAliasToID(
|
||||||
var resp gomatrixserverlib.RespDirectory
|
var resp gomatrixserverlib.RespDirectory
|
||||||
|
|
||||||
if domain == cfg.Matrix.ServerName {
|
if domain == cfg.Matrix.ServerName {
|
||||||
queryReq := roomserverAPI.GetRoomIDForAliasRequest{Alias: roomAlias, ShouldHitAppservice: true}
|
queryReq := &roomserverAPI.GetRoomIDForAliasRequest{
|
||||||
var queryRes roomserverAPI.GetRoomIDForAliasResponse
|
Alias: roomAlias,
|
||||||
if err = rsAPI.GetRoomIDForAlias(httpReq.Context(), &queryReq, &queryRes); err != nil {
|
IncludeAppservices: true,
|
||||||
|
}
|
||||||
|
queryRes := &roomserverAPI.GetRoomIDForAliasResponse{}
|
||||||
|
if err = rsAPI.GetRoomIDForAlias(httpReq.Context(), queryReq, queryRes); err != nil {
|
||||||
util.GetLogger(httpReq.Context()).WithError(err).Error("aliasAPI.GetRoomIDForAlias failed")
|
util.GetLogger(httpReq.Context()).WithError(err).Error("aliasAPI.GetRoomIDForAlias failed")
|
||||||
return jsonerror.InternalServerError()
|
return jsonerror.InternalServerError()
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -33,8 +33,10 @@ type SetRoomAliasResponse struct {
|
||||||
// GetRoomIDForAliasRequest is a request to GetRoomIDForAlias
|
// GetRoomIDForAliasRequest is a request to GetRoomIDForAlias
|
||||||
type GetRoomIDForAliasRequest struct {
|
type GetRoomIDForAliasRequest struct {
|
||||||
// Alias we want to lookup
|
// Alias we want to lookup
|
||||||
Alias string `json:"alias"`
|
Alias string `json:"alias"`
|
||||||
ShouldHitAppservice bool `json:"shouldHitAppservice"`
|
// Should we ask appservices for their aliases as a part of
|
||||||
|
// the request?
|
||||||
|
IncludeAppservices bool `json:"include_appservices"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetRoomIDForAliasResponse is a response to GetRoomIDForAlias
|
// GetRoomIDForAliasResponse is a response to GetRoomIDForAlias
|
||||||
|
|
|
||||||
|
|
@ -93,25 +93,26 @@ func (r *RoomserverInternalAPI) GetRoomIDForAlias(
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check appservice on err
|
// Check appservice on err, but only if the appservice API is
|
||||||
if r.asAPI != nil && request.ShouldHitAppservice { // appservice component is wired in
|
// wired in and no room ID was found.
|
||||||
if roomID == "" {
|
if r.asAPI != nil && request.IncludeAppservices && roomID == "" {
|
||||||
// No room found locally, try our application services by making a call to
|
// No room found locally, try our application services by making a call to
|
||||||
// the appservice component
|
// the appservice component
|
||||||
aliasReq := asAPI.RoomAliasExistsRequest{Alias: request.Alias}
|
aliasReq := &asAPI.RoomAliasExistsRequest{
|
||||||
var aliasResp asAPI.RoomAliasExistsResponse
|
Alias: request.Alias,
|
||||||
if err = r.asAPI.RoomAliasExists(ctx, &aliasReq, &aliasResp); err != nil {
|
}
|
||||||
|
aliasRes := &asAPI.RoomAliasExistsResponse{}
|
||||||
|
if err = r.asAPI.RoomAliasExists(ctx, aliasReq, aliasRes); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if aliasRes.AliasExists {
|
||||||
|
roomID, err = r.DB.GetRoomIDForAlias(ctx, request.Alias)
|
||||||
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
response.RoomID = roomID
|
||||||
if aliasResp.AliasExists {
|
return nil
|
||||||
roomID, err = r.DB.GetRoomIDForAlias(ctx, request.Alias)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
response.RoomID = roomID
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -124,8 +124,8 @@ func (r *Joiner) performJoinRoomByAlias(
|
||||||
req.ServerNames = append(req.ServerNames, dirRes.ServerNames...)
|
req.ServerNames = append(req.ServerNames, dirRes.ServerNames...)
|
||||||
} else {
|
} else {
|
||||||
var getRoomReq = rsAPI.GetRoomIDForAliasRequest{
|
var getRoomReq = rsAPI.GetRoomIDForAliasRequest{
|
||||||
Alias: req.RoomIDOrAlias,
|
Alias: req.RoomIDOrAlias,
|
||||||
ShouldHitAppservice: true,
|
IncludeAppservices: true,
|
||||||
}
|
}
|
||||||
var getRoomRes = rsAPI.GetRoomIDForAliasResponse{}
|
var getRoomRes = rsAPI.GetRoomIDForAliasResponse{}
|
||||||
// Otherwise, look up if we know this room alias locally.
|
// Otherwise, look up if we know this room alias locally.
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue