mirror of
https://github.com/mappu/miqt.git
synced 2025-01-06 23:58:37 +00:00
518 lines
20 KiB
Go
518 lines
20 KiB
Go
|
package network
|
||
|
|
||
|
/*
|
||
|
|
||
|
#include "gen_qsslcertificate.h"
|
||
|
#include <stdlib.h>
|
||
|
|
||
|
*/
|
||
|
import "C"
|
||
|
|
||
|
import (
|
||
|
"github.com/mappu/miqt/qt6"
|
||
|
"runtime"
|
||
|
"unsafe"
|
||
|
)
|
||
|
|
||
|
type QSslCertificate__SubjectInfo int
|
||
|
|
||
|
const (
|
||
|
QSslCertificate__Organization QSslCertificate__SubjectInfo = 0
|
||
|
QSslCertificate__CommonName QSslCertificate__SubjectInfo = 1
|
||
|
QSslCertificate__LocalityName QSslCertificate__SubjectInfo = 2
|
||
|
QSslCertificate__OrganizationalUnitName QSslCertificate__SubjectInfo = 3
|
||
|
QSslCertificate__CountryName QSslCertificate__SubjectInfo = 4
|
||
|
QSslCertificate__StateOrProvinceName QSslCertificate__SubjectInfo = 5
|
||
|
QSslCertificate__DistinguishedNameQualifier QSslCertificate__SubjectInfo = 6
|
||
|
QSslCertificate__SerialNumber QSslCertificate__SubjectInfo = 7
|
||
|
QSslCertificate__EmailAddress QSslCertificate__SubjectInfo = 8
|
||
|
)
|
||
|
|
||
|
type QSslCertificate__PatternSyntax int
|
||
|
|
||
|
const (
|
||
|
QSslCertificate__RegularExpression QSslCertificate__PatternSyntax = 0
|
||
|
QSslCertificate__Wildcard QSslCertificate__PatternSyntax = 1
|
||
|
QSslCertificate__FixedString QSslCertificate__PatternSyntax = 2
|
||
|
)
|
||
|
|
||
|
type QSslCertificate struct {
|
||
|
h *C.QSslCertificate
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) cPointer() *C.QSslCertificate {
|
||
|
if this == nil {
|
||
|
return nil
|
||
|
}
|
||
|
return this.h
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) UnsafePointer() unsafe.Pointer {
|
||
|
if this == nil {
|
||
|
return nil
|
||
|
}
|
||
|
return unsafe.Pointer(this.h)
|
||
|
}
|
||
|
|
||
|
func newQSslCertificate(h *C.QSslCertificate) *QSslCertificate {
|
||
|
if h == nil {
|
||
|
return nil
|
||
|
}
|
||
|
return &QSslCertificate{h: h}
|
||
|
}
|
||
|
|
||
|
func UnsafeNewQSslCertificate(h unsafe.Pointer) *QSslCertificate {
|
||
|
return newQSslCertificate((*C.QSslCertificate)(h))
|
||
|
}
|
||
|
|
||
|
// NewQSslCertificate constructs a new QSslCertificate object.
|
||
|
func NewQSslCertificate(device *qt6.QIODevice) *QSslCertificate {
|
||
|
ret := C.QSslCertificate_new((*C.QIODevice)(device.UnsafePointer()))
|
||
|
return newQSslCertificate(ret)
|
||
|
}
|
||
|
|
||
|
// NewQSslCertificate2 constructs a new QSslCertificate object.
|
||
|
func NewQSslCertificate2() *QSslCertificate {
|
||
|
ret := C.QSslCertificate_new2()
|
||
|
return newQSslCertificate(ret)
|
||
|
}
|
||
|
|
||
|
// NewQSslCertificate3 constructs a new QSslCertificate object.
|
||
|
func NewQSslCertificate3(other *QSslCertificate) *QSslCertificate {
|
||
|
ret := C.QSslCertificate_new3(other.cPointer())
|
||
|
return newQSslCertificate(ret)
|
||
|
}
|
||
|
|
||
|
// NewQSslCertificate4 constructs a new QSslCertificate object.
|
||
|
func NewQSslCertificate4(device *qt6.QIODevice, format QSsl__EncodingFormat) *QSslCertificate {
|
||
|
ret := C.QSslCertificate_new4((*C.QIODevice)(device.UnsafePointer()), (C.int)(format))
|
||
|
return newQSslCertificate(ret)
|
||
|
}
|
||
|
|
||
|
// NewQSslCertificate5 constructs a new QSslCertificate object.
|
||
|
func NewQSslCertificate5(data []byte) *QSslCertificate {
|
||
|
data_alias := C.struct_miqt_string{}
|
||
|
data_alias.data = (*C.char)(unsafe.Pointer(&data[0]))
|
||
|
data_alias.len = C.size_t(len(data))
|
||
|
ret := C.QSslCertificate_new5(data_alias)
|
||
|
return newQSslCertificate(ret)
|
||
|
}
|
||
|
|
||
|
// NewQSslCertificate6 constructs a new QSslCertificate object.
|
||
|
func NewQSslCertificate6(data []byte, format QSsl__EncodingFormat) *QSslCertificate {
|
||
|
data_alias := C.struct_miqt_string{}
|
||
|
data_alias.data = (*C.char)(unsafe.Pointer(&data[0]))
|
||
|
data_alias.len = C.size_t(len(data))
|
||
|
ret := C.QSslCertificate_new6(data_alias, (C.int)(format))
|
||
|
return newQSslCertificate(ret)
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) OperatorAssign(other *QSslCertificate) {
|
||
|
C.QSslCertificate_OperatorAssign(this.h, other.cPointer())
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) Swap(other *QSslCertificate) {
|
||
|
C.QSslCertificate_Swap(this.h, other.cPointer())
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) OperatorEqual(other *QSslCertificate) bool {
|
||
|
return (bool)(C.QSslCertificate_OperatorEqual(this.h, other.cPointer()))
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) OperatorNotEqual(other *QSslCertificate) bool {
|
||
|
return (bool)(C.QSslCertificate_OperatorNotEqual(this.h, other.cPointer()))
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) IsNull() bool {
|
||
|
return (bool)(C.QSslCertificate_IsNull(this.h))
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) IsBlacklisted() bool {
|
||
|
return (bool)(C.QSslCertificate_IsBlacklisted(this.h))
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) IsSelfSigned() bool {
|
||
|
return (bool)(C.QSslCertificate_IsSelfSigned(this.h))
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) Clear() {
|
||
|
C.QSslCertificate_Clear(this.h)
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) Version() []byte {
|
||
|
var _bytearray C.struct_miqt_string = C.QSslCertificate_Version(this.h)
|
||
|
_ret := C.GoBytes(unsafe.Pointer(_bytearray.data), C.int(int64(_bytearray.len)))
|
||
|
C.free(unsafe.Pointer(_bytearray.data))
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) SerialNumber() []byte {
|
||
|
var _bytearray C.struct_miqt_string = C.QSslCertificate_SerialNumber(this.h)
|
||
|
_ret := C.GoBytes(unsafe.Pointer(_bytearray.data), C.int(int64(_bytearray.len)))
|
||
|
C.free(unsafe.Pointer(_bytearray.data))
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) Digest() []byte {
|
||
|
var _bytearray C.struct_miqt_string = C.QSslCertificate_Digest(this.h)
|
||
|
_ret := C.GoBytes(unsafe.Pointer(_bytearray.data), C.int(int64(_bytearray.len)))
|
||
|
C.free(unsafe.Pointer(_bytearray.data))
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) IssuerInfo(info QSslCertificate__SubjectInfo) []string {
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_IssuerInfo(this.h, (C.int)(info))
|
||
|
_ret := make([]string, int(_ma.len))
|
||
|
_outCast := (*[0xffff]C.struct_miqt_string)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
var _lv_ms C.struct_miqt_string = _outCast[i]
|
||
|
_lv_ret := C.GoStringN(_lv_ms.data, C.int(int64(_lv_ms.len)))
|
||
|
C.free(unsafe.Pointer(_lv_ms.data))
|
||
|
_ret[i] = _lv_ret
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) IssuerInfoWithAttribute(attribute []byte) []string {
|
||
|
attribute_alias := C.struct_miqt_string{}
|
||
|
attribute_alias.data = (*C.char)(unsafe.Pointer(&attribute[0]))
|
||
|
attribute_alias.len = C.size_t(len(attribute))
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_IssuerInfoWithAttribute(this.h, attribute_alias)
|
||
|
_ret := make([]string, int(_ma.len))
|
||
|
_outCast := (*[0xffff]C.struct_miqt_string)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
var _lv_ms C.struct_miqt_string = _outCast[i]
|
||
|
_lv_ret := C.GoStringN(_lv_ms.data, C.int(int64(_lv_ms.len)))
|
||
|
C.free(unsafe.Pointer(_lv_ms.data))
|
||
|
_ret[i] = _lv_ret
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) SubjectInfo(info QSslCertificate__SubjectInfo) []string {
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_SubjectInfo(this.h, (C.int)(info))
|
||
|
_ret := make([]string, int(_ma.len))
|
||
|
_outCast := (*[0xffff]C.struct_miqt_string)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
var _lv_ms C.struct_miqt_string = _outCast[i]
|
||
|
_lv_ret := C.GoStringN(_lv_ms.data, C.int(int64(_lv_ms.len)))
|
||
|
C.free(unsafe.Pointer(_lv_ms.data))
|
||
|
_ret[i] = _lv_ret
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) SubjectInfoWithAttribute(attribute []byte) []string {
|
||
|
attribute_alias := C.struct_miqt_string{}
|
||
|
attribute_alias.data = (*C.char)(unsafe.Pointer(&attribute[0]))
|
||
|
attribute_alias.len = C.size_t(len(attribute))
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_SubjectInfoWithAttribute(this.h, attribute_alias)
|
||
|
_ret := make([]string, int(_ma.len))
|
||
|
_outCast := (*[0xffff]C.struct_miqt_string)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
var _lv_ms C.struct_miqt_string = _outCast[i]
|
||
|
_lv_ret := C.GoStringN(_lv_ms.data, C.int(int64(_lv_ms.len)))
|
||
|
C.free(unsafe.Pointer(_lv_ms.data))
|
||
|
_ret[i] = _lv_ret
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) IssuerDisplayName() string {
|
||
|
var _ms C.struct_miqt_string = C.QSslCertificate_IssuerDisplayName(this.h)
|
||
|
_ret := C.GoStringN(_ms.data, C.int(int64(_ms.len)))
|
||
|
C.free(unsafe.Pointer(_ms.data))
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) SubjectDisplayName() string {
|
||
|
var _ms C.struct_miqt_string = C.QSslCertificate_SubjectDisplayName(this.h)
|
||
|
_ret := C.GoStringN(_ms.data, C.int(int64(_ms.len)))
|
||
|
C.free(unsafe.Pointer(_ms.data))
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) SubjectInfoAttributes() [][]byte {
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_SubjectInfoAttributes(this.h)
|
||
|
_ret := make([][]byte, int(_ma.len))
|
||
|
_outCast := (*[0xffff]C.struct_miqt_string)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
var _lv_bytearray C.struct_miqt_string = _outCast[i]
|
||
|
_lv_ret := C.GoBytes(unsafe.Pointer(_lv_bytearray.data), C.int(int64(_lv_bytearray.len)))
|
||
|
C.free(unsafe.Pointer(_lv_bytearray.data))
|
||
|
_ret[i] = _lv_ret
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) IssuerInfoAttributes() [][]byte {
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_IssuerInfoAttributes(this.h)
|
||
|
_ret := make([][]byte, int(_ma.len))
|
||
|
_outCast := (*[0xffff]C.struct_miqt_string)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
var _lv_bytearray C.struct_miqt_string = _outCast[i]
|
||
|
_lv_ret := C.GoBytes(unsafe.Pointer(_lv_bytearray.data), C.int(int64(_lv_bytearray.len)))
|
||
|
C.free(unsafe.Pointer(_lv_bytearray.data))
|
||
|
_ret[i] = _lv_ret
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) EffectiveDate() *qt6.QDateTime {
|
||
|
_ret := C.QSslCertificate_EffectiveDate(this.h)
|
||
|
_goptr := qt6.UnsafeNewQDateTime(unsafe.Pointer(_ret))
|
||
|
_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
||
|
return _goptr
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) ExpiryDate() *qt6.QDateTime {
|
||
|
_ret := C.QSslCertificate_ExpiryDate(this.h)
|
||
|
_goptr := qt6.UnsafeNewQDateTime(unsafe.Pointer(_ret))
|
||
|
_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
||
|
return _goptr
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) PublicKey() *QSslKey {
|
||
|
_ret := C.QSslCertificate_PublicKey(this.h)
|
||
|
_goptr := newQSslKey(_ret)
|
||
|
_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
||
|
return _goptr
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) Extensions() []QSslCertificateExtension {
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_Extensions(this.h)
|
||
|
_ret := make([]QSslCertificateExtension, int(_ma.len))
|
||
|
_outCast := (*[0xffff]*C.QSslCertificateExtension)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
_lv_ret := _outCast[i]
|
||
|
_lv_goptr := newQSslCertificateExtension(_lv_ret)
|
||
|
_lv_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
||
|
_ret[i] = *_lv_goptr
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) ToPem() []byte {
|
||
|
var _bytearray C.struct_miqt_string = C.QSslCertificate_ToPem(this.h)
|
||
|
_ret := C.GoBytes(unsafe.Pointer(_bytearray.data), C.int(int64(_bytearray.len)))
|
||
|
C.free(unsafe.Pointer(_bytearray.data))
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) ToDer() []byte {
|
||
|
var _bytearray C.struct_miqt_string = C.QSslCertificate_ToDer(this.h)
|
||
|
_ret := C.GoBytes(unsafe.Pointer(_bytearray.data), C.int(int64(_bytearray.len)))
|
||
|
C.free(unsafe.Pointer(_bytearray.data))
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) ToText() string {
|
||
|
var _ms C.struct_miqt_string = C.QSslCertificate_ToText(this.h)
|
||
|
_ret := C.GoStringN(_ms.data, C.int(int64(_ms.len)))
|
||
|
C.free(unsafe.Pointer(_ms.data))
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func QSslCertificate_FromPath(path string) []QSslCertificate {
|
||
|
path_ms := C.struct_miqt_string{}
|
||
|
path_ms.data = C.CString(path)
|
||
|
path_ms.len = C.size_t(len(path))
|
||
|
defer C.free(unsafe.Pointer(path_ms.data))
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_FromPath(path_ms)
|
||
|
_ret := make([]QSslCertificate, int(_ma.len))
|
||
|
_outCast := (*[0xffff]*C.QSslCertificate)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
_lv_ret := _outCast[i]
|
||
|
_lv_goptr := newQSslCertificate(_lv_ret)
|
||
|
_lv_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
||
|
_ret[i] = *_lv_goptr
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func QSslCertificate_FromDevice(device *qt6.QIODevice) []QSslCertificate {
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_FromDevice((*C.QIODevice)(device.UnsafePointer()))
|
||
|
_ret := make([]QSslCertificate, int(_ma.len))
|
||
|
_outCast := (*[0xffff]*C.QSslCertificate)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
_lv_ret := _outCast[i]
|
||
|
_lv_goptr := newQSslCertificate(_lv_ret)
|
||
|
_lv_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
||
|
_ret[i] = *_lv_goptr
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func QSslCertificate_FromData(data []byte) []QSslCertificate {
|
||
|
data_alias := C.struct_miqt_string{}
|
||
|
data_alias.data = (*C.char)(unsafe.Pointer(&data[0]))
|
||
|
data_alias.len = C.size_t(len(data))
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_FromData(data_alias)
|
||
|
_ret := make([]QSslCertificate, int(_ma.len))
|
||
|
_outCast := (*[0xffff]*C.QSslCertificate)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
_lv_ret := _outCast[i]
|
||
|
_lv_goptr := newQSslCertificate(_lv_ret)
|
||
|
_lv_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
||
|
_ret[i] = *_lv_goptr
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func QSslCertificate_Verify(certificateChain []QSslCertificate) []QSslError {
|
||
|
certificateChain_CArray := (*[0xffff]*C.QSslCertificate)(C.malloc(C.size_t(8 * len(certificateChain))))
|
||
|
defer C.free(unsafe.Pointer(certificateChain_CArray))
|
||
|
for i := range certificateChain {
|
||
|
certificateChain_CArray[i] = certificateChain[i].cPointer()
|
||
|
}
|
||
|
certificateChain_ma := C.struct_miqt_array{len: C.size_t(len(certificateChain)), data: unsafe.Pointer(certificateChain_CArray)}
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_Verify(certificateChain_ma)
|
||
|
_ret := make([]QSslError, int(_ma.len))
|
||
|
_outCast := (*[0xffff]*C.QSslError)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
_lv_ret := _outCast[i]
|
||
|
_lv_goptr := newQSslError(_lv_ret)
|
||
|
_lv_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
||
|
_ret[i] = *_lv_goptr
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func QSslCertificate_ImportPkcs12(device *qt6.QIODevice, key *QSslKey, cert *QSslCertificate) bool {
|
||
|
return (bool)(C.QSslCertificate_ImportPkcs12((*C.QIODevice)(device.UnsafePointer()), key.cPointer(), cert.cPointer()))
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) Handle() unsafe.Pointer {
|
||
|
return (unsafe.Pointer)(C.QSslCertificate_Handle(this.h))
|
||
|
}
|
||
|
|
||
|
func (this *QSslCertificate) Digest1(algorithm qt6.QCryptographicHash__Algorithm) []byte {
|
||
|
var _bytearray C.struct_miqt_string = C.QSslCertificate_Digest1(this.h, (C.int)(algorithm))
|
||
|
_ret := C.GoBytes(unsafe.Pointer(_bytearray.data), C.int(int64(_bytearray.len)))
|
||
|
C.free(unsafe.Pointer(_bytearray.data))
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func QSslCertificate_FromPath2(path string, format QSsl__EncodingFormat) []QSslCertificate {
|
||
|
path_ms := C.struct_miqt_string{}
|
||
|
path_ms.data = C.CString(path)
|
||
|
path_ms.len = C.size_t(len(path))
|
||
|
defer C.free(unsafe.Pointer(path_ms.data))
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_FromPath2(path_ms, (C.int)(format))
|
||
|
_ret := make([]QSslCertificate, int(_ma.len))
|
||
|
_outCast := (*[0xffff]*C.QSslCertificate)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
_lv_ret := _outCast[i]
|
||
|
_lv_goptr := newQSslCertificate(_lv_ret)
|
||
|
_lv_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
||
|
_ret[i] = *_lv_goptr
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func QSslCertificate_FromPath3(path string, format QSsl__EncodingFormat, syntax QSslCertificate__PatternSyntax) []QSslCertificate {
|
||
|
path_ms := C.struct_miqt_string{}
|
||
|
path_ms.data = C.CString(path)
|
||
|
path_ms.len = C.size_t(len(path))
|
||
|
defer C.free(unsafe.Pointer(path_ms.data))
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_FromPath3(path_ms, (C.int)(format), (C.int)(syntax))
|
||
|
_ret := make([]QSslCertificate, int(_ma.len))
|
||
|
_outCast := (*[0xffff]*C.QSslCertificate)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
_lv_ret := _outCast[i]
|
||
|
_lv_goptr := newQSslCertificate(_lv_ret)
|
||
|
_lv_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
||
|
_ret[i] = *_lv_goptr
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func QSslCertificate_FromDevice2(device *qt6.QIODevice, format QSsl__EncodingFormat) []QSslCertificate {
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_FromDevice2((*C.QIODevice)(device.UnsafePointer()), (C.int)(format))
|
||
|
_ret := make([]QSslCertificate, int(_ma.len))
|
||
|
_outCast := (*[0xffff]*C.QSslCertificate)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
_lv_ret := _outCast[i]
|
||
|
_lv_goptr := newQSslCertificate(_lv_ret)
|
||
|
_lv_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
||
|
_ret[i] = *_lv_goptr
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func QSslCertificate_FromData2(data []byte, format QSsl__EncodingFormat) []QSslCertificate {
|
||
|
data_alias := C.struct_miqt_string{}
|
||
|
data_alias.data = (*C.char)(unsafe.Pointer(&data[0]))
|
||
|
data_alias.len = C.size_t(len(data))
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_FromData2(data_alias, (C.int)(format))
|
||
|
_ret := make([]QSslCertificate, int(_ma.len))
|
||
|
_outCast := (*[0xffff]*C.QSslCertificate)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
_lv_ret := _outCast[i]
|
||
|
_lv_goptr := newQSslCertificate(_lv_ret)
|
||
|
_lv_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
||
|
_ret[i] = *_lv_goptr
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func QSslCertificate_Verify2(certificateChain []QSslCertificate, hostName string) []QSslError {
|
||
|
certificateChain_CArray := (*[0xffff]*C.QSslCertificate)(C.malloc(C.size_t(8 * len(certificateChain))))
|
||
|
defer C.free(unsafe.Pointer(certificateChain_CArray))
|
||
|
for i := range certificateChain {
|
||
|
certificateChain_CArray[i] = certificateChain[i].cPointer()
|
||
|
}
|
||
|
certificateChain_ma := C.struct_miqt_array{len: C.size_t(len(certificateChain)), data: unsafe.Pointer(certificateChain_CArray)}
|
||
|
hostName_ms := C.struct_miqt_string{}
|
||
|
hostName_ms.data = C.CString(hostName)
|
||
|
hostName_ms.len = C.size_t(len(hostName))
|
||
|
defer C.free(unsafe.Pointer(hostName_ms.data))
|
||
|
var _ma C.struct_miqt_array = C.QSslCertificate_Verify2(certificateChain_ma, hostName_ms)
|
||
|
_ret := make([]QSslError, int(_ma.len))
|
||
|
_outCast := (*[0xffff]*C.QSslError)(unsafe.Pointer(_ma.data)) // hey ya
|
||
|
for i := 0; i < int(_ma.len); i++ {
|
||
|
_lv_ret := _outCast[i]
|
||
|
_lv_goptr := newQSslError(_lv_ret)
|
||
|
_lv_goptr.GoGC() // Qt uses pass-by-value semantics for this type. Mimic with finalizer
|
||
|
_ret[i] = *_lv_goptr
|
||
|
}
|
||
|
return _ret
|
||
|
}
|
||
|
|
||
|
func QSslCertificate_ImportPkcs124(device *qt6.QIODevice, key *QSslKey, cert *QSslCertificate, caCertificates []QSslCertificate) bool {
|
||
|
caCertificates_CArray := (*[0xffff]*C.QSslCertificate)(C.malloc(C.size_t(8 * len(caCertificates))))
|
||
|
defer C.free(unsafe.Pointer(caCertificates_CArray))
|
||
|
for i := range caCertificates {
|
||
|
caCertificates_CArray[i] = caCertificates[i].cPointer()
|
||
|
}
|
||
|
caCertificates_ma := C.struct_miqt_array{len: C.size_t(len(caCertificates)), data: unsafe.Pointer(caCertificates_CArray)}
|
||
|
return (bool)(C.QSslCertificate_ImportPkcs124((*C.QIODevice)(device.UnsafePointer()), key.cPointer(), cert.cPointer(), caCertificates_ma))
|
||
|
}
|
||
|
|
||
|
func QSslCertificate_ImportPkcs125(device *qt6.QIODevice, key *QSslKey, cert *QSslCertificate, caCertificates []QSslCertificate, passPhrase []byte) bool {
|
||
|
caCertificates_CArray := (*[0xffff]*C.QSslCertificate)(C.malloc(C.size_t(8 * len(caCertificates))))
|
||
|
defer C.free(unsafe.Pointer(caCertificates_CArray))
|
||
|
for i := range caCertificates {
|
||
|
caCertificates_CArray[i] = caCertificates[i].cPointer()
|
||
|
}
|
||
|
caCertificates_ma := C.struct_miqt_array{len: C.size_t(len(caCertificates)), data: unsafe.Pointer(caCertificates_CArray)}
|
||
|
passPhrase_alias := C.struct_miqt_string{}
|
||
|
passPhrase_alias.data = (*C.char)(unsafe.Pointer(&passPhrase[0]))
|
||
|
passPhrase_alias.len = C.size_t(len(passPhrase))
|
||
|
return (bool)(C.QSslCertificate_ImportPkcs125((*C.QIODevice)(device.UnsafePointer()), key.cPointer(), cert.cPointer(), caCertificates_ma, passPhrase_alias))
|
||
|
}
|
||
|
|
||
|
// Delete this object from C++ memory.
|
||
|
func (this *QSslCertificate) Delete() {
|
||
|
C.QSslCertificate_Delete(this.h)
|
||
|
}
|
||
|
|
||
|
// GoGC adds a Go Finalizer to this pointer, so that it will be deleted
|
||
|
// from C++ memory once it is unreachable from Go memory.
|
||
|
func (this *QSslCertificate) GoGC() {
|
||
|
runtime.SetFinalizer(this, func(this *QSslCertificate) {
|
||
|
this.Delete()
|
||
|
runtime.KeepAlive(this.h)
|
||
|
})
|
||
|
}
|