File: _EndTxn.pm

package info (click to toggle)
libmongodb-perl 2.2.2-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 10,292 kB
  • sloc: perl: 14,421; python: 299; makefile: 20; sh: 11
file content (98 lines) | stat: -rw-r--r-- 2,747 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#  Copyright 2015 - present MongoDB, Inc.
#
#  Licensed under the Apache License, Version 2.0 (the "License");
#  you may not use this file except in compliance with the License.
#  You may obtain a copy of the License at
#
#  http://www.apache.org/licenses/LICENSE-2.0
#
#  Unless required by applicable law or agreed to in writing, software
#  distributed under the License is distributed on an "AS IS" BASIS,
#  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
#  See the License for the specific language governing permissions and
#  limitations under the License.

use strict;
use warnings;
package MongoDB::Op::_EndTxn;

# Encapsulate code path for end transaction commands

use version;
our $VERSION = 'v2.2.2';

use Moo;

use MongoDB::Op::_Command;
use MongoDB::_Types qw(
    Document
    to_IxHash
);
use MongoDB::_Constants qw( TXN_WTIMEOUT_RETRY_DEFAULT );
use Types::Standard qw(
    HashRef
    Maybe
    Int
);

use namespace::clean;

with $_ for qw(
  MongoDB::Role::_PrivateConstructor
  MongoDB::Role::_DatabaseOp
  MongoDB::Role::_SessionSupport
  MongoDB::Role::_CommandMonitoring
);

has query => (
    is       => 'ro',
    required => 1,
    writer   => '_set_query',
    isa      => Document,
);

sub _get_query_maybe_with_write_concern {
    my ( $self, $topology ) = @_;

    my $query = to_IxHash( $self->query );

    if ( $self->session->_has_attempted_end_transaction ) {
        my $wc_existing = $self->session->_get_transaction_write_concern;
        my $wc = $wc_existing->as_args->[1];

        $query->Push( writeConcern => {
            # allows for an override if set
            wtimeout => TXN_WTIMEOUT_RETRY_DEFAULT,
            ( $wc ? %$wc : () ),
            # must be a majority on retrying
            w => 'majority',
        });
    }

    # If we've gotten this far and a sharded topology doesnt support
    # transactions, something has gone seriously wrong
    if ( $topology eq 'Sharded' && defined $self->session->_recovery_token ) {
        $query->Push( recoveryToken => $self->session->_recovery_token );
    }

    return $query;
}

sub execute {
    my ( $self, $link, $topology ) = @_;

    my $query = $self->_get_query_maybe_with_write_concern( $topology );
    # Set that an attempt to commit the transaction has been made after getting
    # query but before execute - stops error unwind losing it
    $self->session->_has_attempted_end_transaction( 1 );
    my $op = MongoDB::Op::_Command->_new(
        query_flags => {},
        query => $query,
        map { $_ => $self->$_ } qw(db_name bson_codec session monitoring_callback)
    );
    my $result = $op->execute( $link, $topology );
    $result->assert_no_write_concern_error;
    return $result;
}

1;