Compare commits
6 Commits
3.8.3+hotf
...
0.0.4
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
a8942269b4 | ||
|
|
408f12eb57 | ||
|
|
875dbf5bb2 | ||
|
|
a091534d2c | ||
|
|
3263ebb46f | ||
|
|
a3752065fa |
@@ -1,11 +1,3 @@
|
|||||||
## 3.8.3+3
|
|
||||||
|
|
||||||
- [Bug fixes and performance enhancements.](https://github.com/openimsdk/openim-sdk-core/releases/tag/v3.8.3-patch.3)
|
|
||||||
|
|
||||||
## 3.8.2
|
|
||||||
|
|
||||||
- [Bug fixes and performance enhancements.](https://github.com/openimsdk/openim-sdk-core/releases/tag/v3.8.2)
|
|
||||||
|
|
||||||
## 3.8.1+2
|
## 3.8.1+2
|
||||||
|
|
||||||
- [Bug fixes and performance enhancements.](https://github.com/openimsdk/openim-sdk-core/releases/tag/v3.8.1)
|
- [Bug fixes and performance enhancements.](https://github.com/openimsdk/openim-sdk-core/releases/tag/v3.8.1)
|
||||||
|
|||||||
682
LICENSE
682
LICENSE
@@ -1,661 +1,21 @@
|
|||||||
GNU AFFERO GENERAL PUBLIC LICENSE
|
MIT License
|
||||||
Version 3, 19 November 2007
|
|
||||||
|
Copyright (c) 2018 OpenIM Corporation
|
||||||
Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
|
|
||||||
Everyone is permitted to copy and distribute verbatim copies
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this license document, but changing it is not allowed.
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
Preamble
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
The GNU Affero General Public License is a free, copyleft license for
|
furnished to do so, subject to the following conditions:
|
||||||
software and other kinds of works, specifically designed to ensure
|
|
||||||
cooperation with the community in the case of network server software.
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
The licenses for most software and other practical works are designed
|
|
||||||
to take away your freedom to share and change the works. By contrast,
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
our General Public Licenses are intended to guarantee your freedom to
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
share and change all versions of a program--to make sure it remains free
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
software for all its users.
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
When we speak of free software, we are referring to freedom, not
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
price. Our General Public Licenses are designed to make sure that you
|
SOFTWARE.
|
||||||
have the freedom to distribute copies of free software (and charge for
|
|
||||||
them if you wish), that you receive source code or can get it if you
|
|
||||||
want it, that you can change the software or use pieces of it in new
|
|
||||||
free programs, and that you know you can do these things.
|
|
||||||
|
|
||||||
Developers that use our General Public Licenses protect your rights
|
|
||||||
with two steps: (1) assert copyright on the software, and (2) offer
|
|
||||||
you this License which gives you legal permission to copy, distribute
|
|
||||||
and/or modify the software.
|
|
||||||
|
|
||||||
A secondary benefit of defending all users' freedom is that
|
|
||||||
improvements made in alternate versions of the program, if they
|
|
||||||
receive widespread use, become available for other developers to
|
|
||||||
incorporate. Many developers of free software are heartened and
|
|
||||||
encouraged by the resulting cooperation. However, in the case of
|
|
||||||
software used on network servers, this result may fail to come about.
|
|
||||||
The GNU General Public License permits making a modified version and
|
|
||||||
letting the public access it on a server without ever releasing its
|
|
||||||
source code to the public.
|
|
||||||
|
|
||||||
The GNU Affero General Public License is designed specifically to
|
|
||||||
ensure that, in such cases, the modified source code becomes available
|
|
||||||
to the community. It requires the operator of a network server to
|
|
||||||
provide the source code of the modified version running there to the
|
|
||||||
users of that server. Therefore, public use of a modified version, on
|
|
||||||
a publicly accessible server, gives the public access to the source
|
|
||||||
code of the modified version.
|
|
||||||
|
|
||||||
An older license, called the Affero General Public License and
|
|
||||||
published by Affero, was designed to accomplish similar goals. This is
|
|
||||||
a different license, not a version of the Affero GPL, but Affero has
|
|
||||||
released a new version of the Affero GPL which permits relicensing under
|
|
||||||
this license.
|
|
||||||
|
|
||||||
The precise terms and conditions for copying, distribution and
|
|
||||||
modification follow.
|
|
||||||
|
|
||||||
TERMS AND CONDITIONS
|
|
||||||
|
|
||||||
0. Definitions.
|
|
||||||
|
|
||||||
"This License" refers to version 3 of the GNU Affero General Public License.
|
|
||||||
|
|
||||||
"Copyright" also means copyright-like laws that apply to other kinds of
|
|
||||||
works, such as semiconductor masks.
|
|
||||||
|
|
||||||
"The Program" refers to any copyrightable work licensed under this
|
|
||||||
License. Each licensee is addressed as "you". "Licensees" and
|
|
||||||
"recipients" may be individuals or organizations.
|
|
||||||
|
|
||||||
To "modify" a work means to copy from or adapt all or part of the work
|
|
||||||
in a fashion requiring copyright permission, other than the making of an
|
|
||||||
exact copy. The resulting work is called a "modified version" of the
|
|
||||||
earlier work or a work "based on" the earlier work.
|
|
||||||
|
|
||||||
A "covered work" means either the unmodified Program or a work based
|
|
||||||
on the Program.
|
|
||||||
|
|
||||||
To "propagate" a work means to do anything with it that, without
|
|
||||||
permission, would make you directly or secondarily liable for
|
|
||||||
infringement under applicable copyright law, except executing it on a
|
|
||||||
computer or modifying a private copy. Propagation includes copying,
|
|
||||||
distribution (with or without modification), making available to the
|
|
||||||
public, and in some countries other activities as well.
|
|
||||||
|
|
||||||
To "convey" a work means any kind of propagation that enables other
|
|
||||||
parties to make or receive copies. Mere interaction with a user through
|
|
||||||
a computer network, with no transfer of a copy, is not conveying.
|
|
||||||
|
|
||||||
An interactive user interface displays "Appropriate Legal Notices"
|
|
||||||
to the extent that it includes a convenient and prominently visible
|
|
||||||
feature that (1) displays an appropriate copyright notice, and (2)
|
|
||||||
tells the user that there is no warranty for the work (except to the
|
|
||||||
extent that warranties are provided), that licensees may convey the
|
|
||||||
work under this License, and how to view a copy of this License. If
|
|
||||||
the interface presents a list of user commands or options, such as a
|
|
||||||
menu, a prominent item in the list meets this criterion.
|
|
||||||
|
|
||||||
1. Source Code.
|
|
||||||
|
|
||||||
The "source code" for a work means the preferred form of the work
|
|
||||||
for making modifications to it. "Object code" means any non-source
|
|
||||||
form of a work.
|
|
||||||
|
|
||||||
A "Standard Interface" means an interface that either is an official
|
|
||||||
standard defined by a recognized standards body, or, in the case of
|
|
||||||
interfaces specified for a particular programming language, one that
|
|
||||||
is widely used among developers working in that language.
|
|
||||||
|
|
||||||
The "System Libraries" of an executable work include anything, other
|
|
||||||
than the work as a whole, that (a) is included in the normal form of
|
|
||||||
packaging a Major Component, but which is not part of that Major
|
|
||||||
Component, and (b) serves only to enable use of the work with that
|
|
||||||
Major Component, or to implement a Standard Interface for which an
|
|
||||||
implementation is available to the public in source code form. A
|
|
||||||
"Major Component", in this context, means a major essential component
|
|
||||||
(kernel, window system, and so on) of the specific operating system
|
|
||||||
(if any) on which the executable work runs, or a compiler used to
|
|
||||||
produce the work, or an object code interpreter used to run it.
|
|
||||||
|
|
||||||
The "Corresponding Source" for a work in object code form means all
|
|
||||||
the source code needed to generate, install, and (for an executable
|
|
||||||
work) run the object code and to modify the work, including scripts to
|
|
||||||
control those activities. However, it does not include the work's
|
|
||||||
System Libraries, or general-purpose tools or generally available free
|
|
||||||
programs which are used unmodified in performing those activities but
|
|
||||||
which are not part of the work. For example, Corresponding Source
|
|
||||||
includes interface definition files associated with source files for
|
|
||||||
the work, and the source code for shared libraries and dynamically
|
|
||||||
linked subprograms that the work is specifically designed to require,
|
|
||||||
such as by intimate data communication or control flow between those
|
|
||||||
subprograms and other parts of the work.
|
|
||||||
|
|
||||||
The Corresponding Source need not include anything that users
|
|
||||||
can regenerate automatically from other parts of the Corresponding
|
|
||||||
Source.
|
|
||||||
|
|
||||||
The Corresponding Source for a work in source code form is that
|
|
||||||
same work.
|
|
||||||
|
|
||||||
2. Basic Permissions.
|
|
||||||
|
|
||||||
All rights granted under this License are granted for the term of
|
|
||||||
copyright on the Program, and are irrevocable provided the stated
|
|
||||||
conditions are met. This License explicitly affirms your unlimited
|
|
||||||
permission to run the unmodified Program. The output from running a
|
|
||||||
covered work is covered by this License only if the output, given its
|
|
||||||
content, constitutes a covered work. This License acknowledges your
|
|
||||||
rights of fair use or other equivalent, as provided by copyright law.
|
|
||||||
|
|
||||||
You may make, run and propagate covered works that you do not
|
|
||||||
convey, without conditions so long as your license otherwise remains
|
|
||||||
in force. You may convey covered works to others for the sole purpose
|
|
||||||
of having them make modifications exclusively for you, or provide you
|
|
||||||
with facilities for running those works, provided that you comply with
|
|
||||||
the terms of this License in conveying all material for which you do
|
|
||||||
not control copyright. Those thus making or running the covered works
|
|
||||||
for you must do so exclusively on your behalf, under your direction
|
|
||||||
and control, on terms that prohibit them from making any copies of
|
|
||||||
your copyrighted material outside their relationship with you.
|
|
||||||
|
|
||||||
Conveying under any other circumstances is permitted solely under
|
|
||||||
the conditions stated below. Sublicensing is not allowed; section 10
|
|
||||||
makes it unnecessary.
|
|
||||||
|
|
||||||
3. Protecting Users' Legal Rights From Anti-Circumvention Law.
|
|
||||||
|
|
||||||
No covered work shall be deemed part of an effective technological
|
|
||||||
measure under any applicable law fulfilling obligations under article
|
|
||||||
11 of the WIPO copyright treaty adopted on 20 December 1996, or
|
|
||||||
similar laws prohibiting or restricting circumvention of such
|
|
||||||
measures.
|
|
||||||
|
|
||||||
When you convey a covered work, you waive any legal power to forbid
|
|
||||||
circumvention of technological measures to the extent such circumvention
|
|
||||||
is effected by exercising rights under this License with respect to
|
|
||||||
the covered work, and you disclaim any intention to limit operation or
|
|
||||||
modification of the work as a means of enforcing, against the work's
|
|
||||||
users, your or third parties' legal rights to forbid circumvention of
|
|
||||||
technological measures.
|
|
||||||
|
|
||||||
4. Conveying Verbatim Copies.
|
|
||||||
|
|
||||||
You may convey verbatim copies of the Program's source code as you
|
|
||||||
receive it, in any medium, provided that you conspicuously and
|
|
||||||
appropriately publish on each copy an appropriate copyright notice;
|
|
||||||
keep intact all notices stating that this License and any
|
|
||||||
non-permissive terms added in accord with section 7 apply to the code;
|
|
||||||
keep intact all notices of the absence of any warranty; and give all
|
|
||||||
recipients a copy of this License along with the Program.
|
|
||||||
|
|
||||||
You may charge any price or no price for each copy that you convey,
|
|
||||||
and you may offer support or warranty protection for a fee.
|
|
||||||
|
|
||||||
5. Conveying Modified Source Versions.
|
|
||||||
|
|
||||||
You may convey a work based on the Program, or the modifications to
|
|
||||||
produce it from the Program, in the form of source code under the
|
|
||||||
terms of section 4, provided that you also meet all of these conditions:
|
|
||||||
|
|
||||||
a) The work must carry prominent notices stating that you modified
|
|
||||||
it, and giving a relevant date.
|
|
||||||
|
|
||||||
b) The work must carry prominent notices stating that it is
|
|
||||||
released under this License and any conditions added under section
|
|
||||||
7. This requirement modifies the requirement in section 4 to
|
|
||||||
"keep intact all notices".
|
|
||||||
|
|
||||||
c) You must license the entire work, as a whole, under this
|
|
||||||
License to anyone who comes into possession of a copy. This
|
|
||||||
License will therefore apply, along with any applicable section 7
|
|
||||||
additional terms, to the whole of the work, and all its parts,
|
|
||||||
regardless of how they are packaged. This License gives no
|
|
||||||
permission to license the work in any other way, but it does not
|
|
||||||
invalidate such permission if you have separately received it.
|
|
||||||
|
|
||||||
d) If the work has interactive user interfaces, each must display
|
|
||||||
Appropriate Legal Notices; however, if the Program has interactive
|
|
||||||
interfaces that do not display Appropriate Legal Notices, your
|
|
||||||
work need not make them do so.
|
|
||||||
|
|
||||||
A compilation of a covered work with other separate and independent
|
|
||||||
works, which are not by their nature extensions of the covered work,
|
|
||||||
and which are not combined with it such as to form a larger program,
|
|
||||||
in or on a volume of a storage or distribution medium, is called an
|
|
||||||
"aggregate" if the compilation and its resulting copyright are not
|
|
||||||
used to limit the access or legal rights of the compilation's users
|
|
||||||
beyond what the individual works permit. Inclusion of a covered work
|
|
||||||
in an aggregate does not cause this License to apply to the other
|
|
||||||
parts of the aggregate.
|
|
||||||
|
|
||||||
6. Conveying Non-Source Forms.
|
|
||||||
|
|
||||||
You may convey a covered work in object code form under the terms
|
|
||||||
of sections 4 and 5, provided that you also convey the
|
|
||||||
machine-readable Corresponding Source under the terms of this License,
|
|
||||||
in one of these ways:
|
|
||||||
|
|
||||||
a) Convey the object code in, or embodied in, a physical product
|
|
||||||
(including a physical distribution medium), accompanied by the
|
|
||||||
Corresponding Source fixed on a durable physical medium
|
|
||||||
customarily used for software interchange.
|
|
||||||
|
|
||||||
b) Convey the object code in, or embodied in, a physical product
|
|
||||||
(including a physical distribution medium), accompanied by a
|
|
||||||
written offer, valid for at least three years and valid for as
|
|
||||||
long as you offer spare parts or customer support for that product
|
|
||||||
model, to give anyone who possesses the object code either (1) a
|
|
||||||
copy of the Corresponding Source for all the software in the
|
|
||||||
product that is covered by this License, on a durable physical
|
|
||||||
medium customarily used for software interchange, for a price no
|
|
||||||
more than your reasonable cost of physically performing this
|
|
||||||
conveying of source, or (2) access to copy the
|
|
||||||
Corresponding Source from a network server at no charge.
|
|
||||||
|
|
||||||
c) Convey individual copies of the object code with a copy of the
|
|
||||||
written offer to provide the Corresponding Source. This
|
|
||||||
alternative is allowed only occasionally and noncommercially, and
|
|
||||||
only if you received the object code with such an offer, in accord
|
|
||||||
with subsection 6b.
|
|
||||||
|
|
||||||
d) Convey the object code by offering access from a designated
|
|
||||||
place (gratis or for a charge), and offer equivalent access to the
|
|
||||||
Corresponding Source in the same way through the same place at no
|
|
||||||
further charge. You need not require recipients to copy the
|
|
||||||
Corresponding Source along with the object code. If the place to
|
|
||||||
copy the object code is a network server, the Corresponding Source
|
|
||||||
may be on a different server (operated by you or a third party)
|
|
||||||
that supports equivalent copying facilities, provided you maintain
|
|
||||||
clear directions next to the object code saying where to find the
|
|
||||||
Corresponding Source. Regardless of what server hosts the
|
|
||||||
Corresponding Source, you remain obligated to ensure that it is
|
|
||||||
available for as long as needed to satisfy these requirements.
|
|
||||||
|
|
||||||
e) Convey the object code using peer-to-peer transmission, provided
|
|
||||||
you inform other peers where the object code and Corresponding
|
|
||||||
Source of the work are being offered to the general public at no
|
|
||||||
charge under subsection 6d.
|
|
||||||
|
|
||||||
A separable portion of the object code, whose source code is excluded
|
|
||||||
from the Corresponding Source as a System Library, need not be
|
|
||||||
included in conveying the object code work.
|
|
||||||
|
|
||||||
A "User Product" is either (1) a "consumer product", which means any
|
|
||||||
tangible personal property which is normally used for personal, family,
|
|
||||||
or household purposes, or (2) anything designed or sold for incorporation
|
|
||||||
into a dwelling. In determining whether a product is a consumer product,
|
|
||||||
doubtful cases shall be resolved in favor of coverage. For a particular
|
|
||||||
product received by a particular user, "normally used" refers to a
|
|
||||||
typical or common use of that class of product, regardless of the status
|
|
||||||
of the particular user or of the way in which the particular user
|
|
||||||
actually uses, or expects or is expected to use, the product. A product
|
|
||||||
is a consumer product regardless of whether the product has substantial
|
|
||||||
commercial, industrial or non-consumer uses, unless such uses represent
|
|
||||||
the only significant mode of use of the product.
|
|
||||||
|
|
||||||
"Installation Information" for a User Product means any methods,
|
|
||||||
procedures, authorization keys, or other information required to install
|
|
||||||
and execute modified versions of a covered work in that User Product from
|
|
||||||
a modified version of its Corresponding Source. The information must
|
|
||||||
suffice to ensure that the continued functioning of the modified object
|
|
||||||
code is in no case prevented or interfered with solely because
|
|
||||||
modification has been made.
|
|
||||||
|
|
||||||
If you convey an object code work under this section in, or with, or
|
|
||||||
specifically for use in, a User Product, and the conveying occurs as
|
|
||||||
part of a transaction in which the right of possession and use of the
|
|
||||||
User Product is transferred to the recipient in perpetuity or for a
|
|
||||||
fixed term (regardless of how the transaction is characterized), the
|
|
||||||
Corresponding Source conveyed under this section must be accompanied
|
|
||||||
by the Installation Information. But this requirement does not apply
|
|
||||||
if neither you nor any third party retains the ability to install
|
|
||||||
modified object code on the User Product (for example, the work has
|
|
||||||
been installed in ROM).
|
|
||||||
|
|
||||||
The requirement to provide Installation Information does not include a
|
|
||||||
requirement to continue to provide support service, warranty, or updates
|
|
||||||
for a work that has been modified or installed by the recipient, or for
|
|
||||||
the User Product in which it has been modified or installed. Access to a
|
|
||||||
network may be denied when the modification itself materially and
|
|
||||||
adversely affects the operation of the network or violates the rules and
|
|
||||||
protocols for communication across the network.
|
|
||||||
|
|
||||||
Corresponding Source conveyed, and Installation Information provided,
|
|
||||||
in accord with this section must be in a format that is publicly
|
|
||||||
documented (and with an implementation available to the public in
|
|
||||||
source code form), and must require no special password or key for
|
|
||||||
unpacking, reading or copying.
|
|
||||||
|
|
||||||
7. Additional Terms.
|
|
||||||
|
|
||||||
"Additional permissions" are terms that supplement the terms of this
|
|
||||||
License by making exceptions from one or more of its conditions.
|
|
||||||
Additional permissions that are applicable to the entire Program shall
|
|
||||||
be treated as though they were included in this License, to the extent
|
|
||||||
that they are valid under applicable law. If additional permissions
|
|
||||||
apply only to part of the Program, that part may be used separately
|
|
||||||
under those permissions, but the entire Program remains governed by
|
|
||||||
this License without regard to the additional permissions.
|
|
||||||
|
|
||||||
When you convey a copy of a covered work, you may at your option
|
|
||||||
remove any additional permissions from that copy, or from any part of
|
|
||||||
it. (Additional permissions may be written to require their own
|
|
||||||
removal in certain cases when you modify the work.) You may place
|
|
||||||
additional permissions on material, added by you to a covered work,
|
|
||||||
for which you have or can give appropriate copyright permission.
|
|
||||||
|
|
||||||
Notwithstanding any other provision of this License, for material you
|
|
||||||
add to a covered work, you may (if authorized by the copyright holders of
|
|
||||||
that material) supplement the terms of this License with terms:
|
|
||||||
|
|
||||||
a) Disclaiming warranty or limiting liability differently from the
|
|
||||||
terms of sections 15 and 16 of this License; or
|
|
||||||
|
|
||||||
b) Requiring preservation of specified reasonable legal notices or
|
|
||||||
author attributions in that material or in the Appropriate Legal
|
|
||||||
Notices displayed by works containing it; or
|
|
||||||
|
|
||||||
c) Prohibiting misrepresentation of the origin of that material, or
|
|
||||||
requiring that modified versions of such material be marked in
|
|
||||||
reasonable ways as different from the original version; or
|
|
||||||
|
|
||||||
d) Limiting the use for publicity purposes of names of licensors or
|
|
||||||
authors of the material; or
|
|
||||||
|
|
||||||
e) Declining to grant rights under trademark law for use of some
|
|
||||||
trade names, trademarks, or service marks; or
|
|
||||||
|
|
||||||
f) Requiring indemnification of licensors and authors of that
|
|
||||||
material by anyone who conveys the material (or modified versions of
|
|
||||||
it) with contractual assumptions of liability to the recipient, for
|
|
||||||
any liability that these contractual assumptions directly impose on
|
|
||||||
those licensors and authors.
|
|
||||||
|
|
||||||
All other non-permissive additional terms are considered "further
|
|
||||||
restrictions" within the meaning of section 10. If the Program as you
|
|
||||||
received it, or any part of it, contains a notice stating that it is
|
|
||||||
governed by this License along with a term that is a further
|
|
||||||
restriction, you may remove that term. If a license document contains
|
|
||||||
a further restriction but permits relicensing or conveying under this
|
|
||||||
License, you may add to a covered work material governed by the terms
|
|
||||||
of that license document, provided that the further restriction does
|
|
||||||
not survive such relicensing or conveying.
|
|
||||||
|
|
||||||
If you add terms to a covered work in accord with this section, you
|
|
||||||
must place, in the relevant source files, a statement of the
|
|
||||||
additional terms that apply to those files, or a notice indicating
|
|
||||||
where to find the applicable terms.
|
|
||||||
|
|
||||||
Additional terms, permissive or non-permissive, may be stated in the
|
|
||||||
form of a separately written license, or stated as exceptions;
|
|
||||||
the above requirements apply either way.
|
|
||||||
|
|
||||||
8. Termination.
|
|
||||||
|
|
||||||
You may not propagate or modify a covered work except as expressly
|
|
||||||
provided under this License. Any attempt otherwise to propagate or
|
|
||||||
modify it is void, and will automatically terminate your rights under
|
|
||||||
this License (including any patent licenses granted under the third
|
|
||||||
paragraph of section 11).
|
|
||||||
|
|
||||||
However, if you cease all violation of this License, then your
|
|
||||||
license from a particular copyright holder is reinstated (a)
|
|
||||||
provisionally, unless and until the copyright holder explicitly and
|
|
||||||
finally terminates your license, and (b) permanently, if the copyright
|
|
||||||
holder fails to notify you of the violation by some reasonable means
|
|
||||||
prior to 60 days after the cessation.
|
|
||||||
|
|
||||||
Moreover, your license from a particular copyright holder is
|
|
||||||
reinstated permanently if the copyright holder notifies you of the
|
|
||||||
violation by some reasonable means, this is the first time you have
|
|
||||||
received notice of violation of this License (for any work) from that
|
|
||||||
copyright holder, and you cure the violation prior to 30 days after
|
|
||||||
your receipt of the notice.
|
|
||||||
|
|
||||||
Termination of your rights under this section does not terminate the
|
|
||||||
licenses of parties who have received copies or rights from you under
|
|
||||||
this License. If your rights have been terminated and not permanently
|
|
||||||
reinstated, you do not qualify to receive new licenses for the same
|
|
||||||
material under section 10.
|
|
||||||
|
|
||||||
9. Acceptance Not Required for Having Copies.
|
|
||||||
|
|
||||||
You are not required to accept this License in order to receive or
|
|
||||||
run a copy of the Program. Ancillary propagation of a covered work
|
|
||||||
occurring solely as a consequence of using peer-to-peer transmission
|
|
||||||
to receive a copy likewise does not require acceptance. However,
|
|
||||||
nothing other than this License grants you permission to propagate or
|
|
||||||
modify any covered work. These actions infringe copyright if you do
|
|
||||||
not accept this License. Therefore, by modifying or propagating a
|
|
||||||
covered work, you indicate your acceptance of this License to do so.
|
|
||||||
|
|
||||||
10. Automatic Licensing of Downstream Recipients.
|
|
||||||
|
|
||||||
Each time you convey a covered work, the recipient automatically
|
|
||||||
receives a license from the original licensors, to run, modify and
|
|
||||||
propagate that work, subject to this License. You are not responsible
|
|
||||||
for enforcing compliance by third parties with this License.
|
|
||||||
|
|
||||||
An "entity transaction" is a transaction transferring control of an
|
|
||||||
organization, or substantially all assets of one, or subdividing an
|
|
||||||
organization, or merging organizations. If propagation of a covered
|
|
||||||
work results from an entity transaction, each party to that
|
|
||||||
transaction who receives a copy of the work also receives whatever
|
|
||||||
licenses to the work the party's predecessor in interest had or could
|
|
||||||
give under the previous paragraph, plus a right to possession of the
|
|
||||||
Corresponding Source of the work from the predecessor in interest, if
|
|
||||||
the predecessor has it or can get it with reasonable efforts.
|
|
||||||
|
|
||||||
You may not impose any further restrictions on the exercise of the
|
|
||||||
rights granted or affirmed under this License. For example, you may
|
|
||||||
not impose a license fee, royalty, or other charge for exercise of
|
|
||||||
rights granted under this License, and you may not initiate litigation
|
|
||||||
(including a cross-claim or counterclaim in a lawsuit) alleging that
|
|
||||||
any patent claim is infringed by making, using, selling, offering for
|
|
||||||
sale, or importing the Program or any portion of it.
|
|
||||||
|
|
||||||
11. Patents.
|
|
||||||
|
|
||||||
A "contributor" is a copyright holder who authorizes use under this
|
|
||||||
License of the Program or a work on which the Program is based. The
|
|
||||||
work thus licensed is called the contributor's "contributor version".
|
|
||||||
|
|
||||||
A contributor's "essential patent claims" are all patent claims
|
|
||||||
owned or controlled by the contributor, whether already acquired or
|
|
||||||
hereafter acquired, that would be infringed by some manner, permitted
|
|
||||||
by this License, of making, using, or selling its contributor version,
|
|
||||||
but do not include claims that would be infringed only as a
|
|
||||||
consequence of further modification of the contributor version. For
|
|
||||||
purposes of this definition, "control" includes the right to grant
|
|
||||||
patent sublicenses in a manner consistent with the requirements of
|
|
||||||
this License.
|
|
||||||
|
|
||||||
Each contributor grants you a non-exclusive, worldwide, royalty-free
|
|
||||||
patent license under the contributor's essential patent claims, to
|
|
||||||
make, use, sell, offer for sale, import and otherwise run, modify and
|
|
||||||
propagate the contents of its contributor version.
|
|
||||||
|
|
||||||
In the following three paragraphs, a "patent license" is any express
|
|
||||||
agreement or commitment, however denominated, not to enforce a patent
|
|
||||||
(such as an express permission to practice a patent or covenant not to
|
|
||||||
sue for patent infringement). To "grant" such a patent license to a
|
|
||||||
party means to make such an agreement or commitment not to enforce a
|
|
||||||
patent against the party.
|
|
||||||
|
|
||||||
If you convey a covered work, knowingly relying on a patent license,
|
|
||||||
and the Corresponding Source of the work is not available for anyone
|
|
||||||
to copy, free of charge and under the terms of this License, through a
|
|
||||||
publicly available network server or other readily accessible means,
|
|
||||||
then you must either (1) cause the Corresponding Source to be so
|
|
||||||
available, or (2) arrange to deprive yourself of the benefit of the
|
|
||||||
patent license for this particular work, or (3) arrange, in a manner
|
|
||||||
consistent with the requirements of this License, to extend the patent
|
|
||||||
license to downstream recipients. "Knowingly relying" means you have
|
|
||||||
actual knowledge that, but for the patent license, your conveying the
|
|
||||||
covered work in a country, or your recipient's use of the covered work
|
|
||||||
in a country, would infringe one or more identifiable patents in that
|
|
||||||
country that you have reason to believe are valid.
|
|
||||||
|
|
||||||
If, pursuant to or in connection with a single transaction or
|
|
||||||
arrangement, you convey, or propagate by procuring conveyance of, a
|
|
||||||
covered work, and grant a patent license to some of the parties
|
|
||||||
receiving the covered work authorizing them to use, propagate, modify
|
|
||||||
or convey a specific copy of the covered work, then the patent license
|
|
||||||
you grant is automatically extended to all recipients of the covered
|
|
||||||
work and works based on it.
|
|
||||||
|
|
||||||
A patent license is "discriminatory" if it does not include within
|
|
||||||
the scope of its coverage, prohibits the exercise of, or is
|
|
||||||
conditioned on the non-exercise of one or more of the rights that are
|
|
||||||
specifically granted under this License. You may not convey a covered
|
|
||||||
work if you are a party to an arrangement with a third party that is
|
|
||||||
in the business of distributing software, under which you make payment
|
|
||||||
to the third party based on the extent of your activity of conveying
|
|
||||||
the work, and under which the third party grants, to any of the
|
|
||||||
parties who would receive the covered work from you, a discriminatory
|
|
||||||
patent license (a) in connection with copies of the covered work
|
|
||||||
conveyed by you (or copies made from those copies), or (b) primarily
|
|
||||||
for and in connection with specific products or compilations that
|
|
||||||
contain the covered work, unless you entered into that arrangement,
|
|
||||||
or that patent license was granted, prior to 28 March 2007.
|
|
||||||
|
|
||||||
Nothing in this License shall be construed as excluding or limiting
|
|
||||||
any implied license or other defenses to infringement that may
|
|
||||||
otherwise be available to you under applicable patent law.
|
|
||||||
|
|
||||||
12. No Surrender of Others' Freedom.
|
|
||||||
|
|
||||||
If conditions are imposed on you (whether by court order, agreement or
|
|
||||||
otherwise) that contradict the conditions of this License, they do not
|
|
||||||
excuse you from the conditions of this License. If you cannot convey a
|
|
||||||
covered work so as to satisfy simultaneously your obligations under this
|
|
||||||
License and any other pertinent obligations, then as a consequence you may
|
|
||||||
not convey it at all. For example, if you agree to terms that obligate you
|
|
||||||
to collect a royalty for further conveying from those to whom you convey
|
|
||||||
the Program, the only way you could satisfy both those terms and this
|
|
||||||
License would be to refrain entirely from conveying the Program.
|
|
||||||
|
|
||||||
13. Remote Network Interaction; Use with the GNU General Public License.
|
|
||||||
|
|
||||||
Notwithstanding any other provision of this License, if you modify the
|
|
||||||
Program, your modified version must prominently offer all users
|
|
||||||
interacting with it remotely through a computer network (if your version
|
|
||||||
supports such interaction) an opportunity to receive the Corresponding
|
|
||||||
Source of your version by providing access to the Corresponding Source
|
|
||||||
from a network server at no charge, through some standard or customary
|
|
||||||
means of facilitating copying of software. This Corresponding Source
|
|
||||||
shall include the Corresponding Source for any work covered by version 3
|
|
||||||
of the GNU General Public License that is incorporated pursuant to the
|
|
||||||
following paragraph.
|
|
||||||
|
|
||||||
Notwithstanding any other provision of this License, you have
|
|
||||||
permission to link or combine any covered work with a work licensed
|
|
||||||
under version 3 of the GNU General Public License into a single
|
|
||||||
combined work, and to convey the resulting work. The terms of this
|
|
||||||
License will continue to apply to the part which is the covered work,
|
|
||||||
but the work with which it is combined will remain governed by version
|
|
||||||
3 of the GNU General Public License.
|
|
||||||
|
|
||||||
14. Revised Versions of this License.
|
|
||||||
|
|
||||||
The Free Software Foundation may publish revised and/or new versions of
|
|
||||||
the GNU Affero General Public License from time to time. Such new versions
|
|
||||||
will be similar in spirit to the present version, but may differ in detail to
|
|
||||||
address new problems or concerns.
|
|
||||||
|
|
||||||
Each version is given a distinguishing version number. If the
|
|
||||||
Program specifies that a certain numbered version of the GNU Affero General
|
|
||||||
Public License "or any later version" applies to it, you have the
|
|
||||||
option of following the terms and conditions either of that numbered
|
|
||||||
version or of any later version published by the Free Software
|
|
||||||
Foundation. If the Program does not specify a version number of the
|
|
||||||
GNU Affero General Public License, you may choose any version ever published
|
|
||||||
by the Free Software Foundation.
|
|
||||||
|
|
||||||
If the Program specifies that a proxy can decide which future
|
|
||||||
versions of the GNU Affero General Public License can be used, that proxy's
|
|
||||||
public statement of acceptance of a version permanently authorizes you
|
|
||||||
to choose that version for the Program.
|
|
||||||
|
|
||||||
Later license versions may give you additional or different
|
|
||||||
permissions. However, no additional obligations are imposed on any
|
|
||||||
author or copyright holder as a result of your choosing to follow a
|
|
||||||
later version.
|
|
||||||
|
|
||||||
15. Disclaimer of Warranty.
|
|
||||||
|
|
||||||
THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
|
|
||||||
APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
|
|
||||||
HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
|
|
||||||
OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
|
|
||||||
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
||||||
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
|
|
||||||
IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
|
|
||||||
ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
|
|
||||||
|
|
||||||
16. Limitation of Liability.
|
|
||||||
|
|
||||||
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
|
||||||
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
|
|
||||||
THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
|
|
||||||
GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
|
|
||||||
USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
|
|
||||||
DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
|
|
||||||
PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
|
|
||||||
EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
|
|
||||||
SUCH DAMAGES.
|
|
||||||
|
|
||||||
17. Interpretation of Sections 15 and 16.
|
|
||||||
|
|
||||||
If the disclaimer of warranty and limitation of liability provided
|
|
||||||
above cannot be given local legal effect according to their terms,
|
|
||||||
reviewing courts shall apply local law that most closely approximates
|
|
||||||
an absolute waiver of all civil liability in connection with the
|
|
||||||
Program, unless a warranty or assumption of liability accompanies a
|
|
||||||
copy of the Program in return for a fee.
|
|
||||||
|
|
||||||
END OF TERMS AND CONDITIONS
|
|
||||||
|
|
||||||
How to Apply These Terms to Your New Programs
|
|
||||||
|
|
||||||
If you develop a new program, and you want it to be of the greatest
|
|
||||||
possible use to the public, the best way to achieve this is to make it
|
|
||||||
free software which everyone can redistribute and change under these terms.
|
|
||||||
|
|
||||||
To do so, attach the following notices to the program. It is safest
|
|
||||||
to attach them to the start of each source file to most effectively
|
|
||||||
state the exclusion of warranty; and each file should have at least
|
|
||||||
the "copyright" line and a pointer to where the full notice is found.
|
|
||||||
|
|
||||||
<one line to give the program's name and a brief idea of what it does.>
|
|
||||||
Copyright (C) <year> <name of author>
|
|
||||||
|
|
||||||
This program is free software: you can redistribute it and/or modify
|
|
||||||
it under the terms of the GNU Affero General Public License as published
|
|
||||||
by the Free Software Foundation, either version 3 of the License, or
|
|
||||||
(at your option) any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
GNU Affero General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Affero General Public License
|
|
||||||
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
Also add information on how to contact you by electronic and paper mail.
|
|
||||||
|
|
||||||
If your software can interact with users remotely through a computer
|
|
||||||
network, you should also make sure that it provides a way for users to
|
|
||||||
get its source. For example, if your program is a web application, its
|
|
||||||
interface could display a "Source" link that leads users to an archive
|
|
||||||
of the code. There are many ways you could offer source, and different
|
|
||||||
solutions will be better for different programs; see section 13 for the
|
|
||||||
specific requirements.
|
|
||||||
|
|
||||||
You should also get your employer (if you work as a programmer) or school,
|
|
||||||
if any, to sign a "copyright disclaimer" for the program, if necessary.
|
|
||||||
For more information on this, and how to apply and follow the GNU AGPL, see
|
|
||||||
<https://www.gnu.org/licenses/>.
|
|
||||||
12
README.md
12
README.md
@@ -155,14 +155,4 @@ Check out our [user case studies](https://github.com/OpenIMSDK/community/blob/ma
|
|||||||
|
|
||||||
## License :page_facing_up:
|
## License :page_facing_up:
|
||||||
|
|
||||||
This software is licensed under a dual-license model:
|
OpenIM is licensed under the Apache 2.0 license. See [LICENSE](https://github.com/openimsdk/open-im-server/tree/main/LICENSE) for the full license text.
|
||||||
|
|
||||||
- The GNU Affero General Public License (AGPL), Version 3 or later; **OR**
|
|
||||||
- Commercial license terms from OpenIMSDK.
|
|
||||||
|
|
||||||
If you wish to use this software under commercial terms, please contact us at: contact@openim.io
|
|
||||||
|
|
||||||
For more information, see: https://www.openim.io/en/licensing
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -15,10 +15,6 @@ def getCurrentProjectDir() {
|
|||||||
|
|
||||||
buildscript {
|
buildscript {
|
||||||
repositories {
|
repositories {
|
||||||
maven { url 'https://maven.aliyun.com/repository/public' }
|
|
||||||
maven { url 'https://maven.aliyun.com/repository/central' }
|
|
||||||
maven { url 'https://maven.aliyun.com/nexus/content/repositories/google' }
|
|
||||||
maven { url 'https://maven.aliyun.com/repository/gradle-plugin' }
|
|
||||||
google()
|
google()
|
||||||
mavenCentral()
|
mavenCentral()
|
||||||
}
|
}
|
||||||
@@ -30,6 +26,10 @@ buildscript {
|
|||||||
|
|
||||||
rootProject.allprojects {
|
rootProject.allprojects {
|
||||||
repositories {
|
repositories {
|
||||||
|
maven {
|
||||||
|
url 'http://192.168.77.132:8081/repository/mvn2-group'
|
||||||
|
allowInsecureProtocol true
|
||||||
|
}
|
||||||
google()
|
google()
|
||||||
mavenCentral()
|
mavenCentral()
|
||||||
}
|
}
|
||||||
@@ -38,10 +38,13 @@ rootProject.allprojects {
|
|||||||
apply plugin: 'com.android.library'
|
apply plugin: 'com.android.library'
|
||||||
|
|
||||||
android {
|
android {
|
||||||
compileSdkVersion 34
|
compileSdkVersion 30
|
||||||
|
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
minSdkVersion 21
|
minSdkVersion 21
|
||||||
|
ndk {
|
||||||
|
abiFilters "arm64-v8a","x86" // 根据需要添加其他 ABI
|
||||||
|
}
|
||||||
}
|
}
|
||||||
compileOptions {
|
compileOptions {
|
||||||
sourceCompatibility JavaVersion.VERSION_1_8
|
sourceCompatibility JavaVersion.VERSION_1_8
|
||||||
@@ -50,5 +53,5 @@ android {
|
|||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
implementation 'io.openim:core-sdk:3.8.3-patch3@aar'
|
implementation 'com.openim:sdkcore:1.0.0'
|
||||||
}
|
}
|
||||||
@@ -1,5 +1,6 @@
|
|||||||
|
#Tue Nov 12 14:22:37 CST 2024
|
||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
|
distributionUrl=https\://mirrors.cloud.tencent.com/gradle/gradle-7.4-bin.zip
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-6.7-all.zip
|
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ import io.openim.flutter_openim_sdk.manager.GroupManager;
|
|||||||
import io.openim.flutter_openim_sdk.manager.IMManager;
|
import io.openim.flutter_openim_sdk.manager.IMManager;
|
||||||
import io.openim.flutter_openim_sdk.manager.MessageManager;
|
import io.openim.flutter_openim_sdk.manager.MessageManager;
|
||||||
import io.openim.flutter_openim_sdk.manager.UserManager;
|
import io.openim.flutter_openim_sdk.manager.UserManager;
|
||||||
|
import io.openim.flutter_openim_sdk.manager.ChannelManager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* FlutterOpenimSdkPlugin
|
* FlutterOpenimSdkPlugin
|
||||||
@@ -42,6 +42,7 @@ public class FlutterOpenimSdkPlugin implements FlutterPlugin, MethodCallHandler,
|
|||||||
private static MessageManager messageManager;
|
private static MessageManager messageManager;
|
||||||
private static ConversationManager conversationManager;
|
private static ConversationManager conversationManager;
|
||||||
private static GroupManager groupManager;
|
private static GroupManager groupManager;
|
||||||
|
private static ChannelManager channelManager;
|
||||||
private static Activity activity;
|
private static Activity activity;
|
||||||
private static Context context;
|
private static Context context;
|
||||||
private ConnectivityListener connectivityListener;
|
private ConnectivityListener connectivityListener;
|
||||||
@@ -55,6 +56,8 @@ public class FlutterOpenimSdkPlugin implements FlutterPlugin, MethodCallHandler,
|
|||||||
FlutterOpenimSdkPlugin.messageManager = new MessageManager();
|
FlutterOpenimSdkPlugin.messageManager = new MessageManager();
|
||||||
FlutterOpenimSdkPlugin.conversationManager = new ConversationManager();
|
FlutterOpenimSdkPlugin.conversationManager = new ConversationManager();
|
||||||
FlutterOpenimSdkPlugin.groupManager = new GroupManager();
|
FlutterOpenimSdkPlugin.groupManager = new GroupManager();
|
||||||
|
FlutterOpenimSdkPlugin.channelManager = new ChannelManager();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,32 @@
|
|||||||
|
package io.openim.flutter_openim_sdk.listener;
|
||||||
|
|
||||||
|
import io.openim.flutter_openim_sdk.util.CommonUtil;
|
||||||
|
|
||||||
|
public class OnChannelListener implements open_im_sdk_callback.OnChannelListener {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChannelDismissed(String s) {
|
||||||
|
CommonUtil.emitEvent("channelListener", "onChannelDismissed", s);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChannelInfoChanged(String s) {
|
||||||
|
CommonUtil.emitEvent("channelListener", "onChannelInfoChanged", s);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChannelMemberAdded(String s) {
|
||||||
|
CommonUtil.emitEvent("channelListener", "onChannelMemberAdded", s);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChannelMemberDeleted(String s) {
|
||||||
|
CommonUtil.emitEvent("channelListener", "onChannelMemberDeleted", s);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChannelMemberInfoChanged(String s) {
|
||||||
|
CommonUtil.emitEvent("channelListener", "onChannelMemberInfoChanged", s);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,103 @@
|
|||||||
|
package io.openim.flutter_openim_sdk.manager;
|
||||||
|
|
||||||
|
import io.flutter.plugin.common.MethodCall;
|
||||||
|
import io.flutter.plugin.common.MethodChannel;
|
||||||
|
import io.openim.flutter_openim_sdk.listener.OnBaseListener;
|
||||||
|
import io.openim.flutter_openim_sdk.listener.OnChannelListener;
|
||||||
|
import open_im_sdk.Open_im_sdk;
|
||||||
|
|
||||||
|
public class ChannelManager extends BaseManager {
|
||||||
|
|
||||||
|
public void setChannelListener(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
Open_im_sdk.setChannelListener(new OnChannelListener());
|
||||||
|
|
||||||
|
result.success(null);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void getChannelMembersInfo(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
Open_im_sdk.getSpecifiedChannelMembersInfo(
|
||||||
|
new OnBaseListener(result, methodCall),
|
||||||
|
value(methodCall, "operationID"),
|
||||||
|
value(methodCall, "channelID"),
|
||||||
|
jsonValue(methodCall, "userIDList")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void getChannelMemberList(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
Open_im_sdk.getChannelMemberList(
|
||||||
|
new OnBaseListener(result, methodCall),
|
||||||
|
value(methodCall, "operationID"),
|
||||||
|
value(methodCall, "channelID"),
|
||||||
|
value(methodCall, "filter"),
|
||||||
|
value(methodCall, "offset"),
|
||||||
|
value(methodCall, "count")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void getChannelsInfo(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
Open_im_sdk.getSpecifiedChannelsInfo(
|
||||||
|
new OnBaseListener(result, methodCall),
|
||||||
|
value(methodCall, "operationID"),
|
||||||
|
jsonValue(methodCall, "channelIDList")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void joinChannel(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
Open_im_sdk.joinChannel(
|
||||||
|
new OnBaseListener(result, methodCall),
|
||||||
|
value(methodCall, "operationID"),
|
||||||
|
value(methodCall, "channelID"),
|
||||||
|
value(methodCall, "reason"),
|
||||||
|
value(methodCall, "joinSource"),
|
||||||
|
value(methodCall, "ex")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void quitChannel(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
Open_im_sdk.quitChannel(
|
||||||
|
new OnBaseListener(result, methodCall),
|
||||||
|
value(methodCall, "operationID"),
|
||||||
|
value(methodCall, "channelID")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public void changeChannelMute(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
Open_im_sdk.changeChannelMute(
|
||||||
|
new OnBaseListener(result, methodCall),
|
||||||
|
value(methodCall, "operationID"),
|
||||||
|
value(methodCall, "channelID"),
|
||||||
|
value(methodCall, "mute")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void changeChannelMemberMute(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
Open_im_sdk.changeChannelMemberMute(
|
||||||
|
new OnBaseListener(result, methodCall),
|
||||||
|
value(methodCall, "operationID"),
|
||||||
|
value(methodCall, "channelID"),
|
||||||
|
value(methodCall, "userID"),
|
||||||
|
int2long(methodCall, "seconds")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public void isJoinChannel(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
Open_im_sdk.isJoinChannel(new OnBaseListener(result, methodCall),
|
||||||
|
value(methodCall, "operationID"),
|
||||||
|
value(methodCall, "channelID")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void getUsersInChannel(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
Open_im_sdk.getUsersInChannel(new OnBaseListener(result, methodCall),
|
||||||
|
value(methodCall, "operationID"),
|
||||||
|
value(methodCall, "channelID"),
|
||||||
|
jsonValue(methodCall, "userIDs")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -27,6 +27,7 @@ public class MessageManager extends BaseManager {
|
|||||||
jsonValue(methodCall, "message"),
|
jsonValue(methodCall, "message"),
|
||||||
value(methodCall, "userID"),
|
value(methodCall, "userID"),
|
||||||
value(methodCall, "groupID"),
|
value(methodCall, "groupID"),
|
||||||
|
value(methodCall, "channelID"),
|
||||||
jsonValue(methodCall, "offlinePushInfo"),
|
jsonValue(methodCall, "offlinePushInfo"),
|
||||||
value(methodCall, "isOnlineOnly")
|
value(methodCall, "isOnlineOnly")
|
||||||
);
|
);
|
||||||
@@ -89,6 +90,7 @@ public class MessageManager extends BaseManager {
|
|||||||
value(methodCall, "operationID"),
|
value(methodCall, "operationID"),
|
||||||
jsonValue(methodCall, "message"),
|
jsonValue(methodCall, "message"),
|
||||||
value(methodCall, "groupID"),
|
value(methodCall, "groupID"),
|
||||||
|
value(methodCall, "channelID"),
|
||||||
value(methodCall, "senderID")
|
value(methodCall, "senderID")
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -339,6 +341,7 @@ public class MessageManager extends BaseManager {
|
|||||||
jsonValue(methodCall, "message"),
|
jsonValue(methodCall, "message"),
|
||||||
value(methodCall, "userID"),
|
value(methodCall, "userID"),
|
||||||
value(methodCall, "groupID"),
|
value(methodCall, "groupID"),
|
||||||
|
value(methodCall, "channelId"),
|
||||||
jsonValue(methodCall, "offlinePushInfo"),
|
jsonValue(methodCall, "offlinePushInfo"),
|
||||||
value(methodCall, "isOnlineOnly")
|
value(methodCall, "isOnlineOnly")
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -1,29 +0,0 @@
|
|||||||
PODS:
|
|
||||||
- Flutter (1.0.0)
|
|
||||||
- flutter_openim_sdk (0.0.1):
|
|
||||||
- Flutter
|
|
||||||
- OpenIMSDKCore (= 3.8.2)
|
|
||||||
- OpenIMSDKCore (3.8.2)
|
|
||||||
|
|
||||||
DEPENDENCIES:
|
|
||||||
- Flutter (from `Flutter`)
|
|
||||||
- flutter_openim_sdk (from `.symlinks/plugins/flutter_openim_sdk/ios`)
|
|
||||||
|
|
||||||
SPEC REPOS:
|
|
||||||
trunk:
|
|
||||||
- OpenIMSDKCore
|
|
||||||
|
|
||||||
EXTERNAL SOURCES:
|
|
||||||
Flutter:
|
|
||||||
:path: Flutter
|
|
||||||
flutter_openim_sdk:
|
|
||||||
:path: ".symlinks/plugins/flutter_openim_sdk/ios"
|
|
||||||
|
|
||||||
SPEC CHECKSUMS:
|
|
||||||
Flutter: e0871f40cf51350855a761d2e70bf5af5b9b5de7
|
|
||||||
flutter_openim_sdk: 77bdd08fb8dda1644a0c150b8ba7324f11b32404
|
|
||||||
OpenIMSDKCore: aaffd63079a874d9272b8b962598723cb8128d32
|
|
||||||
|
|
||||||
PODFILE CHECKSUM: 819463e6a0290f5a72f145ba7cde16e8b6ef0796
|
|
||||||
|
|
||||||
COCOAPODS: 1.15.2
|
|
||||||
@@ -10,12 +10,10 @@
|
|||||||
1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */ = {isa = PBXBuildFile; fileRef = 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */; };
|
1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */ = {isa = PBXBuildFile; fileRef = 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */; };
|
||||||
331C808B294A63AB00263BE5 /* RunnerTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 331C807B294A618700263BE5 /* RunnerTests.swift */; };
|
331C808B294A63AB00263BE5 /* RunnerTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 331C807B294A618700263BE5 /* RunnerTests.swift */; };
|
||||||
3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */ = {isa = PBXBuildFile; fileRef = 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */; };
|
3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */ = {isa = PBXBuildFile; fileRef = 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */; };
|
||||||
3E0FE62DE2A4D4E61AC3FD02 /* Pods_Runner.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 8BB3D975831D21A8FACEF96B /* Pods_Runner.framework */; };
|
|
||||||
74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 74858FAE1ED2DC5600515810 /* AppDelegate.swift */; };
|
74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 74858FAE1ED2DC5600515810 /* AppDelegate.swift */; };
|
||||||
97C146FC1CF9000F007C117D /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FA1CF9000F007C117D /* Main.storyboard */; };
|
97C146FC1CF9000F007C117D /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FA1CF9000F007C117D /* Main.storyboard */; };
|
||||||
97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FD1CF9000F007C117D /* Assets.xcassets */; };
|
97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FD1CF9000F007C117D /* Assets.xcassets */; };
|
||||||
97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */; };
|
97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */; };
|
||||||
F32475A5B591900F07118022 /* Pods_RunnerTests.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 119B0071FAB85FAD36937602 /* Pods_RunnerTests.framework */; };
|
|
||||||
/* End PBXBuildFile section */
|
/* End PBXBuildFile section */
|
||||||
|
|
||||||
/* Begin PBXContainerItemProxy section */
|
/* Begin PBXContainerItemProxy section */
|
||||||
@@ -42,19 +40,14 @@
|
|||||||
/* End PBXCopyFilesBuildPhase section */
|
/* End PBXCopyFilesBuildPhase section */
|
||||||
|
|
||||||
/* Begin PBXFileReference section */
|
/* Begin PBXFileReference section */
|
||||||
119B0071FAB85FAD36937602 /* Pods_RunnerTests.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_RunnerTests.framework; sourceTree = BUILT_PRODUCTS_DIR; };
|
|
||||||
1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = GeneratedPluginRegistrant.h; sourceTree = "<group>"; };
|
1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = GeneratedPluginRegistrant.h; sourceTree = "<group>"; };
|
||||||
1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = GeneratedPluginRegistrant.m; sourceTree = "<group>"; };
|
1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = GeneratedPluginRegistrant.m; sourceTree = "<group>"; };
|
||||||
331C807B294A618700263BE5 /* RunnerTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RunnerTests.swift; sourceTree = "<group>"; };
|
331C807B294A618700263BE5 /* RunnerTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RunnerTests.swift; sourceTree = "<group>"; };
|
||||||
331C8081294A63A400263BE5 /* RunnerTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = RunnerTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
|
331C8081294A63A400263BE5 /* RunnerTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = RunnerTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = "<group>"; };
|
3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = "<group>"; };
|
||||||
4D6806EF7C87F4A8E899A73E /* Pods-Runner.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.release.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"; sourceTree = "<group>"; };
|
|
||||||
5C84146D7BEE11433AA4DE9E /* Pods-RunnerTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.release.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.release.xcconfig"; sourceTree = "<group>"; };
|
|
||||||
74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Runner-Bridging-Header.h"; sourceTree = "<group>"; };
|
74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Runner-Bridging-Header.h"; sourceTree = "<group>"; };
|
||||||
74858FAE1ED2DC5600515810 /* AppDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = "<group>"; };
|
74858FAE1ED2DC5600515810 /* AppDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = "<group>"; };
|
||||||
7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = Release.xcconfig; path = Flutter/Release.xcconfig; sourceTree = "<group>"; };
|
7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = Release.xcconfig; path = Flutter/Release.xcconfig; sourceTree = "<group>"; };
|
||||||
7D277EA428A8FDCA196F3196 /* Pods-Runner.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.profile.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.profile.xcconfig"; sourceTree = "<group>"; };
|
|
||||||
8BB3D975831D21A8FACEF96B /* Pods_Runner.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Runner.framework; sourceTree = BUILT_PRODUCTS_DIR; };
|
|
||||||
9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Debug.xcconfig; path = Flutter/Debug.xcconfig; sourceTree = "<group>"; };
|
9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Debug.xcconfig; path = Flutter/Debug.xcconfig; sourceTree = "<group>"; };
|
||||||
9740EEB31CF90195004384FC /* Generated.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Generated.xcconfig; path = Flutter/Generated.xcconfig; sourceTree = "<group>"; };
|
9740EEB31CF90195004384FC /* Generated.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Generated.xcconfig; path = Flutter/Generated.xcconfig; sourceTree = "<group>"; };
|
||||||
97C146EE1CF9000F007C117D /* Runner.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Runner.app; sourceTree = BUILT_PRODUCTS_DIR; };
|
97C146EE1CF9000F007C117D /* Runner.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Runner.app; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
@@ -62,25 +55,13 @@
|
|||||||
97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
|
97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
|
||||||
97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; };
|
97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; };
|
||||||
97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
|
97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
|
||||||
BD60456F5D1660BF5A90F9A1 /* Pods-RunnerTests.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.profile.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.profile.xcconfig"; sourceTree = "<group>"; };
|
|
||||||
F0FFA291A8BB24B66A6DCC8C /* Pods-RunnerTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.debug.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.debug.xcconfig"; sourceTree = "<group>"; };
|
|
||||||
FA507785CCEA4423C40C3CCD /* Pods-Runner.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.debug.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"; sourceTree = "<group>"; };
|
|
||||||
/* End PBXFileReference section */
|
/* End PBXFileReference section */
|
||||||
|
|
||||||
/* Begin PBXFrameworksBuildPhase section */
|
/* Begin PBXFrameworksBuildPhase section */
|
||||||
1B803A0F046E9658A8FCEED0 /* Frameworks */ = {
|
|
||||||
isa = PBXFrameworksBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
F32475A5B591900F07118022 /* Pods_RunnerTests.framework in Frameworks */,
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
};
|
|
||||||
97C146EB1CF9000F007C117D /* Frameworks */ = {
|
97C146EB1CF9000F007C117D /* Frameworks */ = {
|
||||||
isa = PBXFrameworksBuildPhase;
|
isa = PBXFrameworksBuildPhase;
|
||||||
buildActionMask = 2147483647;
|
buildActionMask = 2147483647;
|
||||||
files = (
|
files = (
|
||||||
3E0FE62DE2A4D4E61AC3FD02 /* Pods_Runner.framework in Frameworks */,
|
|
||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
};
|
};
|
||||||
@@ -95,20 +76,6 @@
|
|||||||
path = RunnerTests;
|
path = RunnerTests;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
8575235C80CAB4F7FB7F5B46 /* Pods */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
FA507785CCEA4423C40C3CCD /* Pods-Runner.debug.xcconfig */,
|
|
||||||
4D6806EF7C87F4A8E899A73E /* Pods-Runner.release.xcconfig */,
|
|
||||||
7D277EA428A8FDCA196F3196 /* Pods-Runner.profile.xcconfig */,
|
|
||||||
F0FFA291A8BB24B66A6DCC8C /* Pods-RunnerTests.debug.xcconfig */,
|
|
||||||
5C84146D7BEE11433AA4DE9E /* Pods-RunnerTests.release.xcconfig */,
|
|
||||||
BD60456F5D1660BF5A90F9A1 /* Pods-RunnerTests.profile.xcconfig */,
|
|
||||||
);
|
|
||||||
name = Pods;
|
|
||||||
path = Pods;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
9740EEB11CF90186004384FC /* Flutter */ = {
|
9740EEB11CF90186004384FC /* Flutter */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
@@ -127,8 +94,6 @@
|
|||||||
97C146F01CF9000F007C117D /* Runner */,
|
97C146F01CF9000F007C117D /* Runner */,
|
||||||
97C146EF1CF9000F007C117D /* Products */,
|
97C146EF1CF9000F007C117D /* Products */,
|
||||||
331C8082294A63A400263BE5 /* RunnerTests */,
|
331C8082294A63A400263BE5 /* RunnerTests */,
|
||||||
8575235C80CAB4F7FB7F5B46 /* Pods */,
|
|
||||||
B94289CF044A7671B3BECB8E /* Frameworks */,
|
|
||||||
);
|
);
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
@@ -156,15 +121,6 @@
|
|||||||
path = Runner;
|
path = Runner;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
B94289CF044A7671B3BECB8E /* Frameworks */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
8BB3D975831D21A8FACEF96B /* Pods_Runner.framework */,
|
|
||||||
119B0071FAB85FAD36937602 /* Pods_RunnerTests.framework */,
|
|
||||||
);
|
|
||||||
name = Frameworks;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
/* End PBXGroup section */
|
/* End PBXGroup section */
|
||||||
|
|
||||||
/* Begin PBXNativeTarget section */
|
/* Begin PBXNativeTarget section */
|
||||||
@@ -172,10 +128,8 @@
|
|||||||
isa = PBXNativeTarget;
|
isa = PBXNativeTarget;
|
||||||
buildConfigurationList = 331C8087294A63A400263BE5 /* Build configuration list for PBXNativeTarget "RunnerTests" */;
|
buildConfigurationList = 331C8087294A63A400263BE5 /* Build configuration list for PBXNativeTarget "RunnerTests" */;
|
||||||
buildPhases = (
|
buildPhases = (
|
||||||
70DBF52745AF25A4FC72D8C3 /* [CP] Check Pods Manifest.lock */,
|
|
||||||
331C807D294A63A400263BE5 /* Sources */,
|
331C807D294A63A400263BE5 /* Sources */,
|
||||||
331C807F294A63A400263BE5 /* Resources */,
|
331C807F294A63A400263BE5 /* Resources */,
|
||||||
1B803A0F046E9658A8FCEED0 /* Frameworks */,
|
|
||||||
);
|
);
|
||||||
buildRules = (
|
buildRules = (
|
||||||
);
|
);
|
||||||
@@ -191,7 +145,6 @@
|
|||||||
isa = PBXNativeTarget;
|
isa = PBXNativeTarget;
|
||||||
buildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */;
|
buildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */;
|
||||||
buildPhases = (
|
buildPhases = (
|
||||||
3DCEC8459668E43AE9B4C8D5 /* [CP] Check Pods Manifest.lock */,
|
|
||||||
9740EEB61CF901F6004384FC /* Run Script */,
|
9740EEB61CF901F6004384FC /* Run Script */,
|
||||||
97C146EA1CF9000F007C117D /* Sources */,
|
97C146EA1CF9000F007C117D /* Sources */,
|
||||||
97C146EB1CF9000F007C117D /* Frameworks */,
|
97C146EB1CF9000F007C117D /* Frameworks */,
|
||||||
@@ -285,50 +238,6 @@
|
|||||||
shellPath = /bin/sh;
|
shellPath = /bin/sh;
|
||||||
shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" embed_and_thin";
|
shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" embed_and_thin";
|
||||||
};
|
};
|
||||||
3DCEC8459668E43AE9B4C8D5 /* [CP] Check Pods Manifest.lock */ = {
|
|
||||||
isa = PBXShellScriptBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
);
|
|
||||||
inputFileListPaths = (
|
|
||||||
);
|
|
||||||
inputPaths = (
|
|
||||||
"${PODS_PODFILE_DIR_PATH}/Podfile.lock",
|
|
||||||
"${PODS_ROOT}/Manifest.lock",
|
|
||||||
);
|
|
||||||
name = "[CP] Check Pods Manifest.lock";
|
|
||||||
outputFileListPaths = (
|
|
||||||
);
|
|
||||||
outputPaths = (
|
|
||||||
"$(DERIVED_FILE_DIR)/Pods-Runner-checkManifestLockResult.txt",
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
shellPath = /bin/sh;
|
|
||||||
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
|
|
||||||
showEnvVarsInLog = 0;
|
|
||||||
};
|
|
||||||
70DBF52745AF25A4FC72D8C3 /* [CP] Check Pods Manifest.lock */ = {
|
|
||||||
isa = PBXShellScriptBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
);
|
|
||||||
inputFileListPaths = (
|
|
||||||
);
|
|
||||||
inputPaths = (
|
|
||||||
"${PODS_PODFILE_DIR_PATH}/Podfile.lock",
|
|
||||||
"${PODS_ROOT}/Manifest.lock",
|
|
||||||
);
|
|
||||||
name = "[CP] Check Pods Manifest.lock";
|
|
||||||
outputFileListPaths = (
|
|
||||||
);
|
|
||||||
outputPaths = (
|
|
||||||
"$(DERIVED_FILE_DIR)/Pods-RunnerTests-checkManifestLockResult.txt",
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
shellPath = /bin/sh;
|
|
||||||
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
|
|
||||||
showEnvVarsInLog = 0;
|
|
||||||
};
|
|
||||||
9740EEB61CF901F6004384FC /* Run Script */ = {
|
9740EEB61CF901F6004384FC /* Run Script */ = {
|
||||||
isa = PBXShellScriptBuildPhase;
|
isa = PBXShellScriptBuildPhase;
|
||||||
alwaysOutOfDate = 1;
|
alwaysOutOfDate = 1;
|
||||||
@@ -470,7 +379,6 @@
|
|||||||
};
|
};
|
||||||
331C8088294A63A400263BE5 /* Debug */ = {
|
331C8088294A63A400263BE5 /* Debug */ = {
|
||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
baseConfigurationReference = F0FFA291A8BB24B66A6DCC8C /* Pods-RunnerTests.debug.xcconfig */;
|
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
BUNDLE_LOADER = "$(TEST_HOST)";
|
BUNDLE_LOADER = "$(TEST_HOST)";
|
||||||
CODE_SIGN_STYLE = Automatic;
|
CODE_SIGN_STYLE = Automatic;
|
||||||
@@ -488,7 +396,6 @@
|
|||||||
};
|
};
|
||||||
331C8089294A63A400263BE5 /* Release */ = {
|
331C8089294A63A400263BE5 /* Release */ = {
|
||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
baseConfigurationReference = 5C84146D7BEE11433AA4DE9E /* Pods-RunnerTests.release.xcconfig */;
|
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
BUNDLE_LOADER = "$(TEST_HOST)";
|
BUNDLE_LOADER = "$(TEST_HOST)";
|
||||||
CODE_SIGN_STYLE = Automatic;
|
CODE_SIGN_STYLE = Automatic;
|
||||||
@@ -504,7 +411,6 @@
|
|||||||
};
|
};
|
||||||
331C808A294A63A400263BE5 /* Profile */ = {
|
331C808A294A63A400263BE5 /* Profile */ = {
|
||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
baseConfigurationReference = BD60456F5D1660BF5A90F9A1 /* Pods-RunnerTests.profile.xcconfig */;
|
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
BUNDLE_LOADER = "$(TEST_HOST)";
|
BUNDLE_LOADER = "$(TEST_HOST)";
|
||||||
CODE_SIGN_STYLE = Automatic;
|
CODE_SIGN_STYLE = Automatic;
|
||||||
|
|||||||
@@ -4,7 +4,4 @@
|
|||||||
<FileRef
|
<FileRef
|
||||||
location = "group:Runner.xcodeproj">
|
location = "group:Runner.xcodeproj">
|
||||||
</FileRef>
|
</FileRef>
|
||||||
<FileRef
|
|
||||||
location = "group:Pods/Pods.xcodeproj">
|
|
||||||
</FileRef>
|
|
||||||
</Workspace>
|
</Workspace>
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
import Flutter
|
import Flutter
|
||||||
import UIKit
|
import UIKit
|
||||||
|
|
||||||
@main
|
@UIApplicationMain
|
||||||
@objc class AppDelegate: FlutterAppDelegate {
|
@objc class AppDelegate: FlutterAppDelegate {
|
||||||
override func application(
|
override func application(
|
||||||
_ application: UIApplication,
|
_ application: UIApplication,
|
||||||
|
|||||||
@@ -76,7 +76,7 @@ packages:
|
|||||||
path: ".."
|
path: ".."
|
||||||
relative: true
|
relative: true
|
||||||
source: path
|
source: path
|
||||||
version: "3.8.3+hotfix.3"
|
version: "3.8.1+1"
|
||||||
flutter_test:
|
flutter_test:
|
||||||
dependency: "direct dev"
|
dependency: "direct dev"
|
||||||
description: flutter
|
description: flutter
|
||||||
@@ -86,18 +86,18 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: leak_tracker
|
name: leak_tracker
|
||||||
sha256: "3f87a60e8c63aecc975dda1ceedbc8f24de75f09e4856ea27daf8958f2f0ce05"
|
sha256: "7f0df31977cb2c0b88585095d168e689669a2cc9b97c309665e3386f3e9d341a"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "10.0.5"
|
version: "10.0.4"
|
||||||
leak_tracker_flutter_testing:
|
leak_tracker_flutter_testing:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: leak_tracker_flutter_testing
|
name: leak_tracker_flutter_testing
|
||||||
sha256: "932549fb305594d82d7183ecd9fa93463e9914e1b67cacc34bc40906594a1806"
|
sha256: "06e98f569d004c1315b991ded39924b21af84cf14cc94791b8aea337d25b57f8"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "3.0.5"
|
version: "3.0.3"
|
||||||
leak_tracker_testing:
|
leak_tracker_testing:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -126,18 +126,18 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: material_color_utilities
|
name: material_color_utilities
|
||||||
sha256: f7142bb1154231d7ea5f96bc7bde4bda2a0945d2806bb11670e30b850d56bdec
|
sha256: "0e0a020085b65b6083975e499759762399b4475f766c21668c4ecca34ea74e5a"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "0.11.1"
|
version: "0.8.0"
|
||||||
meta:
|
meta:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: meta
|
name: meta
|
||||||
sha256: bdb68674043280c3428e9ec998512fb681678676b3c54e773629ffe74419f8c7
|
sha256: "7687075e408b093f36e6bbf6c91878cc0d4cd10f409506f7bc996f68220b9136"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.15.0"
|
version: "1.12.0"
|
||||||
path:
|
path:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -195,10 +195,10 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: test_api
|
name: test_api
|
||||||
sha256: "5b8a98dafc4d5c4c9c72d8b31ab2b23fc13422348d2997120294d3bac86b4ddb"
|
sha256: "9955ae474176f7ac8ee4e989dadfb411a58c30415bcfb648fa04b2b8a03afa7f"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "0.7.2"
|
version: "0.7.0"
|
||||||
vector_math:
|
vector_math:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -211,10 +211,10 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: vm_service
|
name: vm_service
|
||||||
sha256: "5c5f338a667b4c644744b661f309fb8080bb94b18a7e91ef1dbd343bed00ed6d"
|
sha256: "3923c89304b715fb1eb6423f017651664a03bf5f4b29983627c4da791f74a4ec"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "14.2.5"
|
version: "14.2.1"
|
||||||
sdks:
|
sdks:
|
||||||
dart: ">=3.4.4 <4.0.0"
|
dart: ">=3.4.4 <4.0.0"
|
||||||
flutter: ">=3.18.0-18.0.pre.54"
|
flutter: ">=3.18.0-18.0.pre.54"
|
||||||
|
|||||||
101
ios/Classes/Module/ChannelManager.swift
Normal file
101
ios/Classes/Module/ChannelManager.swift
Normal file
@@ -0,0 +1,101 @@
|
|||||||
|
import Foundation
|
||||||
|
import OpenIMCore
|
||||||
|
|
||||||
|
public class ChannelManager: BaseServiceManager {
|
||||||
|
|
||||||
|
public override func registerHandlers() {
|
||||||
|
super.registerHandlers()
|
||||||
|
|
||||||
|
// self["changeChannelMemberMute"] = changeChannelMemberMute
|
||||||
|
// self["changeChannelMute"] = changeChannelMute
|
||||||
|
|
||||||
|
// self["getChannelMemberList"] = getChannelMemberList
|
||||||
|
|
||||||
|
|
||||||
|
self["getChannelMembersInfo"] = getChannelMembersInfo
|
||||||
|
self["getChannelsInfo"] = getChannelsInfo
|
||||||
|
|
||||||
|
|
||||||
|
self["getUsersInChannel"] = getUsersInChannel
|
||||||
|
self["isJoinChannel"] = isJoinChannel
|
||||||
|
self["joinChannel"] = joinChannel
|
||||||
|
self["quitChannel"] = quitChannel
|
||||||
|
self["setChannelListener"] = setChannelListener
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// func changeChannelMemberMute(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
|
// Open_im_sdkChangeChannelMemberMute(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"], methodCall[string:"userID"], methodCall[int:"seconds"])
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func changeChannelMute(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
|
// Open_im_sdkChangeChannelMute(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"], methodCall[bool: "mute"])
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func getChannelMemberList(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
|
// Open_im_sdkGetChannelMemberList(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"], methodCall[int32: "filter"],
|
||||||
|
// methodCall[int32: "offset"], methodCall[int32: "count"])
|
||||||
|
// }
|
||||||
|
|
||||||
|
func getChannelMembersInfo(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
|
Open_im_sdkGetSpecifiedChannelMembersInfo(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"], methodCall[jsonString: "userIDList"])
|
||||||
|
}
|
||||||
|
|
||||||
|
func getChannelsInfo(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
|
Open_im_sdkGetSpecifiedChannelsInfo(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "channelIDList"])
|
||||||
|
}
|
||||||
|
|
||||||
|
func getUsersInChannel(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
|
Open_im_sdkGetUsersInChannel(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"],
|
||||||
|
methodCall[jsonString: "userIDs"])
|
||||||
|
}
|
||||||
|
|
||||||
|
func isJoinChannel(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
|
Open_im_sdkIsJoinChannel(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"])
|
||||||
|
}
|
||||||
|
|
||||||
|
func joinChannel(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
|
Open_im_sdkJoinChannel(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"], methodCall[string:
|
||||||
|
"reason"], methodCall[int32: "joinSource"], methodCall[jsonString: "ex"])
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
func quitChannel(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
|
Open_im_sdkQuitChannel(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"])
|
||||||
|
}
|
||||||
|
|
||||||
|
func setChannelListener(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
|
Open_im_sdkSetChannelListener(ChannelListener(channel: channel))
|
||||||
|
callBack(result)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class ChannelListener: NSObject, Open_im_sdk_callbackOnChannelListenerProtocol {
|
||||||
|
|
||||||
|
private let channel: FlutterMethodChannel
|
||||||
|
|
||||||
|
init(channel: FlutterMethodChannel) {
|
||||||
|
self.channel = channel
|
||||||
|
}
|
||||||
|
|
||||||
|
public func onChannelDismissed(_ s: String?) {
|
||||||
|
CommonUtil.emitEvent(channel: channel, method: "channelListener", type: "onChannelDismissed", errCode: nil, errMsg: nil, data: s)
|
||||||
|
}
|
||||||
|
|
||||||
|
public func onChannelInfoChanged(_ s: String?) {
|
||||||
|
CommonUtil.emitEvent(channel: channel, method: "channelListener", type: "onChannelInfoChanged", errCode: nil, errMsg: nil, data: s)
|
||||||
|
}
|
||||||
|
|
||||||
|
public func onChannelMemberAdded(_ s: String?) {
|
||||||
|
CommonUtil.emitEvent(channel: channel, method: "channelListener", type: "onChannelMemberAdded", errCode: nil, errMsg: nil, data: s)
|
||||||
|
}
|
||||||
|
|
||||||
|
public func onChannelMemberDeleted(_ s: String?) {
|
||||||
|
CommonUtil.emitEvent(channel: channel, method: "channelListener", type: "onChannelMemberDeleted", errCode: nil, errMsg: nil, data: s)
|
||||||
|
}
|
||||||
|
|
||||||
|
public func onChannelMemberInfoChanged(_ s: String?) {
|
||||||
|
CommonUtil.emitEvent(channel: channel, method: "channelListener", type: "onChannelMemberInfoChanged", errCode: nil, errMsg: nil, data: s)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -65,7 +65,7 @@ public class MessageManager: BaseServiceManager {
|
|||||||
func sendMessage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func sendMessage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
let sendMsgProgressListener: SendMsgProgressListener = SendMsgProgressListener(channel: channel,result: result,methodCall: methodCall)
|
let sendMsgProgressListener: SendMsgProgressListener = SendMsgProgressListener(channel: channel,result: result,methodCall: methodCall)
|
||||||
Open_im_sdkSendMessage(sendMsgProgressListener, methodCall[string: "operationID"], methodCall[jsonString: "message"], methodCall[string: "userID"],
|
Open_im_sdkSendMessage(sendMsgProgressListener, methodCall[string: "operationID"], methodCall[jsonString: "message"], methodCall[string: "userID"],
|
||||||
methodCall[string: "groupID"], methodCall[jsonString: "offlinePushInfo"], methodCall[bool: "isOnlineOnly"])
|
methodCall[string: "groupID"], methodCall[string: "channelID"],methodCall[jsonString: "offlinePushInfo"], methodCall[bool: "isOnlineOnly"])
|
||||||
}
|
}
|
||||||
|
|
||||||
func revokeMessage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func revokeMessage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
@@ -95,7 +95,7 @@ public class MessageManager: BaseServiceManager {
|
|||||||
|
|
||||||
func insertGroupMessageToLocalStorage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func insertGroupMessageToLocalStorage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkInsertGroupMessageToLocalStorage(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "message"],
|
Open_im_sdkInsertGroupMessageToLocalStorage(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "message"],
|
||||||
methodCall[string: "groupID"], methodCall[string: "senderID"])
|
methodCall[string: "groupID"], methodCall[string: "channelID"],methodCall[string: "senderID"])
|
||||||
}
|
}
|
||||||
|
|
||||||
func markMessagesAsReadByMsgID(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func markMessagesAsReadByMsgID(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
@@ -227,7 +227,7 @@ public class MessageManager: BaseServiceManager {
|
|||||||
|
|
||||||
func sendMessageNotOss(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func sendMessageNotOss(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
let sendMsgProgressListener: SendMsgProgressListener = SendMsgProgressListener(channel: channel,result: result,methodCall: methodCall)
|
let sendMsgProgressListener: SendMsgProgressListener = SendMsgProgressListener(channel: channel,result: result,methodCall: methodCall)
|
||||||
Open_im_sdkSendMessageNotOss(sendMsgProgressListener, methodCall[string: "operationID"], methodCall[jsonString: "message"], methodCall[string: "userID"], methodCall[string: "groupID"], methodCall[jsonString: "offlinePushInfo"], methodCall[bool: "isOnlineOnly"])
|
Open_im_sdkSendMessageNotOss(sendMsgProgressListener, methodCall[string: "operationID"], methodCall[jsonString: "message"], methodCall[string: "userID"], methodCall[string: "groupID"], methodCall[string: "channelID"],methodCall[jsonString: "offlinePushInfo"], methodCall[bool: "isOnlineOnly"])
|
||||||
}
|
}
|
||||||
|
|
||||||
func createImageMessageByURL(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func createImageMessageByURL(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
|
|||||||
@@ -8,13 +8,15 @@ public class SwiftFlutterOpenimSdkPlugin: NSObject, FlutterPlugin {
|
|||||||
let messageManager: MessageManager
|
let messageManager: MessageManager
|
||||||
let groupManager: GroupManager
|
let groupManager: GroupManager
|
||||||
let userManger: UserManager
|
let userManger: UserManager
|
||||||
|
let channelManager: ChannelManager
|
||||||
|
|
||||||
init(channel: FlutterMethodChannel) {
|
init(channel: FlutterMethodChannel) {
|
||||||
self.imManager = IMMananger(channel: channel)
|
self.imManager = IMMananger(channel: channel)
|
||||||
self.conversationManager = ConversationManager(channel: channel)
|
self.conversationManager = ConversationManager(channel: channel)
|
||||||
self.friendshipManager = FriendshipManager(channel: channel)
|
self.friendshipManager = FriendshipManager(channel: channel)
|
||||||
self.messageManager = MessageManager(channel: channel)
|
self.messageManager = MessageManager(channel: channel)
|
||||||
self.groupManager = GroupManager(channel: channel)
|
self.groupManager = GroupManager(channel: channel)
|
||||||
|
self.channelManager = ChannelManager(channel: channel)
|
||||||
self.userManger = UserManager(channel: channel)
|
self.userManger = UserManager(channel: channel)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -37,6 +39,8 @@ public class SwiftFlutterOpenimSdkPlugin: NSObject, FlutterPlugin {
|
|||||||
friendshipManager.handleMethod(call: call, result: result)
|
friendshipManager.handleMethod(call: call, result: result)
|
||||||
case "groupManager":
|
case "groupManager":
|
||||||
groupManager.handleMethod(call: call, result: result)
|
groupManager.handleMethod(call: call, result: result)
|
||||||
|
case "channelManager":
|
||||||
|
channelManager.handleMethod(call: call, result: result)
|
||||||
case "userManager":
|
case "userManager":
|
||||||
userManger.handleMethod(call: call, result: result)
|
userManger.handleMethod(call: call, result: result)
|
||||||
default:
|
default:
|
||||||
|
|||||||
@@ -17,10 +17,15 @@ A new Flutter project.
|
|||||||
s.dependency 'Flutter'
|
s.dependency 'Flutter'
|
||||||
s.platform = :ios, '11.0'
|
s.platform = :ios, '11.0'
|
||||||
|
|
||||||
s.dependency 'OpenIMSDKCore','3.8.3+3'
|
#s.ios.vendored_frameworks = 'frameworks/*.xcframework'
|
||||||
|
#s.vendored_frameworks = 'frameworks/*.xcframework'
|
||||||
|
s.dependency 'openim_sdk_core_ios','0.2.0'
|
||||||
s.static_framework = true
|
s.static_framework = true
|
||||||
s.library = 'resolv'
|
s.library = 'resolv'
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# s.vendored_frameworks = 'Framework/*.xcframework'
|
# s.vendored_frameworks = 'Framework/*.xcframework'
|
||||||
# Flutter.framework does not contain a i386 slice.
|
# Flutter.framework does not contain a i386 slice.
|
||||||
s.pod_target_xcconfig = { 'DEFINES_MODULE' => 'YES', 'EXCLUDED_ARCHS[sdk=iphonesimulator*]' => 'i386 arm64' }
|
s.pod_target_xcconfig = { 'DEFINES_MODULE' => 'YES', 'EXCLUDED_ARCHS[sdk=iphonesimulator*]' => 'i386 arm64' }
|
||||||
|
|||||||
@@ -17,6 +17,7 @@ export 'src/listener/conversation_listener.dart';
|
|||||||
export 'src/listener/custom_business_listener.dart';
|
export 'src/listener/custom_business_listener.dart';
|
||||||
export 'src/listener/friendship_listener.dart';
|
export 'src/listener/friendship_listener.dart';
|
||||||
export 'src/listener/group_listener.dart';
|
export 'src/listener/group_listener.dart';
|
||||||
|
export 'src/listener/channel_listener.dart';
|
||||||
export 'src/listener/listener_for_service.dart';
|
export 'src/listener/listener_for_service.dart';
|
||||||
export 'src/listener/msg_send_progress_listener.dart';
|
export 'src/listener/msg_send_progress_listener.dart';
|
||||||
export 'src/listener/upload_file_listener.dart';
|
export 'src/listener/upload_file_listener.dart';
|
||||||
@@ -24,11 +25,13 @@ export 'src/listener/user_listener.dart';
|
|||||||
export 'src/manager/im_conversation_manager.dart';
|
export 'src/manager/im_conversation_manager.dart';
|
||||||
export 'src/manager/im_friendship_manager.dart';
|
export 'src/manager/im_friendship_manager.dart';
|
||||||
export 'src/manager/im_group_manager.dart';
|
export 'src/manager/im_group_manager.dart';
|
||||||
|
export 'src/manager/im_channel_manager.dart';
|
||||||
export 'src/manager/im_manager.dart';
|
export 'src/manager/im_manager.dart';
|
||||||
export 'src/manager/im_message_manager.dart';
|
export 'src/manager/im_message_manager.dart';
|
||||||
export 'src/manager/im_user_manager.dart';
|
export 'src/manager/im_user_manager.dart';
|
||||||
export 'src/models/conversation_info.dart';
|
export 'src/models/conversation_info.dart';
|
||||||
export 'src/models/group_info.dart';
|
export 'src/models/group_info.dart';
|
||||||
|
export 'src/models/channel_info.dart';
|
||||||
export 'src/models/init_config.dart';
|
export 'src/models/init_config.dart';
|
||||||
export 'src/models/message.dart';
|
export 'src/models/message.dart';
|
||||||
export 'src/models/notification_info.dart';
|
export 'src/models/notification_info.dart';
|
||||||
|
|||||||
@@ -12,4 +12,8 @@ class ConversationType {
|
|||||||
|
|
||||||
/// Notification
|
/// Notification
|
||||||
static const notification = 4;
|
static const notification = 4;
|
||||||
|
|
||||||
|
/// Super channel chat
|
||||||
|
static const superChannel = 11;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ class ListenerType {
|
|||||||
static const connectListener = 'connectListener';
|
static const connectListener = 'connectListener';
|
||||||
static const userListener = 'userListener';
|
static const userListener = 'userListener';
|
||||||
static const groupListener = 'groupListener';
|
static const groupListener = 'groupListener';
|
||||||
|
static const channelListener = 'channelListener';
|
||||||
static const advancedMsgListener = 'advancedMsgListener';
|
static const advancedMsgListener = 'advancedMsgListener';
|
||||||
static const conversationListener = 'conversationListener';
|
static const conversationListener = 'conversationListener';
|
||||||
static const friendListener = 'friendListener';
|
static const friendListener = 'friendListener';
|
||||||
|
|||||||
@@ -12,12 +12,3 @@ class MessageStatus {
|
|||||||
/// Already deleted
|
/// Already deleted
|
||||||
static const deleted = 4;
|
static const deleted = 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
enum GetHistoryViewType {
|
|
||||||
history(0),
|
|
||||||
search(1);
|
|
||||||
|
|
||||||
final int rawValue;
|
|
||||||
|
|
||||||
const GetHistoryViewType(this.rawValue);
|
|
||||||
}
|
|
||||||
|
|||||||
60
lib/src/listener/channel_listener.dart
Normal file
60
lib/src/listener/channel_listener.dart
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
||||||
|
|
||||||
|
import '../models/channel_info.dart';
|
||||||
|
|
||||||
|
/// Channel Listener
|
||||||
|
class OnChannelListener {
|
||||||
|
|
||||||
|
Function(ChannelInfo info)? onChannelDismissed;
|
||||||
|
Function(ChannelInfo info)? onChannelInfoChanged;
|
||||||
|
Function(ChannelMembersInfo info)? onChannelMemberAdded;
|
||||||
|
Function(ChannelMembersInfo info)? onChannelMemberDeleted;
|
||||||
|
Function(ChannelMembersInfo info)? onChannelMemberInfoChanged;
|
||||||
|
Function(ChannelInfo info)? onJoinedChannelAdded;
|
||||||
|
Function(ChannelInfo info)? onJoinedChannelDeleted;
|
||||||
|
|
||||||
|
OnChannelListener({
|
||||||
|
this.onChannelDismissed,
|
||||||
|
this.onChannelInfoChanged,
|
||||||
|
this.onChannelMemberAdded,
|
||||||
|
this.onChannelMemberDeleted,
|
||||||
|
this.onChannelMemberInfoChanged,
|
||||||
|
this.onJoinedChannelAdded,
|
||||||
|
this.onJoinedChannelDeleted,
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
void channelDismissed(ChannelInfo info) {
|
||||||
|
onChannelDismissed?.call(info);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Channel information changed
|
||||||
|
void channelInfoChanged(ChannelInfo info) {
|
||||||
|
onChannelInfoChanged?.call(info);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Channel member added
|
||||||
|
void channelMemberAdded(ChannelMembersInfo info) {
|
||||||
|
onChannelMemberAdded?.call(info);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Channel member deleted
|
||||||
|
void channelMemberDeleted(ChannelMembersInfo info) {
|
||||||
|
onChannelMemberDeleted?.call(info);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Channel member information changed
|
||||||
|
void channelMemberInfoChanged(ChannelMembersInfo info) {
|
||||||
|
onChannelMemberInfoChanged?.call(info);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Joined channel added
|
||||||
|
void joinedChannelAdded(ChannelInfo info) {
|
||||||
|
onJoinedChannelAdded?.call(info);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Joined channel deleted
|
||||||
|
void joinedChannelDeleted(ChannelInfo info) {
|
||||||
|
onJoinedChannelDeleted?.call(info);
|
||||||
|
}
|
||||||
|
}
|
||||||
323
lib/src/manager/im_channel_manager.dart
Normal file
323
lib/src/manager/im_channel_manager.dart
Normal file
@@ -0,0 +1,323 @@
|
|||||||
|
import 'dart:developer';
|
||||||
|
|
||||||
|
import 'package:flutter/services.dart';
|
||||||
|
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
||||||
|
import 'package:flutter_openim_sdk/src/models/set_channel_member_info.dart';
|
||||||
|
|
||||||
|
import '../listener/channel_listener.dart';
|
||||||
|
import '../models/channel_info.dart';
|
||||||
|
|
||||||
|
class ChannelManager {
|
||||||
|
MethodChannel _channel;
|
||||||
|
late OnChannelListener listener;
|
||||||
|
|
||||||
|
ChannelManager(this._channel);
|
||||||
|
|
||||||
|
/// Channel relationship listener
|
||||||
|
Future setChannelListener(OnChannelListener listener) {
|
||||||
|
this.listener = listener;
|
||||||
|
return _channel.invokeMethod('setChannelListener', _buildParam({}));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Query channel member information
|
||||||
|
/// [channelID] Channel ID
|
||||||
|
/// [userIDList] List of user IDs
|
||||||
|
Future<List<ChannelMembersInfo>> getChannelMembersInfo({
|
||||||
|
required String channelID,
|
||||||
|
required List<String> userIDList,
|
||||||
|
String? operationID,
|
||||||
|
}) =>
|
||||||
|
_channel
|
||||||
|
.invokeMethod(
|
||||||
|
'getChannelMembersInfo',
|
||||||
|
_buildParam({
|
||||||
|
'channelID': channelID,
|
||||||
|
'userIDList': userIDList,
|
||||||
|
"operationID": Utils.checkOperationID(operationID),
|
||||||
|
}))
|
||||||
|
.then((value) =>
|
||||||
|
Utils.toList(value, (map) => ChannelMembersInfo.fromJson(map)));
|
||||||
|
|
||||||
|
/// Paginate and retrieve the channel member list
|
||||||
|
/// [channelID] Channel ID
|
||||||
|
/// [filter] Member filter (0: All, 1: Channel owner, 2: Administrator, 3: Regular member, 4: Admin + Regular member, 5: Channel owner + Admin)
|
||||||
|
/// [offset] Starting index
|
||||||
|
/// [count] Total count
|
||||||
|
Future<List<ChannelMembersInfo>> getChannelMemberList({
|
||||||
|
required String channelID,
|
||||||
|
int filter = 0,
|
||||||
|
int offset = 0,
|
||||||
|
int count = 0,
|
||||||
|
String? operationID,
|
||||||
|
}) =>
|
||||||
|
_channel
|
||||||
|
.invokeMethod(
|
||||||
|
'getChannelMemberList',
|
||||||
|
_buildParam({
|
||||||
|
'channelID': channelID,
|
||||||
|
'filter': filter,
|
||||||
|
'offset': offset,
|
||||||
|
'count': count,
|
||||||
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
|
}))
|
||||||
|
.then((value) =>
|
||||||
|
Utils.toList(value, (map) => ChannelMembersInfo.fromJson(map)));
|
||||||
|
|
||||||
|
// /// Paginate and retrieve the channel member list as a map
|
||||||
|
// /// [channelID] Channel ID
|
||||||
|
// /// [filter] Member filter (0: All, 1: Channel owner, 2: Administrator, 3: Regular member, 4: Admin + Regular member, 5: Channel owner + Admin)
|
||||||
|
// /// [offset] Starting index
|
||||||
|
// /// [count] Total count
|
||||||
|
// Future<List<dynamic>> getChannelMemberListMap({
|
||||||
|
// required String channelID,
|
||||||
|
// int filter = 0,
|
||||||
|
// int offset = 0,
|
||||||
|
// int count = 0,
|
||||||
|
// String? operationID,
|
||||||
|
// }) =>
|
||||||
|
// _channel
|
||||||
|
// .invokeMethod(
|
||||||
|
// 'getChannelMemberList',
|
||||||
|
// _buildParam({
|
||||||
|
// 'channelID': channelID,
|
||||||
|
// 'filter': filter,
|
||||||
|
// 'offset': offset,
|
||||||
|
// 'count': count,
|
||||||
|
// 'operationID': Utils.checkOperationID(operationID),
|
||||||
|
// }))
|
||||||
|
// .then((value) => Utils.toListMap(value));
|
||||||
|
|
||||||
|
// /// Query the list of joined channels
|
||||||
|
// Future<List<ChannelInfo>> getJoinedChannelList({String? operationID}) => _channel
|
||||||
|
// .invokeMethod(
|
||||||
|
// 'getJoinedChannelList',
|
||||||
|
// _buildParam({
|
||||||
|
// 'operationID': Utils.checkOperationID(operationID),
|
||||||
|
// }))
|
||||||
|
// .then((value) => Utils.toList(value, (map) => ChannelInfo.fromJson(map)));
|
||||||
|
//
|
||||||
|
// Future<List<ChannelInfo>> getJoinedChannelListPage({String? operationID, int offset = 0, int count = 40}) => _channel
|
||||||
|
// .invokeMethod(
|
||||||
|
// 'getJoinedChannelListPage',
|
||||||
|
// _buildParam({
|
||||||
|
// 'offset': offset,
|
||||||
|
// 'count': count,
|
||||||
|
// 'operationID': Utils.checkOperationID(operationID),
|
||||||
|
// }))
|
||||||
|
// .then((value) => Utils.toList(value, (map) => ChannelInfo.fromJson(map)));
|
||||||
|
|
||||||
|
// /// Query the list of joined channels
|
||||||
|
// Future<List<dynamic>> getJoinedChannelListMap({String? operationID}) =>
|
||||||
|
// _channel
|
||||||
|
// .invokeMethod(
|
||||||
|
// 'getJoinedChannelList',
|
||||||
|
// _buildParam({
|
||||||
|
// 'operationID': Utils.checkOperationID(operationID),
|
||||||
|
// }))
|
||||||
|
// .then((value) => Utils.toListMap(value));
|
||||||
|
|
||||||
|
/// Check if the user has joined a channel
|
||||||
|
/// [channelID] Channel ID
|
||||||
|
Future<bool> isJoinedChannel({
|
||||||
|
required String channelID,
|
||||||
|
String? operationID,
|
||||||
|
}) =>
|
||||||
|
_channel
|
||||||
|
.invokeMethod(
|
||||||
|
'isJoinChannel',
|
||||||
|
_buildParam({
|
||||||
|
'channelID': channelID,
|
||||||
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
|
}))
|
||||||
|
.then((value) => value == 'true' ? true : false);
|
||||||
|
|
||||||
|
/// Query channel information
|
||||||
|
Future<List<ChannelInfo>> getChannelsInfo({
|
||||||
|
required List<String> channelIDList,
|
||||||
|
String? operationID,
|
||||||
|
}) =>
|
||||||
|
_channel
|
||||||
|
.invokeMethod(
|
||||||
|
'getChannelsInfo',
|
||||||
|
_buildParam({
|
||||||
|
'channelIDList': channelIDList,
|
||||||
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
|
}))
|
||||||
|
.then((value) =>
|
||||||
|
Utils.toList(value, (map) => ChannelInfo.fromJson(map)));
|
||||||
|
|
||||||
|
/// Apply to join a channel, requiring approval from an administrator or the channel.
|
||||||
|
/// [joinSource] 2: Invited, 3: Searched, 4: Using a QR code
|
||||||
|
Future<dynamic> joinChannel(
|
||||||
|
{required String channelID,
|
||||||
|
String? reason,
|
||||||
|
String? operationID,
|
||||||
|
int joinSource = 3,
|
||||||
|
String? ex}) =>
|
||||||
|
_channel.invokeMethod(
|
||||||
|
'joinChannel',
|
||||||
|
_buildParam({
|
||||||
|
'channelID': channelID,
|
||||||
|
'reason': reason,
|
||||||
|
'joinSource': joinSource,
|
||||||
|
'ex': ex,
|
||||||
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
|
}));
|
||||||
|
|
||||||
|
/// Exit a channel
|
||||||
|
Future<dynamic> quitChannel({
|
||||||
|
required String channelID,
|
||||||
|
String? operationID,
|
||||||
|
}) =>
|
||||||
|
_channel.invokeMethod(
|
||||||
|
'quitChannel',
|
||||||
|
_buildParam({
|
||||||
|
'channelID': channelID,
|
||||||
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
|
}));
|
||||||
|
|
||||||
|
//
|
||||||
|
// /// Query a channel
|
||||||
|
// /// [keywordList] Search keywords; currently, only one keyword is supported, and it cannot be empty.
|
||||||
|
// /// [isSearchChannelID] Whether to search by channel ID (Note: cannot set both to false at the same time); defaults to false if not set.
|
||||||
|
// /// [isSearchChannelName] Whether to search by channel name; defaults to false if not set.
|
||||||
|
// Future<List<ChannelInfo>> searchChannels({
|
||||||
|
// List<String> keywordList = const [],
|
||||||
|
// bool isSearchChannelID = false,
|
||||||
|
// bool isSearchChannelName = false,
|
||||||
|
// String? operationID,
|
||||||
|
// }) =>
|
||||||
|
// _channel
|
||||||
|
// .invokeMethod(
|
||||||
|
// 'searchChannels',
|
||||||
|
// _buildParam({
|
||||||
|
// 'searchParam': {
|
||||||
|
// 'keywordList': keywordList,
|
||||||
|
// 'isSearchChannelID': isSearchChannelID,
|
||||||
|
// 'isSearchChannelName': isSearchChannelName,
|
||||||
|
// },
|
||||||
|
// 'operationID': Utils.checkOperationID(operationID),
|
||||||
|
// }))
|
||||||
|
// .then((value) => Utils.toList(value, (map) => ChannelInfo.fromJson(map)));
|
||||||
|
|
||||||
|
// /// Get a channel member list based on join time
|
||||||
|
// Future<List<ChannelMembersInfo>> getChannelMemberListByJoinTime({
|
||||||
|
// required String channelID,
|
||||||
|
// int offset = 0,
|
||||||
|
// int count = 0,
|
||||||
|
// int joinTimeBegin = 0,
|
||||||
|
// int joinTimeEnd = 0,
|
||||||
|
// List<String> filterUserIDList = const [],
|
||||||
|
// String? operationID,
|
||||||
|
// }) =>
|
||||||
|
// _channel
|
||||||
|
// .invokeMethod(
|
||||||
|
// 'getChannelMemberListByJoinTimeFilter',
|
||||||
|
// _buildParam({
|
||||||
|
// 'channelID': channelID,
|
||||||
|
// 'offset': offset,
|
||||||
|
// 'count': count,
|
||||||
|
// 'joinTimeBegin': joinTimeBegin,
|
||||||
|
// 'joinTimeEnd': joinTimeEnd,
|
||||||
|
// 'excludeUserIDList': filterUserIDList,
|
||||||
|
// 'operationID': Utils.checkOperationID(operationID),
|
||||||
|
// }))
|
||||||
|
// .then((value) => Utils.toList(value, (map) => ChannelMembersInfo.fromJson(map)));
|
||||||
|
|
||||||
|
// /// Search for channel members
|
||||||
|
// /// [channelID] Channel ID
|
||||||
|
// /// [keywordList] Search keywords; currently, only one keyword is supported, and it cannot be empty.
|
||||||
|
// /// [isSearchUserID] Whether to search by member ID
|
||||||
|
// /// [isSearchMemberNickname] Whether to search by member nickname
|
||||||
|
// /// [offset] Start index
|
||||||
|
// /// [count] Total count to retrieve
|
||||||
|
// Future<List<ChannelMembersInfo>> searchChannelMembers({
|
||||||
|
// required String channelID,
|
||||||
|
// List<String> keywordList = const [],
|
||||||
|
// bool isSearchUserID = false,
|
||||||
|
// bool isSearchMemberNickname = false,
|
||||||
|
// int offset = 0,
|
||||||
|
// int count = 40,
|
||||||
|
// String? operationID,
|
||||||
|
// }) =>
|
||||||
|
// _channel
|
||||||
|
// .invokeMethod(
|
||||||
|
// 'searchChannelMembers',
|
||||||
|
// _buildParam({
|
||||||
|
// 'searchParam': {
|
||||||
|
// 'channelID': channelID,
|
||||||
|
// 'keywordList': keywordList,
|
||||||
|
// 'isSearchUserID': isSearchUserID,
|
||||||
|
// 'isSearchMemberNickname': isSearchMemberNickname,
|
||||||
|
// 'offset': offset,
|
||||||
|
// 'count': count,
|
||||||
|
// },
|
||||||
|
// 'operationID': Utils.checkOperationID(operationID),
|
||||||
|
// }))
|
||||||
|
// .then((value) => Utils.toList(value, (map) => ChannelMembersInfo.fromJson(map)));
|
||||||
|
|
||||||
|
// /// Query a channel
|
||||||
|
// /// [channelID] Channel ID
|
||||||
|
// /// [keywordList] Search keyword, currently only supports searching with one keyword, and it cannot be empty
|
||||||
|
// /// [isSearchUserID] Whether to search member IDs with the keyword
|
||||||
|
// /// [isSearchMemberNickname] Whether to search member nicknames with the keyword
|
||||||
|
// /// [offset] Starting index
|
||||||
|
// /// [count] Total number to retrieve each time
|
||||||
|
// Future<List<dynamic>> searchChannelMembersListMap({
|
||||||
|
// required String channelID,
|
||||||
|
// List<String> keywordList = const [],
|
||||||
|
// bool isSearchUserID = false,
|
||||||
|
// bool isSearchMemberNickname = false,
|
||||||
|
// int offset = 0,
|
||||||
|
// int count = 40,
|
||||||
|
// String? operationID,
|
||||||
|
// }) =>
|
||||||
|
// _channel
|
||||||
|
// .invokeMethod(
|
||||||
|
// 'searchChannelMembers',
|
||||||
|
// _buildParam({
|
||||||
|
// 'searchParam': {
|
||||||
|
// 'channelID': channelID,
|
||||||
|
// 'keywordList': keywordList,
|
||||||
|
// 'isSearchUserID': isSearchUserID,
|
||||||
|
// 'isSearchMemberNickname': isSearchMemberNickname,
|
||||||
|
// 'offset': offset,
|
||||||
|
// 'count': count,
|
||||||
|
// },
|
||||||
|
// 'operationID': Utils.checkOperationID(operationID),
|
||||||
|
// }))
|
||||||
|
// .then((value) => Utils.toListMap(value));
|
||||||
|
//
|
||||||
|
// /// Modify the ChannelMemberInfo ex field
|
||||||
|
// Future<dynamic> setChannelMemberInfo({
|
||||||
|
// required SetChannelMemberInfo channelMembersInfo,
|
||||||
|
// String? operationID,
|
||||||
|
// }) =>
|
||||||
|
// _channel.invokeMethod(
|
||||||
|
// 'setChannelMemberInfo',
|
||||||
|
// _buildParam({
|
||||||
|
// 'info': channelMembersInfo.toJson(),
|
||||||
|
// 'operationID': Utils.checkOperationID(operationID),
|
||||||
|
// }));
|
||||||
|
|
||||||
|
Future<dynamic> getUsersInChannel(
|
||||||
|
String channelID,
|
||||||
|
List<String> userIDs, {
|
||||||
|
String? operationID,
|
||||||
|
}) =>
|
||||||
|
_channel.invokeMethod(
|
||||||
|
'getUsersInChannel',
|
||||||
|
_buildParam({
|
||||||
|
'channelID': channelID,
|
||||||
|
'userIDs': userIDs,
|
||||||
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
|
}));
|
||||||
|
|
||||||
|
static Map _buildParam(Map<String, dynamic> param) {
|
||||||
|
param["ManagerName"] = "channelManager";
|
||||||
|
param = Utils.cleanMap(param);
|
||||||
|
log('param: $param');
|
||||||
|
|
||||||
|
return param;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -6,6 +6,9 @@ import 'package:flutter/services.dart';
|
|||||||
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
||||||
import 'package:flutter_openim_sdk/src/logger.dart';
|
import 'package:flutter_openim_sdk/src/logger.dart';
|
||||||
|
|
||||||
|
import '../models/channel_info.dart';
|
||||||
|
import 'im_channel_manager.dart';
|
||||||
|
|
||||||
class IMManager {
|
class IMManager {
|
||||||
MethodChannel _channel;
|
MethodChannel _channel;
|
||||||
late ConversationManager conversationManager;
|
late ConversationManager conversationManager;
|
||||||
@@ -13,6 +16,7 @@ class IMManager {
|
|||||||
late MessageManager messageManager;
|
late MessageManager messageManager;
|
||||||
late GroupManager groupManager;
|
late GroupManager groupManager;
|
||||||
late UserManager userManager;
|
late UserManager userManager;
|
||||||
|
late ChannelManager channelManager;
|
||||||
|
|
||||||
late OnConnectListener _connectListener;
|
late OnConnectListener _connectListener;
|
||||||
OnListenerForService? _listenerForService;
|
OnListenerForService? _listenerForService;
|
||||||
@@ -29,6 +33,7 @@ class IMManager {
|
|||||||
friendshipManager = FriendshipManager(_channel);
|
friendshipManager = FriendshipManager(_channel);
|
||||||
messageManager = MessageManager(_channel);
|
messageManager = MessageManager(_channel);
|
||||||
groupManager = GroupManager(_channel);
|
groupManager = GroupManager(_channel);
|
||||||
|
channelManager = ChannelManager(_channel);
|
||||||
userManager = UserManager(_channel);
|
userManager = UserManager(_channel);
|
||||||
_addNativeCallback(_channel);
|
_addNativeCallback(_channel);
|
||||||
}
|
}
|
||||||
@@ -57,7 +62,7 @@ class IMManager {
|
|||||||
case 'onUserTokenExpired':
|
case 'onUserTokenExpired':
|
||||||
_connectListener.userTokenExpired();
|
_connectListener.userTokenExpired();
|
||||||
break;
|
break;
|
||||||
case 'onUserTokenInvalid':
|
case 'onUserTokenInvalid':
|
||||||
_connectListener.userTokenInvalid();
|
_connectListener.userTokenInvalid();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -123,7 +128,44 @@ class IMManager {
|
|||||||
groupManager.listener.joinedGroupDeleted(i);
|
groupManager.listener.joinedGroupDeleted(i);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else if (call.method == ListenerType.advancedMsgListener) {
|
} else if (call.method == ListenerType.channelListener) {
|
||||||
|
String type = call.arguments['type'];
|
||||||
|
dynamic data = call.arguments['data'];
|
||||||
|
switch (type) {
|
||||||
|
|
||||||
|
case 'onChannelDismissed':
|
||||||
|
final i = Utils.toObj(data, (map) => ChannelInfo.fromJson(map));
|
||||||
|
channelManager.listener.channelDismissed(i);
|
||||||
|
break;
|
||||||
|
case 'onChannelInfoChanged':
|
||||||
|
final i = Utils.toObj(data, (map) => ChannelInfo.fromJson(map));
|
||||||
|
channelManager.listener.channelInfoChanged(i);
|
||||||
|
break;
|
||||||
|
case 'onChannelMemberAdded':
|
||||||
|
final i = Utils.toObj(
|
||||||
|
data, (map) => ChannelMembersInfo.fromJson(map));
|
||||||
|
channelManager.listener.channelMemberAdded(i);
|
||||||
|
break;
|
||||||
|
case 'onChannelMemberDeleted':
|
||||||
|
final i = Utils.toObj(
|
||||||
|
data, (map) => ChannelMembersInfo.fromJson(map));
|
||||||
|
channelManager.listener.channelMemberDeleted(i);
|
||||||
|
break;
|
||||||
|
case 'onChannelMemberInfoChanged':
|
||||||
|
final i = Utils.toObj(
|
||||||
|
data, (map) => ChannelMembersInfo.fromJson(map));
|
||||||
|
channelManager.listener.channelMemberInfoChanged(i);
|
||||||
|
break;
|
||||||
|
case 'onJoinedChannelAdded':
|
||||||
|
final i = Utils.toObj(data, (map) => ChannelInfo.fromJson(map));
|
||||||
|
channelManager.listener.joinedChannelAdded(i);
|
||||||
|
break;
|
||||||
|
case 'onJoinedChannelDeleted':
|
||||||
|
final i = Utils.toObj(data, (map) => ChannelInfo.fromJson(map));
|
||||||
|
channelManager.listener.joinedChannelDeleted(i);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}else if (call.method == ListenerType.advancedMsgListener) {
|
||||||
var type = call.arguments['type'];
|
var type = call.arguments['type'];
|
||||||
// var id = call.arguments['data']['id'];
|
// var id = call.arguments['data']['id'];
|
||||||
switch (type) {
|
switch (type) {
|
||||||
@@ -412,8 +454,8 @@ class IMManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Deinitialize the SDK
|
/// Deinitialize the SDK
|
||||||
void unInitSDK() {
|
Future<dynamic> unInitSDK() {
|
||||||
_channel.invokeMethod('unInitSDK', _buildParam({}));
|
return _channel.invokeMethod('unInitSDK', _buildParam({}));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Login
|
/// Login
|
||||||
|
|||||||
@@ -36,6 +36,7 @@ class MessageManager {
|
|||||||
required OfflinePushInfo offlinePushInfo,
|
required OfflinePushInfo offlinePushInfo,
|
||||||
String? userID,
|
String? userID,
|
||||||
String? groupID,
|
String? groupID,
|
||||||
|
String? channelID,
|
||||||
bool isOnlineOnly = false,
|
bool isOnlineOnly = false,
|
||||||
String? operationID,
|
String? operationID,
|
||||||
}) =>
|
}) =>
|
||||||
@@ -47,6 +48,7 @@ class MessageManager {
|
|||||||
'offlinePushInfo': offlinePushInfo.toJson(),
|
'offlinePushInfo': offlinePushInfo.toJson(),
|
||||||
'userID': userID ?? '',
|
'userID': userID ?? '',
|
||||||
'groupID': groupID ?? '',
|
'groupID': groupID ?? '',
|
||||||
|
'channelID': channelID ?? '',
|
||||||
'isOnlineOnly': isOnlineOnly,
|
'isOnlineOnly': isOnlineOnly,
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
@@ -130,6 +132,7 @@ class MessageManager {
|
|||||||
/// [message] Message content
|
/// [message] Message content
|
||||||
Future<Message> insertGroupMessageToLocalStorage({
|
Future<Message> insertGroupMessageToLocalStorage({
|
||||||
String? groupID,
|
String? groupID,
|
||||||
|
String? channelID,
|
||||||
String? senderID,
|
String? senderID,
|
||||||
Message? message,
|
Message? message,
|
||||||
String? operationID,
|
String? operationID,
|
||||||
@@ -140,6 +143,7 @@ class MessageManager {
|
|||||||
_buildParam({
|
_buildParam({
|
||||||
"message": message?.toJson(),
|
"message": message?.toJson(),
|
||||||
"groupID": groupID,
|
"groupID": groupID,
|
||||||
|
"channelID": channelID,
|
||||||
"senderID": senderID,
|
"senderID": senderID,
|
||||||
"operationID": Utils.checkOperationID(operationID),
|
"operationID": Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
@@ -569,7 +573,7 @@ class MessageManager {
|
|||||||
Future<AdvancedMessage> getAdvancedHistoryMessageList({
|
Future<AdvancedMessage> getAdvancedHistoryMessageList({
|
||||||
String? conversationID,
|
String? conversationID,
|
||||||
Message? startMsg,
|
Message? startMsg,
|
||||||
GetHistoryViewType viewType = GetHistoryViewType.history,
|
int? lastMinSeq,
|
||||||
int? count,
|
int? count,
|
||||||
String? operationID,
|
String? operationID,
|
||||||
}) =>
|
}) =>
|
||||||
@@ -580,7 +584,7 @@ class MessageManager {
|
|||||||
'conversationID': conversationID ?? '',
|
'conversationID': conversationID ?? '',
|
||||||
'startClientMsgID': startMsg?.clientMsgID ?? '',
|
'startClientMsgID': startMsg?.clientMsgID ?? '',
|
||||||
'count': count ?? 40,
|
'count': count ?? 40,
|
||||||
'viewType': viewType.rawValue,
|
'lastMinSeq': lastMinSeq ?? 0,
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
.then((value) => Utils.toObj(value, (map) => AdvancedMessage.fromJson(map)));
|
.then((value) => Utils.toObj(value, (map) => AdvancedMessage.fromJson(map)));
|
||||||
@@ -592,7 +596,7 @@ class MessageManager {
|
|||||||
Future<AdvancedMessage> getAdvancedHistoryMessageListReverse({
|
Future<AdvancedMessage> getAdvancedHistoryMessageListReverse({
|
||||||
String? conversationID,
|
String? conversationID,
|
||||||
Message? startMsg,
|
Message? startMsg,
|
||||||
GetHistoryViewType viewType = GetHistoryViewType.history,
|
int? lastMinSeq,
|
||||||
int? count,
|
int? count,
|
||||||
String? operationID,
|
String? operationID,
|
||||||
}) =>
|
}) =>
|
||||||
@@ -603,7 +607,7 @@ class MessageManager {
|
|||||||
'conversationID': conversationID ?? '',
|
'conversationID': conversationID ?? '',
|
||||||
'startClientMsgID': startMsg?.clientMsgID ?? '',
|
'startClientMsgID': startMsg?.clientMsgID ?? '',
|
||||||
'count': count ?? 40,
|
'count': count ?? 40,
|
||||||
'viewType': viewType.rawValue,
|
'lastMinSeq': lastMinSeq ?? 0,
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
.then((value) => Utils.toObj(value, (map) => AdvancedMessage.fromJson(map)));
|
.then((value) => Utils.toObj(value, (map) => AdvancedMessage.fromJson(map)));
|
||||||
@@ -674,6 +678,7 @@ class MessageManager {
|
|||||||
required OfflinePushInfo offlinePushInfo,
|
required OfflinePushInfo offlinePushInfo,
|
||||||
String? userID,
|
String? userID,
|
||||||
String? groupID,
|
String? groupID,
|
||||||
|
String? channelID,
|
||||||
bool isOnlineOnly = false,
|
bool isOnlineOnly = false,
|
||||||
String? operationID,
|
String? operationID,
|
||||||
}) =>
|
}) =>
|
||||||
@@ -685,6 +690,7 @@ class MessageManager {
|
|||||||
'offlinePushInfo': offlinePushInfo.toJson(),
|
'offlinePushInfo': offlinePushInfo.toJson(),
|
||||||
'userID': userID ?? '',
|
'userID': userID ?? '',
|
||||||
'groupID': groupID ?? '',
|
'groupID': groupID ?? '',
|
||||||
|
'channelID': channelID ?? '',
|
||||||
'isOnlineOnly': isOnlineOnly,
|
'isOnlineOnly': isOnlineOnly,
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
|
|||||||
165
lib/src/models/channel_info.dart
Normal file
165
lib/src/models/channel_info.dart
Normal file
@@ -0,0 +1,165 @@
|
|||||||
|
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
||||||
|
|
||||||
|
/// Channel Information
|
||||||
|
class ChannelInfo {
|
||||||
|
/// Channel ID
|
||||||
|
String channelID;
|
||||||
|
|
||||||
|
/// Channel Name
|
||||||
|
String? channelName;
|
||||||
|
|
||||||
|
/// Channel Announcement
|
||||||
|
String? notification;
|
||||||
|
|
||||||
|
/// Channel Introduction
|
||||||
|
String? introduction;
|
||||||
|
|
||||||
|
/// Channel Avatar
|
||||||
|
String? faceURL;
|
||||||
|
|
||||||
|
/// Creation Time
|
||||||
|
int? createTime;
|
||||||
|
|
||||||
|
/// Number of Channel Members
|
||||||
|
int? memberCount;
|
||||||
|
|
||||||
|
/// Channel Status: 0 - Normal, 1 - Blocked, 2 - Dissolved, 3 - Muted
|
||||||
|
int? status;
|
||||||
|
|
||||||
|
/// Creator's ID
|
||||||
|
String? creatorUserID;
|
||||||
|
|
||||||
|
/// Channel Type [ChannelType]
|
||||||
|
int? channelType;
|
||||||
|
|
||||||
|
/// Extra Information
|
||||||
|
String? ex;
|
||||||
|
|
||||||
|
|
||||||
|
ChannelInfo({
|
||||||
|
required this.channelID,
|
||||||
|
this.channelName,
|
||||||
|
this.notification,
|
||||||
|
this.introduction,
|
||||||
|
this.faceURL,
|
||||||
|
this.createTime,
|
||||||
|
this.memberCount,
|
||||||
|
this.status,
|
||||||
|
this.creatorUserID,
|
||||||
|
this.channelType,
|
||||||
|
this.ex,
|
||||||
|
});
|
||||||
|
|
||||||
|
ChannelInfo.fromJson(Map<String, dynamic> json) : channelID = json['channelID'] {
|
||||||
|
channelName = json['channelName'];
|
||||||
|
notification = json['notification'];
|
||||||
|
introduction = json['introduction'];
|
||||||
|
faceURL = json['faceURL'];
|
||||||
|
createTime = json['createTime'];
|
||||||
|
memberCount = json['memberCount'];
|
||||||
|
status = json['status'];
|
||||||
|
creatorUserID = json['creatorUserID'];
|
||||||
|
channelType = json['channelType'];
|
||||||
|
ex = json['ex'];
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = Map<String, dynamic>();
|
||||||
|
data['channelID'] = this.channelID;
|
||||||
|
data['channelName'] = this.channelName;
|
||||||
|
data['notification'] = this.notification;
|
||||||
|
data['introduction'] = this.introduction;
|
||||||
|
data['faceURL'] = this.faceURL;
|
||||||
|
data['createTime'] = this.createTime;
|
||||||
|
data['memberCount'] = this.memberCount;
|
||||||
|
data['status'] = this.status;
|
||||||
|
data['creatorUserID'] = this.creatorUserID;
|
||||||
|
data['channelType'] = this.channelType;
|
||||||
|
data['ex'] = this.ex;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Corresponding Conversation Type for Channel Type
|
||||||
|
int get sessionType => ConversationType.superChannel;
|
||||||
|
|
||||||
|
@override
|
||||||
|
bool operator ==(Object other) =>
|
||||||
|
identical(this, other) || other is ChannelInfo && runtimeType == other.runtimeType && channelID == other.channelID;
|
||||||
|
|
||||||
|
@override
|
||||||
|
int get hashCode => channelID.hashCode;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Channel Member Information
|
||||||
|
class ChannelMembersInfo {
|
||||||
|
/// Channel ID
|
||||||
|
String? channelID;
|
||||||
|
|
||||||
|
/// User ID
|
||||||
|
String? userID;
|
||||||
|
|
||||||
|
/// Nickname
|
||||||
|
String? nickname;
|
||||||
|
|
||||||
|
/// Avatar
|
||||||
|
String? faceURL;
|
||||||
|
|
||||||
|
/// Role [ChannelRoleLevel]
|
||||||
|
int? roleLevel;
|
||||||
|
|
||||||
|
/// Join Time
|
||||||
|
int? joinTime;
|
||||||
|
|
||||||
|
/// Extra Information
|
||||||
|
String? ex;
|
||||||
|
|
||||||
|
/// Mute End Time (seconds)
|
||||||
|
int? muteEndTime;
|
||||||
|
|
||||||
|
ChannelMembersInfo({
|
||||||
|
this.channelID,
|
||||||
|
this.userID,
|
||||||
|
this.roleLevel,
|
||||||
|
this.joinTime,
|
||||||
|
this.nickname,
|
||||||
|
this.faceURL,
|
||||||
|
this.ex,
|
||||||
|
this.muteEndTime,
|
||||||
|
});
|
||||||
|
|
||||||
|
ChannelMembersInfo.fromJson(Map<String, dynamic> json) {
|
||||||
|
channelID = json['channelID'];
|
||||||
|
userID = json['userID'];
|
||||||
|
roleLevel = json['roleLevel'];
|
||||||
|
joinTime = json['joinTime'];
|
||||||
|
nickname = json['nickname'];
|
||||||
|
faceURL = json['faceURL'];
|
||||||
|
ex = json['ex'];
|
||||||
|
muteEndTime = json['muteEndTime'];
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = Map<String, dynamic>();
|
||||||
|
data['channelID'] = this.channelID;
|
||||||
|
data['userID'] = this.userID;
|
||||||
|
data['roleLevel'] = this.roleLevel;
|
||||||
|
data['joinTime'] = this.joinTime;
|
||||||
|
data['nickname'] = this.nickname;
|
||||||
|
data['faceURL'] = this.faceURL;
|
||||||
|
data['ex'] = this.ex;
|
||||||
|
data['muteEndTime'] = this.muteEndTime;
|
||||||
|
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
bool operator ==(Object other) =>
|
||||||
|
identical(this, other) ||
|
||||||
|
other is ChannelMembersInfo &&
|
||||||
|
runtimeType == other.runtimeType &&
|
||||||
|
channelID == other.channelID &&
|
||||||
|
userID == other.userID;
|
||||||
|
|
||||||
|
@override
|
||||||
|
int get hashCode => channelID.hashCode ^ userID.hashCode;
|
||||||
|
}
|
||||||
@@ -15,6 +15,9 @@ class ConversationInfo {
|
|||||||
// Group ID in case of a group chat
|
// Group ID in case of a group chat
|
||||||
String? groupID;
|
String? groupID;
|
||||||
|
|
||||||
|
// Channel ID in case of a channel chat
|
||||||
|
String? channelID;
|
||||||
|
|
||||||
// Display name or nickname
|
// Display name or nickname
|
||||||
String? showName;
|
String? showName;
|
||||||
|
|
||||||
@@ -69,6 +72,7 @@ class ConversationInfo {
|
|||||||
this.conversationType,
|
this.conversationType,
|
||||||
this.userID,
|
this.userID,
|
||||||
this.groupID,
|
this.groupID,
|
||||||
|
this.channelID,
|
||||||
this.showName,
|
this.showName,
|
||||||
this.faceURL,
|
this.faceURL,
|
||||||
this.recvMsgOpt,
|
this.recvMsgOpt,
|
||||||
@@ -91,6 +95,7 @@ class ConversationInfo {
|
|||||||
conversationType = json['conversationType'];
|
conversationType = json['conversationType'];
|
||||||
userID = json['userID'];
|
userID = json['userID'];
|
||||||
groupID = json['groupID'];
|
groupID = json['groupID'];
|
||||||
|
channelID = json['channelID'];
|
||||||
showName = json['showName'];
|
showName = json['showName'];
|
||||||
faceURL = json['faceURL'];
|
faceURL = json['faceURL'];
|
||||||
recvMsgOpt = json['recvMsgOpt'];
|
recvMsgOpt = json['recvMsgOpt'];
|
||||||
@@ -122,6 +127,7 @@ class ConversationInfo {
|
|||||||
data['conversationType'] = this.conversationType;
|
data['conversationType'] = this.conversationType;
|
||||||
data['userID'] = this.userID;
|
data['userID'] = this.userID;
|
||||||
data['groupID'] = this.groupID;
|
data['groupID'] = this.groupID;
|
||||||
|
data['channelID'] = this.channelID;
|
||||||
data['showName'] = this.showName;
|
data['showName'] = this.showName;
|
||||||
data['faceURL'] = this.faceURL;
|
data['faceURL'] = this.faceURL;
|
||||||
data['recvMsgOpt'] = this.recvMsgOpt;
|
data['recvMsgOpt'] = this.recvMsgOpt;
|
||||||
@@ -147,6 +153,10 @@ class ConversationInfo {
|
|||||||
// Check if it's a group chat
|
// Check if it's a group chat
|
||||||
bool get isGroupChat => conversationType == ConversationType.group || conversationType == ConversationType.superGroup;
|
bool get isGroupChat => conversationType == ConversationType.group || conversationType == ConversationType.superGroup;
|
||||||
|
|
||||||
|
// Check if it's a channel chat
|
||||||
|
bool get isChannelChat => conversationType == ConversationType.superChannel;
|
||||||
|
|
||||||
|
|
||||||
// Check if it's a valid conversation (not in a group if isNotInGroup is true)
|
// Check if it's a valid conversation (not in a group if isNotInGroup is true)
|
||||||
bool get isValid => isSingleChat || (isGroupChat && !isNotInGroup!);
|
bool get isValid => isSingleChat || (isGroupChat && !isNotInGroup!);
|
||||||
|
|
||||||
|
|||||||
@@ -42,6 +42,9 @@ class Message {
|
|||||||
/// Group ID.
|
/// Group ID.
|
||||||
String? groupID;
|
String? groupID;
|
||||||
|
|
||||||
|
/// Channel ID.
|
||||||
|
String? channelID;
|
||||||
|
|
||||||
/// Message localEx.
|
/// Message localEx.
|
||||||
String? localEx;
|
String? localEx;
|
||||||
|
|
||||||
@@ -137,6 +140,7 @@ class Message {
|
|||||||
this.senderNickname,
|
this.senderNickname,
|
||||||
this.senderFaceUrl,
|
this.senderFaceUrl,
|
||||||
this.groupID,
|
this.groupID,
|
||||||
|
this.channelID,
|
||||||
this.localEx,
|
this.localEx,
|
||||||
this.seq,
|
this.seq,
|
||||||
this.isRead,
|
this.isRead,
|
||||||
@@ -179,6 +183,7 @@ class Message {
|
|||||||
senderNickname = json['senderNickname'];
|
senderNickname = json['senderNickname'];
|
||||||
senderFaceUrl = json['senderFaceUrl'];
|
senderFaceUrl = json['senderFaceUrl'];
|
||||||
groupID = json['groupID'];
|
groupID = json['groupID'];
|
||||||
|
channelID = json['channelID'];
|
||||||
localEx = json['localEx'];
|
localEx = json['localEx'];
|
||||||
seq = json['seq'];
|
seq = json['seq'];
|
||||||
isRead = json['isRead'];
|
isRead = json['isRead'];
|
||||||
@@ -224,6 +229,7 @@ class Message {
|
|||||||
data['senderNickname'] = this.senderNickname;
|
data['senderNickname'] = this.senderNickname;
|
||||||
data['senderFaceUrl'] = this.senderFaceUrl;
|
data['senderFaceUrl'] = this.senderFaceUrl;
|
||||||
data['groupID'] = this.groupID;
|
data['groupID'] = this.groupID;
|
||||||
|
data['channelID'] = this.channelID;
|
||||||
data['localEx'] = this.localEx;
|
data['localEx'] = this.localEx;
|
||||||
data['seq'] = this.seq;
|
data['seq'] = this.seq;
|
||||||
data['isRead'] = this.isRead;
|
data['isRead'] = this.isRead;
|
||||||
@@ -275,6 +281,7 @@ class Message {
|
|||||||
senderNickname = message.senderNickname;
|
senderNickname = message.senderNickname;
|
||||||
senderFaceUrl = message.senderFaceUrl;
|
senderFaceUrl = message.senderFaceUrl;
|
||||||
groupID = message.groupID;
|
groupID = message.groupID;
|
||||||
|
channelID = message.channelID;
|
||||||
// content = message.content;
|
// content = message.content;
|
||||||
seq = message.seq;
|
seq = message.seq;
|
||||||
isRead = message.isRead;
|
isRead = message.isRead;
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import '../../flutter_openim_sdk.dart';
|
import '../../flutter_openim_sdk.dart';
|
||||||
|
import 'channel_info.dart';
|
||||||
|
|
||||||
/// OA Notification
|
/// OA notification
|
||||||
class OANotification {
|
class OANotification {
|
||||||
/// Title
|
/// Title
|
||||||
String? notificationName;
|
String? notificationName;
|
||||||
@@ -58,50 +59,57 @@ class OANotification {
|
|||||||
text = json['text'];
|
text = json['text'];
|
||||||
externalUrl = json['externalUrl'];
|
externalUrl = json['externalUrl'];
|
||||||
mixType = json['mixType'];
|
mixType = json['mixType'];
|
||||||
pictureElem = json['pictureElem'] != null ? PictureElem.fromJson(json['pictureElem']) : null;
|
pictureElem = json['pictureElem'] != null
|
||||||
soundElem = json['soundElem'] != null ? SoundElem.fromJson(json['soundElem']) : null;
|
? PictureElem.fromJson(json['pictureElem'])
|
||||||
videoElem = json['videoElem'] != null ? VideoElem.fromJson(json['videoElem']) : null;
|
: null;
|
||||||
fileElem = json['fileElem'] != null ? FileElem.fromJson(json['fileElem']) : null;
|
soundElem = json['soundElem'] != null
|
||||||
|
? SoundElem.fromJson(json['soundElem'])
|
||||||
|
: null;
|
||||||
|
videoElem = json['videoElem'] != null
|
||||||
|
? VideoElem.fromJson(json['videoElem'])
|
||||||
|
: null;
|
||||||
|
fileElem =
|
||||||
|
json['fileElem'] != null ? FileElem.fromJson(json['fileElem']) : null;
|
||||||
ex = json['ex'];
|
ex = json['ex'];
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
data['notificationName'] = notificationName;
|
data['notificationName'] = this.notificationName;
|
||||||
data['notificationFaceURL'] = notificationFaceURL;
|
data['notificationFaceURL'] = this.notificationFaceURL;
|
||||||
data['notificationType'] = notificationType;
|
data['notificationType'] = this.notificationType;
|
||||||
data['text'] = text;
|
data['text'] = this.text;
|
||||||
data['externalUrl'] = externalUrl;
|
data['externalUrl'] = this.externalUrl;
|
||||||
data['mixType'] = mixType;
|
data['mixType'] = this.mixType;
|
||||||
if (pictureElem != null) {
|
if (this.pictureElem != null) {
|
||||||
data['pictureElem'] = pictureElem!.toJson();
|
data['pictureElem'] = this.pictureElem!.toJson();
|
||||||
}
|
}
|
||||||
if (soundElem != null) {
|
if (this.soundElem != null) {
|
||||||
data['soundElem'] = soundElem!.toJson();
|
data['soundElem'] = this.soundElem!.toJson();
|
||||||
}
|
}
|
||||||
if (videoElem != null) {
|
if (this.videoElem != null) {
|
||||||
data['videoElem'] = videoElem!.toJson();
|
data['videoElem'] = this.videoElem!.toJson();
|
||||||
}
|
}
|
||||||
if (fileElem != null) {
|
if (this.fileElem != null) {
|
||||||
data['fileElem'] = fileElem!.toJson();
|
data['fileElem'] = this.fileElem!.toJson();
|
||||||
}
|
}
|
||||||
data['ex'] = ex;
|
data['ex'] = this.ex;
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Group Event Notification
|
/// 群事件通知
|
||||||
class GroupNotification {
|
class GroupNotification {
|
||||||
/// Group information
|
/// 群信息
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// Current event operator information
|
/// 当前事件操作者信息
|
||||||
GroupMembersInfo? opUser;
|
GroupMembersInfo? opUser;
|
||||||
|
|
||||||
/// Group owner information
|
/// 群拥有者信息
|
||||||
GroupMembersInfo? groupOwnerUser;
|
GroupMembersInfo? groupOwnerUser;
|
||||||
|
|
||||||
/// List of affected group members
|
/// 产生影响的群成员列表
|
||||||
List<GroupMembersInfo>? memberList;
|
List<GroupMembersInfo>? memberList;
|
||||||
|
|
||||||
GroupNotification({
|
GroupNotification({
|
||||||
@@ -113,8 +121,12 @@ class GroupNotification {
|
|||||||
|
|
||||||
GroupNotification.fromJson(Map<String, dynamic> json) {
|
GroupNotification.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
opUser = json['opUser'] != null ? GroupMembersInfo.fromJson(json['opUser']) : null;
|
opUser = json['opUser'] != null
|
||||||
groupOwnerUser = json['groupOwnerUser'] != null ? GroupMembersInfo.fromJson(json['groupOwnerUser']) : null;
|
? GroupMembersInfo.fromJson(json['opUser'])
|
||||||
|
: null;
|
||||||
|
groupOwnerUser = json['groupOwnerUser'] != null
|
||||||
|
? GroupMembersInfo.fromJson(json['groupOwnerUser'])
|
||||||
|
: null;
|
||||||
if (json['memberList'] != null) {
|
if (json['memberList'] != null) {
|
||||||
memberList = <GroupMembersInfo>[];
|
memberList = <GroupMembersInfo>[];
|
||||||
json['memberList'].forEach((v) {
|
json['memberList'].forEach((v) {
|
||||||
@@ -125,42 +137,40 @@ class GroupNotification {
|
|||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
if (group != null) {
|
if (this.group != null) {
|
||||||
data['group'] = group!.toJson();
|
data['group'] = this.group!.toJson();
|
||||||
}
|
}
|
||||||
if (opUser != null) {
|
if (this.opUser != null) {
|
||||||
data['opUser'] = opUser!.toJson();
|
data['opUser'] = this.opUser!.toJson();
|
||||||
}
|
}
|
||||||
if (groupOwnerUser != null) {
|
if (this.groupOwnerUser != null) {
|
||||||
data['groupOwnerUser'] = groupOwnerUser!.toJson();
|
data['groupOwnerUser'] = this.groupOwnerUser!.toJson();
|
||||||
}
|
}
|
||||||
if (memberList != null) {
|
if (this.memberList != null) {
|
||||||
data['memberList'] = memberList!.map((v) => v.toJson()).toList();
|
data['memberList'] = this.memberList!.map((v) => v.toJson()).toList();
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// User Invited to Join Group Notification
|
/// 用户被邀请进群通知
|
||||||
class InvitedJoinGroupNotification {
|
class InvitedJoinGroupNotification {
|
||||||
/// Group information
|
/// 群信息
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// Operator information
|
/// 操作者信息
|
||||||
GroupMembersInfo? opUser;
|
GroupMembersInfo? opUser;
|
||||||
|
|
||||||
/// Inviter information
|
/// 被邀请进群的成员信息
|
||||||
GroupMembersInfo? inviterUser;
|
|
||||||
|
|
||||||
/// List of members invited to join the group
|
|
||||||
List<GroupMembersInfo>? invitedUserList;
|
List<GroupMembersInfo>? invitedUserList;
|
||||||
|
|
||||||
InvitedJoinGroupNotification({this.group, this.opUser, this.invitedUserList});
|
InvitedJoinGroupNotification({this.group, this.opUser, this.invitedUserList});
|
||||||
|
|
||||||
InvitedJoinGroupNotification.fromJson(Map<String, dynamic> json) {
|
InvitedJoinGroupNotification.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
opUser = json['opUser'] != null ? GroupMembersInfo.fromJson(json['opUser']) : null;
|
opUser = json['opUser'] != null
|
||||||
inviterUser = json['inviterUser'] != null ? GroupMembersInfo.fromJson(json['inviterUser']) : null;
|
? GroupMembersInfo.fromJson(json['opUser'])
|
||||||
|
: null;
|
||||||
if (json['invitedUserList'] != null) {
|
if (json['invitedUserList'] != null) {
|
||||||
invitedUserList = <GroupMembersInfo>[];
|
invitedUserList = <GroupMembersInfo>[];
|
||||||
json['invitedUserList'].forEach((v) {
|
json['invitedUserList'].forEach((v) {
|
||||||
@@ -170,39 +180,40 @@ class InvitedJoinGroupNotification {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final Map<String, dynamic> data = <String, dynamic>{};
|
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||||
if (group != null) {
|
if (this.group != null) {
|
||||||
data['group'] = group!.toJson();
|
data['group'] = this.group!.toJson();
|
||||||
}
|
}
|
||||||
if (opUser != null) {
|
if (this.opUser != null) {
|
||||||
data['opUser'] = opUser!.toJson();
|
data['opUser'] = this.opUser!.toJson();
|
||||||
}
|
}
|
||||||
if (inviterUser != null) {
|
if (this.invitedUserList != null) {
|
||||||
data['inviterUser'] = inviterUser!.toJson();
|
data['invitedUserList'] =
|
||||||
}
|
this.invitedUserList!.map((v) => v.toJson()).toList();
|
||||||
if (invitedUserList != null) {
|
|
||||||
data['invitedUserList'] = invitedUserList!.map((v) => v.toJson()).toList();
|
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Group Member Kicked Notification
|
/// 组踢出成员通知
|
||||||
class KickedGroupMemeberNotification {
|
class KickedGroupMemeberNotification {
|
||||||
/// Group information
|
/// 群信息
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// Operator information
|
/// 操作者信息
|
||||||
GroupMembersInfo? opUser;
|
GroupMembersInfo? opUser;
|
||||||
|
|
||||||
/// List of members kicked from the group
|
/// 被踢出群的成员信息列表
|
||||||
List<GroupMembersInfo>? kickedUserList;
|
List<GroupMembersInfo>? kickedUserList;
|
||||||
|
|
||||||
KickedGroupMemeberNotification({this.group, this.opUser, this.kickedUserList});
|
KickedGroupMemeberNotification(
|
||||||
|
{this.group, this.opUser, this.kickedUserList});
|
||||||
|
|
||||||
KickedGroupMemeberNotification.fromJson(Map<String, dynamic> json) {
|
KickedGroupMemeberNotification.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
opUser = json['opUser'] != null ? GroupMembersInfo.fromJson(json['opUser']) : null;
|
opUser = json['opUser'] != null
|
||||||
|
? GroupMembersInfo.fromJson(json['opUser'])
|
||||||
|
: null;
|
||||||
if (json['kickedUserList'] != null) {
|
if (json['kickedUserList'] != null) {
|
||||||
kickedUserList = <GroupMembersInfo>[];
|
kickedUserList = <GroupMembersInfo>[];
|
||||||
json['kickedUserList'].forEach((v) {
|
json['kickedUserList'].forEach((v) {
|
||||||
@@ -213,82 +224,87 @@ class KickedGroupMemeberNotification {
|
|||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||||
if (group != null) {
|
if (this.group != null) {
|
||||||
data['group'] = group!.toJson();
|
data['group'] = this.group!.toJson();
|
||||||
}
|
}
|
||||||
if (opUser != null) {
|
if (this.opUser != null) {
|
||||||
data['opUser'] = opUser!.toJson();
|
data['opUser'] = this.opUser!.toJson();
|
||||||
}
|
}
|
||||||
if (kickedUserList != null) {
|
if (this.kickedUserList != null) {
|
||||||
data['kickedUserList'] = kickedUserList!.map((v) => v.toJson()).toList();
|
data['kickedUserList'] =
|
||||||
|
this.kickedUserList!.map((v) => v.toJson()).toList();
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Quit Group Notification
|
/// 退出群通知
|
||||||
class QuitGroupNotification {
|
class QuitGroupNotification {
|
||||||
/// Group information
|
/// 群信息
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// Information of the member who quit the group
|
/// 退群的成员信息
|
||||||
GroupMembersInfo? quitUser;
|
GroupMembersInfo? quitUser;
|
||||||
|
|
||||||
QuitGroupNotification({this.group, this.quitUser});
|
QuitGroupNotification({this.group, this.quitUser});
|
||||||
|
|
||||||
QuitGroupNotification.fromJson(Map<String, dynamic> json) {
|
QuitGroupNotification.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
quitUser = json['quitUser'] != null ? GroupMembersInfo.fromJson(json['quitUser']) : null;
|
quitUser = json['quitUser'] != null
|
||||||
|
? GroupMembersInfo.fromJson(json['quitUser'])
|
||||||
|
: null;
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
if (group != null) {
|
if (this.group != null) {
|
||||||
data['group'] = group!.toJson();
|
data['group'] = this.group!.toJson();
|
||||||
}
|
}
|
||||||
if (quitUser != null) {
|
if (this.quitUser != null) {
|
||||||
data['quitUser'] = quitUser!.toJson();
|
data['quitUser'] = this.quitUser!.toJson();
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Enter Group Notification
|
/// 进群通知
|
||||||
class EnterGroupNotification {
|
class EnterGroupNotification {
|
||||||
/// Group information
|
/// 群信息
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// Information of the member who entered the group
|
/// 进入群的成员信息
|
||||||
GroupMembersInfo? entrantUser;
|
GroupMembersInfo? entrantUser;
|
||||||
|
|
||||||
EnterGroupNotification({this.group, this.entrantUser});
|
EnterGroupNotification({this.group, this.entrantUser});
|
||||||
|
|
||||||
EnterGroupNotification.fromJson(Map<String, dynamic> json) {
|
EnterGroupNotification.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
entrantUser = json['entrantUser'] != null ? GroupMembersInfo.fromJson(json['entrantUser']) : null;
|
entrantUser = json['entrantUser'] != null
|
||||||
|
? GroupMembersInfo.fromJson(json['entrantUser'])
|
||||||
|
: null;
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
if (group != null) {
|
if (this.group != null) {
|
||||||
data['group'] = group!.toJson();
|
data['group'] = this.group!.toJson();
|
||||||
}
|
}
|
||||||
if (entrantUser != null) {
|
if (this.entrantUser != null) {
|
||||||
data['entrantUser'] = entrantUser!.toJson();
|
data['quitUser'] = this.entrantUser!.toJson();
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Group Rights Transfer Notification
|
/// 群权转让通知
|
||||||
class GroupRightsTransferNoticication {
|
class GroupRightsTransferNoticication {
|
||||||
/// Group information
|
/// 群信息
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// Operator information
|
/// 操作者信息
|
||||||
GroupMembersInfo? opUser;
|
GroupMembersInfo? opUser;
|
||||||
|
|
||||||
/// New group owner information
|
/// 群新的拥有者信息
|
||||||
GroupMembersInfo? newGroupOwner;
|
GroupMembersInfo? newGroupOwner;
|
||||||
|
|
||||||
GroupRightsTransferNoticication({
|
GroupRightsTransferNoticication({
|
||||||
@@ -299,37 +315,41 @@ class GroupRightsTransferNoticication {
|
|||||||
|
|
||||||
GroupRightsTransferNoticication.fromJson(Map<String, dynamic> json) {
|
GroupRightsTransferNoticication.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
opUser = json['opUser'] != null ? GroupMembersInfo.fromJson(json['opUser']) : null;
|
opUser = json['opUser'] != null
|
||||||
newGroupOwner = json['newGroupOwner'] != null ? GroupMembersInfo.fromJson(json['newGroupOwner']) : null;
|
? GroupMembersInfo.fromJson(json['opUser'])
|
||||||
|
: null;
|
||||||
|
newGroupOwner = json['newGroupOwner'] != null
|
||||||
|
? GroupMembersInfo.fromJson(json['newGroupOwner'])
|
||||||
|
: null;
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
if (group != null) {
|
if (this.group != null) {
|
||||||
data['group'] = group!.toJson();
|
data['group'] = this.group!.toJson();
|
||||||
}
|
}
|
||||||
if (opUser != null) {
|
if (this.opUser != null) {
|
||||||
data['opUser'] = opUser!.toJson();
|
data['opUser'] = this.opUser!.toJson();
|
||||||
}
|
}
|
||||||
if (newGroupOwner != null) {
|
if (this.newGroupOwner != null) {
|
||||||
data['newGroupOwner'] = newGroupOwner!.toJson();
|
data['newGroupOwner'] = this.newGroupOwner!.toJson();
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Mute Member Notification
|
/// 禁言成员通知
|
||||||
class MuteMemberNotification {
|
class MuteMemberNotification {
|
||||||
/// Group information
|
/// 群信息
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// Operator information
|
/// 操作者信息
|
||||||
GroupMembersInfo? opUser;
|
GroupMembersInfo? opUser;
|
||||||
|
|
||||||
/// Muted member information
|
/// 被禁言的成员信息
|
||||||
GroupMembersInfo? mutedUser;
|
GroupMembersInfo? mutedUser;
|
||||||
|
|
||||||
/// Mute duration in seconds
|
/// 禁言时间s
|
||||||
int? mutedSeconds;
|
int? mutedSeconds;
|
||||||
|
|
||||||
MuteMemberNotification({
|
MuteMemberNotification({
|
||||||
@@ -341,36 +361,40 @@ class MuteMemberNotification {
|
|||||||
|
|
||||||
MuteMemberNotification.fromJson(Map<String, dynamic> json) {
|
MuteMemberNotification.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
opUser = json['opUser'] != null ? GroupMembersInfo.fromJson(json['opUser']) : null;
|
opUser = json['opUser'] != null
|
||||||
mutedUser = json['mutedUser'] != null ? GroupMembersInfo.fromJson(json['mutedUser']) : null;
|
? GroupMembersInfo.fromJson(json['opUser'])
|
||||||
|
: null;
|
||||||
|
mutedUser = json['mutedUser'] != null
|
||||||
|
? GroupMembersInfo.fromJson(json['mutedUser'])
|
||||||
|
: null;
|
||||||
mutedSeconds = json['mutedSeconds'];
|
mutedSeconds = json['mutedSeconds'];
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
if (group != null) {
|
if (this.group != null) {
|
||||||
data['group'] = group!.toJson();
|
data['group'] = this.group!.toJson();
|
||||||
}
|
}
|
||||||
if (opUser != null) {
|
if (this.opUser != null) {
|
||||||
data['opUser'] = opUser!.toJson();
|
data['opUser'] = this.opUser!.toJson();
|
||||||
}
|
}
|
||||||
if (mutedUser != null) {
|
if (this.mutedUser != null) {
|
||||||
data['mutedUser'] = mutedUser!.toJson();
|
data['mutedUser'] = this.mutedUser!.toJson();
|
||||||
}
|
}
|
||||||
data['mutedSeconds'] = mutedSeconds;
|
data['mutedSeconds'] = this.mutedSeconds;
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Burn After Reading Notification
|
/// 阅后即焚通知
|
||||||
class BurnAfterReadingNotification {
|
class BurnAfterReadingNotification {
|
||||||
/// Receiver
|
/// 接收者
|
||||||
String? recvID;
|
String? recvID;
|
||||||
|
|
||||||
/// Sender
|
/// 发送者
|
||||||
String? sendID;
|
String? sendID;
|
||||||
|
|
||||||
/// Whether enabled
|
/// 是否开启
|
||||||
bool? isPrivate;
|
bool? isPrivate;
|
||||||
|
|
||||||
BurnAfterReadingNotification({this.recvID, this.sendID, this.isPrivate});
|
BurnAfterReadingNotification({this.recvID, this.sendID, this.isPrivate});
|
||||||
@@ -383,22 +407,22 @@ class BurnAfterReadingNotification {
|
|||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
data['recvID'] = recvID;
|
data['recvID'] = this.recvID;
|
||||||
data['sendID'] = sendID;
|
data['sendID'] = this.sendID;
|
||||||
data['isPrivate'] = isPrivate;
|
data['isPrivate'] = this.isPrivate;
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Group Member Information Changed Notification
|
/// 群成员信息发送变化通知
|
||||||
class GroupMemberInfoChangedNotification {
|
class GroupMemberInfoChangedNotification {
|
||||||
/// Group information
|
/// 群信息
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// Operator information
|
/// 操作者信息
|
||||||
GroupMembersInfo? opUser;
|
GroupMembersInfo? opUser;
|
||||||
|
|
||||||
/// Member with changed information
|
/// 资料发生改变的成员
|
||||||
GroupMembersInfo? changedUser;
|
GroupMembersInfo? changedUser;
|
||||||
|
|
||||||
GroupMemberInfoChangedNotification({
|
GroupMemberInfoChangedNotification({
|
||||||
@@ -409,21 +433,276 @@ class GroupMemberInfoChangedNotification {
|
|||||||
|
|
||||||
GroupMemberInfoChangedNotification.fromJson(Map<String, dynamic> json) {
|
GroupMemberInfoChangedNotification.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
opUser = json['opUser'] != null ? GroupMembersInfo.fromJson(json['opUser']) : null;
|
opUser = json['opUser'] != null
|
||||||
changedUser = json['changedUser'] != null ? GroupMembersInfo.fromJson(json['changedUser']) : null;
|
? GroupMembersInfo.fromJson(json['opUser'])
|
||||||
|
: null;
|
||||||
|
changedUser = json['changedUser'] != null
|
||||||
|
? GroupMembersInfo.fromJson(json['changedUser'])
|
||||||
|
: null;
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
if (group != null) {
|
if (this.group != null) {
|
||||||
data['group'] = group!.toJson();
|
data['group'] = this.group!.toJson();
|
||||||
}
|
}
|
||||||
if (opUser != null) {
|
if (this.opUser != null) {
|
||||||
data['opUser'] = opUser!.toJson();
|
data['opUser'] = this.opUser!.toJson();
|
||||||
}
|
}
|
||||||
if (changedUser != null) {
|
if (this.changedUser != null) {
|
||||||
data['changedUser'] = changedUser!.toJson();
|
data['changedUser'] = this.changedUser!.toJson();
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
///todo 所有的聊天的操作者都没有,暂时没有处理
|
||||||
|
/// 聊天室事件通知
|
||||||
|
class ChannelNotification {
|
||||||
|
/// 聊天室信息
|
||||||
|
ChannelInfo? Channel;
|
||||||
|
|
||||||
|
/// 当前事件操作者信息
|
||||||
|
ChannelMembersInfo? opUser;
|
||||||
|
|
||||||
|
/// 聊天室拥有者信息
|
||||||
|
ChannelMembersInfo? ChannelOwnerUser;
|
||||||
|
|
||||||
|
/// 产生影响的聊天室成员列表
|
||||||
|
List<ChannelMembersInfo>? memberList;
|
||||||
|
|
||||||
|
ChannelNotification({
|
||||||
|
this.Channel,
|
||||||
|
this.opUser,
|
||||||
|
this.ChannelOwnerUser,
|
||||||
|
this.memberList,
|
||||||
|
});
|
||||||
|
|
||||||
|
ChannelNotification.fromJson(Map<String, dynamic> json) {
|
||||||
|
Channel = json['channel'] != null ? ChannelInfo.fromJson(json['channel']) : null;
|
||||||
|
opUser = json['opUser'] != null
|
||||||
|
? ChannelMembersInfo.fromJson(json['opUser'])
|
||||||
|
: null;
|
||||||
|
ChannelOwnerUser = json['channelOwnerUser'] != null
|
||||||
|
? ChannelMembersInfo.fromJson(json['channelOwnerUser'])
|
||||||
|
: null;
|
||||||
|
if (json['memberList'] != null) {
|
||||||
|
memberList = <ChannelMembersInfo>[];
|
||||||
|
json['memberList'].forEach((v) {
|
||||||
|
memberList!.add(ChannelMembersInfo.fromJson(v));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = Map<String, dynamic>();
|
||||||
|
if (this.Channel != null) {
|
||||||
|
data['channel'] = this.Channel!.toJson();
|
||||||
|
}
|
||||||
|
if (this.opUser != null) {
|
||||||
|
data['opUser'] = this.opUser!.toJson();
|
||||||
|
}
|
||||||
|
if (this.ChannelOwnerUser != null) {
|
||||||
|
data['channelOwnerUser'] = this.ChannelOwnerUser!.toJson();
|
||||||
|
}
|
||||||
|
if (this.memberList != null) {
|
||||||
|
data['memberList'] = this.memberList!.map((v) => v.toJson()).toList();
|
||||||
|
}
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/// 组踢出成员通知
|
||||||
|
class KickedChannelMemeberNotification {
|
||||||
|
/// 聊天室信息
|
||||||
|
ChannelInfo? Channel;
|
||||||
|
|
||||||
|
/// 操作者信息
|
||||||
|
ChannelMembersInfo? opUser;
|
||||||
|
|
||||||
|
/// 被踢出聊天室的成员信息列表
|
||||||
|
List<ChannelMembersInfo>? kickedUserList;
|
||||||
|
|
||||||
|
KickedChannelMemeberNotification(
|
||||||
|
{this.Channel, this.opUser, this.kickedUserList});
|
||||||
|
|
||||||
|
KickedChannelMemeberNotification.fromJson(Map<String, dynamic> json) {
|
||||||
|
Channel = json['channel'] != null ? ChannelInfo.fromJson(json['channel']) : null;
|
||||||
|
opUser = json['opUser'] != null
|
||||||
|
? ChannelMembersInfo.fromJson(json['opUser'])
|
||||||
|
: null;
|
||||||
|
if (json['kickedUserList'] != null) {
|
||||||
|
kickedUserList = <ChannelMembersInfo>[];
|
||||||
|
json['kickedUserList'].forEach((v) {
|
||||||
|
kickedUserList!.add(ChannelMembersInfo.fromJson(v));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||||
|
if (this.Channel != null) {
|
||||||
|
data['channel'] = this.Channel!.toJson();
|
||||||
|
}
|
||||||
|
if (this.opUser != null) {
|
||||||
|
data['opUser'] = this.opUser!.toJson();
|
||||||
|
}
|
||||||
|
if (this.kickedUserList != null) {
|
||||||
|
data['kickedUserList'] =
|
||||||
|
this.kickedUserList!.map((v) => v.toJson()).toList();
|
||||||
|
}
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// 退出聊天室通知
|
||||||
|
class QuitChannelNotification {
|
||||||
|
/// 聊天室信息
|
||||||
|
ChannelInfo? Channel;
|
||||||
|
|
||||||
|
/// 退聊天室的成员信息
|
||||||
|
ChannelMembersInfo? quitUser;
|
||||||
|
|
||||||
|
QuitChannelNotification({this.Channel, this.quitUser});
|
||||||
|
|
||||||
|
QuitChannelNotification.fromJson(Map<String, dynamic> json) {
|
||||||
|
Channel = json['channel'] != null ? ChannelInfo.fromJson(json['channel']) : null;
|
||||||
|
quitUser = json['quitUser'] != null
|
||||||
|
? ChannelMembersInfo.fromJson(json['quitUser'])
|
||||||
|
: null;
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = Map<String, dynamic>();
|
||||||
|
if (this.Channel != null) {
|
||||||
|
data['channel'] = this.Channel!.toJson();
|
||||||
|
}
|
||||||
|
if (this.quitUser != null) {
|
||||||
|
data['quitUser'] = this.quitUser!.toJson();
|
||||||
|
}
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// 进聊天室通知
|
||||||
|
class EnterChannelNotification {
|
||||||
|
/// 聊天室信息
|
||||||
|
ChannelInfo? Channel;
|
||||||
|
|
||||||
|
/// 进入聊天室的成员信息
|
||||||
|
ChannelMembersInfo? entrantUser;
|
||||||
|
|
||||||
|
EnterChannelNotification({this.Channel, this.entrantUser});
|
||||||
|
|
||||||
|
EnterChannelNotification.fromJson(Map<String, dynamic> json) {
|
||||||
|
Channel = json['channel'] != null ? ChannelInfo.fromJson(json['channel']) : null;
|
||||||
|
entrantUser = json['entrantUser'] != null
|
||||||
|
? ChannelMembersInfo.fromJson(json['entrantUser'])
|
||||||
|
: null;
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = Map<String, dynamic>();
|
||||||
|
if (this.Channel != null) {
|
||||||
|
data['channel'] = this.Channel!.toJson();
|
||||||
|
}
|
||||||
|
if (this.entrantUser != null) {
|
||||||
|
data['quitUser'] = this.entrantUser!.toJson();
|
||||||
|
}
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/// 禁言成员通知
|
||||||
|
class MuteChannelMemberNotification {
|
||||||
|
/// 聊天室信息
|
||||||
|
ChannelInfo? Channel;
|
||||||
|
|
||||||
|
/// 操作者信息
|
||||||
|
ChannelMembersInfo? opUser;
|
||||||
|
|
||||||
|
/// 被禁言的成员信息
|
||||||
|
ChannelMembersInfo? mutedUser;
|
||||||
|
|
||||||
|
/// 禁言时间s
|
||||||
|
int? mutedSeconds;
|
||||||
|
|
||||||
|
MuteChannelMemberNotification({
|
||||||
|
this.Channel,
|
||||||
|
this.opUser,
|
||||||
|
this.mutedUser,
|
||||||
|
this.mutedSeconds,
|
||||||
|
});
|
||||||
|
|
||||||
|
MuteChannelMemberNotification.fromJson(Map<String, dynamic> json) {
|
||||||
|
Channel = json['channel'] != null ? ChannelInfo.fromJson(json['channel']) : null;
|
||||||
|
opUser = json['opUser'] != null
|
||||||
|
? ChannelMembersInfo.fromJson(json['opUser'])
|
||||||
|
: null;
|
||||||
|
mutedUser = json['mutedUser'] != null
|
||||||
|
? ChannelMembersInfo.fromJson(json['mutedUser'])
|
||||||
|
: null;
|
||||||
|
mutedSeconds = json['mutedSeconds'];
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = Map<String, dynamic>();
|
||||||
|
if (this.Channel != null) {
|
||||||
|
data['channel'] = this.Channel!.toJson();
|
||||||
|
}
|
||||||
|
if (this.opUser != null) {
|
||||||
|
data['opUser'] = this.opUser!.toJson();
|
||||||
|
}
|
||||||
|
if (this.mutedUser != null) {
|
||||||
|
data['mutedUser'] = this.mutedUser!.toJson();
|
||||||
|
}
|
||||||
|
data['mutedSeconds'] = this.mutedSeconds;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// 聊天室成员信息发送变化通知
|
||||||
|
class ChannelMemberInfoChangedNotification {
|
||||||
|
/// 聊天室信息
|
||||||
|
ChannelInfo? Channel;
|
||||||
|
|
||||||
|
/// 操作者信息
|
||||||
|
ChannelMembersInfo? opUser;
|
||||||
|
|
||||||
|
/// 资料发生改变的成员
|
||||||
|
ChannelMembersInfo? changedUser;
|
||||||
|
|
||||||
|
ChannelMemberInfoChangedNotification({
|
||||||
|
this.Channel,
|
||||||
|
this.opUser,
|
||||||
|
this.changedUser,
|
||||||
|
});
|
||||||
|
|
||||||
|
ChannelMemberInfoChangedNotification.fromJson(Map<String, dynamic> json) {
|
||||||
|
Channel = json['channel'] != null ? ChannelInfo.fromJson(json['channel']) : null;
|
||||||
|
opUser = json['opUser'] != null
|
||||||
|
? ChannelMembersInfo.fromJson(json['opUser'])
|
||||||
|
: null;
|
||||||
|
changedUser = json['changedUser'] != null
|
||||||
|
? ChannelMembersInfo.fromJson(json['changedUser'])
|
||||||
|
: null;
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = Map<String, dynamic>();
|
||||||
|
if (this.Channel != null) {
|
||||||
|
data['Channel'] = this.Channel!.toJson();
|
||||||
|
}
|
||||||
|
if (this.opUser != null) {
|
||||||
|
data['opUser'] = this.opUser!.toJson();
|
||||||
|
}
|
||||||
|
if (this.changedUser != null) {
|
||||||
|
data['changedUser'] = this.changedUser!.toJson();
|
||||||
|
}
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
41
lib/src/models/set_channel_member_info.dart
Normal file
41
lib/src/models/set_channel_member_info.dart
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
class SetChannelMemberInfo {
|
||||||
|
SetChannelMemberInfo({
|
||||||
|
required this.channelID,
|
||||||
|
required this.userID,
|
||||||
|
this.roleLevel,
|
||||||
|
this.nickname,
|
||||||
|
this.faceURL,
|
||||||
|
this.ex,
|
||||||
|
});
|
||||||
|
|
||||||
|
final String channelID;
|
||||||
|
final String userID;
|
||||||
|
final int? roleLevel;
|
||||||
|
final String? nickname;
|
||||||
|
final String? faceURL;
|
||||||
|
final String? ex;
|
||||||
|
|
||||||
|
SetChannelMemberInfo.fromJson(Map<String, dynamic> json)
|
||||||
|
: channelID = json['channelID'],
|
||||||
|
userID = json['userID'],
|
||||||
|
roleLevel = json['roleLevel'],
|
||||||
|
nickname = json['nickname'],
|
||||||
|
faceURL = json['faceURL'],
|
||||||
|
ex = json['ex'];
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = Map<String, dynamic>();
|
||||||
|
data['channelID'] = channelID;
|
||||||
|
data['userID'] = userID;
|
||||||
|
data['roleLevel'] = roleLevel;
|
||||||
|
data['nickname'] = nickname;
|
||||||
|
data['faceURL'] = faceURL;
|
||||||
|
data['ex'] = ex;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
String toString() {
|
||||||
|
return 'SetChannelMemberInfo{channelID: $channelID, userID: $userID, roleLevel: $roleLevel, nickname: $nickname, faceURL: $faceURL, ex: $ex}';
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -47,6 +47,8 @@ class ConversationReq {
|
|||||||
final bool? isMsgDestruct;
|
final bool? isMsgDestruct;
|
||||||
final int? msgDestructTime;
|
final int? msgDestructTime;
|
||||||
final int? groupAtType;
|
final int? groupAtType;
|
||||||
|
final String? channelID;
|
||||||
|
final int? channelAtType;
|
||||||
|
|
||||||
ConversationReq({
|
ConversationReq({
|
||||||
this.userID,
|
this.userID,
|
||||||
@@ -59,6 +61,8 @@ class ConversationReq {
|
|||||||
this.isMsgDestruct,
|
this.isMsgDestruct,
|
||||||
this.msgDestructTime,
|
this.msgDestructTime,
|
||||||
this.groupAtType,
|
this.groupAtType,
|
||||||
|
this.channelID,
|
||||||
|
this.channelAtType,
|
||||||
});
|
});
|
||||||
|
|
||||||
ConversationReq.fromJson(Map<String, dynamic> json)
|
ConversationReq.fromJson(Map<String, dynamic> json)
|
||||||
@@ -71,8 +75,11 @@ class ConversationReq {
|
|||||||
burnDuration = json['burnDuration'],
|
burnDuration = json['burnDuration'],
|
||||||
isMsgDestruct = json['isMsgDestruct'],
|
isMsgDestruct = json['isMsgDestruct'],
|
||||||
msgDestructTime = json['msgDestructTime'],
|
msgDestructTime = json['msgDestructTime'],
|
||||||
|
channelID=json['channelID'],
|
||||||
|
channelAtType = json['channelAtType'],
|
||||||
groupAtType = json['groupAtType'];
|
groupAtType = json['groupAtType'];
|
||||||
|
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = <String, dynamic>{};
|
final data = <String, dynamic>{};
|
||||||
data['userID'] = userID;
|
data['userID'] = userID;
|
||||||
@@ -85,7 +92,8 @@ class ConversationReq {
|
|||||||
data['isMsgDestruct'] = isMsgDestruct;
|
data['isMsgDestruct'] = isMsgDestruct;
|
||||||
data['msgDestructTime'] = msgDestructTime;
|
data['msgDestructTime'] = msgDestructTime;
|
||||||
data['groupAtType'] = groupAtType;
|
data['groupAtType'] = groupAtType;
|
||||||
|
data['channelID'] = channelID;
|
||||||
|
data['channelAtType'] = channelAtType;
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ import 'package:flutter/services.dart';
|
|||||||
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
||||||
|
|
||||||
class OpenIM {
|
class OpenIM {
|
||||||
static const version = '3.8.3+hotfix.3.1';
|
static const version = '3.8.1+2';
|
||||||
|
|
||||||
static const _channel = MethodChannel('flutter_openim_sdk');
|
static const _channel = MethodChannel('flutter_openim_sdk');
|
||||||
|
|
||||||
|
|||||||
24
pubspec.lock
24
pubspec.lock
@@ -63,18 +63,18 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: leak_tracker
|
name: leak_tracker
|
||||||
sha256: "3f87a60e8c63aecc975dda1ceedbc8f24de75f09e4856ea27daf8958f2f0ce05"
|
sha256: "7f0df31977cb2c0b88585095d168e689669a2cc9b97c309665e3386f3e9d341a"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "10.0.5"
|
version: "10.0.4"
|
||||||
leak_tracker_flutter_testing:
|
leak_tracker_flutter_testing:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: leak_tracker_flutter_testing
|
name: leak_tracker_flutter_testing
|
||||||
sha256: "932549fb305594d82d7183ecd9fa93463e9914e1b67cacc34bc40906594a1806"
|
sha256: "06e98f569d004c1315b991ded39924b21af84cf14cc94791b8aea337d25b57f8"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "3.0.5"
|
version: "3.0.3"
|
||||||
leak_tracker_testing:
|
leak_tracker_testing:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -95,18 +95,18 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: material_color_utilities
|
name: material_color_utilities
|
||||||
sha256: f7142bb1154231d7ea5f96bc7bde4bda2a0945d2806bb11670e30b850d56bdec
|
sha256: "0e0a020085b65b6083975e499759762399b4475f766c21668c4ecca34ea74e5a"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "0.11.1"
|
version: "0.8.0"
|
||||||
meta:
|
meta:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: meta
|
name: meta
|
||||||
sha256: bdb68674043280c3428e9ec998512fb681678676b3c54e773629ffe74419f8c7
|
sha256: "7687075e408b093f36e6bbf6c91878cc0d4cd10f409506f7bc996f68220b9136"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.15.0"
|
version: "1.12.0"
|
||||||
path:
|
path:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -164,10 +164,10 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: test_api
|
name: test_api
|
||||||
sha256: "5b8a98dafc4d5c4c9c72d8b31ab2b23fc13422348d2997120294d3bac86b4ddb"
|
sha256: "9955ae474176f7ac8ee4e989dadfb411a58c30415bcfb648fa04b2b8a03afa7f"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "0.7.2"
|
version: "0.7.0"
|
||||||
vector_math:
|
vector_math:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -180,10 +180,10 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: vm_service
|
name: vm_service
|
||||||
sha256: "5c5f338a667b4c644744b661f309fb8080bb94b18a7e91ef1dbd343bed00ed6d"
|
sha256: "3923c89304b715fb1eb6423f017651664a03bf5f4b29983627c4da791f74a4ec"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "14.2.5"
|
version: "14.2.1"
|
||||||
sdks:
|
sdks:
|
||||||
dart: ">=3.3.0 <4.0.0"
|
dart: ">=3.3.0 <4.0.0"
|
||||||
flutter: ">=3.18.0-18.0.pre.54"
|
flutter: ">=3.18.0-18.0.pre.54"
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
name: flutter_openim_sdk
|
name: flutter_openim_sdk
|
||||||
description: An instant messaging plug-in that supports Android and IOS. And the server is also all open source.
|
description: An instant messaging plug-in that supports Android and IOS. And the server is also all open source.
|
||||||
version: 3.8.3+hotfix.3.1
|
version: 3.8.1+2
|
||||||
homepage: https://www.openim.io
|
homepage: https://www.openim.io
|
||||||
repository: https://github.com/openimsdk/open-im-sdk-flutter
|
repository: https://github.com/openimsdk/open-im-sdk-flutter
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user