[][src]Struct openssl::ec::EcPoint

pub struct EcPoint(_);

Represents a point on the curve

OpenSSL documentation at EC_POINT_new

Implementations

impl EcPoint[src]

pub fn new(group: &EcGroupRef) -> Result<EcPoint, ErrorStack>[src]

Creates a new point on the specified curve.

OpenSSL documentation at EC_POINT_new

pub fn from_bytes(
    group: &EcGroupRef,
    buf: &[u8],
    ctx: &mut BigNumContextRef
) -> Result<EcPoint, ErrorStack>
[src]

Creates point from a binary representation

OpenSSL documentation at EC_POINT_oct2point

Methods from Deref<Target = EcPointRef>

pub fn add(
    &mut self,
    group: &EcGroupRef,
    a: &EcPointRef,
    b: &EcPointRef,
    ctx: &mut BigNumContextRef
) -> Result<(), ErrorStack>
[src]

Computes a + b, storing the result in self.

OpenSSL documentation at EC_POINT_add

pub fn mul(
    &mut self,
    group: &EcGroupRef,
    q: &EcPointRef,
    m: &BigNumRef,
    ctx: &BigNumContextRef
) -> Result<(), ErrorStack>
[src]

Computes q * m, storing the result in self.

OpenSSL documentation at EC_POINT_mul

pub fn mul_generator(
    &mut self,
    group: &EcGroupRef,
    n: &BigNumRef,
    ctx: &BigNumContextRef
) -> Result<(), ErrorStack>
[src]

Computes generator * n, storing the result in self.

pub fn mul_full(
    &mut self,
    group: &EcGroupRef,
    n: &BigNumRef,
    q: &EcPointRef,
    m: &BigNumRef,
    ctx: &mut BigNumContextRef
) -> Result<(), ErrorStack>
[src]

Computes generator * n + q * m, storing the result in self.

pub fn invert(
    &mut self,
    group: &EcGroupRef,
    ctx: &BigNumContextRef
) -> Result<(), ErrorStack>
[src]

Inverts self.

OpenSSL documentation at EC_POINT_invert

pub fn to_bytes(
    &self,
    group: &EcGroupRef,
    form: PointConversionForm,
    ctx: &mut BigNumContextRef
) -> Result<Vec<u8>, ErrorStack>
[src]

Serializes the point to a binary representation.

OpenSSL documentation at EC_POINT_point2oct

pub fn to_owned(&self, group: &EcGroupRef) -> Result<EcPoint, ErrorStack>[src]

Creates a new point on the specified curve with the same value.

OpenSSL documentation at EC_POINT_dup

pub fn eq(
    &self,
    group: &EcGroupRef,
    other: &EcPointRef,
    ctx: &mut BigNumContextRef
) -> Result<bool, ErrorStack>
[src]

Determines if this point is equal to another.

OpenSSL doucmentation at EC_POINT_cmp

pub fn affine_coordinates_gfp(
    &self,
    group: &EcGroupRef,
    x: &mut BigNumRef,
    y: &mut BigNumRef,
    ctx: &mut BigNumContextRef
) -> Result<(), ErrorStack>
[src]

Place affine coordinates of a curve over a prime field in the provided x and y BigNums

OpenSSL documentation at EC_POINT_get_affine_coordinates_GFp

pub fn affine_coordinates_gf2m(
    &self,
    group: &EcGroupRef,
    x: &mut BigNumRef,
    y: &mut BigNumRef,
    ctx: &mut BigNumContextRef
) -> Result<(), ErrorStack>
[src]

Place affine coordinates of a curve over a binary field in the provided x and y BigNums

OpenSSL documentation at EC_POINT_get_affine_coordinates_GF2m

pub fn is_infinity(&self, group: &EcGroupRef) -> bool[src]

Checks if point is infinity

OpenSSL documentation at EC_POINT_is_at_infinity

pub fn is_on_curve(
    &self,
    group: &EcGroupRef,
    ctx: &mut BigNumContextRef
) -> Result<bool, ErrorStack>
[src]

Checks if point is on a given curve

OpenSSL documentation at EC_POINT_is_on_curve

Trait Implementations

impl AsRef<EcPointRef> for EcPoint[src]

impl Borrow<EcPointRef> for EcPoint[src]

impl Deref for EcPoint[src]

type Target = EcPointRef

The resulting type after dereferencing.

impl DerefMut for EcPoint[src]

impl Drop for EcPoint[src]

impl ForeignType for EcPoint[src]

type CType = EC_POINT

The raw C type.

type Ref = EcPointRef

The type representing a reference to this type.

impl Send for EcPoint[src]

impl Sync for EcPoint[src]

Auto Trait Implementations

impl RefUnwindSafe for EcPoint

impl Unpin for EcPoint

impl UnwindSafe for EcPoint

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.