mirror of
https://github.com/openziti/zrok.git
synced 2025-01-22 13:58:49 +01:00
Merge branch 'main' of github.com:openziti/zrok into oauth-email-change
This commit is contained in:
commit
53fd2e349e
@ -6,6 +6,10 @@ FEATURE: Public share oauth email domains renamed to `email address patterns`. T
|
||||
Old `zrok share` and `zrok reserve` flag: `oauth-email-domains`.
|
||||
Changed to: `oauth-email-address-patterns`.
|
||||
|
||||
CHANGE: Creating a reserved share checks for token collision and returns a more appropriate error message (https://github.com/openziti/zrok/issues/531)
|
||||
|
||||
CHANGE: Update UI to add a 'true' value on `reserved` boolean (https://github.com/openziti/zrok/issues/443)
|
||||
|
||||
## v0.4.24
|
||||
|
||||
FEATURE: New `socks` backend mode for use with private sharing. Use `zrok share private --backend-mode socks` and then `zrok access private` that share from somewhere else... very lightweight VPN-like functionality (https://github.com/openziti/zrok/issues/558)
|
||||
|
@ -135,6 +135,16 @@ func (h *shareHandler) Handle(params share.ShareParams, principal *rest_model_zr
|
||||
sshr.FrontendEndpoint = &sshr.ShareMode
|
||||
}
|
||||
|
||||
sh, err := str.FindShareWithToken(sshr.Token, trx)
|
||||
if err != nil {
|
||||
logrus.Errorf("error checking share for token collision: %v", err)
|
||||
return share.NewShareInternalServerError()
|
||||
}
|
||||
if sh != nil {
|
||||
logrus.Errorf("token '%v' already exists; cannot create share", sshr.Token)
|
||||
return share.NewShareConflict()
|
||||
}
|
||||
|
||||
sid, err := str.CreateShare(envId, sshr, trx)
|
||||
if err != nil {
|
||||
logrus.Errorf("error creating share record: %v", err)
|
||||
|
@ -41,6 +41,12 @@ func (o *ShareReader) ReadResponse(response runtime.ClientResponse, consumer run
|
||||
return nil, err
|
||||
}
|
||||
return nil, result
|
||||
case 409:
|
||||
result := NewShareConflict()
|
||||
if err := result.readResponse(response, consumer, o.formats); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return nil, result
|
||||
case 422:
|
||||
result := NewShareUnprocessableEntity()
|
||||
if err := result.readResponse(response, consumer, o.formats); err != nil {
|
||||
@ -238,6 +244,62 @@ func (o *ShareNotFound) readResponse(response runtime.ClientResponse, consumer r
|
||||
return nil
|
||||
}
|
||||
|
||||
// NewShareConflict creates a ShareConflict with default headers values
|
||||
func NewShareConflict() *ShareConflict {
|
||||
return &ShareConflict{}
|
||||
}
|
||||
|
||||
/*
|
||||
ShareConflict describes a response with status code 409, with default header values.
|
||||
|
||||
conflict
|
||||
*/
|
||||
type ShareConflict struct {
|
||||
}
|
||||
|
||||
// IsSuccess returns true when this share conflict response has a 2xx status code
|
||||
func (o *ShareConflict) IsSuccess() bool {
|
||||
return false
|
||||
}
|
||||
|
||||
// IsRedirect returns true when this share conflict response has a 3xx status code
|
||||
func (o *ShareConflict) IsRedirect() bool {
|
||||
return false
|
||||
}
|
||||
|
||||
// IsClientError returns true when this share conflict response has a 4xx status code
|
||||
func (o *ShareConflict) IsClientError() bool {
|
||||
return true
|
||||
}
|
||||
|
||||
// IsServerError returns true when this share conflict response has a 5xx status code
|
||||
func (o *ShareConflict) IsServerError() bool {
|
||||
return false
|
||||
}
|
||||
|
||||
// IsCode returns true when this share conflict response a status code equal to that given
|
||||
func (o *ShareConflict) IsCode(code int) bool {
|
||||
return code == 409
|
||||
}
|
||||
|
||||
// Code gets the status code for the share conflict response
|
||||
func (o *ShareConflict) Code() int {
|
||||
return 409
|
||||
}
|
||||
|
||||
func (o *ShareConflict) Error() string {
|
||||
return fmt.Sprintf("[POST /share][%d] shareConflict ", 409)
|
||||
}
|
||||
|
||||
func (o *ShareConflict) String() string {
|
||||
return fmt.Sprintf("[POST /share][%d] shareConflict ", 409)
|
||||
}
|
||||
|
||||
func (o *ShareConflict) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error {
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
// NewShareUnprocessableEntity creates a ShareUnprocessableEntity with default headers values
|
||||
func NewShareUnprocessableEntity() *ShareUnprocessableEntity {
|
||||
return &ShareUnprocessableEntity{}
|
||||
|
@ -865,6 +865,9 @@ func init() {
|
||||
"404": {
|
||||
"description": "not found"
|
||||
},
|
||||
"409": {
|
||||
"description": "conflict"
|
||||
},
|
||||
"422": {
|
||||
"description": "unprocessable"
|
||||
},
|
||||
@ -2489,6 +2492,9 @@ func init() {
|
||||
"404": {
|
||||
"description": "not found"
|
||||
},
|
||||
"409": {
|
||||
"description": "conflict"
|
||||
},
|
||||
"422": {
|
||||
"description": "unprocessable"
|
||||
},
|
||||
|
@ -108,6 +108,31 @@ func (o *ShareNotFound) WriteResponse(rw http.ResponseWriter, producer runtime.P
|
||||
rw.WriteHeader(404)
|
||||
}
|
||||
|
||||
// ShareConflictCode is the HTTP code returned for type ShareConflict
|
||||
const ShareConflictCode int = 409
|
||||
|
||||
/*
|
||||
ShareConflict conflict
|
||||
|
||||
swagger:response shareConflict
|
||||
*/
|
||||
type ShareConflict struct {
|
||||
}
|
||||
|
||||
// NewShareConflict creates ShareConflict with default headers values
|
||||
func NewShareConflict() *ShareConflict {
|
||||
|
||||
return &ShareConflict{}
|
||||
}
|
||||
|
||||
// WriteResponse to the client
|
||||
func (o *ShareConflict) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) {
|
||||
|
||||
rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses
|
||||
|
||||
rw.WriteHeader(409)
|
||||
}
|
||||
|
||||
// ShareUnprocessableEntityCode is the HTTP code returned for type ShareUnprocessableEntity
|
||||
const ShareUnprocessableEntityCode int = 422
|
||||
|
||||
|
@ -577,6 +577,8 @@ paths:
|
||||
description: unauthorized
|
||||
404:
|
||||
description: not found
|
||||
409:
|
||||
description: conflict
|
||||
422:
|
||||
description: unprocessable
|
||||
500:
|
||||
|
@ -18,7 +18,7 @@ const rowToValue = (row) => {
|
||||
if(row.property.endsWith("At")) {
|
||||
return new Date(row.value).toLocaleString();
|
||||
}
|
||||
return row.value;
|
||||
return row.value.toString();
|
||||
};
|
||||
|
||||
const PropertyTable = (props) => {
|
||||
|
Loading…
Reference in New Issue
Block a user