♻️ Basiclly moved to Dealer from Consul
This commit is contained in:
		
							
								
								
									
										95
									
								
								.idea/workspace.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										95
									
								
								.idea/workspace.xml
									
									
									
										generated
									
									
									
								
							@@ -4,8 +4,43 @@
 | 
			
		||||
    <option name="autoReloadType" value="ALL" />
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="ChangeListManager">
 | 
			
		||||
    <list default="true" id="3fefb2c4-b6f9-466b-a523-53352e8d6f95" name="更改" comment=":bug: Bug fixes">
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/services/ticket.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/internal/services/ticket.go" afterDir="false" />
 | 
			
		||||
    <list default="true" id="3fefb2c4-b6f9-466b-a523-53352e8d6f95" name="更改" comment=":bug: Fix oauth ticket need mfa">
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/go.mod" beforeDir="false" afterPath="$PROJECT_DIR$/go.mod" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/go.sum" beforeDir="false" afterPath="$PROJECT_DIR$/go.sum" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/hyper/auth.go" beforeDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/hyper/auth_adaptor.go" beforeDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/hyper/conn.go" beforeDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/gap/server.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/internal/gap/server.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/grpc/auth.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/internal/grpc/auth.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/grpc/server.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/internal/grpc/server.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/i18n/bundle.go" beforeDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/i18n/embed.go" beforeDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/i18n/locale.en.json" beforeDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/i18n/locale.zh.json" beforeDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/i18n/middleware.go" beforeDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/models/accounts.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/internal/models/accounts.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/server/api/avatar_api.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/internal/server/api/avatar_api.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/server/api/index.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/internal/server/api/index.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/server/api/ws.go" beforeDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/server/exts/auth.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/internal/server/exts/auth.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/server/exts/cookies.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/internal/server/exts/cookies.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/server/server.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/internal/server/server.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/services/connections.go" beforeDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/services/e2ee.go" beforeDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/services/notifications.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/internal/services/notifications.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/internal/services/statuses.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/internal/services/statuses.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/main.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/main.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/proto/auth.pb.go" beforeDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/proto/auth.proto" beforeDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/proto/auth_grpc.pb.go" beforeDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/proto/friendships.pb.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/proto/friendships.pb.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/proto/friendships_grpc.pb.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/proto/friendships_grpc.pb.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/proto/notify.pb.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/proto/notify.pb.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/proto/notify_grpc.pb.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/proto/notify_grpc.pb.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/proto/realms.pb.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/proto/realms.pb.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/pkg/proto/realms_grpc.pb.go" beforeDir="false" afterPath="$PROJECT_DIR$/pkg/proto/realms_grpc.pb.go" afterDir="false" />
 | 
			
		||||
      <change beforePath="$PROJECT_DIR$/settings.toml" beforeDir="false" afterPath="$PROJECT_DIR$/settings.toml" afterDir="false" />
 | 
			
		||||
    </list>
 | 
			
		||||
    <option name="SHOW_DIALOG" value="false" />
 | 
			
		||||
    <option name="HIGHLIGHT_CONFLICTS" value="true" />
 | 
			
		||||
@@ -23,7 +58,7 @@
 | 
			
		||||
  <component name="Git.Settings">
 | 
			
		||||
    <option name="RECENT_BRANCH_BY_REPOSITORY">
 | 
			
		||||
      <map>
 | 
			
		||||
        <entry key="$PROJECT_DIR$" value="features/kex" />
 | 
			
		||||
        <entry key="$PROJECT_DIR$" value="master" />
 | 
			
		||||
      </map>
 | 
			
		||||
    </option>
 | 
			
		||||
    <option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" />
 | 
			
		||||
@@ -40,34 +75,34 @@
 | 
			
		||||
    <option name="hideEmptyMiddlePackages" value="true" />
 | 
			
		||||
    <option name="showLibraryContents" value="true" />
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="PropertiesComponent">{
 | 
			
		||||
  "keyToString": {
 | 
			
		||||
    "DefaultGoTemplateProperty": "Go File",
 | 
			
		||||
    "Go Build.Backend.executor": "Run",
 | 
			
		||||
    "Go 构建.Backend.executor": "Run",
 | 
			
		||||
    "RunOnceActivity.ShowReadmeOnStart": "true",
 | 
			
		||||
    "RunOnceActivity.go.formatter.settings.were.checked": "true",
 | 
			
		||||
    "RunOnceActivity.go.migrated.go.modules.settings": "true",
 | 
			
		||||
    "RunOnceActivity.go.modules.automatic.dependencies.download": "true",
 | 
			
		||||
    "RunOnceActivity.go.modules.go.list.on.any.changes.was.set": "true",
 | 
			
		||||
    "git-widget-placeholder": "master",
 | 
			
		||||
    "go.import.settings.migrated": "true",
 | 
			
		||||
    "go.sdk.automatically.set": "true",
 | 
			
		||||
    "last_opened_file_path": "/Users/littlesheep/Documents/Projects/Hydrogen/Passport/web/src/components/admin",
 | 
			
		||||
    "node.js.detected.package.eslint": "true",
 | 
			
		||||
    "node.js.selected.package.eslint": "(autodetect)",
 | 
			
		||||
    "nodejs_package_manager_path": "npm",
 | 
			
		||||
    "run.code.analysis.last.selected.profile": "pProject Default",
 | 
			
		||||
    "settings.editor.selected.configurable": "preferences.pluginManager",
 | 
			
		||||
    "ts.external.directory.path": "/Users/littlesheep/Documents/Projects/Hydrogen/Passport/web/node_modules/typescript/lib",
 | 
			
		||||
    "vue.rearranger.settings.migration": "true"
 | 
			
		||||
  <component name="PropertiesComponent"><![CDATA[{
 | 
			
		||||
  "keyToString": {
 | 
			
		||||
    "DefaultGoTemplateProperty": "Go File",
 | 
			
		||||
    "Go Build.Backend.executor": "Run",
 | 
			
		||||
    "Go 构建.Backend.executor": "Run",
 | 
			
		||||
    "RunOnceActivity.ShowReadmeOnStart": "true",
 | 
			
		||||
    "RunOnceActivity.go.formatter.settings.were.checked": "true",
 | 
			
		||||
    "RunOnceActivity.go.migrated.go.modules.settings": "true",
 | 
			
		||||
    "RunOnceActivity.go.modules.automatic.dependencies.download": "true",
 | 
			
		||||
    "RunOnceActivity.go.modules.go.list.on.any.changes.was.set": "true",
 | 
			
		||||
    "git-widget-placeholder": "refactor/dealer",
 | 
			
		||||
    "go.import.settings.migrated": "true",
 | 
			
		||||
    "go.sdk.automatically.set": "true",
 | 
			
		||||
    "last_opened_file_path": "/Users/littlesheep/Documents/Projects/Hydrogen/Passport/web/src/components/admin",
 | 
			
		||||
    "node.js.detected.package.eslint": "true",
 | 
			
		||||
    "node.js.selected.package.eslint": "(autodetect)",
 | 
			
		||||
    "nodejs_package_manager_path": "npm",
 | 
			
		||||
    "run.code.analysis.last.selected.profile": "pProject Default",
 | 
			
		||||
    "settings.editor.selected.configurable": "preferences.pluginManager",
 | 
			
		||||
    "ts.external.directory.path": "/Users/littlesheep/Documents/Projects/Hydrogen/Passport/web/node_modules/typescript/lib",
 | 
			
		||||
    "vue.rearranger.settings.migration": "true"
 | 
			
		||||
  },
 | 
			
		||||
  "keyToStringList": {
 | 
			
		||||
    "DatabaseDriversLRU": [
 | 
			
		||||
      "postgresql"
 | 
			
		||||
  "keyToStringList": {
 | 
			
		||||
    "DatabaseDriversLRU": [
 | 
			
		||||
      "postgresql"
 | 
			
		||||
    ]
 | 
			
		||||
  }
 | 
			
		||||
}</component>
 | 
			
		||||
}]]></component>
 | 
			
		||||
  <component name="RecentsManager">
 | 
			
		||||
    <key name="CopyFile.RECENT_KEYS">
 | 
			
		||||
      <recent name="$PROJECT_DIR$/web/src/components/admin" />
 | 
			
		||||
@@ -151,7 +186,6 @@
 | 
			
		||||
    </option>
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="VcsManagerConfiguration">
 | 
			
		||||
    <MESSAGE value=":ambulance: Fix nil pointer panic" />
 | 
			
		||||
    <MESSAGE value=":bug: Not supposed to appear to status at the same time" />
 | 
			
		||||
    <MESSAGE value=":ambulance: Fix getting user panic again..." />
 | 
			
		||||
    <MESSAGE value=":bug: Fix status validation issue" />
 | 
			
		||||
@@ -176,7 +210,8 @@
 | 
			
		||||
    <MESSAGE value=":rotating_light: Fix ts lint issue" />
 | 
			
		||||
    <MESSAGE value=":poop: Remove mis-imported cgo" />
 | 
			
		||||
    <MESSAGE value=":bug: Bug fixes" />
 | 
			
		||||
    <option name="LAST_COMMIT_MESSAGE" value=":bug: Bug fixes" />
 | 
			
		||||
    <MESSAGE value=":bug: Fix oauth ticket need mfa" />
 | 
			
		||||
    <option name="LAST_COMMIT_MESSAGE" value=":bug: Fix oauth ticket need mfa" />
 | 
			
		||||
  </component>
 | 
			
		||||
  <component name="VgoProject">
 | 
			
		||||
    <settings-migrated>true</settings-migrated>
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										1
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								go.mod
									
									
									
									
									
								
							@@ -42,6 +42,7 @@ require (
 | 
			
		||||
	cloud.google.com/go/iam v1.1.8 // indirect
 | 
			
		||||
	cloud.google.com/go/longrunning v0.5.7 // indirect
 | 
			
		||||
	cloud.google.com/go/storage v1.41.0 // indirect
 | 
			
		||||
	git.solsynth.dev/hydrogen/dealer v0.0.0-20240714155615-ad83100677ab // indirect
 | 
			
		||||
	github.com/andybalholm/brotli v1.1.0 // indirect
 | 
			
		||||
	github.com/armon/go-metrics v0.4.1 // indirect
 | 
			
		||||
	github.com/fasthttp/websocket v1.5.8 // indirect
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										12
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								go.sum
									
									
									
									
									
								
							@@ -17,6 +17,18 @@ cloud.google.com/go/storage v1.41.0 h1:RusiwatSu6lHeEXe3kglxakAmAbfV+rhtPqA6i8RB
 | 
			
		||||
cloud.google.com/go/storage v1.41.0/go.mod h1:J1WCa/Z2FcgdEDuPUY8DxT5I+d9mFKsCepp5vR6Sq80=
 | 
			
		||||
firebase.google.com/go v3.13.0+incompatible h1:3TdYC3DDi6aHn20qoRkxwGqNgdjtblwVAyRLQwGn/+4=
 | 
			
		||||
firebase.google.com/go v3.13.0+incompatible/go.mod h1:xlah6XbEyW6tbfSklcfe5FHJIwjt8toICdV5Wh9ptHs=
 | 
			
		||||
git.solsynth.dev/hydrogen/dealer v0.0.0-20240714122530-466b240e95a6 h1:QH5FGLdU7sfQ63RsgbP5iTjWE3/2VicJfewI4s28ThU=
 | 
			
		||||
git.solsynth.dev/hydrogen/dealer v0.0.0-20240714122530-466b240e95a6/go.mod h1:eZwAwP7ahL7TO8GWBlYFYDdjlna+8zHYbDfNabnuUEU=
 | 
			
		||||
git.solsynth.dev/hydrogen/dealer v0.0.0-20240714125606-31e73c438e33 h1:Zz0SQQ6xIBhBaNnGddl9AwX+5Id9J89NohzHjvG7/WM=
 | 
			
		||||
git.solsynth.dev/hydrogen/dealer v0.0.0-20240714125606-31e73c438e33/go.mod h1:eZwAwP7ahL7TO8GWBlYFYDdjlna+8zHYbDfNabnuUEU=
 | 
			
		||||
git.solsynth.dev/hydrogen/dealer v0.0.0-20240714135616-d371c4fbfae2 h1:95ofnv70QDsK5ZxENY8LdV04KT0SjQZN6Mz6xJfSDhg=
 | 
			
		||||
git.solsynth.dev/hydrogen/dealer v0.0.0-20240714135616-d371c4fbfae2/go.mod h1:eZwAwP7ahL7TO8GWBlYFYDdjlna+8zHYbDfNabnuUEU=
 | 
			
		||||
git.solsynth.dev/hydrogen/dealer v0.0.0-20240714154518-8f996bb69731 h1:8O1mbCnwpIt/51HUhF4fMtE6GEmBjiyJhtvBm2uwAHg=
 | 
			
		||||
git.solsynth.dev/hydrogen/dealer v0.0.0-20240714154518-8f996bb69731/go.mod h1:eZwAwP7ahL7TO8GWBlYFYDdjlna+8zHYbDfNabnuUEU=
 | 
			
		||||
git.solsynth.dev/hydrogen/dealer v0.0.0-20240714154934-7812a06cb195 h1:TuO+yRnsr9sGGpzpU58N6K1AIbTEEMtBML1lUcIp1rE=
 | 
			
		||||
git.solsynth.dev/hydrogen/dealer v0.0.0-20240714154934-7812a06cb195/go.mod h1:eZwAwP7ahL7TO8GWBlYFYDdjlna+8zHYbDfNabnuUEU=
 | 
			
		||||
git.solsynth.dev/hydrogen/dealer v0.0.0-20240714155615-ad83100677ab h1:hxqJkL4Ha3Y3SfeSA9TPKBJK6mtY88Q2uialHsDbGf0=
 | 
			
		||||
git.solsynth.dev/hydrogen/dealer v0.0.0-20240714155615-ad83100677ab/go.mod h1:eZwAwP7ahL7TO8GWBlYFYDdjlna+8zHYbDfNabnuUEU=
 | 
			
		||||
git.solsynth.dev/hydrogen/paperclip v0.0.0-20240622051057-0f56dba45745 h1:40BUsQMNXjqHyytkyF9py1HjTAWlRgO6R57YXUrHNy4=
 | 
			
		||||
git.solsynth.dev/hydrogen/paperclip v0.0.0-20240622051057-0f56dba45745/go.mod h1:FsQGSLTl0gvo+9Jmbot02S72suyF9tFTrzDj70Xhifo=
 | 
			
		||||
github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU=
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										
											BIN
										
									
								
								pkg/.DS_Store
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								pkg/.DS_Store
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							@@ -1,63 +0,0 @@
 | 
			
		||||
package hyper
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"context"
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/proto"
 | 
			
		||||
	"google.golang.org/grpc"
 | 
			
		||||
	"time"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func (v *HyperConn) DoAuthenticate(atk, rtk string) (acc *proto.Userinfo, accessTk string, refreshTk string, err error) {
 | 
			
		||||
	ctx, cancel := context.WithTimeout(context.Background(), time.Second*10)
 | 
			
		||||
	defer cancel()
 | 
			
		||||
 | 
			
		||||
	var in *grpc.ClientConn
 | 
			
		||||
	in, err = v.DiscoverServiceGRPC("Hydrogen.Passport")
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	var reply *proto.AuthReply
 | 
			
		||||
	reply, err = proto.NewAuthClient(in).Authenticate(ctx, &proto.AuthRequest{
 | 
			
		||||
		AccessToken:  atk,
 | 
			
		||||
		RefreshToken: &rtk,
 | 
			
		||||
	})
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	if reply != nil {
 | 
			
		||||
		acc = reply.GetUserinfo()
 | 
			
		||||
		accessTk = reply.GetAccessToken()
 | 
			
		||||
		refreshTk = reply.GetRefreshToken()
 | 
			
		||||
		if !reply.IsValid {
 | 
			
		||||
			err = fmt.Errorf("invalid authorization context")
 | 
			
		||||
			return
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (v *HyperConn) DoCheckPerm(atk string, key string, val []byte) error {
 | 
			
		||||
	ctx, cancel := context.WithTimeout(context.Background(), time.Second*10)
 | 
			
		||||
	defer cancel()
 | 
			
		||||
 | 
			
		||||
	in, err := v.DiscoverServiceGRPC("Hydrogen.Passport")
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	reply, err := proto.NewAuthClient(in).CheckPerm(ctx, &proto.CheckPermRequest{
 | 
			
		||||
		Token: atk,
 | 
			
		||||
		Key:   key,
 | 
			
		||||
		Value: val,
 | 
			
		||||
	})
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	} else if !reply.GetIsValid() {
 | 
			
		||||
		return fmt.Errorf("missing permission: %s", key)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
@@ -1,69 +0,0 @@
 | 
			
		||||
package hyper
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/proto"
 | 
			
		||||
	"github.com/gofiber/fiber/v2"
 | 
			
		||||
	jsoniter "github.com/json-iterator/go"
 | 
			
		||||
	"strings"
 | 
			
		||||
	"time"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
const CookieAtk = "__hydrogen_atk"
 | 
			
		||||
const CookieRtk = "__hydrogen_rtk"
 | 
			
		||||
 | 
			
		||||
func (v *HyperConn) AuthMiddleware(c *fiber.Ctx) error {
 | 
			
		||||
	var atk string
 | 
			
		||||
	if cookie := c.Cookies(CookieAtk); len(cookie) > 0 {
 | 
			
		||||
		atk = cookie
 | 
			
		||||
	}
 | 
			
		||||
	if header := c.Get(fiber.HeaderAuthorization); len(header) > 0 {
 | 
			
		||||
		tk := strings.Replace(header, "Bearer", "", 1)
 | 
			
		||||
		atk = strings.TrimSpace(tk)
 | 
			
		||||
	}
 | 
			
		||||
	if tk := c.Query("tk"); len(tk) > 0 {
 | 
			
		||||
		atk = strings.TrimSpace(tk)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	c.Locals("p_token", atk)
 | 
			
		||||
 | 
			
		||||
	rtk := c.Cookies(CookieRtk)
 | 
			
		||||
	if user, newAtk, newRtk, err := v.DoAuthenticate(atk, rtk); err == nil {
 | 
			
		||||
		if newAtk != atk {
 | 
			
		||||
			c.Cookie(&fiber.Cookie{
 | 
			
		||||
				Name:     CookieAtk,
 | 
			
		||||
				Value:    newAtk,
 | 
			
		||||
				SameSite: "Lax",
 | 
			
		||||
				Expires:  time.Now().Add(60 * time.Minute),
 | 
			
		||||
				Path:     "/",
 | 
			
		||||
			})
 | 
			
		||||
			c.Cookie(&fiber.Cookie{
 | 
			
		||||
				Name:     CookieRtk,
 | 
			
		||||
				Value:    newRtk,
 | 
			
		||||
				SameSite: "Lax",
 | 
			
		||||
				Expires:  time.Now().Add(24 * 30 * time.Hour),
 | 
			
		||||
				Path:     "/",
 | 
			
		||||
			})
 | 
			
		||||
		}
 | 
			
		||||
		c.Locals("p_user", user)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return c.Next()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (v *HyperConn) EnsureAuthenticated(c *fiber.Ctx) error {
 | 
			
		||||
	if _, ok := c.Locals("p_user").(*proto.Userinfo); !ok {
 | 
			
		||||
		return fiber.NewError(fiber.StatusUnauthorized)
 | 
			
		||||
	}
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (v *HyperConn) EnsureGrantedPerm(c *fiber.Ctx, key string, val any) error {
 | 
			
		||||
	if err := v.EnsureAuthenticated(c); err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	encodedVal, _ := jsoniter.Marshal(val)
 | 
			
		||||
	if err := v.DoCheckPerm(c.Locals("p_token").(string), key, encodedVal); err != nil {
 | 
			
		||||
		return fiber.NewError(fiber.StatusForbidden, err.Error())
 | 
			
		||||
	}
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
@@ -1,51 +0,0 @@
 | 
			
		||||
package hyper
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"context"
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"google.golang.org/grpc"
 | 
			
		||||
	"google.golang.org/grpc/credentials/insecure"
 | 
			
		||||
	health "google.golang.org/grpc/health/grpc_health_v1"
 | 
			
		||||
	"time"
 | 
			
		||||
 | 
			
		||||
	_ "github.com/mbobakov/grpc-consul-resolver"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type HyperConn struct {
 | 
			
		||||
	Addr string
 | 
			
		||||
 | 
			
		||||
	cacheGrpcConn map[string]*grpc.ClientConn
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func NewHyperConn(addr string) *HyperConn {
 | 
			
		||||
	return &HyperConn{
 | 
			
		||||
		Addr: addr,
 | 
			
		||||
 | 
			
		||||
		cacheGrpcConn: make(map[string]*grpc.ClientConn),
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (v *HyperConn) DiscoverServiceGRPC(name string) (*grpc.ClientConn, error) {
 | 
			
		||||
	if val, ok := v.cacheGrpcConn[name]; ok {
 | 
			
		||||
		ctx, cancel := context.WithTimeout(context.Background(), time.Second*10)
 | 
			
		||||
		defer cancel()
 | 
			
		||||
		if _, err := health.NewHealthClient(val).Check(ctx, &health.HealthCheckRequest{
 | 
			
		||||
			Service: name,
 | 
			
		||||
		}); err == nil {
 | 
			
		||||
			return val, nil
 | 
			
		||||
		} else {
 | 
			
		||||
			delete(v.cacheGrpcConn, name)
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	target := fmt.Sprintf("consul://%s/%s", v.Addr, name)
 | 
			
		||||
	conn, err := grpc.NewClient(
 | 
			
		||||
		target,
 | 
			
		||||
		grpc.WithTransportCredentials(insecure.NewCredentials()),
 | 
			
		||||
		grpc.WithDefaultServiceConfig(`{"loadBalancingPolicy": "round_robin"}`),
 | 
			
		||||
	)
 | 
			
		||||
	if err == nil {
 | 
			
		||||
		v.cacheGrpcConn[name] = conn
 | 
			
		||||
	}
 | 
			
		||||
	return conn, err
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										
											BIN
										
									
								
								pkg/internal/.DS_Store
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								pkg/internal/.DS_Store
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							@@ -2,51 +2,41 @@ package gap
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"strconv"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/dealer/pkg/hyper"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/dealer/pkg/proto"
 | 
			
		||||
	"github.com/rs/zerolog/log"
 | 
			
		||||
	"strings"
 | 
			
		||||
 | 
			
		||||
	"github.com/hashicorp/consul/api"
 | 
			
		||||
	"github.com/spf13/viper"
 | 
			
		||||
	"google.golang.org/grpc"
 | 
			
		||||
	"google.golang.org/grpc/credentials/insecure"
 | 
			
		||||
 | 
			
		||||
	_ "github.com/mbobakov/grpc-consul-resolver"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func Register() error {
 | 
			
		||||
	cfg := api.DefaultConfig()
 | 
			
		||||
	cfg.Address = viper.GetString("consul.addr")
 | 
			
		||||
 | 
			
		||||
	client, err := api.NewClient(cfg)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
var H *hyper.HyperConn
 | 
			
		||||
 | 
			
		||||
func RegisterService() error {
 | 
			
		||||
	grpcBind := strings.SplitN(viper.GetString("grpc_bind"), ":", 2)
 | 
			
		||||
	httpBind := strings.SplitN(viper.GetString("bind"), ":", 2)
 | 
			
		||||
 | 
			
		||||
	outboundIp, _ := GetOutboundIP()
 | 
			
		||||
	port, _ := strconv.Atoi(grpcBind[1])
 | 
			
		||||
 | 
			
		||||
	registration := new(api.AgentServiceRegistration)
 | 
			
		||||
	registration.ID = viper.GetString("id")
 | 
			
		||||
	registration.Name = "Hydrogen.Passport"
 | 
			
		||||
	registration.Address = outboundIp.String()
 | 
			
		||||
	registration.Port = port
 | 
			
		||||
	registration.Check = &api.AgentServiceCheck{
 | 
			
		||||
		GRPC:                           fmt.Sprintf("%s:%s", outboundIp, grpcBind[1]),
 | 
			
		||||
		Timeout:                        "5s",
 | 
			
		||||
		Interval:                       "1m",
 | 
			
		||||
		DeregisterCriticalServiceAfter: "3m",
 | 
			
		||||
	grpcOutbound := fmt.Sprintf("%s:%s", outboundIp, grpcBind[1])
 | 
			
		||||
	httpOutbound := fmt.Sprintf("%s:%s", outboundIp, httpBind[1])
 | 
			
		||||
 | 
			
		||||
	var err error
 | 
			
		||||
	H, err = hyper.NewHyperConn(viper.GetString("dealer.addr"), &proto.ServiceInfo{
 | 
			
		||||
		Id:       viper.GetString("id"),
 | 
			
		||||
		Type:     hyper.ServiceTypeAuthProvider,
 | 
			
		||||
		Label:    "Passport",
 | 
			
		||||
		GrpcAddr: grpcOutbound,
 | 
			
		||||
		HttpAddr: &httpOutbound,
 | 
			
		||||
	})
 | 
			
		||||
	if err == nil {
 | 
			
		||||
		go func() {
 | 
			
		||||
			err := H.KeepRegisterService()
 | 
			
		||||
			if err != nil {
 | 
			
		||||
				log.Error().Err(err).Msg("An error occurred while registering service...")
 | 
			
		||||
			}
 | 
			
		||||
		}()
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return client.Agent().ServiceRegister(registration)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func DiscoverPaperclip() (*grpc.ClientConn, error) {
 | 
			
		||||
	target := fmt.Sprintf("consul://%s/Hydrogen.Paperclip", viper.GetString("consul.addr"))
 | 
			
		||||
	return grpc.NewClient(
 | 
			
		||||
		target,
 | 
			
		||||
		grpc.WithTransportCredentials(insecure.NewCredentials()),
 | 
			
		||||
		grpc.WithDefaultServiceConfig(`{"loadBalancingPolicy": "round_robin"}`),
 | 
			
		||||
	)
 | 
			
		||||
	return err
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -3,23 +3,22 @@ package grpc
 | 
			
		||||
import (
 | 
			
		||||
	"context"
 | 
			
		||||
 | 
			
		||||
	exproto "git.solsynth.dev/hydrogen/dealer/pkg/proto"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/services"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/proto"
 | 
			
		||||
	jsoniter "github.com/json-iterator/go"
 | 
			
		||||
	"github.com/samber/lo"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func (v *Server) Authenticate(_ context.Context, in *proto.AuthRequest) (*proto.AuthReply, error) {
 | 
			
		||||
func (v *Server) Authenticate(_ context.Context, in *exproto.AuthRequest) (*exproto.AuthReply, error) {
 | 
			
		||||
	ctx, perms, atk, rtk, err := services.Authenticate(in.GetAccessToken(), in.GetRefreshToken(), 0)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return &proto.AuthReply{
 | 
			
		||||
		return &exproto.AuthReply{
 | 
			
		||||
			IsValid: false,
 | 
			
		||||
		}, nil
 | 
			
		||||
	} else {
 | 
			
		||||
		user := ctx.Account
 | 
			
		||||
		rawPerms, _ := jsoniter.Marshal(perms)
 | 
			
		||||
 | 
			
		||||
		userinfo := &proto.Userinfo{
 | 
			
		||||
		userinfo := &exproto.UserInfo{
 | 
			
		||||
			Id:          uint64(user.ID),
 | 
			
		||||
			Name:        user.Name,
 | 
			
		||||
			Nick:        user.Nick,
 | 
			
		||||
@@ -34,18 +33,20 @@ func (v *Server) Authenticate(_ context.Context, in *proto.AuthRequest) (*proto.
 | 
			
		||||
			userinfo.Banner = *user.GetBanner()
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		return &proto.AuthReply{
 | 
			
		||||
			IsValid:      true,
 | 
			
		||||
			AccessToken:  &atk,
 | 
			
		||||
			RefreshToken: &rtk,
 | 
			
		||||
			Permissions:  rawPerms,
 | 
			
		||||
			TicketId:     lo.ToPtr(uint64(ctx.Ticket.ID)),
 | 
			
		||||
			Userinfo:     userinfo,
 | 
			
		||||
		return &exproto.AuthReply{
 | 
			
		||||
			IsValid: true,
 | 
			
		||||
			Info: &exproto.AuthInfo{
 | 
			
		||||
				NewAccessToken:  &atk,
 | 
			
		||||
				NewRefreshToken: &rtk,
 | 
			
		||||
				Permissions:     rawPerms,
 | 
			
		||||
				TicketId:        uint64(ctx.Ticket.ID),
 | 
			
		||||
				Info:            userinfo,
 | 
			
		||||
			},
 | 
			
		||||
		}, nil
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (v *Server) CheckPerm(_ context.Context, in *proto.CheckPermRequest) (*proto.CheckPermReply, error) {
 | 
			
		||||
func (v *Server) CheckPerm(_ context.Context, in *exproto.CheckPermRequest) (*exproto.CheckPermReply, error) {
 | 
			
		||||
	claims, err := services.DecodeJwt(in.GetToken())
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
@@ -64,7 +65,7 @@ func (v *Server) CheckPerm(_ context.Context, in *proto.CheckPermRequest) (*prot
 | 
			
		||||
	perms := services.FilterPermNodes(heldPerms, ctx.Ticket.Claims)
 | 
			
		||||
	valid := services.HasPermNode(perms, in.GetKey(), value)
 | 
			
		||||
 | 
			
		||||
	return &proto.CheckPermReply{
 | 
			
		||||
	return &exproto.CheckPermReply{
 | 
			
		||||
		IsValid: valid,
 | 
			
		||||
	}, nil
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -4,6 +4,7 @@ import (
 | 
			
		||||
	"google.golang.org/grpc/reflection"
 | 
			
		||||
	"net"
 | 
			
		||||
 | 
			
		||||
	exproto "git.solsynth.dev/hydrogen/dealer/pkg/proto"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/proto"
 | 
			
		||||
	"github.com/spf13/viper"
 | 
			
		||||
	"google.golang.org/grpc"
 | 
			
		||||
@@ -12,7 +13,7 @@ import (
 | 
			
		||||
import health "google.golang.org/grpc/health/grpc_health_v1"
 | 
			
		||||
 | 
			
		||||
type Server struct {
 | 
			
		||||
	proto.UnimplementedAuthServer
 | 
			
		||||
	exproto.UnimplementedAuthServer
 | 
			
		||||
	proto.UnimplementedNotifyServer
 | 
			
		||||
	proto.UnimplementedFriendshipsServer
 | 
			
		||||
	proto.UnimplementedRealmsServer
 | 
			
		||||
@@ -26,7 +27,7 @@ func NewServer() *Server {
 | 
			
		||||
		srv: grpc.NewServer(),
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	proto.RegisterAuthServer(server.srv, &Server{})
 | 
			
		||||
	exproto.RegisterAuthServer(server.srv, &Server{})
 | 
			
		||||
	proto.RegisterNotifyServer(server.srv, &Server{})
 | 
			
		||||
	proto.RegisterFriendshipsServer(server.srv, &Server{})
 | 
			
		||||
	proto.RegisterRealmsServer(server.srv, &Server{})
 | 
			
		||||
 
 | 
			
		||||
@@ -1,16 +0,0 @@
 | 
			
		||||
package i18n
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	jsoniter "github.com/json-iterator/go"
 | 
			
		||||
	"github.com/nicksnyder/go-i18n/v2/i18n"
 | 
			
		||||
	"golang.org/x/text/language"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
var Bundle *i18n.Bundle
 | 
			
		||||
 | 
			
		||||
func InitInternationalization() {
 | 
			
		||||
	Bundle = i18n.NewBundle(language.English)
 | 
			
		||||
	Bundle.RegisterUnmarshalFunc("json", jsoniter.ConfigCompatibleWithStandardLibrary.Unmarshal)
 | 
			
		||||
	Bundle.LoadMessageFileFS(FS, "locale.en.json")
 | 
			
		||||
	Bundle.LoadMessageFileFS(FS, "locale.zh.json")
 | 
			
		||||
}
 | 
			
		||||
@@ -1,6 +0,0 @@
 | 
			
		||||
package i18n
 | 
			
		||||
 | 
			
		||||
import "embed"
 | 
			
		||||
 | 
			
		||||
//go:embed locale.*.json
 | 
			
		||||
var FS embed.FS
 | 
			
		||||
@@ -1,23 +0,0 @@
 | 
			
		||||
{
 | 
			
		||||
  "next": "Next",
 | 
			
		||||
  "email": "Email",
 | 
			
		||||
  "username": "Username",
 | 
			
		||||
  "nickname": "Nickname",
 | 
			
		||||
  "password": "Password",
 | 
			
		||||
  "unknown": "Unknown",
 | 
			
		||||
  "apply": "Apply",
 | 
			
		||||
  "back": "Back",
 | 
			
		||||
  "approve": "Approve",
 | 
			
		||||
  "decline": "Decline",
 | 
			
		||||
  "magicToken": "Magic Token",
 | 
			
		||||
  "signinTitle": "Sign In",
 | 
			
		||||
  "signinCaption": "Sign in to Solarpass to explore entire Solar Network. Explore posts, discover communities, talk with your best friends. All these things in the Solar Network!",
 | 
			
		||||
  "signinRequired": "You need to sign in before do that.",
 | 
			
		||||
  "signupTitle": "Sign Up",
 | 
			
		||||
  "signupCaption": "Sign up to create an account on Solarpass, then you can explore the entire Solar Network! Enjoy the next-generation Internet Ecosystem!",
 | 
			
		||||
  "authorizeTitle": "Authorize",
 | 
			
		||||
  "authorizeCaption": "One Solarpass, get entire network.",
 | 
			
		||||
  "mfaTitle": "Multi Factor Authenticate",
 | 
			
		||||
  "mfaCaption": "We need use one more way to verify it is you.",
 | 
			
		||||
  "mfaFactorEmail": "OTP through your email"
 | 
			
		||||
}
 | 
			
		||||
@@ -1,23 +0,0 @@
 | 
			
		||||
{
 | 
			
		||||
  "next": "下一步",
 | 
			
		||||
  "email": "邮件地址",
 | 
			
		||||
  "username": "用户名",
 | 
			
		||||
  "nickname": "昵称",
 | 
			
		||||
  "password": "密码",
 | 
			
		||||
  "unknown": "未知",
 | 
			
		||||
  "apply": "应用",
 | 
			
		||||
  "back": "返回",
 | 
			
		||||
  "approve": "接受",
 | 
			
		||||
  "decline": "拒绝",
 | 
			
		||||
  "magicToken": "魔法令牌",
 | 
			
		||||
  "signinTitle": "登陆",
 | 
			
		||||
  "signinCaption": "登陆 Solarpass 以探索整个 Solar Network,浏览帖子、探索社区、和你的好朋友聊八卦,一切尽在 Solar Network!",
 | 
			
		||||
  "signinRequired": "你需要在那之前登陆",
 | 
			
		||||
  "signupTitle": "注册",
 | 
			
		||||
  "signupCaption": "注册以在 Solarpass 创建一个账号,之后你就可以探索整个 Solar Network,享受下一代互联网生态系统!",
 | 
			
		||||
  "authorizeTitle": "授权",
 | 
			
		||||
  "authorizeCaption": "一个 Solarpass,整个网络。",
 | 
			
		||||
  "mfaTitle": "多因素验证",
 | 
			
		||||
  "mfaCaption": "我们需要另一个方法来确认你是你。",
 | 
			
		||||
  "mfaFactorEmail": "电子邮寄一次性验证码"
 | 
			
		||||
}
 | 
			
		||||
@@ -1,15 +0,0 @@
 | 
			
		||||
package i18n
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"github.com/gofiber/fiber/v2"
 | 
			
		||||
	"github.com/nicksnyder/go-i18n/v2/i18n"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func I18nMiddleware(c *fiber.Ctx) error {
 | 
			
		||||
	accept := c.Get(fiber.HeaderAcceptLanguage)
 | 
			
		||||
	localizer := i18n.NewLocalizer(Bundle, accept)
 | 
			
		||||
 | 
			
		||||
	c.Locals("localizer", localizer)
 | 
			
		||||
 | 
			
		||||
	return c.Next()
 | 
			
		||||
}
 | 
			
		||||
@@ -21,26 +21,26 @@ type Account struct {
 | 
			
		||||
	SuspendedAt *time.Time        `json:"suspended_at"`
 | 
			
		||||
	PermNodes   datatypes.JSONMap `json:"perm_nodes"`
 | 
			
		||||
 | 
			
		||||
	Profile  AccountProfile `json:"profile"`
 | 
			
		||||
	Statuses []Status       `json:"statuses"`
 | 
			
		||||
	Badges   []Badge        `json:"badges"`
 | 
			
		||||
	Profile  AccountProfile `json:"profile,omitempty"`
 | 
			
		||||
	Statuses []Status       `json:"statuses,omitempty"`
 | 
			
		||||
	Badges   []Badge        `json:"badges,omitempty"`
 | 
			
		||||
 | 
			
		||||
	Contacts        []AccountContact `json:"contacts"`
 | 
			
		||||
	RealmIdentities []RealmMember    `json:"realm_identities"`
 | 
			
		||||
	Contacts        []AccountContact `json:"contacts,omitempty"`
 | 
			
		||||
	RealmIdentities []RealmMember    `json:"realm_identities,omitempty"`
 | 
			
		||||
 | 
			
		||||
	Tickets []AuthTicket `json:"tickets"`
 | 
			
		||||
	Factors []AuthFactor `json:"factors"`
 | 
			
		||||
	Tickets []AuthTicket `json:"tickets,omitempty"`
 | 
			
		||||
	Factors []AuthFactor `json:"factors,omitempty"`
 | 
			
		||||
 | 
			
		||||
	Events      []ActionEvent `json:"events"`
 | 
			
		||||
	Events      []ActionEvent `json:"events,omitempty"`
 | 
			
		||||
	MagicTokens []MagicToken  `json:"-"`
 | 
			
		||||
 | 
			
		||||
	ThirdClients []ThirdClient `json:"clients"`
 | 
			
		||||
	ThirdClients []ThirdClient `json:"clients,omitempty"`
 | 
			
		||||
 | 
			
		||||
	Notifications     []Notification           `json:"notifications" gorm:"foreignKey:RecipientID"`
 | 
			
		||||
	NotifySubscribers []NotificationSubscriber `json:"notify_subscribers"`
 | 
			
		||||
	Notifications     []Notification           `json:"notifications,omitempty" gorm:"foreignKey:RecipientID"`
 | 
			
		||||
	NotifySubscribers []NotificationSubscriber `json:"notify_subscribers,omitempty"`
 | 
			
		||||
 | 
			
		||||
	Friendships        []AccountFriendship `json:"friendships" gorm:"foreignKey:AccountID"`
 | 
			
		||||
	RelatedFriendships []AccountFriendship `json:"related_friendships" gorm:"foreignKey:RelatedID"`
 | 
			
		||||
	Friendships        []AccountFriendship `json:"friendships,omitempty" gorm:"foreignKey:AccountID"`
 | 
			
		||||
	RelatedFriendships []AccountFriendship `json:"related_friendships,omitempty" gorm:"foreignKey:RelatedID"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (v Account) GetAvatar() *string {
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										
											BIN
										
									
								
								pkg/internal/server/.DS_Store
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								pkg/internal/server/.DS_Store
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							@@ -3,6 +3,7 @@ package api
 | 
			
		||||
import (
 | 
			
		||||
	"context"
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/dealer/pkg/hyper"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/paperclip/pkg/proto"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/database"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/gap"
 | 
			
		||||
@@ -27,7 +28,7 @@ func setAvatar(c *fiber.Ctx) error {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	pc, err := gap.DiscoverPaperclip()
 | 
			
		||||
	pc, err := gap.H.GetServiceGrpcConn(hyper.ServiceTypeFileProvider)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return fiber.NewError(fiber.StatusInternalServerError, "attachments services was not available")
 | 
			
		||||
	}
 | 
			
		||||
@@ -63,7 +64,7 @@ func setBanner(c *fiber.Ctx) error {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	pc, err := gap.DiscoverPaperclip()
 | 
			
		||||
	pc, err := gap.H.GetServiceGrpcConn(hyper.ServiceTypeFileProvider)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return fiber.NewError(fiber.StatusInternalServerError, "attachments services was not available")
 | 
			
		||||
	}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,8 +1,6 @@
 | 
			
		||||
package api
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/server/exts"
 | 
			
		||||
	"github.com/gofiber/contrib/websocket"
 | 
			
		||||
	"github.com/gofiber/fiber/v2"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
@@ -99,13 +97,6 @@ func MapAPIs(app *fiber.App) {
 | 
			
		||||
			developers.Post("/notify", notifyUser)
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		api.Use(func(c *fiber.Ctx) error {
 | 
			
		||||
			if err := exts.EnsureAuthenticated(c); err != nil {
 | 
			
		||||
				return err
 | 
			
		||||
			}
 | 
			
		||||
			return c.Next()
 | 
			
		||||
		}).Get("/ws", websocket.New(listenWebsocket))
 | 
			
		||||
 | 
			
		||||
		api.All("/*", func(c *fiber.Ctx) error {
 | 
			
		||||
			return fiber.ErrNotFound
 | 
			
		||||
		})
 | 
			
		||||
 
 | 
			
		||||
@@ -1,82 +0,0 @@
 | 
			
		||||
package api
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/models"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/services"
 | 
			
		||||
	"github.com/gofiber/contrib/websocket"
 | 
			
		||||
	jsoniter "github.com/json-iterator/go"
 | 
			
		||||
	"github.com/rs/zerolog/log"
 | 
			
		||||
	"github.com/samber/lo"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func listenWebsocket(c *websocket.Conn) {
 | 
			
		||||
	user := c.Locals("user").(models.Account)
 | 
			
		||||
 | 
			
		||||
	// Push connection
 | 
			
		||||
	services.ClientRegister(user, c)
 | 
			
		||||
	log.Debug().Uint("user", user.ID).Msg("New websocket connection established...")
 | 
			
		||||
 | 
			
		||||
	// Event loop
 | 
			
		||||
	var task models.UnifiedCommand
 | 
			
		||||
 | 
			
		||||
	var messageType int
 | 
			
		||||
	var payload []byte
 | 
			
		||||
	var packet []byte
 | 
			
		||||
	var err error
 | 
			
		||||
 | 
			
		||||
	for {
 | 
			
		||||
		if messageType, packet, err = c.ReadMessage(); err != nil {
 | 
			
		||||
			break
 | 
			
		||||
		} else if err := jsoniter.Unmarshal(packet, &task); err != nil {
 | 
			
		||||
			_ = c.WriteMessage(messageType, models.UnifiedCommand{
 | 
			
		||||
				Action:  "error",
 | 
			
		||||
				Message: "unable to unmarshal your command, requires json request",
 | 
			
		||||
			}.Marshal())
 | 
			
		||||
			continue
 | 
			
		||||
		} else {
 | 
			
		||||
			payload, _ = jsoniter.Marshal(task.Payload)
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		var message *models.UnifiedCommand
 | 
			
		||||
		switch task.Action {
 | 
			
		||||
		case "kex.request":
 | 
			
		||||
			var req struct {
 | 
			
		||||
				RequestID string `json:"request_id"`
 | 
			
		||||
				KeypairID string `json:"keypair_id"`
 | 
			
		||||
				Algorithm string `json:"algorithm"`
 | 
			
		||||
				OwnerID   uint   `json:"owner_id"`
 | 
			
		||||
				Deadline  int64  `json:"deadline"`
 | 
			
		||||
			}
 | 
			
		||||
			_ = jsoniter.Unmarshal(payload, &req)
 | 
			
		||||
			if len(req.RequestID) <= 0 || len(req.KeypairID) <= 0 || req.OwnerID <= 0 {
 | 
			
		||||
				message = lo.ToPtr(models.UnifiedCommandFromError(fmt.Errorf("invalid request")))
 | 
			
		||||
			}
 | 
			
		||||
			services.KexRequest(c, req.RequestID, req.KeypairID, req.Algorithm, req.OwnerID, req.Deadline)
 | 
			
		||||
		case "kex.provide":
 | 
			
		||||
			var req struct {
 | 
			
		||||
				RequestID string `json:"request_id"`
 | 
			
		||||
				KeypairID string `json:"keypair_id"`
 | 
			
		||||
				Algorithm string `json:"algorithm"`
 | 
			
		||||
				PublicKey []byte `json:"public_key"`
 | 
			
		||||
			}
 | 
			
		||||
			_ = jsoniter.Unmarshal(payload, &req)
 | 
			
		||||
			if len(req.RequestID) <= 0 || len(req.KeypairID) <= 0 {
 | 
			
		||||
				message = lo.ToPtr(models.UnifiedCommandFromError(fmt.Errorf("invalid request")))
 | 
			
		||||
			}
 | 
			
		||||
			services.KexProvide(user.ID, req.RequestID, req.KeypairID, packet)
 | 
			
		||||
		default:
 | 
			
		||||
			message = lo.ToPtr(models.UnifiedCommandFromError(fmt.Errorf("unknown action")))
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		if message != nil {
 | 
			
		||||
			if err = c.WriteMessage(messageType, message.Marshal()); err != nil {
 | 
			
		||||
				break
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Pop connection
 | 
			
		||||
	services.ClientUnregister(user, c)
 | 
			
		||||
	log.Debug().Uint("user", user.ID).Msg("A websocket connection disconnected...")
 | 
			
		||||
}
 | 
			
		||||
@@ -2,7 +2,7 @@ package exts
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/hyper"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/dealer/pkg/hyper"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/models"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/services"
 | 
			
		||||
	"github.com/gofiber/fiber/v2"
 | 
			
		||||
 
 | 
			
		||||
@@ -1,7 +1,7 @@
 | 
			
		||||
package exts
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/hyper"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/dealer/pkg/hyper"
 | 
			
		||||
	"github.com/gofiber/fiber/v2"
 | 
			
		||||
	"github.com/spf13/viper"
 | 
			
		||||
	"time"
 | 
			
		||||
 
 | 
			
		||||
@@ -9,7 +9,6 @@ import (
 | 
			
		||||
	"path/filepath"
 | 
			
		||||
	"strings"
 | 
			
		||||
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/i18n"
 | 
			
		||||
	"github.com/gofiber/fiber/v2"
 | 
			
		||||
	"github.com/gofiber/fiber/v2/middleware/cors"
 | 
			
		||||
	"github.com/gofiber/fiber/v2/middleware/favicon"
 | 
			
		||||
@@ -59,7 +58,6 @@ func NewServer() *HTTPApp {
 | 
			
		||||
	}))
 | 
			
		||||
 | 
			
		||||
	app.Use(exts.AuthMiddleware)
 | 
			
		||||
	app.Use(i18n.I18nMiddleware)
 | 
			
		||||
 | 
			
		||||
	admin.MapAdminAPIs(app)
 | 
			
		||||
	api.MapAPIs(app)
 | 
			
		||||
 
 | 
			
		||||
@@ -1,37 +0,0 @@
 | 
			
		||||
package services
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"sync"
 | 
			
		||||
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/models"
 | 
			
		||||
	"github.com/gofiber/contrib/websocket"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
var (
 | 
			
		||||
	wsMutex sync.Mutex
 | 
			
		||||
	wsConn  = make(map[uint]map[*websocket.Conn]bool)
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func ClientRegister(user models.Account, conn *websocket.Conn) {
 | 
			
		||||
	wsMutex.Lock()
 | 
			
		||||
	if wsConn[user.ID] == nil {
 | 
			
		||||
		wsConn[user.ID] = make(map[*websocket.Conn]bool)
 | 
			
		||||
	}
 | 
			
		||||
	wsConn[user.ID][conn] = true
 | 
			
		||||
	wsMutex.Unlock()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func ClientUnregister(user models.Account, conn *websocket.Conn) {
 | 
			
		||||
	wsMutex.Lock()
 | 
			
		||||
	if wsConn[user.ID] == nil {
 | 
			
		||||
		wsConn[user.ID] = make(map[*websocket.Conn]bool)
 | 
			
		||||
	}
 | 
			
		||||
	delete(wsConn[user.ID], conn)
 | 
			
		||||
	wsMutex.Unlock()
 | 
			
		||||
 | 
			
		||||
	if status, err := GetStatus(user.ID); err != nil || !status.IsInvisible {
 | 
			
		||||
		if len(wsConn[user.ID]) == 0 {
 | 
			
		||||
			_ = SetAccountLastSeen(user.ID)
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
@@ -1,82 +0,0 @@
 | 
			
		||||
package services
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/models"
 | 
			
		||||
	"github.com/gofiber/contrib/websocket"
 | 
			
		||||
	"github.com/gofiber/fiber/v2"
 | 
			
		||||
	"time"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type kexRequest struct {
 | 
			
		||||
	OwnerID  uint
 | 
			
		||||
	Conn     *websocket.Conn
 | 
			
		||||
	Deadline time.Time
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var kexRequests = make(map[string]map[string]kexRequest)
 | 
			
		||||
 | 
			
		||||
func KexRequest(conn *websocket.Conn, requestId, keypairId, algorithm string, ownerId uint, deadline int64) {
 | 
			
		||||
	if kexRequests[keypairId] == nil {
 | 
			
		||||
		kexRequests[keypairId] = make(map[string]kexRequest)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	ddl := time.Now().Add(time.Second * time.Duration(deadline))
 | 
			
		||||
	request := kexRequest{
 | 
			
		||||
		OwnerID:  ownerId,
 | 
			
		||||
		Conn:     conn,
 | 
			
		||||
		Deadline: ddl,
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	flag := false
 | 
			
		||||
	for c := range wsConn[ownerId] {
 | 
			
		||||
		if c == conn {
 | 
			
		||||
			continue
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		if c.WriteMessage(1, models.UnifiedCommand{
 | 
			
		||||
			Action: "kex.request",
 | 
			
		||||
			Payload: fiber.Map{
 | 
			
		||||
				"request_id": requestId,
 | 
			
		||||
				"keypair_id": keypairId,
 | 
			
		||||
				"algorithm":  algorithm,
 | 
			
		||||
				"owner_id":   ownerId,
 | 
			
		||||
				"deadline":   deadline,
 | 
			
		||||
			},
 | 
			
		||||
		}.Marshal()) == nil {
 | 
			
		||||
			flag = true
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if flag {
 | 
			
		||||
		kexRequests[keypairId][requestId] = request
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func KexProvide(userId uint, requestId, keypairId string, pkt []byte) {
 | 
			
		||||
	if kexRequests[keypairId] == nil {
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	val, ok := kexRequests[keypairId][requestId]
 | 
			
		||||
	if !ok {
 | 
			
		||||
		return
 | 
			
		||||
	} else if val.OwnerID != userId {
 | 
			
		||||
		return
 | 
			
		||||
	} else {
 | 
			
		||||
		_ = val.Conn.WriteMessage(1, pkt)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func KexCleanup() {
 | 
			
		||||
	if len(kexRequests) <= 0 {
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	for kp, data := range kexRequests {
 | 
			
		||||
		for idx, req := range data {
 | 
			
		||||
			if req.Deadline.Unix() <= time.Now().Unix() {
 | 
			
		||||
				delete(kexRequests[kp], idx)
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
@@ -2,7 +2,11 @@ package services
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"context"
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/dealer/pkg/proto"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/gap"
 | 
			
		||||
	"reflect"
 | 
			
		||||
	"time"
 | 
			
		||||
 | 
			
		||||
	"firebase.google.com/go/messaging"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/database"
 | 
			
		||||
@@ -56,15 +60,23 @@ func NewNotification(notification models.Notification) error {
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// PushNotification will push the notification what ever it is exists record in the database
 | 
			
		||||
// Recommend push another goroutine when you need to push a lot of notification
 | 
			
		||||
// And just use block statement when you just push one notification, the time of create a new sub-process is much more than push notification
 | 
			
		||||
// PushNotification will push the notification whatever it exists record in the
 | 
			
		||||
// database Recommend push another goroutine when you need to push a lot of
 | 
			
		||||
// notifications And just use a block statement when you just push one
 | 
			
		||||
// notification, the time of create a new subprocess is much more than push
 | 
			
		||||
// notification
 | 
			
		||||
func PushNotification(notification models.Notification) error {
 | 
			
		||||
	for conn := range wsConn[notification.RecipientID] {
 | 
			
		||||
		_ = conn.WriteMessage(1, models.UnifiedCommand{
 | 
			
		||||
	ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
 | 
			
		||||
	defer cancel()
 | 
			
		||||
	_, err := proto.NewStreamControllerClient(gap.H.GetDealerGrpcConn()).PushStream(ctx, &proto.PushStreamRequest{
 | 
			
		||||
		UserId: uint64(notification.RecipientID),
 | 
			
		||||
		Body: models.UnifiedCommand{
 | 
			
		||||
			Action:  "notifications.new",
 | 
			
		||||
			Payload: notification,
 | 
			
		||||
		}.Marshal())
 | 
			
		||||
		}.Marshal(),
 | 
			
		||||
	})
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return fmt.Errorf("failed to push via websocket: %v", err)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Skip push notification
 | 
			
		||||
 
 | 
			
		||||
@@ -1,7 +1,10 @@
 | 
			
		||||
package services
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"context"
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/dealer/pkg/proto"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/gap"
 | 
			
		||||
	"time"
 | 
			
		||||
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/database"
 | 
			
		||||
@@ -32,7 +35,16 @@ func GetStatus(uid uint) (models.Status, error) {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func GetUserOnline(uid uint) bool {
 | 
			
		||||
	return wsConn[uid] != nil && len(wsConn[uid]) > 0
 | 
			
		||||
	pc := proto.NewStreamControllerClient(gap.H.GetDealerGrpcConn())
 | 
			
		||||
	ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
 | 
			
		||||
	defer cancel()
 | 
			
		||||
	resp, err := pc.CountStreamConnection(ctx, &proto.CountConnectionRequest{
 | 
			
		||||
		UserId: uint64(uid),
 | 
			
		||||
	})
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return false
 | 
			
		||||
	}
 | 
			
		||||
	return resp.Count > 0
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func GetStatusDisturbable(uid uint) error {
 | 
			
		||||
@@ -49,7 +61,7 @@ func GetStatusDisturbable(uid uint) error {
 | 
			
		||||
 | 
			
		||||
func GetStatusOnline(uid uint) error {
 | 
			
		||||
	status, err := GetStatus(uid)
 | 
			
		||||
	isOnline := wsConn[uid] != nil && len(wsConn[uid]) > 0
 | 
			
		||||
	isOnline := GetUserOnline(uid)
 | 
			
		||||
	if isOnline && err != nil {
 | 
			
		||||
		return nil
 | 
			
		||||
	} else if err == nil && status.IsInvisible {
 | 
			
		||||
 
 | 
			
		||||
@@ -7,8 +7,6 @@ import (
 | 
			
		||||
	"os/signal"
 | 
			
		||||
	"syscall"
 | 
			
		||||
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/i18n"
 | 
			
		||||
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/grpc"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/server"
 | 
			
		||||
	"git.solsynth.dev/hydrogen/passport/pkg/internal/services"
 | 
			
		||||
@@ -37,8 +35,6 @@ func main() {
 | 
			
		||||
		log.Panic().Err(err).Msg("An error occurred when loading settings.")
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	i18n.InitInternationalization()
 | 
			
		||||
 | 
			
		||||
	// Connect to database
 | 
			
		||||
	if err := database.NewGorm(); err != nil {
 | 
			
		||||
		log.Fatal().Err(err).Msg("An error occurred when connect to database.")
 | 
			
		||||
@@ -47,7 +43,7 @@ func main() {
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Connect other services
 | 
			
		||||
	if err := gap.Register(); err != nil {
 | 
			
		||||
	if err := gap.RegisterService(); err != nil {
 | 
			
		||||
		log.Error().Err(err).Msg("An error occurred when registering service to gateway...")
 | 
			
		||||
	}
 | 
			
		||||
	if err := services.SetupFirebase(); err != nil {
 | 
			
		||||
@@ -69,7 +65,6 @@ func main() {
 | 
			
		||||
	quartz.AddFunc("@every 60m", services.DoAutoDatabaseCleanup)
 | 
			
		||||
	quartz.AddFunc("@every 60s", services.RecycleAuthContext)
 | 
			
		||||
	quartz.AddFunc("@every 60m", services.RecycleUnConfirmAccount)
 | 
			
		||||
	quartz.AddFunc("@every 5m", services.KexCleanup)
 | 
			
		||||
	quartz.AddFunc("@every 60s", services.SaveEventChanges)
 | 
			
		||||
	quartz.Start()
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -1,554 +0,0 @@
 | 
			
		||||
// Code generated by protoc-gen-go. DO NOT EDIT.
 | 
			
		||||
// versions:
 | 
			
		||||
// 	protoc-gen-go v1.33.0
 | 
			
		||||
// 	protoc        v5.26.1
 | 
			
		||||
// source: auth.proto
 | 
			
		||||
 | 
			
		||||
package proto
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	protoreflect "google.golang.org/protobuf/reflect/protoreflect"
 | 
			
		||||
	protoimpl "google.golang.org/protobuf/runtime/protoimpl"
 | 
			
		||||
	reflect "reflect"
 | 
			
		||||
	sync "sync"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
	// Verify that this generated code is sufficiently up-to-date.
 | 
			
		||||
	_ = protoimpl.EnforceVersion(20 - protoimpl.MinVersion)
 | 
			
		||||
	// Verify that runtime/protoimpl is sufficiently up-to-date.
 | 
			
		||||
	_ = protoimpl.EnforceVersion(protoimpl.MaxVersion - 20)
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type Userinfo struct {
 | 
			
		||||
	state         protoimpl.MessageState
 | 
			
		||||
	sizeCache     protoimpl.SizeCache
 | 
			
		||||
	unknownFields protoimpl.UnknownFields
 | 
			
		||||
 | 
			
		||||
	Id          uint64  `protobuf:"varint,1,opt,name=id,proto3" json:"id,omitempty"`
 | 
			
		||||
	Name        string  `protobuf:"bytes,2,opt,name=name,proto3" json:"name,omitempty"`
 | 
			
		||||
	Nick        string  `protobuf:"bytes,3,opt,name=nick,proto3" json:"nick,omitempty"`
 | 
			
		||||
	Email       string  `protobuf:"bytes,4,opt,name=email,proto3" json:"email,omitempty"`
 | 
			
		||||
	Avatar      string  `protobuf:"bytes,5,opt,name=avatar,proto3" json:"avatar,omitempty"`
 | 
			
		||||
	Banner      string  `protobuf:"bytes,6,opt,name=banner,proto3" json:"banner,omitempty"`
 | 
			
		||||
	Description *string `protobuf:"bytes,7,opt,name=description,proto3,oneof" json:"description,omitempty"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *Userinfo) Reset() {
 | 
			
		||||
	*x = Userinfo{}
 | 
			
		||||
	if protoimpl.UnsafeEnabled {
 | 
			
		||||
		mi := &file_auth_proto_msgTypes[0]
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		ms.StoreMessageInfo(mi)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *Userinfo) String() string {
 | 
			
		||||
	return protoimpl.X.MessageStringOf(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (*Userinfo) ProtoMessage() {}
 | 
			
		||||
 | 
			
		||||
func (x *Userinfo) ProtoReflect() protoreflect.Message {
 | 
			
		||||
	mi := &file_auth_proto_msgTypes[0]
 | 
			
		||||
	if protoimpl.UnsafeEnabled && x != nil {
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		if ms.LoadMessageInfo() == nil {
 | 
			
		||||
			ms.StoreMessageInfo(mi)
 | 
			
		||||
		}
 | 
			
		||||
		return ms
 | 
			
		||||
	}
 | 
			
		||||
	return mi.MessageOf(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Deprecated: Use Userinfo.ProtoReflect.Descriptor instead.
 | 
			
		||||
func (*Userinfo) Descriptor() ([]byte, []int) {
 | 
			
		||||
	return file_auth_proto_rawDescGZIP(), []int{0}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *Userinfo) GetId() uint64 {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.Id
 | 
			
		||||
	}
 | 
			
		||||
	return 0
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *Userinfo) GetName() string {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.Name
 | 
			
		||||
	}
 | 
			
		||||
	return ""
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *Userinfo) GetNick() string {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.Nick
 | 
			
		||||
	}
 | 
			
		||||
	return ""
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *Userinfo) GetEmail() string {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.Email
 | 
			
		||||
	}
 | 
			
		||||
	return ""
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *Userinfo) GetAvatar() string {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.Avatar
 | 
			
		||||
	}
 | 
			
		||||
	return ""
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *Userinfo) GetBanner() string {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.Banner
 | 
			
		||||
	}
 | 
			
		||||
	return ""
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *Userinfo) GetDescription() string {
 | 
			
		||||
	if x != nil && x.Description != nil {
 | 
			
		||||
		return *x.Description
 | 
			
		||||
	}
 | 
			
		||||
	return ""
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type AuthRequest struct {
 | 
			
		||||
	state         protoimpl.MessageState
 | 
			
		||||
	sizeCache     protoimpl.SizeCache
 | 
			
		||||
	unknownFields protoimpl.UnknownFields
 | 
			
		||||
 | 
			
		||||
	AccessToken  string  `protobuf:"bytes,1,opt,name=access_token,json=accessToken,proto3" json:"access_token,omitempty"`
 | 
			
		||||
	RefreshToken *string `protobuf:"bytes,2,opt,name=refresh_token,json=refreshToken,proto3,oneof" json:"refresh_token,omitempty"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *AuthRequest) Reset() {
 | 
			
		||||
	*x = AuthRequest{}
 | 
			
		||||
	if protoimpl.UnsafeEnabled {
 | 
			
		||||
		mi := &file_auth_proto_msgTypes[1]
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		ms.StoreMessageInfo(mi)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *AuthRequest) String() string {
 | 
			
		||||
	return protoimpl.X.MessageStringOf(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (*AuthRequest) ProtoMessage() {}
 | 
			
		||||
 | 
			
		||||
func (x *AuthRequest) ProtoReflect() protoreflect.Message {
 | 
			
		||||
	mi := &file_auth_proto_msgTypes[1]
 | 
			
		||||
	if protoimpl.UnsafeEnabled && x != nil {
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		if ms.LoadMessageInfo() == nil {
 | 
			
		||||
			ms.StoreMessageInfo(mi)
 | 
			
		||||
		}
 | 
			
		||||
		return ms
 | 
			
		||||
	}
 | 
			
		||||
	return mi.MessageOf(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Deprecated: Use AuthRequest.ProtoReflect.Descriptor instead.
 | 
			
		||||
func (*AuthRequest) Descriptor() ([]byte, []int) {
 | 
			
		||||
	return file_auth_proto_rawDescGZIP(), []int{1}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *AuthRequest) GetAccessToken() string {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.AccessToken
 | 
			
		||||
	}
 | 
			
		||||
	return ""
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *AuthRequest) GetRefreshToken() string {
 | 
			
		||||
	if x != nil && x.RefreshToken != nil {
 | 
			
		||||
		return *x.RefreshToken
 | 
			
		||||
	}
 | 
			
		||||
	return ""
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type AuthReply struct {
 | 
			
		||||
	state         protoimpl.MessageState
 | 
			
		||||
	sizeCache     protoimpl.SizeCache
 | 
			
		||||
	unknownFields protoimpl.UnknownFields
 | 
			
		||||
 | 
			
		||||
	IsValid      bool      `protobuf:"varint,1,opt,name=is_valid,json=isValid,proto3" json:"is_valid,omitempty"`
 | 
			
		||||
	AccessToken  *string   `protobuf:"bytes,2,opt,name=access_token,json=accessToken,proto3,oneof" json:"access_token,omitempty"`
 | 
			
		||||
	RefreshToken *string   `protobuf:"bytes,3,opt,name=refresh_token,json=refreshToken,proto3,oneof" json:"refresh_token,omitempty"`
 | 
			
		||||
	Userinfo     *Userinfo `protobuf:"bytes,4,opt,name=userinfo,proto3,oneof" json:"userinfo,omitempty"`
 | 
			
		||||
	Permissions  []byte    `protobuf:"bytes,5,opt,name=permissions,proto3,oneof" json:"permissions,omitempty"`
 | 
			
		||||
	TicketId     *uint64   `protobuf:"varint,6,opt,name=ticket_id,json=ticketId,proto3,oneof" json:"ticket_id,omitempty"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *AuthReply) Reset() {
 | 
			
		||||
	*x = AuthReply{}
 | 
			
		||||
	if protoimpl.UnsafeEnabled {
 | 
			
		||||
		mi := &file_auth_proto_msgTypes[2]
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		ms.StoreMessageInfo(mi)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *AuthReply) String() string {
 | 
			
		||||
	return protoimpl.X.MessageStringOf(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (*AuthReply) ProtoMessage() {}
 | 
			
		||||
 | 
			
		||||
func (x *AuthReply) ProtoReflect() protoreflect.Message {
 | 
			
		||||
	mi := &file_auth_proto_msgTypes[2]
 | 
			
		||||
	if protoimpl.UnsafeEnabled && x != nil {
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		if ms.LoadMessageInfo() == nil {
 | 
			
		||||
			ms.StoreMessageInfo(mi)
 | 
			
		||||
		}
 | 
			
		||||
		return ms
 | 
			
		||||
	}
 | 
			
		||||
	return mi.MessageOf(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Deprecated: Use AuthReply.ProtoReflect.Descriptor instead.
 | 
			
		||||
func (*AuthReply) Descriptor() ([]byte, []int) {
 | 
			
		||||
	return file_auth_proto_rawDescGZIP(), []int{2}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *AuthReply) GetIsValid() bool {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.IsValid
 | 
			
		||||
	}
 | 
			
		||||
	return false
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *AuthReply) GetAccessToken() string {
 | 
			
		||||
	if x != nil && x.AccessToken != nil {
 | 
			
		||||
		return *x.AccessToken
 | 
			
		||||
	}
 | 
			
		||||
	return ""
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *AuthReply) GetRefreshToken() string {
 | 
			
		||||
	if x != nil && x.RefreshToken != nil {
 | 
			
		||||
		return *x.RefreshToken
 | 
			
		||||
	}
 | 
			
		||||
	return ""
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *AuthReply) GetUserinfo() *Userinfo {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.Userinfo
 | 
			
		||||
	}
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *AuthReply) GetPermissions() []byte {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.Permissions
 | 
			
		||||
	}
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *AuthReply) GetTicketId() uint64 {
 | 
			
		||||
	if x != nil && x.TicketId != nil {
 | 
			
		||||
		return *x.TicketId
 | 
			
		||||
	}
 | 
			
		||||
	return 0
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type CheckPermRequest struct {
 | 
			
		||||
	state         protoimpl.MessageState
 | 
			
		||||
	sizeCache     protoimpl.SizeCache
 | 
			
		||||
	unknownFields protoimpl.UnknownFields
 | 
			
		||||
 | 
			
		||||
	Token string `protobuf:"bytes,1,opt,name=token,proto3" json:"token,omitempty"`
 | 
			
		||||
	Key   string `protobuf:"bytes,2,opt,name=key,proto3" json:"key,omitempty"`
 | 
			
		||||
	Value []byte `protobuf:"bytes,3,opt,name=value,proto3" json:"value,omitempty"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *CheckPermRequest) Reset() {
 | 
			
		||||
	*x = CheckPermRequest{}
 | 
			
		||||
	if protoimpl.UnsafeEnabled {
 | 
			
		||||
		mi := &file_auth_proto_msgTypes[3]
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		ms.StoreMessageInfo(mi)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *CheckPermRequest) String() string {
 | 
			
		||||
	return protoimpl.X.MessageStringOf(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (*CheckPermRequest) ProtoMessage() {}
 | 
			
		||||
 | 
			
		||||
func (x *CheckPermRequest) ProtoReflect() protoreflect.Message {
 | 
			
		||||
	mi := &file_auth_proto_msgTypes[3]
 | 
			
		||||
	if protoimpl.UnsafeEnabled && x != nil {
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		if ms.LoadMessageInfo() == nil {
 | 
			
		||||
			ms.StoreMessageInfo(mi)
 | 
			
		||||
		}
 | 
			
		||||
		return ms
 | 
			
		||||
	}
 | 
			
		||||
	return mi.MessageOf(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Deprecated: Use CheckPermRequest.ProtoReflect.Descriptor instead.
 | 
			
		||||
func (*CheckPermRequest) Descriptor() ([]byte, []int) {
 | 
			
		||||
	return file_auth_proto_rawDescGZIP(), []int{3}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *CheckPermRequest) GetToken() string {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.Token
 | 
			
		||||
	}
 | 
			
		||||
	return ""
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *CheckPermRequest) GetKey() string {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.Key
 | 
			
		||||
	}
 | 
			
		||||
	return ""
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *CheckPermRequest) GetValue() []byte {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.Value
 | 
			
		||||
	}
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type CheckPermReply struct {
 | 
			
		||||
	state         protoimpl.MessageState
 | 
			
		||||
	sizeCache     protoimpl.SizeCache
 | 
			
		||||
	unknownFields protoimpl.UnknownFields
 | 
			
		||||
 | 
			
		||||
	IsValid bool `protobuf:"varint,1,opt,name=is_valid,json=isValid,proto3" json:"is_valid,omitempty"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *CheckPermReply) Reset() {
 | 
			
		||||
	*x = CheckPermReply{}
 | 
			
		||||
	if protoimpl.UnsafeEnabled {
 | 
			
		||||
		mi := &file_auth_proto_msgTypes[4]
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		ms.StoreMessageInfo(mi)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *CheckPermReply) String() string {
 | 
			
		||||
	return protoimpl.X.MessageStringOf(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (*CheckPermReply) ProtoMessage() {}
 | 
			
		||||
 | 
			
		||||
func (x *CheckPermReply) ProtoReflect() protoreflect.Message {
 | 
			
		||||
	mi := &file_auth_proto_msgTypes[4]
 | 
			
		||||
	if protoimpl.UnsafeEnabled && x != nil {
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		if ms.LoadMessageInfo() == nil {
 | 
			
		||||
			ms.StoreMessageInfo(mi)
 | 
			
		||||
		}
 | 
			
		||||
		return ms
 | 
			
		||||
	}
 | 
			
		||||
	return mi.MessageOf(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Deprecated: Use CheckPermReply.ProtoReflect.Descriptor instead.
 | 
			
		||||
func (*CheckPermReply) Descriptor() ([]byte, []int) {
 | 
			
		||||
	return file_auth_proto_rawDescGZIP(), []int{4}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *CheckPermReply) GetIsValid() bool {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.IsValid
 | 
			
		||||
	}
 | 
			
		||||
	return false
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var File_auth_proto protoreflect.FileDescriptor
 | 
			
		||||
 | 
			
		||||
var file_auth_proto_rawDesc = []byte{
 | 
			
		||||
	0x0a, 0x0a, 0x61, 0x75, 0x74, 0x68, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x12, 0x05, 0x70, 0x72,
 | 
			
		||||
	0x6f, 0x74, 0x6f, 0x22, 0xbf, 0x01, 0x0a, 0x08, 0x55, 0x73, 0x65, 0x72, 0x69, 0x6e, 0x66, 0x6f,
 | 
			
		||||
	0x12, 0x0e, 0x0a, 0x02, 0x69, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x04, 0x52, 0x02, 0x69, 0x64,
 | 
			
		||||
	0x12, 0x12, 0x0a, 0x04, 0x6e, 0x61, 0x6d, 0x65, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x04,
 | 
			
		||||
	0x6e, 0x61, 0x6d, 0x65, 0x12, 0x12, 0x0a, 0x04, 0x6e, 0x69, 0x63, 0x6b, 0x18, 0x03, 0x20, 0x01,
 | 
			
		||||
	0x28, 0x09, 0x52, 0x04, 0x6e, 0x69, 0x63, 0x6b, 0x12, 0x14, 0x0a, 0x05, 0x65, 0x6d, 0x61, 0x69,
 | 
			
		||||
	0x6c, 0x18, 0x04, 0x20, 0x01, 0x28, 0x09, 0x52, 0x05, 0x65, 0x6d, 0x61, 0x69, 0x6c, 0x12, 0x16,
 | 
			
		||||
	0x0a, 0x06, 0x61, 0x76, 0x61, 0x74, 0x61, 0x72, 0x18, 0x05, 0x20, 0x01, 0x28, 0x09, 0x52, 0x06,
 | 
			
		||||
	0x61, 0x76, 0x61, 0x74, 0x61, 0x72, 0x12, 0x16, 0x0a, 0x06, 0x62, 0x61, 0x6e, 0x6e, 0x65, 0x72,
 | 
			
		||||
	0x18, 0x06, 0x20, 0x01, 0x28, 0x09, 0x52, 0x06, 0x62, 0x61, 0x6e, 0x6e, 0x65, 0x72, 0x12, 0x25,
 | 
			
		||||
	0x0a, 0x0b, 0x64, 0x65, 0x73, 0x63, 0x72, 0x69, 0x70, 0x74, 0x69, 0x6f, 0x6e, 0x18, 0x07, 0x20,
 | 
			
		||||
	0x01, 0x28, 0x09, 0x48, 0x00, 0x52, 0x0b, 0x64, 0x65, 0x73, 0x63, 0x72, 0x69, 0x70, 0x74, 0x69,
 | 
			
		||||
	0x6f, 0x6e, 0x88, 0x01, 0x01, 0x42, 0x0e, 0x0a, 0x0c, 0x5f, 0x64, 0x65, 0x73, 0x63, 0x72, 0x69,
 | 
			
		||||
	0x70, 0x74, 0x69, 0x6f, 0x6e, 0x22, 0x6c, 0x0a, 0x0b, 0x41, 0x75, 0x74, 0x68, 0x52, 0x65, 0x71,
 | 
			
		||||
	0x75, 0x65, 0x73, 0x74, 0x12, 0x21, 0x0a, 0x0c, 0x61, 0x63, 0x63, 0x65, 0x73, 0x73, 0x5f, 0x74,
 | 
			
		||||
	0x6f, 0x6b, 0x65, 0x6e, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x0b, 0x61, 0x63, 0x63, 0x65,
 | 
			
		||||
	0x73, 0x73, 0x54, 0x6f, 0x6b, 0x65, 0x6e, 0x12, 0x28, 0x0a, 0x0d, 0x72, 0x65, 0x66, 0x72, 0x65,
 | 
			
		||||
	0x73, 0x68, 0x5f, 0x74, 0x6f, 0x6b, 0x65, 0x6e, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x48, 0x00,
 | 
			
		||||
	0x52, 0x0c, 0x72, 0x65, 0x66, 0x72, 0x65, 0x73, 0x68, 0x54, 0x6f, 0x6b, 0x65, 0x6e, 0x88, 0x01,
 | 
			
		||||
	0x01, 0x42, 0x10, 0x0a, 0x0e, 0x5f, 0x72, 0x65, 0x66, 0x72, 0x65, 0x73, 0x68, 0x5f, 0x74, 0x6f,
 | 
			
		||||
	0x6b, 0x65, 0x6e, 0x22, 0xc1, 0x02, 0x0a, 0x09, 0x41, 0x75, 0x74, 0x68, 0x52, 0x65, 0x70, 0x6c,
 | 
			
		||||
	0x79, 0x12, 0x19, 0x0a, 0x08, 0x69, 0x73, 0x5f, 0x76, 0x61, 0x6c, 0x69, 0x64, 0x18, 0x01, 0x20,
 | 
			
		||||
	0x01, 0x28, 0x08, 0x52, 0x07, 0x69, 0x73, 0x56, 0x61, 0x6c, 0x69, 0x64, 0x12, 0x26, 0x0a, 0x0c,
 | 
			
		||||
	0x61, 0x63, 0x63, 0x65, 0x73, 0x73, 0x5f, 0x74, 0x6f, 0x6b, 0x65, 0x6e, 0x18, 0x02, 0x20, 0x01,
 | 
			
		||||
	0x28, 0x09, 0x48, 0x00, 0x52, 0x0b, 0x61, 0x63, 0x63, 0x65, 0x73, 0x73, 0x54, 0x6f, 0x6b, 0x65,
 | 
			
		||||
	0x6e, 0x88, 0x01, 0x01, 0x12, 0x28, 0x0a, 0x0d, 0x72, 0x65, 0x66, 0x72, 0x65, 0x73, 0x68, 0x5f,
 | 
			
		||||
	0x74, 0x6f, 0x6b, 0x65, 0x6e, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, 0x48, 0x01, 0x52, 0x0c, 0x72,
 | 
			
		||||
	0x65, 0x66, 0x72, 0x65, 0x73, 0x68, 0x54, 0x6f, 0x6b, 0x65, 0x6e, 0x88, 0x01, 0x01, 0x12, 0x30,
 | 
			
		||||
	0x0a, 0x08, 0x75, 0x73, 0x65, 0x72, 0x69, 0x6e, 0x66, 0x6f, 0x18, 0x04, 0x20, 0x01, 0x28, 0x0b,
 | 
			
		||||
	0x32, 0x0f, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x55, 0x73, 0x65, 0x72, 0x69, 0x6e, 0x66,
 | 
			
		||||
	0x6f, 0x48, 0x02, 0x52, 0x08, 0x75, 0x73, 0x65, 0x72, 0x69, 0x6e, 0x66, 0x6f, 0x88, 0x01, 0x01,
 | 
			
		||||
	0x12, 0x25, 0x0a, 0x0b, 0x70, 0x65, 0x72, 0x6d, 0x69, 0x73, 0x73, 0x69, 0x6f, 0x6e, 0x73, 0x18,
 | 
			
		||||
	0x05, 0x20, 0x01, 0x28, 0x0c, 0x48, 0x03, 0x52, 0x0b, 0x70, 0x65, 0x72, 0x6d, 0x69, 0x73, 0x73,
 | 
			
		||||
	0x69, 0x6f, 0x6e, 0x73, 0x88, 0x01, 0x01, 0x12, 0x20, 0x0a, 0x09, 0x74, 0x69, 0x63, 0x6b, 0x65,
 | 
			
		||||
	0x74, 0x5f, 0x69, 0x64, 0x18, 0x06, 0x20, 0x01, 0x28, 0x04, 0x48, 0x04, 0x52, 0x08, 0x74, 0x69,
 | 
			
		||||
	0x63, 0x6b, 0x65, 0x74, 0x49, 0x64, 0x88, 0x01, 0x01, 0x42, 0x0f, 0x0a, 0x0d, 0x5f, 0x61, 0x63,
 | 
			
		||||
	0x63, 0x65, 0x73, 0x73, 0x5f, 0x74, 0x6f, 0x6b, 0x65, 0x6e, 0x42, 0x10, 0x0a, 0x0e, 0x5f, 0x72,
 | 
			
		||||
	0x65, 0x66, 0x72, 0x65, 0x73, 0x68, 0x5f, 0x74, 0x6f, 0x6b, 0x65, 0x6e, 0x42, 0x0b, 0x0a, 0x09,
 | 
			
		||||
	0x5f, 0x75, 0x73, 0x65, 0x72, 0x69, 0x6e, 0x66, 0x6f, 0x42, 0x0e, 0x0a, 0x0c, 0x5f, 0x70, 0x65,
 | 
			
		||||
	0x72, 0x6d, 0x69, 0x73, 0x73, 0x69, 0x6f, 0x6e, 0x73, 0x42, 0x0c, 0x0a, 0x0a, 0x5f, 0x74, 0x69,
 | 
			
		||||
	0x63, 0x6b, 0x65, 0x74, 0x5f, 0x69, 0x64, 0x22, 0x50, 0x0a, 0x10, 0x43, 0x68, 0x65, 0x63, 0x6b,
 | 
			
		||||
	0x50, 0x65, 0x72, 0x6d, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x14, 0x0a, 0x05, 0x74,
 | 
			
		||||
	0x6f, 0x6b, 0x65, 0x6e, 0x18, 0x01, 0x20, 0x01, 0x28, 0x09, 0x52, 0x05, 0x74, 0x6f, 0x6b, 0x65,
 | 
			
		||||
	0x6e, 0x12, 0x10, 0x0a, 0x03, 0x6b, 0x65, 0x79, 0x18, 0x02, 0x20, 0x01, 0x28, 0x09, 0x52, 0x03,
 | 
			
		||||
	0x6b, 0x65, 0x79, 0x12, 0x14, 0x0a, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x18, 0x03, 0x20, 0x01,
 | 
			
		||||
	0x28, 0x0c, 0x52, 0x05, 0x76, 0x61, 0x6c, 0x75, 0x65, 0x22, 0x2b, 0x0a, 0x0e, 0x43, 0x68, 0x65,
 | 
			
		||||
	0x63, 0x6b, 0x50, 0x65, 0x72, 0x6d, 0x52, 0x65, 0x70, 0x6c, 0x79, 0x12, 0x19, 0x0a, 0x08, 0x69,
 | 
			
		||||
	0x73, 0x5f, 0x76, 0x61, 0x6c, 0x69, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x08, 0x52, 0x07, 0x69,
 | 
			
		||||
	0x73, 0x56, 0x61, 0x6c, 0x69, 0x64, 0x32, 0x7d, 0x0a, 0x04, 0x41, 0x75, 0x74, 0x68, 0x12, 0x36,
 | 
			
		||||
	0x0a, 0x0c, 0x41, 0x75, 0x74, 0x68, 0x65, 0x6e, 0x74, 0x69, 0x63, 0x61, 0x74, 0x65, 0x12, 0x12,
 | 
			
		||||
	0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x41, 0x75, 0x74, 0x68, 0x52, 0x65, 0x71, 0x75, 0x65,
 | 
			
		||||
	0x73, 0x74, 0x1a, 0x10, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x41, 0x75, 0x74, 0x68, 0x52,
 | 
			
		||||
	0x65, 0x70, 0x6c, 0x79, 0x22, 0x00, 0x12, 0x3d, 0x0a, 0x09, 0x43, 0x68, 0x65, 0x63, 0x6b, 0x50,
 | 
			
		||||
	0x65, 0x72, 0x6d, 0x12, 0x17, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x43, 0x68, 0x65, 0x63,
 | 
			
		||||
	0x6b, 0x50, 0x65, 0x72, 0x6d, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x15, 0x2e, 0x70,
 | 
			
		||||
	0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x43, 0x68, 0x65, 0x63, 0x6b, 0x50, 0x65, 0x72, 0x6d, 0x52, 0x65,
 | 
			
		||||
	0x70, 0x6c, 0x79, 0x22, 0x00, 0x42, 0x09, 0x5a, 0x07, 0x2e, 0x3b, 0x70, 0x72, 0x6f, 0x74, 0x6f,
 | 
			
		||||
	0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33,
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var (
 | 
			
		||||
	file_auth_proto_rawDescOnce sync.Once
 | 
			
		||||
	file_auth_proto_rawDescData = file_auth_proto_rawDesc
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func file_auth_proto_rawDescGZIP() []byte {
 | 
			
		||||
	file_auth_proto_rawDescOnce.Do(func() {
 | 
			
		||||
		file_auth_proto_rawDescData = protoimpl.X.CompressGZIP(file_auth_proto_rawDescData)
 | 
			
		||||
	})
 | 
			
		||||
	return file_auth_proto_rawDescData
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var file_auth_proto_msgTypes = make([]protoimpl.MessageInfo, 5)
 | 
			
		||||
var file_auth_proto_goTypes = []interface{}{
 | 
			
		||||
	(*Userinfo)(nil),         // 0: proto.Userinfo
 | 
			
		||||
	(*AuthRequest)(nil),      // 1: proto.AuthRequest
 | 
			
		||||
	(*AuthReply)(nil),        // 2: proto.AuthReply
 | 
			
		||||
	(*CheckPermRequest)(nil), // 3: proto.CheckPermRequest
 | 
			
		||||
	(*CheckPermReply)(nil),   // 4: proto.CheckPermReply
 | 
			
		||||
}
 | 
			
		||||
var file_auth_proto_depIdxs = []int32{
 | 
			
		||||
	0, // 0: proto.AuthReply.userinfo:type_name -> proto.Userinfo
 | 
			
		||||
	1, // 1: proto.Auth.Authenticate:input_type -> proto.AuthRequest
 | 
			
		||||
	3, // 2: proto.Auth.CheckPerm:input_type -> proto.CheckPermRequest
 | 
			
		||||
	2, // 3: proto.Auth.Authenticate:output_type -> proto.AuthReply
 | 
			
		||||
	4, // 4: proto.Auth.CheckPerm:output_type -> proto.CheckPermReply
 | 
			
		||||
	3, // [3:5] is the sub-list for method output_type
 | 
			
		||||
	1, // [1:3] is the sub-list for method input_type
 | 
			
		||||
	1, // [1:1] is the sub-list for extension type_name
 | 
			
		||||
	1, // [1:1] is the sub-list for extension extendee
 | 
			
		||||
	0, // [0:1] is the sub-list for field type_name
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func init() { file_auth_proto_init() }
 | 
			
		||||
func file_auth_proto_init() {
 | 
			
		||||
	if File_auth_proto != nil {
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	if !protoimpl.UnsafeEnabled {
 | 
			
		||||
		file_auth_proto_msgTypes[0].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
			switch v := v.(*Userinfo); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
			case 1:
 | 
			
		||||
				return &v.sizeCache
 | 
			
		||||
			case 2:
 | 
			
		||||
				return &v.unknownFields
 | 
			
		||||
			default:
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_auth_proto_msgTypes[1].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
			switch v := v.(*AuthRequest); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
			case 1:
 | 
			
		||||
				return &v.sizeCache
 | 
			
		||||
			case 2:
 | 
			
		||||
				return &v.unknownFields
 | 
			
		||||
			default:
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_auth_proto_msgTypes[2].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
			switch v := v.(*AuthReply); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
			case 1:
 | 
			
		||||
				return &v.sizeCache
 | 
			
		||||
			case 2:
 | 
			
		||||
				return &v.unknownFields
 | 
			
		||||
			default:
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_auth_proto_msgTypes[3].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
			switch v := v.(*CheckPermRequest); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
			case 1:
 | 
			
		||||
				return &v.sizeCache
 | 
			
		||||
			case 2:
 | 
			
		||||
				return &v.unknownFields
 | 
			
		||||
			default:
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_auth_proto_msgTypes[4].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
			switch v := v.(*CheckPermReply); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
			case 1:
 | 
			
		||||
				return &v.sizeCache
 | 
			
		||||
			case 2:
 | 
			
		||||
				return &v.unknownFields
 | 
			
		||||
			default:
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	file_auth_proto_msgTypes[0].OneofWrappers = []interface{}{}
 | 
			
		||||
	file_auth_proto_msgTypes[1].OneofWrappers = []interface{}{}
 | 
			
		||||
	file_auth_proto_msgTypes[2].OneofWrappers = []interface{}{}
 | 
			
		||||
	type x struct{}
 | 
			
		||||
	out := protoimpl.TypeBuilder{
 | 
			
		||||
		File: protoimpl.DescBuilder{
 | 
			
		||||
			GoPackagePath: reflect.TypeOf(x{}).PkgPath(),
 | 
			
		||||
			RawDescriptor: file_auth_proto_rawDesc,
 | 
			
		||||
			NumEnums:      0,
 | 
			
		||||
			NumMessages:   5,
 | 
			
		||||
			NumExtensions: 0,
 | 
			
		||||
			NumServices:   1,
 | 
			
		||||
		},
 | 
			
		||||
		GoTypes:           file_auth_proto_goTypes,
 | 
			
		||||
		DependencyIndexes: file_auth_proto_depIdxs,
 | 
			
		||||
		MessageInfos:      file_auth_proto_msgTypes,
 | 
			
		||||
	}.Build()
 | 
			
		||||
	File_auth_proto = out.File
 | 
			
		||||
	file_auth_proto_rawDesc = nil
 | 
			
		||||
	file_auth_proto_goTypes = nil
 | 
			
		||||
	file_auth_proto_depIdxs = nil
 | 
			
		||||
}
 | 
			
		||||
@@ -1,44 +0,0 @@
 | 
			
		||||
syntax = "proto3";
 | 
			
		||||
 | 
			
		||||
option go_package = ".;proto";
 | 
			
		||||
 | 
			
		||||
package proto;
 | 
			
		||||
 | 
			
		||||
service Auth {
 | 
			
		||||
  rpc Authenticate(AuthRequest) returns (AuthReply) {}
 | 
			
		||||
  rpc CheckPerm(CheckPermRequest) returns (CheckPermReply) {}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
message Userinfo {
 | 
			
		||||
  uint64 id = 1;
 | 
			
		||||
  string name = 2;
 | 
			
		||||
  string nick = 3;
 | 
			
		||||
  string email = 4;
 | 
			
		||||
  string avatar = 5;
 | 
			
		||||
  string banner = 6;
 | 
			
		||||
  optional string description = 7;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
message AuthRequest {
 | 
			
		||||
  string access_token = 1;
 | 
			
		||||
  optional string refresh_token = 2;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
message AuthReply {
 | 
			
		||||
  bool is_valid = 1;
 | 
			
		||||
  optional string access_token = 2;
 | 
			
		||||
  optional string refresh_token = 3;
 | 
			
		||||
  optional Userinfo userinfo = 4;
 | 
			
		||||
  optional bytes permissions = 5;
 | 
			
		||||
  optional uint64 ticket_id = 6;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
message CheckPermRequest {
 | 
			
		||||
  string token = 1;
 | 
			
		||||
  string key = 2;
 | 
			
		||||
  bytes value = 3;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
message CheckPermReply {
 | 
			
		||||
  bool is_valid = 1;
 | 
			
		||||
}
 | 
			
		||||
@@ -1,146 +0,0 @@
 | 
			
		||||
// Code generated by protoc-gen-go-grpc. DO NOT EDIT.
 | 
			
		||||
// versions:
 | 
			
		||||
// - protoc-gen-go-grpc v1.3.0
 | 
			
		||||
// - protoc             v5.26.1
 | 
			
		||||
// source: auth.proto
 | 
			
		||||
 | 
			
		||||
package proto
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	context "context"
 | 
			
		||||
	grpc "google.golang.org/grpc"
 | 
			
		||||
	codes "google.golang.org/grpc/codes"
 | 
			
		||||
	status "google.golang.org/grpc/status"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// This is a compile-time assertion to ensure that this generated file
 | 
			
		||||
// is compatible with the grpc package it is being compiled against.
 | 
			
		||||
// Requires gRPC-Go v1.32.0 or later.
 | 
			
		||||
const _ = grpc.SupportPackageIsVersion7
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
	Auth_Authenticate_FullMethodName = "/proto.Auth/Authenticate"
 | 
			
		||||
	Auth_CheckPerm_FullMethodName    = "/proto.Auth/CheckPerm"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// AuthClient is the client API for Auth service.
 | 
			
		||||
//
 | 
			
		||||
// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://pkg.go.dev/google.golang.org/grpc/?tab=doc#ClientConn.NewStream.
 | 
			
		||||
type AuthClient interface {
 | 
			
		||||
	Authenticate(ctx context.Context, in *AuthRequest, opts ...grpc.CallOption) (*AuthReply, error)
 | 
			
		||||
	CheckPerm(ctx context.Context, in *CheckPermRequest, opts ...grpc.CallOption) (*CheckPermReply, error)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type authClient struct {
 | 
			
		||||
	cc grpc.ClientConnInterface
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func NewAuthClient(cc grpc.ClientConnInterface) AuthClient {
 | 
			
		||||
	return &authClient{cc}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *authClient) Authenticate(ctx context.Context, in *AuthRequest, opts ...grpc.CallOption) (*AuthReply, error) {
 | 
			
		||||
	out := new(AuthReply)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Auth_Authenticate_FullMethodName, in, out, opts...)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	return out, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *authClient) CheckPerm(ctx context.Context, in *CheckPermRequest, opts ...grpc.CallOption) (*CheckPermReply, error) {
 | 
			
		||||
	out := new(CheckPermReply)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Auth_CheckPerm_FullMethodName, in, out, opts...)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	return out, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// AuthServer is the server API for Auth service.
 | 
			
		||||
// All implementations must embed UnimplementedAuthServer
 | 
			
		||||
// for forward compatibility
 | 
			
		||||
type AuthServer interface {
 | 
			
		||||
	Authenticate(context.Context, *AuthRequest) (*AuthReply, error)
 | 
			
		||||
	CheckPerm(context.Context, *CheckPermRequest) (*CheckPermReply, error)
 | 
			
		||||
	mustEmbedUnimplementedAuthServer()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// UnimplementedAuthServer must be embedded to have forward compatible implementations.
 | 
			
		||||
type UnimplementedAuthServer struct {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (UnimplementedAuthServer) Authenticate(context.Context, *AuthRequest) (*AuthReply, error) {
 | 
			
		||||
	return nil, status.Errorf(codes.Unimplemented, "method Authenticate not implemented")
 | 
			
		||||
}
 | 
			
		||||
func (UnimplementedAuthServer) CheckPerm(context.Context, *CheckPermRequest) (*CheckPermReply, error) {
 | 
			
		||||
	return nil, status.Errorf(codes.Unimplemented, "method CheckPerm not implemented")
 | 
			
		||||
}
 | 
			
		||||
func (UnimplementedAuthServer) mustEmbedUnimplementedAuthServer() {}
 | 
			
		||||
 | 
			
		||||
// UnsafeAuthServer may be embedded to opt out of forward compatibility for this service.
 | 
			
		||||
// Use of this interface is not recommended, as added methods to AuthServer will
 | 
			
		||||
// result in compilation errors.
 | 
			
		||||
type UnsafeAuthServer interface {
 | 
			
		||||
	mustEmbedUnimplementedAuthServer()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func RegisterAuthServer(s grpc.ServiceRegistrar, srv AuthServer) {
 | 
			
		||||
	s.RegisterService(&Auth_ServiceDesc, srv)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func _Auth_Authenticate_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
 | 
			
		||||
	in := new(AuthRequest)
 | 
			
		||||
	if err := dec(in); err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if interceptor == nil {
 | 
			
		||||
		return srv.(AuthServer).Authenticate(ctx, in)
 | 
			
		||||
	}
 | 
			
		||||
	info := &grpc.UnaryServerInfo{
 | 
			
		||||
		Server:     srv,
 | 
			
		||||
		FullMethod: Auth_Authenticate_FullMethodName,
 | 
			
		||||
	}
 | 
			
		||||
	handler := func(ctx context.Context, req interface{}) (interface{}, error) {
 | 
			
		||||
		return srv.(AuthServer).Authenticate(ctx, req.(*AuthRequest))
 | 
			
		||||
	}
 | 
			
		||||
	return interceptor(ctx, in, info, handler)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func _Auth_CheckPerm_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
 | 
			
		||||
	in := new(CheckPermRequest)
 | 
			
		||||
	if err := dec(in); err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	if interceptor == nil {
 | 
			
		||||
		return srv.(AuthServer).CheckPerm(ctx, in)
 | 
			
		||||
	}
 | 
			
		||||
	info := &grpc.UnaryServerInfo{
 | 
			
		||||
		Server:     srv,
 | 
			
		||||
		FullMethod: Auth_CheckPerm_FullMethodName,
 | 
			
		||||
	}
 | 
			
		||||
	handler := func(ctx context.Context, req interface{}) (interface{}, error) {
 | 
			
		||||
		return srv.(AuthServer).CheckPerm(ctx, req.(*CheckPermRequest))
 | 
			
		||||
	}
 | 
			
		||||
	return interceptor(ctx, in, info, handler)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Auth_ServiceDesc is the grpc.ServiceDesc for Auth service.
 | 
			
		||||
// It's only intended for direct use with grpc.RegisterService,
 | 
			
		||||
// and not to be introspected or modified (even as a copy)
 | 
			
		||||
var Auth_ServiceDesc = grpc.ServiceDesc{
 | 
			
		||||
	ServiceName: "proto.Auth",
 | 
			
		||||
	HandlerType: (*AuthServer)(nil),
 | 
			
		||||
	Methods: []grpc.MethodDesc{
 | 
			
		||||
		{
 | 
			
		||||
			MethodName: "Authenticate",
 | 
			
		||||
			Handler:    _Auth_Authenticate_Handler,
 | 
			
		||||
		},
 | 
			
		||||
		{
 | 
			
		||||
			MethodName: "CheckPerm",
 | 
			
		||||
			Handler:    _Auth_CheckPerm_Handler,
 | 
			
		||||
		},
 | 
			
		||||
	},
 | 
			
		||||
	Streams:  []grpc.StreamDesc{},
 | 
			
		||||
	Metadata: "auth.proto",
 | 
			
		||||
}
 | 
			
		||||
@@ -1,7 +1,7 @@
 | 
			
		||||
// Code generated by protoc-gen-go. DO NOT EDIT.
 | 
			
		||||
// versions:
 | 
			
		||||
// 	protoc-gen-go v1.33.0
 | 
			
		||||
// 	protoc        v5.26.1
 | 
			
		||||
// 	protoc-gen-go v1.34.2
 | 
			
		||||
// 	protoc        v5.27.1
 | 
			
		||||
// source: friendships.proto
 | 
			
		||||
 | 
			
		||||
package proto
 | 
			
		||||
@@ -138,53 +138,6 @@ func (x *FriendshipTwoSideLookupRequest) GetStatus() uint32 {
 | 
			
		||||
	return 0
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type ListFriendshipResponse struct {
 | 
			
		||||
	state         protoimpl.MessageState
 | 
			
		||||
	sizeCache     protoimpl.SizeCache
 | 
			
		||||
	unknownFields protoimpl.UnknownFields
 | 
			
		||||
 | 
			
		||||
	Data []*FriendshipResponse `protobuf:"bytes,1,rep,name=data,proto3" json:"data,omitempty"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *ListFriendshipResponse) Reset() {
 | 
			
		||||
	*x = ListFriendshipResponse{}
 | 
			
		||||
	if protoimpl.UnsafeEnabled {
 | 
			
		||||
		mi := &file_friendships_proto_msgTypes[2]
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		ms.StoreMessageInfo(mi)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *ListFriendshipResponse) String() string {
 | 
			
		||||
	return protoimpl.X.MessageStringOf(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (*ListFriendshipResponse) ProtoMessage() {}
 | 
			
		||||
 | 
			
		||||
func (x *ListFriendshipResponse) ProtoReflect() protoreflect.Message {
 | 
			
		||||
	mi := &file_friendships_proto_msgTypes[2]
 | 
			
		||||
	if protoimpl.UnsafeEnabled && x != nil {
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		if ms.LoadMessageInfo() == nil {
 | 
			
		||||
			ms.StoreMessageInfo(mi)
 | 
			
		||||
		}
 | 
			
		||||
		return ms
 | 
			
		||||
	}
 | 
			
		||||
	return mi.MessageOf(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Deprecated: Use ListFriendshipResponse.ProtoReflect.Descriptor instead.
 | 
			
		||||
func (*ListFriendshipResponse) Descriptor() ([]byte, []int) {
 | 
			
		||||
	return file_friendships_proto_rawDescGZIP(), []int{2}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *ListFriendshipResponse) GetData() []*FriendshipResponse {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.Data
 | 
			
		||||
	}
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type FriendshipResponse struct {
 | 
			
		||||
	state         protoimpl.MessageState
 | 
			
		||||
	sizeCache     protoimpl.SizeCache
 | 
			
		||||
@@ -198,7 +151,7 @@ type FriendshipResponse struct {
 | 
			
		||||
func (x *FriendshipResponse) Reset() {
 | 
			
		||||
	*x = FriendshipResponse{}
 | 
			
		||||
	if protoimpl.UnsafeEnabled {
 | 
			
		||||
		mi := &file_friendships_proto_msgTypes[3]
 | 
			
		||||
		mi := &file_friendships_proto_msgTypes[2]
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		ms.StoreMessageInfo(mi)
 | 
			
		||||
	}
 | 
			
		||||
@@ -211,7 +164,7 @@ func (x *FriendshipResponse) String() string {
 | 
			
		||||
func (*FriendshipResponse) ProtoMessage() {}
 | 
			
		||||
 | 
			
		||||
func (x *FriendshipResponse) ProtoReflect() protoreflect.Message {
 | 
			
		||||
	mi := &file_friendships_proto_msgTypes[3]
 | 
			
		||||
	mi := &file_friendships_proto_msgTypes[2]
 | 
			
		||||
	if protoimpl.UnsafeEnabled && x != nil {
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		if ms.LoadMessageInfo() == nil {
 | 
			
		||||
@@ -224,7 +177,7 @@ func (x *FriendshipResponse) ProtoReflect() protoreflect.Message {
 | 
			
		||||
 | 
			
		||||
// Deprecated: Use FriendshipResponse.ProtoReflect.Descriptor instead.
 | 
			
		||||
func (*FriendshipResponse) Descriptor() ([]byte, []int) {
 | 
			
		||||
	return file_friendships_proto_rawDescGZIP(), []int{3}
 | 
			
		||||
	return file_friendships_proto_rawDescGZIP(), []int{2}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *FriendshipResponse) GetAccountId() uint64 {
 | 
			
		||||
@@ -248,6 +201,53 @@ func (x *FriendshipResponse) GetStatus() uint32 {
 | 
			
		||||
	return 0
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type ListFriendshipResponse struct {
 | 
			
		||||
	state         protoimpl.MessageState
 | 
			
		||||
	sizeCache     protoimpl.SizeCache
 | 
			
		||||
	unknownFields protoimpl.UnknownFields
 | 
			
		||||
 | 
			
		||||
	Data []*FriendshipResponse `protobuf:"bytes,1,rep,name=data,proto3" json:"data,omitempty"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *ListFriendshipResponse) Reset() {
 | 
			
		||||
	*x = ListFriendshipResponse{}
 | 
			
		||||
	if protoimpl.UnsafeEnabled {
 | 
			
		||||
		mi := &file_friendships_proto_msgTypes[3]
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		ms.StoreMessageInfo(mi)
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *ListFriendshipResponse) String() string {
 | 
			
		||||
	return protoimpl.X.MessageStringOf(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (*ListFriendshipResponse) ProtoMessage() {}
 | 
			
		||||
 | 
			
		||||
func (x *ListFriendshipResponse) ProtoReflect() protoreflect.Message {
 | 
			
		||||
	mi := &file_friendships_proto_msgTypes[3]
 | 
			
		||||
	if protoimpl.UnsafeEnabled && x != nil {
 | 
			
		||||
		ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
 | 
			
		||||
		if ms.LoadMessageInfo() == nil {
 | 
			
		||||
			ms.StoreMessageInfo(mi)
 | 
			
		||||
		}
 | 
			
		||||
		return ms
 | 
			
		||||
	}
 | 
			
		||||
	return mi.MessageOf(x)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Deprecated: Use ListFriendshipResponse.ProtoReflect.Descriptor instead.
 | 
			
		||||
func (*ListFriendshipResponse) Descriptor() ([]byte, []int) {
 | 
			
		||||
	return file_friendships_proto_rawDescGZIP(), []int{3}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (x *ListFriendshipResponse) GetData() []*FriendshipResponse {
 | 
			
		||||
	if x != nil {
 | 
			
		||||
		return x.Data
 | 
			
		||||
	}
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var File_friendships_proto protoreflect.FileDescriptor
 | 
			
		||||
 | 
			
		||||
var file_friendships_proto_rawDesc = []byte{
 | 
			
		||||
@@ -265,18 +265,18 @@ var file_friendships_proto_rawDesc = []byte{
 | 
			
		||||
	0x0a, 0x72, 0x65, 0x6c, 0x61, 0x74, 0x65, 0x64, 0x5f, 0x69, 0x64, 0x18, 0x02, 0x20, 0x01, 0x28,
 | 
			
		||||
	0x04, 0x52, 0x09, 0x72, 0x65, 0x6c, 0x61, 0x74, 0x65, 0x64, 0x49, 0x64, 0x12, 0x16, 0x0a, 0x06,
 | 
			
		||||
	0x73, 0x74, 0x61, 0x74, 0x75, 0x73, 0x18, 0x03, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x06, 0x73, 0x74,
 | 
			
		||||
	0x61, 0x74, 0x75, 0x73, 0x22, 0x47, 0x0a, 0x16, 0x4c, 0x69, 0x73, 0x74, 0x46, 0x72, 0x69, 0x65,
 | 
			
		||||
	0x6e, 0x64, 0x73, 0x68, 0x69, 0x70, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x2d,
 | 
			
		||||
	0x0a, 0x04, 0x64, 0x61, 0x74, 0x61, 0x18, 0x01, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x19, 0x2e, 0x70,
 | 
			
		||||
	0x72, 0x6f, 0x74, 0x6f, 0x2e, 0x46, 0x72, 0x69, 0x65, 0x6e, 0x64, 0x73, 0x68, 0x69, 0x70, 0x52,
 | 
			
		||||
	0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x52, 0x04, 0x64, 0x61, 0x74, 0x61, 0x22, 0x6a, 0x0a,
 | 
			
		||||
	0x12, 0x46, 0x72, 0x69, 0x65, 0x6e, 0x64, 0x73, 0x68, 0x69, 0x70, 0x52, 0x65, 0x73, 0x70, 0x6f,
 | 
			
		||||
	0x6e, 0x73, 0x65, 0x12, 0x1d, 0x0a, 0x0a, 0x61, 0x63, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x5f, 0x69,
 | 
			
		||||
	0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x04, 0x52, 0x09, 0x61, 0x63, 0x63, 0x6f, 0x75, 0x6e, 0x74,
 | 
			
		||||
	0x49, 0x64, 0x12, 0x1d, 0x0a, 0x0a, 0x72, 0x65, 0x6c, 0x61, 0x74, 0x65, 0x64, 0x5f, 0x69, 0x64,
 | 
			
		||||
	0x18, 0x02, 0x20, 0x01, 0x28, 0x04, 0x52, 0x09, 0x72, 0x65, 0x6c, 0x61, 0x74, 0x65, 0x64, 0x49,
 | 
			
		||||
	0x64, 0x12, 0x16, 0x0a, 0x06, 0x73, 0x74, 0x61, 0x74, 0x75, 0x73, 0x18, 0x03, 0x20, 0x01, 0x28,
 | 
			
		||||
	0x0d, 0x52, 0x06, 0x73, 0x74, 0x61, 0x74, 0x75, 0x73, 0x32, 0xb5, 0x01, 0x0a, 0x0b, 0x46, 0x72,
 | 
			
		||||
	0x61, 0x74, 0x75, 0x73, 0x22, 0x6a, 0x0a, 0x12, 0x46, 0x72, 0x69, 0x65, 0x6e, 0x64, 0x73, 0x68,
 | 
			
		||||
	0x69, 0x70, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x1d, 0x0a, 0x0a, 0x61, 0x63,
 | 
			
		||||
	0x63, 0x6f, 0x75, 0x6e, 0x74, 0x5f, 0x69, 0x64, 0x18, 0x01, 0x20, 0x01, 0x28, 0x04, 0x52, 0x09,
 | 
			
		||||
	0x61, 0x63, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x49, 0x64, 0x12, 0x1d, 0x0a, 0x0a, 0x72, 0x65, 0x6c,
 | 
			
		||||
	0x61, 0x74, 0x65, 0x64, 0x5f, 0x69, 0x64, 0x18, 0x02, 0x20, 0x01, 0x28, 0x04, 0x52, 0x09, 0x72,
 | 
			
		||||
	0x65, 0x6c, 0x61, 0x74, 0x65, 0x64, 0x49, 0x64, 0x12, 0x16, 0x0a, 0x06, 0x73, 0x74, 0x61, 0x74,
 | 
			
		||||
	0x75, 0x73, 0x18, 0x03, 0x20, 0x01, 0x28, 0x0d, 0x52, 0x06, 0x73, 0x74, 0x61, 0x74, 0x75, 0x73,
 | 
			
		||||
	0x22, 0x47, 0x0a, 0x16, 0x4c, 0x69, 0x73, 0x74, 0x46, 0x72, 0x69, 0x65, 0x6e, 0x64, 0x73, 0x68,
 | 
			
		||||
	0x69, 0x70, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x2d, 0x0a, 0x04, 0x64, 0x61,
 | 
			
		||||
	0x74, 0x61, 0x18, 0x01, 0x20, 0x03, 0x28, 0x0b, 0x32, 0x19, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f,
 | 
			
		||||
	0x2e, 0x46, 0x72, 0x69, 0x65, 0x6e, 0x64, 0x73, 0x68, 0x69, 0x70, 0x52, 0x65, 0x73, 0x70, 0x6f,
 | 
			
		||||
	0x6e, 0x73, 0x65, 0x52, 0x04, 0x64, 0x61, 0x74, 0x61, 0x32, 0xb5, 0x01, 0x0a, 0x0b, 0x46, 0x72,
 | 
			
		||||
	0x69, 0x65, 0x6e, 0x64, 0x73, 0x68, 0x69, 0x70, 0x73, 0x12, 0x51, 0x0a, 0x0e, 0x4c, 0x69, 0x73,
 | 
			
		||||
	0x74, 0x46, 0x72, 0x69, 0x65, 0x6e, 0x64, 0x73, 0x68, 0x69, 0x70, 0x12, 0x1e, 0x2e, 0x70, 0x72,
 | 
			
		||||
	0x6f, 0x74, 0x6f, 0x2e, 0x46, 0x72, 0x69, 0x65, 0x6e, 0x64, 0x73, 0x68, 0x69, 0x70, 0x4c, 0x6f,
 | 
			
		||||
@@ -305,18 +305,18 @@ func file_friendships_proto_rawDescGZIP() []byte {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var file_friendships_proto_msgTypes = make([]protoimpl.MessageInfo, 4)
 | 
			
		||||
var file_friendships_proto_goTypes = []interface{}{
 | 
			
		||||
var file_friendships_proto_goTypes = []any{
 | 
			
		||||
	(*FriendshipLookupRequest)(nil),        // 0: proto.FriendshipLookupRequest
 | 
			
		||||
	(*FriendshipTwoSideLookupRequest)(nil), // 1: proto.FriendshipTwoSideLookupRequest
 | 
			
		||||
	(*ListFriendshipResponse)(nil),         // 2: proto.ListFriendshipResponse
 | 
			
		||||
	(*FriendshipResponse)(nil),             // 3: proto.FriendshipResponse
 | 
			
		||||
	(*FriendshipResponse)(nil),             // 2: proto.FriendshipResponse
 | 
			
		||||
	(*ListFriendshipResponse)(nil),         // 3: proto.ListFriendshipResponse
 | 
			
		||||
}
 | 
			
		||||
var file_friendships_proto_depIdxs = []int32{
 | 
			
		||||
	3, // 0: proto.ListFriendshipResponse.data:type_name -> proto.FriendshipResponse
 | 
			
		||||
	2, // 0: proto.ListFriendshipResponse.data:type_name -> proto.FriendshipResponse
 | 
			
		||||
	0, // 1: proto.Friendships.ListFriendship:input_type -> proto.FriendshipLookupRequest
 | 
			
		||||
	1, // 2: proto.Friendships.GetFriendship:input_type -> proto.FriendshipTwoSideLookupRequest
 | 
			
		||||
	2, // 3: proto.Friendships.ListFriendship:output_type -> proto.ListFriendshipResponse
 | 
			
		||||
	3, // 4: proto.Friendships.GetFriendship:output_type -> proto.FriendshipResponse
 | 
			
		||||
	3, // 3: proto.Friendships.ListFriendship:output_type -> proto.ListFriendshipResponse
 | 
			
		||||
	2, // 4: proto.Friendships.GetFriendship:output_type -> proto.FriendshipResponse
 | 
			
		||||
	3, // [3:5] is the sub-list for method output_type
 | 
			
		||||
	1, // [1:3] is the sub-list for method input_type
 | 
			
		||||
	1, // [1:1] is the sub-list for extension type_name
 | 
			
		||||
@@ -330,7 +330,7 @@ func file_friendships_proto_init() {
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	if !protoimpl.UnsafeEnabled {
 | 
			
		||||
		file_friendships_proto_msgTypes[0].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
		file_friendships_proto_msgTypes[0].Exporter = func(v any, i int) any {
 | 
			
		||||
			switch v := v.(*FriendshipLookupRequest); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
@@ -342,7 +342,7 @@ func file_friendships_proto_init() {
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_friendships_proto_msgTypes[1].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
		file_friendships_proto_msgTypes[1].Exporter = func(v any, i int) any {
 | 
			
		||||
			switch v := v.(*FriendshipTwoSideLookupRequest); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
@@ -354,8 +354,8 @@ func file_friendships_proto_init() {
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_friendships_proto_msgTypes[2].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
			switch v := v.(*ListFriendshipResponse); i {
 | 
			
		||||
		file_friendships_proto_msgTypes[2].Exporter = func(v any, i int) any {
 | 
			
		||||
			switch v := v.(*FriendshipResponse); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
			case 1:
 | 
			
		||||
@@ -366,8 +366,8 @@ func file_friendships_proto_init() {
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_friendships_proto_msgTypes[3].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
			switch v := v.(*FriendshipResponse); i {
 | 
			
		||||
		file_friendships_proto_msgTypes[3].Exporter = func(v any, i int) any {
 | 
			
		||||
			switch v := v.(*ListFriendshipResponse); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
			case 1:
 | 
			
		||||
 
 | 
			
		||||
@@ -1,7 +1,7 @@
 | 
			
		||||
// Code generated by protoc-gen-go-grpc. DO NOT EDIT.
 | 
			
		||||
// versions:
 | 
			
		||||
// - protoc-gen-go-grpc v1.3.0
 | 
			
		||||
// - protoc             v5.26.1
 | 
			
		||||
// - protoc-gen-go-grpc v1.4.0
 | 
			
		||||
// - protoc             v5.27.1
 | 
			
		||||
// source: friendships.proto
 | 
			
		||||
 | 
			
		||||
package proto
 | 
			
		||||
@@ -15,8 +15,8 @@ import (
 | 
			
		||||
 | 
			
		||||
// This is a compile-time assertion to ensure that this generated file
 | 
			
		||||
// is compatible with the grpc package it is being compiled against.
 | 
			
		||||
// Requires gRPC-Go v1.32.0 or later.
 | 
			
		||||
const _ = grpc.SupportPackageIsVersion7
 | 
			
		||||
// Requires gRPC-Go v1.62.0 or later.
 | 
			
		||||
const _ = grpc.SupportPackageIsVersion8
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
	Friendships_ListFriendship_FullMethodName = "/proto.Friendships/ListFriendship"
 | 
			
		||||
@@ -40,8 +40,9 @@ func NewFriendshipsClient(cc grpc.ClientConnInterface) FriendshipsClient {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *friendshipsClient) ListFriendship(ctx context.Context, in *FriendshipLookupRequest, opts ...grpc.CallOption) (*ListFriendshipResponse, error) {
 | 
			
		||||
	cOpts := append([]grpc.CallOption{grpc.StaticMethod()}, opts...)
 | 
			
		||||
	out := new(ListFriendshipResponse)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Friendships_ListFriendship_FullMethodName, in, out, opts...)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Friendships_ListFriendship_FullMethodName, in, out, cOpts...)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
@@ -49,8 +50,9 @@ func (c *friendshipsClient) ListFriendship(ctx context.Context, in *FriendshipLo
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *friendshipsClient) GetFriendship(ctx context.Context, in *FriendshipTwoSideLookupRequest, opts ...grpc.CallOption) (*FriendshipResponse, error) {
 | 
			
		||||
	cOpts := append([]grpc.CallOption{grpc.StaticMethod()}, opts...)
 | 
			
		||||
	out := new(FriendshipResponse)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Friendships_GetFriendship_FullMethodName, in, out, opts...)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Friendships_GetFriendship_FullMethodName, in, out, cOpts...)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,7 +1,7 @@
 | 
			
		||||
// Code generated by protoc-gen-go. DO NOT EDIT.
 | 
			
		||||
// versions:
 | 
			
		||||
// 	protoc-gen-go v1.33.0
 | 
			
		||||
// 	protoc        v5.26.1
 | 
			
		||||
// 	protoc-gen-go v1.34.2
 | 
			
		||||
// 	protoc        v5.27.1
 | 
			
		||||
// source: notify.proto
 | 
			
		||||
 | 
			
		||||
package proto
 | 
			
		||||
@@ -293,7 +293,7 @@ func file_notify_proto_rawDescGZIP() []byte {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var file_notify_proto_msgTypes = make([]protoimpl.MessageInfo, 3)
 | 
			
		||||
var file_notify_proto_goTypes = []interface{}{
 | 
			
		||||
var file_notify_proto_goTypes = []any{
 | 
			
		||||
	(*NotifyLink)(nil),    // 0: proto.NotifyLink
 | 
			
		||||
	(*NotifyRequest)(nil), // 1: proto.NotifyRequest
 | 
			
		||||
	(*NotifyReply)(nil),   // 2: proto.NotifyReply
 | 
			
		||||
@@ -315,7 +315,7 @@ func file_notify_proto_init() {
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	if !protoimpl.UnsafeEnabled {
 | 
			
		||||
		file_notify_proto_msgTypes[0].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
		file_notify_proto_msgTypes[0].Exporter = func(v any, i int) any {
 | 
			
		||||
			switch v := v.(*NotifyLink); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
@@ -327,7 +327,7 @@ func file_notify_proto_init() {
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_notify_proto_msgTypes[1].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
		file_notify_proto_msgTypes[1].Exporter = func(v any, i int) any {
 | 
			
		||||
			switch v := v.(*NotifyRequest); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
@@ -339,7 +339,7 @@ func file_notify_proto_init() {
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_notify_proto_msgTypes[2].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
		file_notify_proto_msgTypes[2].Exporter = func(v any, i int) any {
 | 
			
		||||
			switch v := v.(*NotifyReply); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
 
 | 
			
		||||
@@ -1,7 +1,7 @@
 | 
			
		||||
// Code generated by protoc-gen-go-grpc. DO NOT EDIT.
 | 
			
		||||
// versions:
 | 
			
		||||
// - protoc-gen-go-grpc v1.3.0
 | 
			
		||||
// - protoc             v5.26.1
 | 
			
		||||
// - protoc-gen-go-grpc v1.4.0
 | 
			
		||||
// - protoc             v5.27.1
 | 
			
		||||
// source: notify.proto
 | 
			
		||||
 | 
			
		||||
package proto
 | 
			
		||||
@@ -15,8 +15,8 @@ import (
 | 
			
		||||
 | 
			
		||||
// This is a compile-time assertion to ensure that this generated file
 | 
			
		||||
// is compatible with the grpc package it is being compiled against.
 | 
			
		||||
// Requires gRPC-Go v1.32.0 or later.
 | 
			
		||||
const _ = grpc.SupportPackageIsVersion7
 | 
			
		||||
// Requires gRPC-Go v1.62.0 or later.
 | 
			
		||||
const _ = grpc.SupportPackageIsVersion8
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
	Notify_NotifyUser_FullMethodName = "/proto.Notify/NotifyUser"
 | 
			
		||||
@@ -38,8 +38,9 @@ func NewNotifyClient(cc grpc.ClientConnInterface) NotifyClient {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *notifyClient) NotifyUser(ctx context.Context, in *NotifyRequest, opts ...grpc.CallOption) (*NotifyReply, error) {
 | 
			
		||||
	cOpts := append([]grpc.CallOption{grpc.StaticMethod()}, opts...)
 | 
			
		||||
	out := new(NotifyReply)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Notify_NotifyUser_FullMethodName, in, out, opts...)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Notify_NotifyUser_FullMethodName, in, out, cOpts...)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,7 +1,7 @@
 | 
			
		||||
// Code generated by protoc-gen-go. DO NOT EDIT.
 | 
			
		||||
// versions:
 | 
			
		||||
// 	protoc-gen-go v1.33.0
 | 
			
		||||
// 	protoc        v5.26.1
 | 
			
		||||
// 	protoc-gen-go v1.34.2
 | 
			
		||||
// 	protoc        v5.27.1
 | 
			
		||||
// source: realms.proto
 | 
			
		||||
 | 
			
		||||
package proto
 | 
			
		||||
@@ -539,7 +539,7 @@ func file_realms_proto_rawDescGZIP() []byte {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var file_realms_proto_msgTypes = make([]protoimpl.MessageInfo, 7)
 | 
			
		||||
var file_realms_proto_goTypes = []interface{}{
 | 
			
		||||
var file_realms_proto_goTypes = []any{
 | 
			
		||||
	(*RealmLookupWithUserRequest)(nil), // 0: proto.RealmLookupWithUserRequest
 | 
			
		||||
	(*RealmLookupRequest)(nil),         // 1: proto.RealmLookupRequest
 | 
			
		||||
	(*RealmResponse)(nil),              // 2: proto.RealmResponse
 | 
			
		||||
@@ -577,7 +577,7 @@ func file_realms_proto_init() {
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	if !protoimpl.UnsafeEnabled {
 | 
			
		||||
		file_realms_proto_msgTypes[0].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
		file_realms_proto_msgTypes[0].Exporter = func(v any, i int) any {
 | 
			
		||||
			switch v := v.(*RealmLookupWithUserRequest); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
@@ -589,7 +589,7 @@ func file_realms_proto_init() {
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_realms_proto_msgTypes[1].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
		file_realms_proto_msgTypes[1].Exporter = func(v any, i int) any {
 | 
			
		||||
			switch v := v.(*RealmLookupRequest); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
@@ -601,7 +601,7 @@ func file_realms_proto_init() {
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_realms_proto_msgTypes[2].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
		file_realms_proto_msgTypes[2].Exporter = func(v any, i int) any {
 | 
			
		||||
			switch v := v.(*RealmResponse); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
@@ -613,7 +613,7 @@ func file_realms_proto_init() {
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_realms_proto_msgTypes[3].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
		file_realms_proto_msgTypes[3].Exporter = func(v any, i int) any {
 | 
			
		||||
			switch v := v.(*ListRealmResponse); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
@@ -625,7 +625,7 @@ func file_realms_proto_init() {
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_realms_proto_msgTypes[4].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
		file_realms_proto_msgTypes[4].Exporter = func(v any, i int) any {
 | 
			
		||||
			switch v := v.(*RealmMemberLookupRequest); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
@@ -637,7 +637,7 @@ func file_realms_proto_init() {
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_realms_proto_msgTypes[5].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
		file_realms_proto_msgTypes[5].Exporter = func(v any, i int) any {
 | 
			
		||||
			switch v := v.(*RealmMemberResponse); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
@@ -649,7 +649,7 @@ func file_realms_proto_init() {
 | 
			
		||||
				return nil
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		file_realms_proto_msgTypes[6].Exporter = func(v interface{}, i int) interface{} {
 | 
			
		||||
		file_realms_proto_msgTypes[6].Exporter = func(v any, i int) any {
 | 
			
		||||
			switch v := v.(*ListRealmMemberResponse); i {
 | 
			
		||||
			case 0:
 | 
			
		||||
				return &v.state
 | 
			
		||||
@@ -662,8 +662,8 @@ func file_realms_proto_init() {
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	file_realms_proto_msgTypes[1].OneofWrappers = []interface{}{}
 | 
			
		||||
	file_realms_proto_msgTypes[4].OneofWrappers = []interface{}{}
 | 
			
		||||
	file_realms_proto_msgTypes[1].OneofWrappers = []any{}
 | 
			
		||||
	file_realms_proto_msgTypes[4].OneofWrappers = []any{}
 | 
			
		||||
	type x struct{}
 | 
			
		||||
	out := protoimpl.TypeBuilder{
 | 
			
		||||
		File: protoimpl.DescBuilder{
 | 
			
		||||
 
 | 
			
		||||
@@ -1,7 +1,7 @@
 | 
			
		||||
// Code generated by protoc-gen-go-grpc. DO NOT EDIT.
 | 
			
		||||
// versions:
 | 
			
		||||
// - protoc-gen-go-grpc v1.3.0
 | 
			
		||||
// - protoc             v5.26.1
 | 
			
		||||
// - protoc-gen-go-grpc v1.4.0
 | 
			
		||||
// - protoc             v5.27.1
 | 
			
		||||
// source: realms.proto
 | 
			
		||||
 | 
			
		||||
package proto
 | 
			
		||||
@@ -16,8 +16,8 @@ import (
 | 
			
		||||
 | 
			
		||||
// This is a compile-time assertion to ensure that this generated file
 | 
			
		||||
// is compatible with the grpc package it is being compiled against.
 | 
			
		||||
// Requires gRPC-Go v1.32.0 or later.
 | 
			
		||||
const _ = grpc.SupportPackageIsVersion7
 | 
			
		||||
// Requires gRPC-Go v1.62.0 or later.
 | 
			
		||||
const _ = grpc.SupportPackageIsVersion8
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
	Realms_ListCommunityRealm_FullMethodName = "/proto.Realms/ListCommunityRealm"
 | 
			
		||||
@@ -49,8 +49,9 @@ func NewRealmsClient(cc grpc.ClientConnInterface) RealmsClient {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *realmsClient) ListCommunityRealm(ctx context.Context, in *emptypb.Empty, opts ...grpc.CallOption) (*ListRealmResponse, error) {
 | 
			
		||||
	cOpts := append([]grpc.CallOption{grpc.StaticMethod()}, opts...)
 | 
			
		||||
	out := new(ListRealmResponse)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Realms_ListCommunityRealm_FullMethodName, in, out, opts...)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Realms_ListCommunityRealm_FullMethodName, in, out, cOpts...)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
@@ -58,8 +59,9 @@ func (c *realmsClient) ListCommunityRealm(ctx context.Context, in *emptypb.Empty
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *realmsClient) ListAvailableRealm(ctx context.Context, in *RealmLookupWithUserRequest, opts ...grpc.CallOption) (*ListRealmResponse, error) {
 | 
			
		||||
	cOpts := append([]grpc.CallOption{grpc.StaticMethod()}, opts...)
 | 
			
		||||
	out := new(ListRealmResponse)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Realms_ListAvailableRealm_FullMethodName, in, out, opts...)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Realms_ListAvailableRealm_FullMethodName, in, out, cOpts...)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
@@ -67,8 +69,9 @@ func (c *realmsClient) ListAvailableRealm(ctx context.Context, in *RealmLookupWi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *realmsClient) ListOwnedRealm(ctx context.Context, in *RealmLookupWithUserRequest, opts ...grpc.CallOption) (*ListRealmResponse, error) {
 | 
			
		||||
	cOpts := append([]grpc.CallOption{grpc.StaticMethod()}, opts...)
 | 
			
		||||
	out := new(ListRealmResponse)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Realms_ListOwnedRealm_FullMethodName, in, out, opts...)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Realms_ListOwnedRealm_FullMethodName, in, out, cOpts...)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
@@ -76,8 +79,9 @@ func (c *realmsClient) ListOwnedRealm(ctx context.Context, in *RealmLookupWithUs
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *realmsClient) GetRealm(ctx context.Context, in *RealmLookupRequest, opts ...grpc.CallOption) (*RealmResponse, error) {
 | 
			
		||||
	cOpts := append([]grpc.CallOption{grpc.StaticMethod()}, opts...)
 | 
			
		||||
	out := new(RealmResponse)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Realms_GetRealm_FullMethodName, in, out, opts...)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Realms_GetRealm_FullMethodName, in, out, cOpts...)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
@@ -85,8 +89,9 @@ func (c *realmsClient) GetRealm(ctx context.Context, in *RealmLookupRequest, opt
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *realmsClient) ListRealmMember(ctx context.Context, in *RealmMemberLookupRequest, opts ...grpc.CallOption) (*ListRealmMemberResponse, error) {
 | 
			
		||||
	cOpts := append([]grpc.CallOption{grpc.StaticMethod()}, opts...)
 | 
			
		||||
	out := new(ListRealmMemberResponse)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Realms_ListRealmMember_FullMethodName, in, out, opts...)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Realms_ListRealmMember_FullMethodName, in, out, cOpts...)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
@@ -94,8 +99,9 @@ func (c *realmsClient) ListRealmMember(ctx context.Context, in *RealmMemberLooku
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (c *realmsClient) GetRealmMember(ctx context.Context, in *RealmMemberLookupRequest, opts ...grpc.CallOption) (*RealmMemberResponse, error) {
 | 
			
		||||
	cOpts := append([]grpc.CallOption{grpc.StaticMethod()}, opts...)
 | 
			
		||||
	out := new(RealmMemberResponse)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Realms_GetRealmMember_FullMethodName, in, out, opts...)
 | 
			
		||||
	err := c.cc.Invoke(ctx, Realms_GetRealmMember_FullMethodName, in, out, cOpts...)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 
 | 
			
		||||
@@ -22,8 +22,8 @@ use_registration_magic_token = false
 | 
			
		||||
database = false
 | 
			
		||||
print_routes = false
 | 
			
		||||
 | 
			
		||||
[consul]
 | 
			
		||||
addr = "127.0.0.1:8500"
 | 
			
		||||
[dealer]
 | 
			
		||||
addr = "127.0.0.1:7442"
 | 
			
		||||
 | 
			
		||||
[mailer]
 | 
			
		||||
name = "Alphabot <alphabot@smartsheep.studio>"
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user