Support "_" placeholder username for domain's own NIP-05
This commit is contained in:
		
							parent
							
								
									7ac3130c18
								
							
						
					
					
						commit
						48ab96dda9
					
				| @ -1,18 +1,23 @@ | |||||||
| class WellKnownController < ApplicationController | class WellKnownController < ApplicationController | ||||||
|  |   before_action :require_nostr_enabled, only: [ :nostr ] | ||||||
|  | 
 | ||||||
|   def nostr |   def nostr | ||||||
|     http_status :unprocessable_entity and return if params[:name].blank? |     http_status :unprocessable_entity and return if params[:name].blank? | ||||||
|     domain = request.headers["X-Forwarded-Host"].presence || Setting.primary_domain |     domain = request.headers["X-Forwarded-Host"].presence || Setting.primary_domain | ||||||
|     @user = User.where(cn: params[:name], ou: domain).first |     relay_url = Setting.nostr_relay_url | ||||||
|     http_status :not_found and return if @user.nil? || @user.nostr_pubkey.blank? |  | ||||||
| 
 | 
 | ||||||
|     res = { |     if params[:name] == "_" | ||||||
|       names: { @user.cn => @user.nostr_pubkey } |       # pubkey for the primary domain without a username (e.g. kosmos.org) | ||||||
|     } |       res = { names: { "_": Setting.nostr_public_key } } | ||||||
|  |     else | ||||||
|  |       @user = User.where(cn: params[:name], ou: domain).first | ||||||
|  |       http_status :not_found and return if @user.nil? || @user.nostr_pubkey.blank? | ||||||
| 
 | 
 | ||||||
|     if Setting.nostr_relay_url |       res = { names: { @user.cn => @user.nostr_pubkey } } | ||||||
|       res[:relays] = { |     end | ||||||
|         @user.nostr_pubkey => [ Setting.nostr_relay_url ] | 
 | ||||||
|       } |     if relay_url | ||||||
|  |       res[:relays] = { @user.nostr_pubkey => [ relay_url ] } | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     respond_to do |format| |     respond_to do |format| | ||||||
| @ -21,4 +26,10 @@ class WellKnownController < ApplicationController | |||||||
|       end |       end | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
|  | 
 | ||||||
|  |   private | ||||||
|  | 
 | ||||||
|  |     def require_nostr_enabled | ||||||
|  |       http_status :not_found unless Setting.nostr_enabled? | ||||||
|  |     end | ||||||
| end | end | ||||||
|  | |||||||
| @ -2,21 +2,21 @@ require 'rails_helper' | |||||||
| 
 | 
 | ||||||
| RSpec.describe "Well-known URLs", type: :request do | RSpec.describe "Well-known URLs", type: :request do | ||||||
|   describe "GET /nostr" do |   describe "GET /nostr" do | ||||||
|     context "without username param" do |     describe "without username param" do | ||||||
|       it "returns a 422 status" do |       it "returns a 422 status" do | ||||||
|         get "/.well-known/nostr.json" |         get "/.well-known/nostr.json" | ||||||
|         expect(response).to have_http_status(:unprocessable_entity) |         expect(response).to have_http_status(:unprocessable_entity) | ||||||
|       end |       end | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     context "non-existent user" do |     describe "non-existent user" do | ||||||
|       it "returns a 404 status" do |       it "returns a 404 status" do | ||||||
|         get "/.well-known/nostr.json?name=bob" |         get "/.well-known/nostr.json?name=bob" | ||||||
|         expect(response).to have_http_status(:not_found) |         expect(response).to have_http_status(:not_found) | ||||||
|       end |       end | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     context "user does not have a nostr pubkey configured" do |     describe "user does not have a nostr pubkey configured" do | ||||||
|       let(:user) { create :user, cn: 'spongebob', ou: 'kosmos.org' } |       let(:user) { create :user, cn: 'spongebob', ou: 'kosmos.org' } | ||||||
| 
 | 
 | ||||||
|       before do |       before do | ||||||
| @ -30,7 +30,7 @@ RSpec.describe "Well-known URLs", type: :request do | |||||||
|       end |       end | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     context "user with nostr pubkey" do |     describe "user with nostr pubkey" do | ||||||
|       let(:user) { create :user, cn: 'bobdylan', ou: 'kosmos.org' } |       let(:user) { create :user, cn: 'bobdylan', ou: 'kosmos.org' } | ||||||
|       before do |       before do | ||||||
|         user.save! |         user.save! | ||||||
| @ -67,5 +67,24 @@ RSpec.describe "Well-known URLs", type: :request do | |||||||
|         end |         end | ||||||
|       end |       end | ||||||
|     end |     end | ||||||
|  | 
 | ||||||
|  |     describe "placeholder username for domain's own pubkey" do | ||||||
|  |       it "returns the configured nostr pubkey" do | ||||||
|  |         get "/.well-known/nostr.json?name=_" | ||||||
|  |         res = JSON.parse(response.body) | ||||||
|  |         expect(res["names"]["_"]).to eq(Setting.nostr_public_key) | ||||||
|  |       end | ||||||
|  | 
 | ||||||
|  |       context "nostr service integration not enabled" do | ||||||
|  |         before do | ||||||
|  |           Setting.nostr_enabled = false | ||||||
|  |         end | ||||||
|  | 
 | ||||||
|  |         it "returns a 404 status" do | ||||||
|  |           get "/.well-known/nostr.json?name=_" | ||||||
|  |           expect(response).to have_http_status(:not_found) | ||||||
|  |         end | ||||||
|  |       end | ||||||
|  |     end | ||||||
|   end |   end | ||||||
| end | end | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user